Commit d71b53c3 authored by Josef Bacik's avatar Josef Bacik Committed by David Sterba

btrfs: convert btrfs_writepage_cow_fixup() to use folio

Instead of a page, use a folio for btrfs_writepage_cow_fixup.  We
already have a folio at the only caller, and the fixup worker uses
folios.
Signed-off-by: default avatarJosef Bacik <josef@toxicpanda.com>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 7d003cc2
...@@ -598,7 +598,7 @@ int btrfs_prealloc_file_range_trans(struct inode *inode, ...@@ -598,7 +598,7 @@ int btrfs_prealloc_file_range_trans(struct inode *inode,
loff_t actual_len, u64 *alloc_hint); loff_t actual_len, u64 *alloc_hint);
int btrfs_run_delalloc_range(struct btrfs_inode *inode, struct folio *locked_folio, int btrfs_run_delalloc_range(struct btrfs_inode *inode, struct folio *locked_folio,
u64 start, u64 end, struct writeback_control *wbc); u64 start, u64 end, struct writeback_control *wbc);
int btrfs_writepage_cow_fixup(struct page *page); int btrfs_writepage_cow_fixup(struct folio *folio);
int btrfs_encoded_io_compression_from_extent(struct btrfs_fs_info *fs_info, int btrfs_encoded_io_compression_from_extent(struct btrfs_fs_info *fs_info,
int compress_type); int compress_type);
int btrfs_encoded_read_regular_fill_pages(struct btrfs_inode *inode, int btrfs_encoded_read_regular_fill_pages(struct btrfs_inode *inode,
......
...@@ -1410,7 +1410,7 @@ static noinline_for_stack int __extent_writepage_io(struct btrfs_inode *inode, ...@@ -1410,7 +1410,7 @@ static noinline_for_stack int __extent_writepage_io(struct btrfs_inode *inode,
ASSERT(start >= folio_pos(folio) && ASSERT(start >= folio_pos(folio) &&
start + len <= folio_pos(folio) + folio_size(folio)); start + len <= folio_pos(folio) + folio_size(folio));
ret = btrfs_writepage_cow_fixup(&folio->page); ret = btrfs_writepage_cow_fixup(folio);
if (ret) { if (ret) {
/* Fixup worker will requeue */ /* Fixup worker will requeue */
folio_redirty_for_writepage(bio_ctrl->wbc, folio); folio_redirty_for_writepage(bio_ctrl->wbc, folio);
......
...@@ -2828,33 +2828,34 @@ static void btrfs_writepage_fixup_worker(struct btrfs_work *work) ...@@ -2828,33 +2828,34 @@ static void btrfs_writepage_fixup_worker(struct btrfs_work *work)
/* /*
* There are a few paths in the higher layers of the kernel that directly * There are a few paths in the higher layers of the kernel that directly
* set the page dirty bit without asking the filesystem if it is a * set the folio dirty bit without asking the filesystem if it is a
* good idea. This causes problems because we want to make sure COW * good idea. This causes problems because we want to make sure COW
* properly happens and the data=ordered rules are followed. * properly happens and the data=ordered rules are followed.
* *
* In our case any range that doesn't have the ORDERED bit set * In our case any range that doesn't have the ORDERED bit set
* hasn't been properly setup for IO. We kick off an async process * hasn't been properly setup for IO. We kick off an async process
* to fix it up. The async helper will wait for ordered extents, set * to fix it up. The async helper will wait for ordered extents, set
* the delalloc bit and make it safe to write the page. * the delalloc bit and make it safe to write the folio.
*/ */
int btrfs_writepage_cow_fixup(struct page *page) int btrfs_writepage_cow_fixup(struct folio *folio)
{ {
struct inode *inode = page->mapping->host; struct inode *inode = folio->mapping->host;
struct btrfs_fs_info *fs_info = inode_to_fs_info(inode); struct btrfs_fs_info *fs_info = inode_to_fs_info(inode);
struct btrfs_writepage_fixup *fixup; struct btrfs_writepage_fixup *fixup;
/* This page has ordered extent covering it already */ /* This folio has ordered extent covering it already */
if (PageOrdered(page)) if (folio_test_ordered(folio))
return 0; return 0;
/* /*
* PageChecked is set below when we create a fixup worker for this page, * folio_checked is set below when we create a fixup worker for this
* don't try to create another one if we're already PageChecked() * folio, don't try to create another one if we're already
* folio_test_checked.
* *
* The extent_io writepage code will redirty the page if we send back * The extent_io writepage code will redirty the foio if we send back
* EAGAIN. * EAGAIN.
*/ */
if (PageChecked(page)) if (folio_test_checked(folio))
return -EAGAIN; return -EAGAIN;
fixup = kzalloc(sizeof(*fixup), GFP_NOFS); fixup = kzalloc(sizeof(*fixup), GFP_NOFS);
...@@ -2864,14 +2865,14 @@ int btrfs_writepage_cow_fixup(struct page *page) ...@@ -2864,14 +2865,14 @@ int btrfs_writepage_cow_fixup(struct page *page)
/* /*
* We are already holding a reference to this inode from * We are already holding a reference to this inode from
* write_cache_pages. We need to hold it because the space reservation * write_cache_pages. We need to hold it because the space reservation
* takes place outside of the page lock, and we can't trust * takes place outside of the folio lock, and we can't trust
* page->mapping outside of the page lock. * page->mapping outside of the folio lock.
*/ */
ihold(inode); ihold(inode);
btrfs_folio_set_checked(fs_info, page_folio(page), page_offset(page), PAGE_SIZE); btrfs_folio_set_checked(fs_info, folio, folio_pos(folio), folio_size(folio));
get_page(page); folio_get(folio);
btrfs_init_work(&fixup->work, btrfs_writepage_fixup_worker, NULL); btrfs_init_work(&fixup->work, btrfs_writepage_fixup_worker, NULL);
fixup->page = page; fixup->page = &folio->page;
fixup->inode = BTRFS_I(inode); fixup->inode = BTRFS_I(inode);
btrfs_queue_work(fs_info->fixup_workers, &fixup->work); btrfs_queue_work(fs_info->fixup_workers, &fixup->work);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment