move page_lruvec() out of add_page_to_lru_list() and del_page_from_lru_list() switch its first argument from zone to lruvec. Signed-off-by: Konstantin Khlebnikov <khlebnikov@xxxxxxxxxx> --- include/linux/mm_inline.h | 10 ++++------ mm/compaction.c | 4 +++- mm/memcontrol.c | 7 +++++-- mm/swap.c | 33 ++++++++++++++++++++++----------- mm/vmscan.c | 16 +++++++++++----- 5 files changed, 45 insertions(+), 25 deletions(-) diff --git a/include/linux/mm_inline.h b/include/linux/mm_inline.h index daa3d15..143a2e8 100644 --- a/include/linux/mm_inline.h +++ b/include/linux/mm_inline.h @@ -22,26 +22,24 @@ static inline int page_is_file_cache(struct page *page) } static inline void -add_page_to_lru_list(struct zone *zone, struct page *page, enum lru_list lru) +add_page_to_lru_list(struct lruvec *lruvec, struct page *page, enum lru_list lru) { - struct lruvec *lruvec = page_lruvec(page); int numpages = hpage_nr_pages(page); list_add(&page->lru, &lruvec->pages_lru[lru]); lruvec->pages_count[lru] += numpages; - __mod_zone_page_state(zone, NR_LRU_BASE + lru, numpages); + __mod_zone_page_state(lruvec_zone(lruvec), NR_LRU_BASE + lru, numpages); } static inline void -del_page_from_lru_list(struct zone *zone, struct page *page, enum lru_list lru) +del_page_from_lru_list(struct lruvec *lruvec, struct page *page, enum lru_list lru) { - struct lruvec *lruvec = page_lruvec(page); int numpages = hpage_nr_pages(page); list_del(&page->lru); lruvec->pages_count[lru] -= numpages; VM_BUG_ON((long)lruvec->pages_count[lru] < 0); - __mod_zone_page_state(zone, NR_LRU_BASE + lru, -numpages); + __mod_zone_page_state(lruvec_zone(lruvec), NR_LRU_BASE + lru, -numpages); } /** diff --git a/mm/compaction.c b/mm/compaction.c index 74a8c82..a976b28 100644 --- a/mm/compaction.c +++ b/mm/compaction.c @@ -262,6 +262,7 @@ static isolate_migrate_t isolate_migratepages(struct zone *zone, unsigned long nr_scanned = 0, nr_isolated = 0; struct list_head *migratelist = &cc->migratepages; isolate_mode_t mode = ISOLATE_ACTIVE|ISOLATE_INACTIVE; + struct lruvec *lruvec; /* Do not scan outside zone boundaries */ low_pfn = max(cc->migrate_pfn, zone->zone_start_pfn); @@ -381,7 +382,8 @@ static isolate_migrate_t isolate_migratepages(struct zone *zone, VM_BUG_ON(PageTransCompound(page)); /* Successfully isolated */ - del_page_from_lru_list(zone, page, page_lru(page)); + lruvec = page_lruvec(page); + del_page_from_lru_list(lruvec, page, page_lru(page)); list_add(&page->lru, migratelist); cc->nr_migratepages++; nr_isolated++; diff --git a/mm/memcontrol.c b/mm/memcontrol.c index 5c1414b..ea1fdeb 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -2529,6 +2529,7 @@ __mem_cgroup_commit_charge_lrucare(struct page *page, struct mem_cgroup *memcg, { struct page_cgroup *pc = lookup_page_cgroup(page); struct zone *zone = page_zone(page); + struct lruvec *lruvec; unsigned long flags; bool removed = false; @@ -2539,13 +2540,15 @@ __mem_cgroup_commit_charge_lrucare(struct page *page, struct mem_cgroup *memcg, */ spin_lock_irqsave(&zone->lru_lock, flags); if (PageLRU(page)) { - del_page_from_lru_list(zone, page, page_lru(page)); + lruvec = page_lruvec(page); + del_page_from_lru_list(lruvec, page, page_lru(page)); ClearPageLRU(page); removed = true; } __mem_cgroup_commit_charge(memcg, page, 1, pc, ctype); if (removed) { - add_page_to_lru_list(zone, page, page_lru(page)); + lruvec = page_lruvec(page); + add_page_to_lru_list(lruvec, page, page_lru(page)); SetPageLRU(page); } spin_unlock_irqrestore(&zone->lru_lock, flags); diff --git a/mm/swap.c b/mm/swap.c index f31bd45..0167d6f 100644 --- a/mm/swap.c +++ b/mm/swap.c @@ -54,11 +54,13 @@ static void __page_cache_release(struct page *page) if (PageLRU(page)) { unsigned long flags; struct zone *zone = page_zone(page); + struct lruvec *lruvec; spin_lock_irqsave(&zone->lru_lock, flags); VM_BUG_ON(!PageLRU(page)); __ClearPageLRU(page); - del_page_from_lru_list(zone, page, page_off_lru(page)); + lruvec = page_lruvec(page); + del_page_from_lru_list(lruvec, page, page_off_lru(page)); spin_unlock_irqrestore(&zone->lru_lock, flags); } } @@ -298,11 +300,13 @@ static void __activate_page(struct page *page, void *arg) if (PageLRU(page) && !PageActive(page) && !PageUnevictable(page)) { int file = page_is_file_cache(page); int lru = page_lru_base_type(page); - del_page_from_lru_list(zone, page, lru); + struct lruvec *lruvec = page_lruvec(page); + + del_page_from_lru_list(lruvec, page, lru); SetPageActive(page); lru += LRU_ACTIVE; - add_page_to_lru_list(zone, page, lru); + add_page_to_lru_list(lruvec, page, lru); __count_vm_event(PGACTIVATE); update_page_reclaim_stat(zone, page, file, 1); @@ -371,6 +375,7 @@ static void __lru_cache_add_list(struct list_head *pages, enum lru_list lru) int file = is_file_lru(lru); int active = is_active_lru(lru); struct page *page, *next; + struct lruvec *lruvec; struct zone *pagezone, *zone = NULL; unsigned long uninitialized_var(flags); LIST_HEAD(free_pages); @@ -390,11 +395,12 @@ static void __lru_cache_add_list(struct list_head *pages, enum lru_list lru) if (active) SetPageActive(page); update_page_reclaim_stat(zone, page, file, active); - add_page_to_lru_list(zone, page, lru); + lruvec = page_lruvec(page); + add_page_to_lru_list(lruvec, page, lru); if (unlikely(put_page_testzero(page))) { __ClearPageLRU(page); __ClearPageActive(page); - del_page_from_lru_list(zone, page, lru); + del_page_from_lru_list(lruvec, page, lru); if (unlikely(PageCompound(page))) { spin_unlock_irqrestore(&zone->lru_lock, flags); zone = NULL; @@ -478,11 +484,13 @@ void lru_cache_add_lru(struct page *page, enum lru_list lru) void add_page_to_unevictable_list(struct page *page) { struct zone *zone = page_zone(page); + struct lruvec *lruvec; spin_lock_irq(&zone->lru_lock); SetPageUnevictable(page); SetPageLRU(page); - add_page_to_lru_list(zone, page, LRU_UNEVICTABLE); + lruvec = page_lruvec(page); + add_page_to_lru_list(lruvec, page, LRU_UNEVICTABLE); spin_unlock_irq(&zone->lru_lock); } @@ -512,6 +520,7 @@ static void lru_deactivate_fn(struct page *page, void *arg) int lru, file; bool active; struct zone *zone = page_zone(page); + struct lruvec *lruvec; if (!PageLRU(page)) return; @@ -527,10 +536,11 @@ static void lru_deactivate_fn(struct page *page, void *arg) file = page_is_file_cache(page); lru = page_lru_base_type(page); - del_page_from_lru_list(zone, page, lru + active); + lruvec = page_lruvec(page); + del_page_from_lru_list(lruvec, page, lru + active); ClearPageActive(page); ClearPageReferenced(page); - add_page_to_lru_list(zone, page, lru); + add_page_to_lru_list(lruvec, page, lru); if (PageWriteback(page) || PageDirty(page)) { /* @@ -540,7 +550,6 @@ static void lru_deactivate_fn(struct page *page, void *arg) */ SetPageReclaim(page); } else { - struct lruvec *lruvec = page_lruvec(page); /* * The page's writeback ends up during pagevec * We moves tha page into tail of inactive. @@ -672,6 +681,7 @@ void release_pages(struct page **pages, int nr, int cold) if (PageLRU(page)) { struct zone *pagezone = page_zone(page); + struct lruvec *lruvec = page_lruvec(page); if (pagezone != zone) { if (zone) @@ -682,7 +692,7 @@ void release_pages(struct page **pages, int nr, int cold) } VM_BUG_ON(!PageLRU(page)); __ClearPageLRU(page); - del_page_from_lru_list(zone, page, page_off_lru(page)); + del_page_from_lru_list(lruvec, page, page_off_lru(page)); } list_add(&page->lru, &pages_to_free); @@ -720,6 +730,7 @@ void lru_add_page_tail(struct zone* zone, int active; enum lru_list lru; const int file = 0; + struct lruvec *lruvec = page_lruvec(page); VM_BUG_ON(!PageHead(page)); VM_BUG_ON(PageCompound(page_tail)); @@ -754,7 +765,7 @@ void lru_add_page_tail(struct zone* zone, * Use the standard add function to put page_tail on the list, * but then correct its position so they all end up in order. */ - add_page_to_lru_list(zone, page_tail, lru); + add_page_to_lru_list(lruvec, page_tail, lru); list_head = page_tail->lru.prev; list_move_tail(&page_tail->lru, list_head); } diff --git a/mm/vmscan.c b/mm/vmscan.c index dc17f61..767d3ac 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -1292,6 +1292,7 @@ int isolate_lru_page(struct page *page) if (PageLRU(page)) { struct zone *zone = page_zone(page); + struct lruvec *lruvec; spin_lock_irq(&zone->lru_lock); if (PageLRU(page)) { @@ -1299,8 +1300,8 @@ int isolate_lru_page(struct page *page) ret = 0; get_page(page); ClearPageLRU(page); - - del_page_from_lru_list(zone, page, lru); + lruvec = page_lruvec(page); + del_page_from_lru_list(lruvec, page, lru); } spin_unlock_irq(&zone->lru_lock); } @@ -1345,6 +1346,7 @@ putback_inactive_pages(struct lruvec *lruvec, */ while (!list_empty(page_list)) { struct page *page = lru_to_page(page_list); + struct lruvec *lruvec; int lru; VM_BUG_ON(PageLRU(page)); @@ -1357,7 +1359,10 @@ putback_inactive_pages(struct lruvec *lruvec, } SetPageLRU(page); lru = page_lru(page); - add_page_to_lru_list(zone, page, lru); + + /* can differ only on lumpy reclaim */ + lruvec = page_lruvec(page); + add_page_to_lru_list(lruvec, page, lru); if (is_active_lru(lru)) { int file = is_file_lru(lru); int numpages = hpage_nr_pages(page); @@ -1366,7 +1371,7 @@ putback_inactive_pages(struct lruvec *lruvec, if (put_page_testzero(page)) { __ClearPageLRU(page); __ClearPageActive(page); - del_page_from_lru_list(zone, page, lru); + del_page_from_lru_list(lruvec, page, lru); if (unlikely(PageCompound(page))) { spin_unlock_irq(&zone->lru_lock); @@ -1640,6 +1645,7 @@ static void move_active_pages_to_lru(struct zone *zone, VM_BUG_ON(PageLRU(page)); SetPageLRU(page); + /* can differ only on lumpy reclaim */ lruvec = page_lruvec(page); list_move(&page->lru, &lruvec->pages_lru[lru]); numpages = hpage_nr_pages(page); @@ -1649,7 +1655,7 @@ static void move_active_pages_to_lru(struct zone *zone, if (put_page_testzero(page)) { __ClearPageLRU(page); __ClearPageActive(page); - del_page_from_lru_list(zone, page, lru); + del_page_from_lru_list(lruvec, page, lru); if (unlikely(PageCompound(page))) { spin_unlock_irq(&zone->lru_lock); -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>