romfs: Convert romfs_read_folio() to use a folio

Remove the conversion back to struct page and use the folio APIs instead
of the page APIs.  It's probably more trouble than it's worth to support
large folios in romfs, so there are still PAGE_SIZE assumptions in
this function.

Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Link: https://lore.kernel.org/r/20240530202110.2653630-13-willy@infradead.org
Signed-off-by: Christian Brauner <brauner@kernel.org>
This commit is contained in:
Matthew Wilcox (Oracle) 2024-05-30 21:21:04 +01:00 committed by Christian Brauner
parent f4c51473d2
commit d86f2de026
No known key found for this signature in database
GPG Key ID: 91C61BC06578DCA2

View File

@ -101,19 +101,15 @@ static struct inode *romfs_iget(struct super_block *sb, unsigned long pos);
*/ */
static int romfs_read_folio(struct file *file, struct folio *folio) static int romfs_read_folio(struct file *file, struct folio *folio)
{ {
struct page *page = &folio->page; struct inode *inode = folio->mapping->host;
struct inode *inode = page->mapping->host;
loff_t offset, size; loff_t offset, size;
unsigned long fillsize, pos; unsigned long fillsize, pos;
void *buf; void *buf;
int ret; int ret;
buf = kmap(page); buf = kmap_local_folio(folio, 0);
if (!buf)
return -ENOMEM;
/* 32 bit warning -- but not for us :) */ offset = folio_pos(folio);
offset = page_offset(page);
size = i_size_read(inode); size = i_size_read(inode);
fillsize = 0; fillsize = 0;
ret = 0; ret = 0;
@ -125,20 +121,14 @@ static int romfs_read_folio(struct file *file, struct folio *folio)
ret = romfs_dev_read(inode->i_sb, pos, buf, fillsize); ret = romfs_dev_read(inode->i_sb, pos, buf, fillsize);
if (ret < 0) { if (ret < 0) {
SetPageError(page);
fillsize = 0; fillsize = 0;
ret = -EIO; ret = -EIO;
} }
} }
if (fillsize < PAGE_SIZE) buf = folio_zero_tail(folio, fillsize, buf);
memset(buf + fillsize, 0, PAGE_SIZE - fillsize); kunmap_local(buf);
if (ret == 0) folio_end_read(folio, ret == 0);
SetPageUptodate(page);
flush_dcache_page(page);
kunmap(page);
unlock_page(page);
return ret; return ret;
} }