Skip to content

Commit

Permalink
erofs: convert z_erofs_pcluster_readmore() to folios
Browse files Browse the repository at this point in the history
Unlike `pagecache_get_page()`, `__filemap_get_folio()` returns error
pointers instead of NULL, thus switching to `IS_ERR_OR_NULL`.

Apart from that, it's just a straightforward conversion.

Signed-off-by: Gao Xiang <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
  • Loading branch information
hsiangkao committed Jul 8, 2024
1 parent 256abd8 commit 1a4821a
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 17 deletions.
14 changes: 5 additions & 9 deletions fs/erofs/internal.h
Original file line number Diff line number Diff line change
Expand Up @@ -312,17 +312,13 @@ static inline unsigned int erofs_inode_datalayout(unsigned int ifmt)
return (ifmt >> EROFS_I_DATALAYOUT_BIT) & EROFS_I_DATALAYOUT_MASK;
}

/*
* Different from grab_cache_page_nowait(), reclaiming is never triggered
* when allocating new pages.
*/
static inline
struct page *erofs_grab_cache_page_nowait(struct address_space *mapping,
pgoff_t index)
/* reclaiming is never triggered when allocating new folios. */
static inline struct folio *erofs_grab_folio_nowait(struct address_space *as,
pgoff_t index)
{
return pagecache_get_page(mapping, index,
return __filemap_get_folio(as, index,
FGP_LOCK|FGP_CREAT|FGP_NOFS|FGP_NOWAIT,
readahead_gfp_mask(mapping) & ~__GFP_RECLAIM);
readahead_gfp_mask(as) & ~__GFP_RECLAIM);
}

/* Has a disk mapping */
Expand Down
15 changes: 7 additions & 8 deletions fs/erofs/zdata.c
Original file line number Diff line number Diff line change
Expand Up @@ -1767,23 +1767,22 @@ static void z_erofs_pcluster_readmore(struct z_erofs_decompress_frontend *f,
end = round_up(end, PAGE_SIZE);
} else {
end = round_up(map->m_la, PAGE_SIZE);

if (!map->m_llen)
return;
}

cur = map->m_la + map->m_llen - 1;
while ((cur >= end) && (cur < i_size_read(inode))) {
pgoff_t index = cur >> PAGE_SHIFT;
struct page *page;
struct folio *folio;

page = erofs_grab_cache_page_nowait(inode->i_mapping, index);
if (page) {
if (PageUptodate(page))
unlock_page(page);
folio = erofs_grab_folio_nowait(inode->i_mapping, index);
if (!IS_ERR_OR_NULL(folio)) {
if (folio_test_uptodate(folio))
folio_unlock(folio);
else
z_erofs_scan_folio(f, page_folio(page), !!rac);
put_page(page);
z_erofs_scan_folio(f, folio, !!rac);
folio_put(folio);
}

if (cur < PAGE_SIZE)
Expand Down

0 comments on commit 1a4821a

Please sign in to comment.