On Wed, 3 Jun 2026, Samuel Moelius wrote:

> dm-ebs can discard a block while a dirty dm-bufio buffer for the
> same block is still cached.  If that buffer is later written back,
> stale data can be written over the discarded state.
> 
> That resurrects data that userspace explicitly discarded and breaks
> the expected discard semantics of the target.
> 
> Invalidate or clean the matching bufio state when processing discards
> so that old dirty buffers cannot be written back after the discard.
> 
> Assisted-by: Codex:gpt-5.5-cyber-preview
> Signed-off-by: Samuel Moelius <[email protected]>
> ---
>  drivers/md/dm-ebs-target.c | 8 ++++++--
>  1 file changed, 6 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/md/dm-ebs-target.c b/drivers/md/dm-ebs-target.c
> index 1e52bde48b91..9fece535a0b3 100644
> --- a/drivers/md/dm-ebs-target.c
> +++ b/drivers/md/dm-ebs-target.c
> @@ -212,8 +212,12 @@ static void __ebs_process_bios(struct work_struct *ws)
>                       write = true;
>                       r = __ebs_rw_bio(ec, REQ_OP_WRITE, bio);
>               } else if (bio_op(bio) == REQ_OP_DISCARD) {
> -                     __ebs_forget_bio(ec, bio);
> -                     r = __ebs_discard_bio(ec, bio);
> +                     if (write)
> +                             r = dm_bufio_write_dirty_buffers(ec->bufio);
> +                     if (!r) {
> +                             __ebs_forget_bio(ec, bio);
> +                             r = __ebs_discard_bio(ec, bio);
> +                     }
>               }
>  
>               if (r < 0)

Hi

There's a bug in the patch - when the "write" variable is false, "r" is 
equal to -EIO, thus __ebs_forget_bio and __ebs_discard_bio is skipped at 
all.

If dm_bufio_write_dirty_buffers returns non-zero, the error is erroneously 
reported on the discard bio (that is innocent) and not on the write bios 
that triggered the error.

Mikulas


Reply via email to