@@ -228,8 +228,7 @@ void __delete_from_page_cache(struct page *page, void *shadow)
page_cache_delete(mapping, page, shadow);
}
-static void page_cache_free_page(struct address_space *mapping,
- struct page *page)
+void page_cache_free_page(struct address_space *mapping, struct page *page)
{
void (*freepage)(struct page *);
@@ -623,4 +623,5 @@ struct migration_target_control {
};
bool truncate_inode_partial_page(struct page *page, loff_t start, loff_t end);
+void page_cache_free_page(struct address_space *mapping, struct page *page);
#endif /* __MM_INTERNAL_H */
@@ -603,10 +603,7 @@ invalidate_complete_page2(struct address_space *mapping, struct page *page)
__delete_from_page_cache(page, NULL);
xa_unlock_irqrestore(&mapping->i_pages, flags);
- if (mapping->a_ops->freepage)
- mapping->a_ops->freepage(page);
-
- put_page(page); /* pagecache ref */
+ page_cache_free_page(mapping, page);
return 1;
failed:
xa_unlock_irqrestore(&mapping->i_pages, flags);
invalidate_complete_page2() currently open-codes page_cache_free_page(), except for the part where it handles THP. Rather than adding that, call page_cache_free_page() from invalidate_complete_page2(). Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org> --- mm/filemap.c | 3 +-- mm/internal.h | 1 + mm/truncate.c | 5 +---- 3 files changed, 3 insertions(+), 6 deletions(-)