]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
ext4: Convert ext4_readpage_inline() to take a folio
authorMatthew Wilcox <willy@infradead.org>
Fri, 24 Mar 2023 18:01:09 +0000 (18:01 +0000)
committerTheodore Ts'o <tytso@mit.edu>
Thu, 6 Apr 2023 17:39:51 +0000 (13:39 -0400)
Use the folio API in this function, saves a few calls to compound_head().

Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Reviewed-by: Theodore Ts'o <tytso@mit.edu>
Link: https://lore.kernel.org/r/20230324180129.1220691-10-willy@infradead.org
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
fs/ext4/ext4.h
fs/ext4/inline.c
fs/ext4/inode.c

index 3535338caf0d7e25baf5c4b633fce5050ef40822..6b21b3aa92d60df49c477f980247fd1180623d06 100644 (file)
@@ -3549,7 +3549,7 @@ extern int ext4_init_inline_data(handle_t *handle, struct inode *inode,
                                 unsigned int len);
 extern int ext4_destroy_inline_data(handle_t *handle, struct inode *inode);
 
-extern int ext4_readpage_inline(struct inode *inode, struct page *page);
+int ext4_readpage_inline(struct inode *inode, struct folio *folio);
 extern int ext4_try_to_write_inline_data(struct address_space *mapping,
                                         struct inode *inode,
                                         loff_t pos, unsigned len,
index 1602d74b5eeb35f0090afb0ec566ed5f00c21ecc..e9bae3002319174f32f311f6ff8b406812e67245 100644 (file)
@@ -501,7 +501,7 @@ out:
        return ret;
 }
 
-int ext4_readpage_inline(struct inode *inode, struct page *page)
+int ext4_readpage_inline(struct inode *inode, struct folio *folio)
 {
        int ret = 0;
 
@@ -515,16 +515,16 @@ int ext4_readpage_inline(struct inode *inode, struct page *page)
         * Current inline data can only exist in the 1st page,
         * So for all the other pages, just set them uptodate.
         */
-       if (!page->index)
-               ret = ext4_read_inline_page(inode, page);
-       else if (!PageUptodate(page)) {
-               zero_user_segment(page, 0, PAGE_SIZE);
-               SetPageUptodate(page);
+       if (!folio->index)
+               ret = ext4_read_inline_page(inode, &folio->page);
+       else if (!folio_test_uptodate(folio)) {
+               folio_zero_segment(folio, 0, folio_size(folio));
+               folio_mark_uptodate(folio);
        }
 
        up_read(&EXT4_I(inode)->xattr_sem);
 
-       unlock_page(page);
+       folio_unlock(folio);
        return ret >= 0 ? 0 : ret;
 }
 
index 2be604af7aec4b0d66d0230756db7b595fa3c509..81bcc73f610f999363bf25e98732f0249d1cf094 100644 (file)
@@ -3155,7 +3155,7 @@ static int ext4_read_folio(struct file *file, struct folio *folio)
        trace_ext4_readpage(page);
 
        if (ext4_has_inline_data(inode))
-               ret = ext4_readpage_inline(inode, page);
+               ret = ext4_readpage_inline(inode, folio);
 
        if (ret == -EAGAIN)
                return ext4_mpage_readpages(inode, NULL, page);