Message ID | 20210126083402.142577-12-wqu@suse.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | btrfs: add read-only support for subpage sector size | expand |
On 1/26/21 3:33 AM, Qu Wenruo wrote: > For btrfs_clone_extent_buffer(), it's mostly the same code of > __alloc_dummy_extent_buffer(), except it has extra page copy. > > So to make it subpage compatible, we only need to: > > - Call set_extent_buffer_uptodate() instead of SetPageUptodate() > This will set correct uptodate bit for subpage and regular sector size > cases. > > Since we're calling set_extent_buffer_uptodate() which will also set > EXTENT_BUFFER_UPTODATE bit, we don't need to manually set that bit > either. > > Signed-off-by: Qu Wenruo <wqu@suse.com> > Reviewed-by: David Sterba <dsterba@suse.com> > Signed-off-by: David Sterba <dsterba@suse.com> Reviewed-by: Josef Bacik <josef@toxicpanda.com> Thanks, Josef
diff --git a/fs/btrfs/extent_io.c b/fs/btrfs/extent_io.c index 78fd36ba1f47..d1c1bbc19226 100644 --- a/fs/btrfs/extent_io.c +++ b/fs/btrfs/extent_io.c @@ -5161,11 +5161,10 @@ struct extent_buffer *btrfs_clone_extent_buffer(const struct extent_buffer *src) return NULL; } WARN_ON(PageDirty(p)); - SetPageUptodate(p); new->pages[i] = p; copy_page(page_address(p), page_address(src->pages[i])); } - set_bit(EXTENT_BUFFER_UPTODATE, &new->bflags); + set_extent_buffer_uptodate(new); return new; }