mm: reimplement folio_is_fsdax()

For callers of folio_is_fsdax(), we save a folio->page->folio conversion. 
Callers of is_fsdax_page() simply move the conversion of page->folio from
the implementation of page_pgmap() to is_fsdax_page().

Link: https://lkml.kernel.org/r/20250805172307.1302730-11-willy@infradead.org
Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Reviewed-by: Zi Yan <ziy@nvidia.com>
Cc: Shakeel Butt <shakeel.butt@linux.dev>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
Matthew Wilcox (Oracle) 2025-08-05 18:23:00 +01:00 committed by Andrew Morton
parent bd0dbbb3fd
commit c995ac3aa3

View File

@ -188,15 +188,15 @@ static inline bool is_device_coherent_page(const struct page *page)
return folio_is_device_coherent(page_folio(page));
}
static inline bool is_fsdax_page(const struct page *page)
{
return is_zone_device_page(page) &&
page_pgmap(page)->type == MEMORY_DEVICE_FS_DAX;
}
static inline bool folio_is_fsdax(const struct folio *folio)
{
return is_fsdax_page(&folio->page);
return folio_is_zone_device(folio) &&
folio->pgmap->type == MEMORY_DEVICE_FS_DAX;
}
static inline bool is_fsdax_page(const struct page *page)
{
return folio_is_fsdax(page_folio(page));
}
#ifdef CONFIG_ZONE_DEVICE