Home
last modified time | relevance | path

Searched refs:lruvec (Results 1 – 19 of 19) sorted by relevance

/linux/mm/
H A Dswap.c73 static void __page_cache_release(struct folio *folio, struct lruvec **lruvecp, in __page_cache_release()
89 struct lruvec *lruvec = NULL; in page_cache_release() local
92 __page_cache_release(folio, &lruvec, &flags); in page_cache_release()
93 if (lruvec) in page_cache_release()
94 unlock_page_lruvec_irqrestore(lruvec, flags); in page_cache_release()
116 typedef void (*move_fn_t)(struct lruvec *lruvec, struct folio *folio);
118 static void lru_add(struct lruvec *lruvec, struc argument
161 struct lruvec *lruvec = NULL; folio_batch_move_lru() local
213 lru_move_tail(struct lruvec * lruvec,struct folio * folio) lru_move_tail() argument
240 lru_note_cost_unlock_irq(struct lruvec * lruvec,bool file,unsigned int nr_io,unsigned int nr_rotated) lru_note_cost_unlock_irq() argument
296 struct lruvec *lruvec; lru_note_cost_refault() local
303 lru_activate(struct lruvec * lruvec,struct folio * folio) lru_activate() argument
345 struct lruvec *lruvec; folio_activate() local
554 lru_deactivate_file(struct lruvec * lruvec,struct folio * folio) lru_deactivate_file() argument
595 lru_deactivate(struct lruvec * lruvec,struct folio * folio) lru_deactivate() argument
611 lru_lazyfree(struct lruvec * lruvec,struct folio * folio) lru_lazyfree() argument
954 struct lruvec *lruvec = NULL; folios_put_refs() local
[all...]
H A Dworkingset.c192 * entry, and after storing the identifier for the lruvec there might
237 struct lruvec *lruvec; in lru_gen_eviction() local
249 lruvec = mem_cgroup_lruvec(memcg, pgdat); in lru_gen_eviction()
250 lrugen = &lruvec->lrugen; in lru_gen_eviction()
262 * Fills in @lruvec, @token, @workingset with the values unpacked from shadow.
264 static bool lru_gen_test_recent(void *shadow, struct lruvec **lruvec, in lru_gen_test_recent() argument
275 *lruvec = mem_cgroup_lruvec(memcg, pgdat); in lru_gen_test_recent()
277 max_seq = READ_ONCE((*lruvec) in lru_gen_test_recent()
289 struct lruvec *lruvec; lru_gen_refault() local
333 lru_gen_test_recent(void * shadow,struct lruvec ** lruvec,unsigned long * token,bool * workingset) lru_gen_test_recent() argument
355 workingset_age_nonresident(struct lruvec * lruvec,unsigned long nr_pages) workingset_age_nonresident() argument
385 struct lruvec *lruvec; workingset_eviction() local
539 struct lruvec *lruvec; workingset_refault() local
675 struct lruvec *lruvec; count_shadow_nodes() local
[all...]
H A Dvmscan.c412 static unsigned long lruvec_lru_size(struct lruvec *lruvec, enum lru_list lru, in lruvec_lru_size() argument
419 for_each_managed_zone_pgdat(zone, lruvec_pgdat(lruvec), zid, zone_idx) { in lruvec_lru_size()
421 size += mem_cgroup_get_zone_lru_size(lruvec, lru, zid); in lruvec_lru_size()
1675 static __always_inline void update_lru_sizes(struct lruvec *lruvec, in update_lru_sizes() argument
1684 update_lru_size(lruvec, lru, zid, -nr_zone_taken[zid]); in update_lru_sizes()
1711 struct lruvec *lruvec, struct list_head *dst, in isolate_lru_folios() argument
1715 struct list_head *src = &lruvec->lists[lru]; in isolate_lru_folios()
1800 update_lru_sizes(lruvec, lru, nr_zone_taken); in isolate_lru_folios()
1834 struct lruvec *lruvec; in folio_isolate_lru() local
1837 lruvec = folio_lruvec_lock_irq(folio); in folio_isolate_lru()
[all …]
H A Dmlock.c61 static struct lruvec *__mlock_folio(struct folio *folio, struct lruvec *lruvec) in __mlock_folio() argument
65 return lruvec; in __mlock_folio()
67 lruvec = folio_lruvec_relock_irq(folio, lruvec); in __mlock_folio()
76 lruvec_del_folio(lruvec, folio); in __mlock_folio()
78 lruvec_add_folio(lruvec, folio); in __mlock_folio()
92 lruvec_del_folio(lruvec, folio); in __mlock_folio()
96 lruvec_add_folio(lruvec, folio); in __mlock_folio()
100 return lruvec; in __mlock_folio()
103 static struct lruvec *__mlock_new_folio(struct folio *folio, struct lruvec *lruvec) in __mlock_new_folio() argument
107 lruvec = folio_lruvec_relock_irq(folio, lruvec); in __mlock_new_folio()
[all …]
H A Dmmzone.c75 void lruvec_init(struct lruvec *lruvec) in lruvec_init() argument
79 memset(lruvec, 0, sizeof(struct lruvec)); in lruvec_init()
80 spin_lock_init(&lruvec->lru_lock); in lruvec_init()
81 zswap_lruvec_state_init(lruvec); in lruvec_init()
84 INIT_LIST_HEAD(&lruvec->lists[lru]); in lruvec_init()
91 list_del(&lruvec->lists[LRU_UNEVICTABLE]); in lruvec_init()
93 lru_gen_init_lruvec(lruvec); in lruvec_init()
H A Dmemcontrol.c393 unsigned long lruvec_page_state(struct lruvec *lruvec, enum node_stat_item idx) in lruvec_page_state() argument
400 return node_page_state(lruvec_pgdat(lruvec), idx); in lruvec_page_state()
406 pn = container_of(lruvec, struct mem_cgroup_per_node, lruvec); in lruvec_page_state()
415 unsigned long lruvec_page_state_local(struct lruvec *lruvec, in lruvec_page_state_local() argument
423 return node_page_state(lruvec_pgdat(lruvec), idx); in lruvec_page_state_local()
429 pn = container_of(lruvec, struct mem_cgroup_per_node, lruvec); in lruvec_page_state_local()
739 static void mod_memcg_lruvec_state(struct lruvec *lruvec, in mod_memcg_lruvec_state() argument
751 pn = container_of(lruvec, struct mem_cgroup_per_node, lruvec); in mod_memcg_lruvec_state()
779 void mod_lruvec_state(struct lruvec *lruvec, enum node_stat_item idx, in mod_lruvec_state() argument
783 mod_node_page_state(lruvec_pgdat(lruvec), idx, val); in mod_lruvec_state()
[all …]
H A Dzswap.c657 void zswap_lruvec_state_init(struct lruvec *lruvec) in zswap_lruvec_state_init() argument
659 atomic_long_set(&lruvec->zswap_lruvec_state.nr_disk_swapins, 0); in zswap_lruvec_state_init()
664 struct lruvec *lruvec; in zswap_folio_swapin() local
667 lruvec = folio_lruvec(folio); in zswap_folio_swapin()
668 atomic_long_inc(&lruvec->zswap_lruvec_state.nr_disk_swapins); in zswap_folio_swapin()
1200 struct lruvec *lruvec = mem_cgroup_lruvec(memcg, NODE_DATA(sc->nid)); in zswap_shrinker_count() local
1202 &lruvec->zswap_lruvec_state.nr_disk_swapins; in zswap_shrinker_count()
H A Dcompaction.c842 struct lruvec *lruvec; in isolate_migratepages_block() local
844 struct lruvec *locked = NULL; in isolate_migratepages_block()
1156 lruvec = folio_lruvec(folio); in isolate_migratepages_block()
1159 if (lruvec != locked) { in isolate_migratepages_block()
1163 compact_lock_irqsave(&lruvec->lru_lock, &flags, cc); in isolate_migratepages_block()
1164 locked = lruvec; in isolate_migratepages_block()
1166 lruvec_memcg_debug(lruvec, folio); in isolate_migratepages_block()
1200 lruvec_del_folio(lruvec, folio); in isolate_migratepages_block()
H A Dmemcontrol-v1.c1765 struct lruvec *lruvec = mem_cgroup_lruvec(memcg, NODE_DATA(nid)); in mem_cgroup_node_nr_lru_pages() local
1775 nr += lruvec_page_state(lruvec, NR_LRU_BASE + lru); in mem_cgroup_node_nr_lru_pages()
1777 nr += lruvec_page_state_local(lruvec, NR_LRU_BASE + lru); in mem_cgroup_node_nr_lru_pages()
1955 anon_cost += mz->lruvec.anon_cost; in memcg1_stat_format()
1956 file_cost += mz->lruvec.file_cost; in memcg1_stat_format()
H A Dmigrate.c672 struct lruvec *old_lruvec, *new_lruvec; in __folio_migrate_mapping()
2729 struct lruvec *lruvec = mem_cgroup_lruvec(memcg, pgdat); in migrate_misplaced_folio() local
2743 mod_lruvec_state(lruvec, PGPROMOTE_SUCCESS, nr_succeeded); in migrate_misplaced_folio()
H A Dhuge_memory.c3443 struct lruvec *lruvec, struct list_head *list) in lru_add_split_folio() argument
3446 lockdep_assert_held(&lruvec->lru_lock); in lru_add_split_folio()
3787 struct lruvec *lruvec; in __folio_freeze_and_split_unmapped() local
3834 lruvec = folio_lruvec_lock(folio); in __folio_freeze_and_split_unmapped()
3859 lru_add_split_folio(folio, new_folio, lruvec, list); in __folio_freeze_and_split_unmapped()
3902 unlock_page_lruvec(lruvec); in __folio_freeze_and_split_unmapped()
/linux/include/linux/
H A Dmm_inline.h38 static __always_inline void __update_lru_size(struct lruvec *lruvec, in __update_lru_size() argument
42 struct pglist_data *pgdat = lruvec_pgdat(lruvec); in __update_lru_size()
44 lockdep_assert_held(&lruvec->lru_lock); in __update_lru_size()
47 mod_lruvec_state(lruvec, NR_LRU_BASE + lru, nr_pages); in __update_lru_size()
52 static __always_inline void update_lru_size(struct lruvec *lruvec, in update_lru_size() argument
56 __update_lru_size(lruvec, lru, zid, nr_pages); in update_lru_size()
58 mem_cgroup_update_lru_size(lruvec, lru, zid, nr_pages); in update_lru_size()
164 static inline bool lru_gen_is_active(const struct lruvec *lruvec, int gen) in lru_gen_is_active() argument
166 unsigned long max_seq = lruvec->lrugen.max_seq; in lru_gen_is_active()
174 static inline void lru_gen_update_size(struct lruvec *lruvec, struct folio *folio, in lru_gen_update_size() argument
[all …]
H A Dmemcontrol.h113 struct lruvec lruvec; member
707 static inline struct lruvec *mem_cgroup_lruvec(struct mem_cgroup *memcg, in mem_cgroup_lruvec()
711 struct lruvec *lruvec; in mem_cgroup_lruvec() local
714 lruvec = &pgdat->__lruvec; in mem_cgroup_lruvec()
722 lruvec = &mz->lruvec; in mem_cgroup_lruvec()
729 if (unlikely(lruvec->pgdat != pgdat)) in mem_cgroup_lruvec()
730 lruvec->pgdat = pgdat; in mem_cgroup_lruvec()
731 return lruvec; in mem_cgroup_lruvec()
740 static inline struct lruvec *folio_lruvec(struct folio *folio) in folio_lruvec()
756 struct lruvec *folio_lruvec_lock(struct folio *folio);
[all …]
H A Dmmzone.h451 struct lruvec;
546 struct lruvec *lruvec; member
618 void lru_gen_init_lruvec(struct lruvec *lruvec);
634 static inline void lru_gen_init_lruvec(struct lruvec *lruvec) in lru_gen_init_lruvec() argument
669 struct lruvec { struct
1499 struct lruvec __lruvec;
1570 extern void lruvec_init(struct lruvec *lruvec);
1572 static inline struct pglist_data *lruvec_pgdat(struct lruvec *lruvec) in lruvec_pgdat() argument
1575 return lruvec->pgdat; in lruvec_pgdat()
1577 return container_of(lruvec, struct pglist_data, __lruvec); in lruvec_pgdat()
H A Dswap.h317 void workingset_age_nonresident(struct lruvec *lruvec, unsigned long nr_pages);
330 void lru_note_cost_unlock_irq(struct lruvec *lruvec, bool file,
332 __releases(lruvec->lru_lock);
H A Dvmstat.h519 void mod_lruvec_state(struct lruvec *lruvec, enum node_stat_item idx,
533 static inline void mod_lruvec_state(struct lruvec *lruvec, in mod_lruvec_page_state()
536 mod_node_page_state(lruvec_pgdat(lruvec), idx, val);
537 mod_lruvec_state(struct lruvec * lruvec,enum node_stat_item idx,int val) mod_lruvec_state() argument
/linux/Documentation/mm/
H A Dmultigen_lru.rst83 ``lruvec``. The youngest generation number is stored in
114 The aging produces young generations. Given an ``lruvec``, it
130 The eviction consumes old generations. Given an ``lruvec``, it
148 set, an ``lruvec`` is protected from the eviction when its oldest
/linux/mm/damon/
H A Dcore.c2111 struct lruvec *lruvec; in damos_get_node_memcg_used_bp() local
2124 lruvec = mem_cgroup_lruvec(memcg, NODE_DATA(goal->nid)); in damos_get_node_memcg_used_bp()
2125 used_pages = lruvec_page_state(lruvec, NR_ACTIVE_ANON); in damos_get_node_memcg_used_bp()
2126 used_pages += lruvec_page_state(lruvec, NR_INACTIVE_ANON); in damos_get_node_memcg_used_bp()
2127 used_pages += lruvec_page_state(lruvec, NR_ACTIVE_FILE); in damos_get_node_memcg_used_bp()
2128 used_pages += lruvec_page_state(lruvec, NR_INACTIVE_FILE); in damos_get_node_memcg_used_bp()
/linux/Documentation/trace/
H A Devents-kmem.rst72 contention on the lruvec->lru_lock.