All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
@ 2021-07-09 16:29 Goldwyn Rodrigues
  2021-07-22 14:34 ` David Sterba
  0 siblings, 1 reply; 8+ messages in thread
From: Goldwyn Rodrigues @ 2021-07-09 16:29 UTC (permalink / raw)
  To: linux-btrfs

In compression write endio sequence, the range which the compressed_bio
writes is marked as uptodate if the last bio of the compressed (sub)bios
is completed successfully. There could be previous bio which may
have failed which is recorded in cb->errors.

Set the writeback range as uptodate only if cb->errors is zero, as opposed
to checking only the last bio's status.

Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
---
 fs/btrfs/compression.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c
index 9a023ae0f98b..30d82cdf128c 100644
--- a/fs/btrfs/compression.c
+++ b/fs/btrfs/compression.c
@@ -352,7 +352,7 @@ static void end_compressed_bio_write(struct bio *bio)
 	btrfs_record_physical_zoned(inode, cb->start, bio);
 	btrfs_writepage_endio_finish_ordered(BTRFS_I(inode), NULL,
 			cb->start, cb->start + cb->len - 1,
-			bio->bi_status == BLK_STS_OK);
+			!cb->errors);
 
 	end_compressed_writeback(inode, cb);
 	/* note, our inode could be gone now */
-- 
2.32.0

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* Re: [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
  2021-07-09 16:29 [PATCH] btrfs: mark compressed range uptodate only if all bio succeed Goldwyn Rodrigues
@ 2021-07-22 14:34 ` David Sterba
  2021-07-22 19:34   ` Goldwyn Rodrigues
  0 siblings, 1 reply; 8+ messages in thread
From: David Sterba @ 2021-07-22 14:34 UTC (permalink / raw)
  To: Goldwyn Rodrigues; +Cc: linux-btrfs

On Fri, Jul 09, 2021 at 11:29:22AM -0500, Goldwyn Rodrigues wrote:
> In compression write endio sequence, the range which the compressed_bio
> writes is marked as uptodate if the last bio of the compressed (sub)bios
> is completed successfully. There could be previous bio which may
> have failed which is recorded in cb->errors.
> 
> Set the writeback range as uptodate only if cb->errors is zero, as opposed
> to checking only the last bio's status.
> 
> Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
> ---
>  fs/btrfs/compression.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c
> index 9a023ae0f98b..30d82cdf128c 100644
> --- a/fs/btrfs/compression.c
> +++ b/fs/btrfs/compression.c
> @@ -352,7 +352,7 @@ static void end_compressed_bio_write(struct bio *bio)
>  	btrfs_record_physical_zoned(inode, cb->start, bio);
>  	btrfs_writepage_endio_finish_ordered(BTRFS_I(inode), NULL,
>  			cb->start, cb->start + cb->len - 1,
> -			bio->bi_status == BLK_STS_OK);
> +			!cb->errors);

Right, that would only test the last bio. Have been able to reproduce
it?

Anyway, added to misc-next, thanks.

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
  2021-07-22 14:34 ` David Sterba
@ 2021-07-22 19:34   ` Goldwyn Rodrigues
  0 siblings, 0 replies; 8+ messages in thread
From: Goldwyn Rodrigues @ 2021-07-22 19:34 UTC (permalink / raw)
  To: dsterba, linux-btrfs

On 16:34 22/07, David Sterba wrote:
> On Fri, Jul 09, 2021 at 11:29:22AM -0500, Goldwyn Rodrigues wrote:
> > In compression write endio sequence, the range which the compressed_bio
> > writes is marked as uptodate if the last bio of the compressed (sub)bios
> > is completed successfully. There could be previous bio which may
> > have failed which is recorded in cb->errors.
> > 
> > Set the writeback range as uptodate only if cb->errors is zero, as opposed
> > to checking only the last bio's status.
> > 
> > Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
> > ---
> >  fs/btrfs/compression.c | 2 +-
> >  1 file changed, 1 insertion(+), 1 deletion(-)
> > 
> > diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c
> > index 9a023ae0f98b..30d82cdf128c 100644
> > --- a/fs/btrfs/compression.c
> > +++ b/fs/btrfs/compression.c
> > @@ -352,7 +352,7 @@ static void end_compressed_bio_write(struct bio *bio)
> >  	btrfs_record_physical_zoned(inode, cb->start, bio);
> >  	btrfs_writepage_endio_finish_ordered(BTRFS_I(inode), NULL,
> >  			cb->start, cb->start + cb->len - 1,
> > -			bio->bi_status == BLK_STS_OK);
> > +			!cb->errors);
> 
> Right, that would only test the last bio. Have been able to reproduce
> it?
> 

No, I don't have a reproducer. Just observed it while reading the code.

> Anyway, added to misc-next, thanks.

Thanks.

-- 
Goldwyn

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
  2021-08-02 14:32 ` [PATCH] btrfs: mark compressed range uptodate only if all bio succeed Goldwyn Rodrigues
@ 2021-08-02 19:41   ` Sasha Levin
  0 siblings, 0 replies; 8+ messages in thread
From: Sasha Levin @ 2021-08-02 19:41 UTC (permalink / raw)
  To: Goldwyn Rodrigues; +Cc: gregkh, stable, dsterba

On Mon, Aug 02, 2021 at 09:32:06AM -0500, Goldwyn Rodrigues wrote:
>For: v4.19
>Git-commit: 240246f6b913b0c23733cfd2def1d283f8cc9bbe
>
>In compression write endio sequence, the range which the compressed_bio
>writes is marked as uptodate if the last bio of the compressed (sub)bios
>is completed successfully. There could be previous bio which may
>have failed which is recorded in cb->errors.
>
>Set the writeback range as uptodate only if cb->errors is zero, as opposed
>to checking only the last bio's status.
>
>Backporting notes: in all versions up to 4.4 the last argument is always
>replaced by "!cb->errors".
>
>Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
>Reviewed-by: David Sterba <dsterba@suse.com>
>Signed-off-by: David Sterba <dsterba@suse.com>

I've queued up this and the other backports, thanks!

-- 
Thanks,
Sasha

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
  2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.19-stable tree gregkh
@ 2021-08-02 14:32 ` Goldwyn Rodrigues
  2021-08-02 19:41   ` Sasha Levin
  0 siblings, 1 reply; 8+ messages in thread
From: Goldwyn Rodrigues @ 2021-08-02 14:32 UTC (permalink / raw)
  To: gregkh; +Cc: stable, dsterba

For: v4.19
Git-commit: 240246f6b913b0c23733cfd2def1d283f8cc9bbe

In compression write endio sequence, the range which the compressed_bio
writes is marked as uptodate if the last bio of the compressed (sub)bios
is completed successfully. There could be previous bio which may
have failed which is recorded in cb->errors.

Set the writeback range as uptodate only if cb->errors is zero, as opposed
to checking only the last bio's status.

Backporting notes: in all versions up to 4.4 the last argument is always
replaced by "!cb->errors".

Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>

diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c
index c71e534ca7ef..919c033b9e31 100644
--- a/fs/btrfs/compression.c
+++ b/fs/btrfs/compression.c
@@ -270,8 +270,7 @@ static void end_compressed_bio_write(struct bio *bio)
 					 cb->start,
 					 cb->start + cb->len - 1,
 					 NULL,
-					 bio->bi_status ?
-					 BLK_STS_OK : BLK_STS_NOTSUPP);
+					 !cb->errors);
 	cb->compressed_pages[0]->mapping = NULL;
 
 	end_compressed_writeback(inode, cb);

-- 
Goldwyn

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
  2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.14-stable tree gregkh
@ 2021-08-02 14:31 ` Goldwyn Rodrigues
  0 siblings, 0 replies; 8+ messages in thread
From: Goldwyn Rodrigues @ 2021-08-02 14:31 UTC (permalink / raw)
  To: gregkh; +Cc: stable, dsterba

Git-commit: 240246f6b913b0c23733cfd2def1d283f8cc9bbe
For: v4.14

In compression write endio sequence, the range which the compressed_bio
writes is marked as uptodate if the last bio of the compressed (sub)bios
is completed successfully. There could be previous bio which may
have failed which is recorded in cb->errors.

Set the writeback range as uptodate only if cb->errors is zero, as opposed
to checking only the last bio's status.

Backporting notes: in all versions up to 4.4 the last argument is always
replaced by "!cb->errors".

Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>

diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c
index ccd9c709375e..24341c97c13f 100644
--- a/fs/btrfs/compression.c
+++ b/fs/btrfs/compression.c
@@ -286,7 +286,7 @@ static void end_compressed_bio_write(struct bio *bio)
 					 cb->start,
 					 cb->start + cb->len - 1,
 					 NULL,
-					 bio->bi_status ? 0 : 1);
+					 !cb->errors);
 	cb->compressed_pages[0]->mapping = NULL;
 
 	end_compressed_writeback(inode, cb);

-- 
Goldwyn

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
  2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.9-stable tree gregkh
@ 2021-08-02 14:31 ` Goldwyn Rodrigues
  0 siblings, 0 replies; 8+ messages in thread
From: Goldwyn Rodrigues @ 2021-08-02 14:31 UTC (permalink / raw)
  To: gregkh; +Cc: stable, dsterba

Git-commit: 240246f6b913b0c23733cfd2def1d283f8cc9bbe
For: v4.9

In compression write endio sequence, the range which the compressed_bio
writes is marked as uptodate if the last bio of the compressed (sub)bios
is completed successfully. There could be previous bio which may
have failed which is recorded in cb->errors.

Set the writeback range as uptodate only if cb->errors is zero, as opposed
to checking only the last bio's status.

Backporting notes: in all versions up to 4.4 the last argument is always
replaced by "!cb->errors".

Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>

diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c
index d4d8b7e36b2f..2534e44cfd40 100644
--- a/fs/btrfs/compression.c
+++ b/fs/btrfs/compression.c
@@ -290,7 +290,7 @@ static void end_compressed_bio_write(struct bio *bio)
 					 cb->start,
 					 cb->start + cb->len - 1,
 					 NULL,
-					 bio->bi_error ? 0 : 1);
+					 !cb->errors);
 	cb->compressed_pages[0]->mapping = NULL;
 
 	end_compressed_writeback(inode, cb);

-- 
Goldwyn

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH] btrfs: mark compressed range uptodate only if all bio succeed
  2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.4-stable tree gregkh
@ 2021-08-02 14:30 ` Goldwyn Rodrigues
  0 siblings, 0 replies; 8+ messages in thread
From: Goldwyn Rodrigues @ 2021-08-02 14:30 UTC (permalink / raw)
  To: gregkh; +Cc: stable, dsterba

Git-commit: 240246f6b913b0c23733cfd2def1d283f8cc9bbe
For: v4.4

In compression write endio sequence, the range which the compressed_bio
writes is marked as uptodate if the last bio of the compressed (sub)bios
is completed successfully. There could be previous bio which may
have failed which is recorded in cb->errors.

Set the writeback range as uptodate only if cb->errors is zero, as opposed
to checking only the last bio's status.

Backporting notes: in all versions up to 4.4 the last argument is always
replaced by "!cb->errors".

Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>

diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c
index bae05c5c75ba..92601775ec5e 100644
--- a/fs/btrfs/compression.c
+++ b/fs/btrfs/compression.c
@@ -290,7 +290,7 @@ static void end_compressed_bio_write(struct bio *bio)
 					 cb->start,
 					 cb->start + cb->len - 1,
 					 NULL,
-					 bio->bi_error ? 0 : 1);
+					 !cb->errors);
 	cb->compressed_pages[0]->mapping = NULL;
 
 	end_compressed_writeback(inode, cb);

-- 
Goldwyn

^ permalink raw reply related	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2021-08-02 19:41 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-07-09 16:29 [PATCH] btrfs: mark compressed range uptodate only if all bio succeed Goldwyn Rodrigues
2021-07-22 14:34 ` David Sterba
2021-07-22 19:34   ` Goldwyn Rodrigues
2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.9-stable tree gregkh
2021-08-02 14:31 ` [PATCH] btrfs: mark compressed range uptodate only if all bio succeed Goldwyn Rodrigues
2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.4-stable tree gregkh
2021-08-02 14:30 ` [PATCH] btrfs: mark compressed range uptodate only if all bio succeed Goldwyn Rodrigues
2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.19-stable tree gregkh
2021-08-02 14:32 ` [PATCH] btrfs: mark compressed range uptodate only if all bio succeed Goldwyn Rodrigues
2021-08-02 19:41   ` Sasha Levin
2021-07-31  6:33 FAILED: patch "[PATCH] btrfs: mark compressed range uptodate only if all bio succeed" failed to apply to 4.14-stable tree gregkh
2021-08-02 14:31 ` [PATCH] btrfs: mark compressed range uptodate only if all bio succeed Goldwyn Rodrigues

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.