Commit 2ec71843 authored by Matthew Wilcox (Oracle)'s avatar Matthew Wilcox (Oracle) Committed by Richard Weinberger

ubifs: Convert write_begin_slow() to use a folio

Update to new APIs, removing several calls to compound_head() and
including support for large folios.
Signed-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Reviewed-by: default avatarZhihao Cheng <chengzhihao1@huawei.com>
Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
parent 85ffbf55
...@@ -222,16 +222,16 @@ static int write_begin_slow(struct address_space *mapping, ...@@ -222,16 +222,16 @@ static int write_begin_slow(struct address_space *mapping,
pgoff_t index = pos >> PAGE_SHIFT; pgoff_t index = pos >> PAGE_SHIFT;
struct ubifs_budget_req req = { .new_page = 1 }; struct ubifs_budget_req req = { .new_page = 1 };
int err, appending = !!(pos + len > inode->i_size); int err, appending = !!(pos + len > inode->i_size);
struct page *page; struct folio *folio;
dbg_gen("ino %lu, pos %llu, len %u, i_size %lld", dbg_gen("ino %lu, pos %llu, len %u, i_size %lld",
inode->i_ino, pos, len, inode->i_size); inode->i_ino, pos, len, inode->i_size);
/* /*
* At the slow path we have to budget before locking the page, because * At the slow path we have to budget before locking the folio, because
* budgeting may force write-back, which would wait on locked pages and * budgeting may force write-back, which would wait on locked folios and
* deadlock if we had the page locked. At this point we do not know * deadlock if we had the folio locked. At this point we do not know
* anything about the page, so assume that this is a new page which is * anything about the folio, so assume that this is a new folio which is
* written to a hole. This corresponds to largest budget. Later the * written to a hole. This corresponds to largest budget. Later the
* budget will be amended if this is not true. * budget will be amended if this is not true.
*/ */
...@@ -243,42 +243,43 @@ static int write_begin_slow(struct address_space *mapping, ...@@ -243,42 +243,43 @@ static int write_begin_slow(struct address_space *mapping,
if (unlikely(err)) if (unlikely(err))
return err; return err;
page = grab_cache_page_write_begin(mapping, index); folio = __filemap_get_folio(mapping, index, FGP_WRITEBEGIN,
if (unlikely(!page)) { mapping_gfp_mask(mapping));
if (IS_ERR(folio)) {
ubifs_release_budget(c, &req); ubifs_release_budget(c, &req);
return -ENOMEM; return PTR_ERR(folio);
} }
if (!PageUptodate(page)) { if (!folio_test_uptodate(folio)) {
if (!(pos & ~PAGE_MASK) && len == PAGE_SIZE) if (pos == folio_pos(folio) && len >= folio_size(folio))
SetPageChecked(page); folio_set_checked(folio);
else { else {
err = do_readpage(page); err = do_readpage(&folio->page);
if (err) { if (err) {
unlock_page(page); folio_unlock(folio);
put_page(page); folio_put(folio);
ubifs_release_budget(c, &req); ubifs_release_budget(c, &req);
return err; return err;
} }
} }
} }
if (PagePrivate(page)) if (folio->private)
/* /*
* The page is dirty, which means it was budgeted twice: * The folio is dirty, which means it was budgeted twice:
* o first time the budget was allocated by the task which * o first time the budget was allocated by the task which
* made the page dirty and set the PG_private flag; * made the folio dirty and set the private field;
* o and then we budgeted for it for the second time at the * o and then we budgeted for it for the second time at the
* very beginning of this function. * very beginning of this function.
* *
* So what we have to do is to release the page budget we * So what we have to do is to release the folio budget we
* allocated. * allocated.
*/ */
release_new_page_budget(c); release_new_page_budget(c);
else if (!PageChecked(page)) else if (!folio_test_checked(folio))
/* /*
* We are changing a page which already exists on the media. * We are changing a folio which already exists on the media.
* This means that changing the page does not make the amount * This means that changing the folio does not make the amount
* of indexing information larger, and this part of the budget * of indexing information larger, and this part of the budget
* which we have already acquired may be released. * which we have already acquired may be released.
*/ */
...@@ -301,7 +302,7 @@ static int write_begin_slow(struct address_space *mapping, ...@@ -301,7 +302,7 @@ static int write_begin_slow(struct address_space *mapping,
ubifs_release_dirty_inode_budget(c, ui); ubifs_release_dirty_inode_budget(c, ui);
} }
*pagep = page; *pagep = &folio->page;
return 0; return 0;
} }
......
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