filemap: Add filemap_release_folio()

Reimplement try_to_release_page() as a wrapper around
filemap_release_folio().
Signed-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarWilliam Kucharski <william.kucharski@oracle.com>
parent 960ea971
...@@ -1970,7 +1970,6 @@ int get_kernel_pages(const struct kvec *iov, int nr_pages, int write, ...@@ -1970,7 +1970,6 @@ int get_kernel_pages(const struct kvec *iov, int nr_pages, int write,
struct page **pages); struct page **pages);
struct page *get_dump_page(unsigned long addr); struct page *get_dump_page(unsigned long addr);
extern int try_to_release_page(struct page * page, gfp_t gfp_mask);
extern void do_invalidatepage(struct page *page, unsigned int offset, extern void do_invalidatepage(struct page *page, unsigned int offset,
unsigned int length); unsigned int length);
......
...@@ -939,6 +939,8 @@ static inline void __delete_from_page_cache(struct page *page, void *shadow) ...@@ -939,6 +939,8 @@ static inline void __delete_from_page_cache(struct page *page, void *shadow)
void replace_page_cache_page(struct page *old, struct page *new); void replace_page_cache_page(struct page *old, struct page *new);
void delete_from_page_cache_batch(struct address_space *mapping, void delete_from_page_cache_batch(struct address_space *mapping,
struct pagevec *pvec); struct pagevec *pvec);
int try_to_release_page(struct page *page, gfp_t gfp);
bool filemap_release_folio(struct folio *folio, gfp_t gfp);
loff_t mapping_seek_hole_data(struct address_space *, loff_t start, loff_t end, loff_t mapping_seek_hole_data(struct address_space *, loff_t start, loff_t end,
int whence); int whence);
......
...@@ -3889,33 +3889,32 @@ ssize_t generic_file_write_iter(struct kiocb *iocb, struct iov_iter *from) ...@@ -3889,33 +3889,32 @@ ssize_t generic_file_write_iter(struct kiocb *iocb, struct iov_iter *from)
EXPORT_SYMBOL(generic_file_write_iter); EXPORT_SYMBOL(generic_file_write_iter);
/** /**
* try_to_release_page() - release old fs-specific metadata on a page * filemap_release_folio() - Release fs-specific metadata on a folio.
* @folio: The folio which the kernel is trying to free.
* @gfp: Memory allocation flags (and I/O mode).
* *
* @page: the page which the kernel is trying to free * The address_space is trying to release any data attached to a folio
* @gfp_mask: memory allocation flags (and I/O mode) * (presumably at folio->private).
* *
* The address_space is to try to release any data against the page * This will also be called if the private_2 flag is set on a page,
* (presumably at page->private). * indicating that the folio has other metadata associated with it.
* *
* This may also be called if PG_fscache is set on a page, indicating that the * The @gfp argument specifies whether I/O may be performed to release
* page is known to the local caching routines. * this page (__GFP_IO), and whether the call may block
* (__GFP_RECLAIM & __GFP_FS).
* *
* The @gfp_mask argument specifies whether I/O may be performed to release * Return: %true if the release was successful, otherwise %false.
* this page (__GFP_IO), and whether the call may block (__GFP_RECLAIM & __GFP_FS).
*
* Return: %1 if the release was successful, otherwise return zero.
*/ */
int try_to_release_page(struct page *page, gfp_t gfp_mask) bool filemap_release_folio(struct folio *folio, gfp_t gfp)
{ {
struct address_space * const mapping = page->mapping; struct address_space * const mapping = folio->mapping;
BUG_ON(!PageLocked(page)); BUG_ON(!folio_test_locked(folio));
if (PageWriteback(page)) if (folio_test_writeback(folio))
return 0; return false;
if (mapping && mapping->a_ops->releasepage) if (mapping && mapping->a_ops->releasepage)
return mapping->a_ops->releasepage(page, gfp_mask); return mapping->a_ops->releasepage(&folio->page, gfp);
return try_to_free_buffers(page); return try_to_free_buffers(&folio->page);
} }
EXPORT_SYMBOL(filemap_release_folio);
EXPORT_SYMBOL(try_to_release_page);
...@@ -145,3 +145,9 @@ void delete_from_page_cache(struct page *page) ...@@ -145,3 +145,9 @@ void delete_from_page_cache(struct page *page)
{ {
return filemap_remove_folio(page_folio(page)); return filemap_remove_folio(page_folio(page));
} }
int try_to_release_page(struct page *page, gfp_t gfp)
{
return filemap_release_folio(page_folio(page), gfp);
}
EXPORT_SYMBOL(try_to_release_page);
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment