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,
 
        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;
 
         * 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;
 }
 
 
        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);