Commit b8cecb93 authored by Matthew Wilcox (Oracle)'s avatar Matthew Wilcox (Oracle) Committed by akpm

mm/vmscan: convert reclaim_clean_pages_from_list() to folios

Patch series "nvert much of vmscan to folios"

vmscan always operates on folios since it puts the pages on the LRU list. 
Switching all of these functions from pages to folios saves 1483 bytes of
text from removing all the baggage around calling compound_page() and
similar functions.


This patch (of 5):

This is a straightforward conversion which removes several hidden calls
to compound_head, saving 330 bytes of kernel text.

Link: https://lkml.kernel.org/r/20220617154248.700416-1-willy@infradead.org
Link: https://lkml.kernel.org/r/20220617154248.700416-2-willy@infradead.orgSigned-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 64fe24a3
...@@ -670,6 +670,12 @@ static __always_inline bool PageAnon(struct page *page) ...@@ -670,6 +670,12 @@ static __always_inline bool PageAnon(struct page *page)
return folio_test_anon(page_folio(page)); return folio_test_anon(page_folio(page));
} }
static __always_inline bool __folio_test_movable(const struct folio *folio)
{
return ((unsigned long)folio->mapping & PAGE_MAPPING_FLAGS) ==
PAGE_MAPPING_MOVABLE;
}
static __always_inline int __PageMovable(struct page *page) static __always_inline int __PageMovable(struct page *page)
{ {
return ((unsigned long)page->mapping & PAGE_MAPPING_FLAGS) == return ((unsigned long)page->mapping & PAGE_MAPPING_FLAGS) ==
......
...@@ -2041,7 +2041,7 @@ static unsigned int shrink_page_list(struct list_head *page_list, ...@@ -2041,7 +2041,7 @@ static unsigned int shrink_page_list(struct list_head *page_list,
} }
unsigned int reclaim_clean_pages_from_list(struct zone *zone, unsigned int reclaim_clean_pages_from_list(struct zone *zone,
struct list_head *page_list) struct list_head *folio_list)
{ {
struct scan_control sc = { struct scan_control sc = {
.gfp_mask = GFP_KERNEL, .gfp_mask = GFP_KERNEL,
...@@ -2049,16 +2049,16 @@ unsigned int reclaim_clean_pages_from_list(struct zone *zone, ...@@ -2049,16 +2049,16 @@ unsigned int reclaim_clean_pages_from_list(struct zone *zone,
}; };
struct reclaim_stat stat; struct reclaim_stat stat;
unsigned int nr_reclaimed; unsigned int nr_reclaimed;
struct page *page, *next; struct folio *folio, *next;
LIST_HEAD(clean_pages); LIST_HEAD(clean_folios);
unsigned int noreclaim_flag; unsigned int noreclaim_flag;
list_for_each_entry_safe(page, next, page_list, lru) { list_for_each_entry_safe(folio, next, folio_list, lru) {
if (!PageHuge(page) && page_is_file_lru(page) && if (!folio_test_hugetlb(folio) && folio_is_file_lru(folio) &&
!PageDirty(page) && !__PageMovable(page) && !folio_test_dirty(folio) && !__folio_test_movable(folio) &&
!PageUnevictable(page)) { !folio_test_unevictable(folio)) {
ClearPageActive(page); folio_clear_active(folio);
list_move(&page->lru, &clean_pages); list_move(&folio->lru, &clean_folios);
} }
} }
...@@ -2069,11 +2069,11 @@ unsigned int reclaim_clean_pages_from_list(struct zone *zone, ...@@ -2069,11 +2069,11 @@ unsigned int reclaim_clean_pages_from_list(struct zone *zone,
* change in the future. * change in the future.
*/ */
noreclaim_flag = memalloc_noreclaim_save(); noreclaim_flag = memalloc_noreclaim_save();
nr_reclaimed = shrink_page_list(&clean_pages, zone->zone_pgdat, &sc, nr_reclaimed = shrink_page_list(&clean_folios, zone->zone_pgdat, &sc,
&stat, true); &stat, true);
memalloc_noreclaim_restore(noreclaim_flag); memalloc_noreclaim_restore(noreclaim_flag);
list_splice(&clean_pages, page_list); list_splice(&clean_folios, folio_list);
mod_node_page_state(zone->zone_pgdat, NR_ISOLATED_FILE, mod_node_page_state(zone->zone_pgdat, NR_ISOLATED_FILE,
-(long)nr_reclaimed); -(long)nr_reclaimed);
/* /*
......
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