Lines Matching refs:lru
21 static void list_lru_register(struct list_lru *lru) in list_lru_register() argument
24 list_add(&lru->list, &list_lrus); in list_lru_register()
28 static void list_lru_unregister(struct list_lru *lru) in list_lru_unregister() argument
31 list_del(&lru->list); in list_lru_unregister()
35 static int lru_shrinker_id(struct list_lru *lru) in lru_shrinker_id() argument
37 return lru->shrinker_id; in lru_shrinker_id()
40 static inline bool list_lru_memcg_aware(struct list_lru *lru) in list_lru_memcg_aware() argument
42 return lru->memcg_aware; in list_lru_memcg_aware()
56 return memcg_lrus->lru[idx]; in list_lru_from_memcg_idx()
57 return &nlru->lru; in list_lru_from_memcg_idx()
64 struct list_lru_one *l = &nlru->lru; in list_lru_from_kmem()
81 static void list_lru_register(struct list_lru *lru) in list_lru_register() argument
85 static void list_lru_unregister(struct list_lru *lru) in list_lru_unregister() argument
89 static int lru_shrinker_id(struct list_lru *lru) in lru_shrinker_id() argument
94 static inline bool list_lru_memcg_aware(struct list_lru *lru) in list_lru_memcg_aware() argument
102 return &nlru->lru; in list_lru_from_memcg_idx()
111 return &nlru->lru; in list_lru_from_kmem()
115 bool list_lru_add(struct list_lru *lru, struct list_head *item) in list_lru_add() argument
118 struct list_lru_node *nlru = &lru->node[nid]; in list_lru_add()
129 lru_shrinker_id(lru)); in list_lru_add()
139 bool list_lru_del(struct list_lru *lru, struct list_head *item) in list_lru_del() argument
142 struct list_lru_node *nlru = &lru->node[nid]; in list_lru_del()
174 unsigned long list_lru_count_one(struct list_lru *lru, in list_lru_count_one() argument
177 struct list_lru_node *nlru = &lru->node[nid]; in list_lru_count_one()
190 unsigned long list_lru_count_node(struct list_lru *lru, int nid) in list_lru_count_node() argument
194 nlru = &lru->node[nid]; in list_lru_count_node()
258 list_lru_walk_one(struct list_lru *lru, int nid, struct mem_cgroup *memcg, in list_lru_walk_one() argument
262 struct list_lru_node *nlru = &lru->node[nid]; in list_lru_walk_one()
274 list_lru_walk_one_irq(struct list_lru *lru, int nid, struct mem_cgroup *memcg, in list_lru_walk_one_irq() argument
278 struct list_lru_node *nlru = &lru->node[nid]; in list_lru_walk_one_irq()
288 unsigned long list_lru_walk_node(struct list_lru *lru, int nid, in list_lru_walk_node() argument
295 isolated += list_lru_walk_one(lru, nid, NULL, isolate, cb_arg, in list_lru_walk_node()
297 if (*nr_to_walk > 0 && list_lru_memcg_aware(lru)) { in list_lru_walk_node()
299 struct list_lru_node *nlru = &lru->node[nid]; in list_lru_walk_node()
328 kfree(memcg_lrus->lru[i]); in __memcg_destroy_list_lru_node()
344 memcg_lrus->lru[i] = l; in __memcg_init_list_lru_node()
409 memcpy(&new->lru, &old->lru, old_size * sizeof(void *)); in memcg_update_list_lru_node()
438 static int memcg_init_list_lru(struct list_lru *lru, bool memcg_aware) in memcg_init_list_lru() argument
442 lru->memcg_aware = memcg_aware; in memcg_init_list_lru()
448 if (memcg_init_list_lru_node(&lru->node[i])) in memcg_init_list_lru()
454 if (!lru->node[i].memcg_lrus) in memcg_init_list_lru()
456 memcg_destroy_list_lru_node(&lru->node[i]); in memcg_init_list_lru()
461 static void memcg_destroy_list_lru(struct list_lru *lru) in memcg_destroy_list_lru() argument
465 if (!list_lru_memcg_aware(lru)) in memcg_destroy_list_lru()
469 memcg_destroy_list_lru_node(&lru->node[i]); in memcg_destroy_list_lru()
472 static int memcg_update_list_lru(struct list_lru *lru, in memcg_update_list_lru() argument
477 if (!list_lru_memcg_aware(lru)) in memcg_update_list_lru()
481 if (memcg_update_list_lru_node(&lru->node[i], in memcg_update_list_lru()
488 if (!lru->node[i].memcg_lrus) in memcg_update_list_lru()
491 memcg_cancel_update_list_lru_node(&lru->node[i], in memcg_update_list_lru()
497 static void memcg_cancel_update_list_lru(struct list_lru *lru, in memcg_cancel_update_list_lru() argument
502 if (!list_lru_memcg_aware(lru)) in memcg_cancel_update_list_lru()
506 memcg_cancel_update_list_lru_node(&lru->node[i], in memcg_cancel_update_list_lru()
513 struct list_lru *lru; in memcg_update_all_list_lrus() local
517 list_for_each_entry(lru, &list_lrus, list) { in memcg_update_all_list_lrus()
518 ret = memcg_update_list_lru(lru, old_size, new_size); in memcg_update_all_list_lrus()
526 list_for_each_entry_continue_reverse(lru, &list_lrus, list) in memcg_update_all_list_lrus()
527 memcg_cancel_update_list_lru(lru, old_size, new_size); in memcg_update_all_list_lrus()
531 static void memcg_drain_list_lru_node(struct list_lru *lru, int nid, in memcg_drain_list_lru_node() argument
534 struct list_lru_node *nlru = &lru->node[nid]; in memcg_drain_list_lru_node()
551 memcg_set_shrinker_bit(dst_memcg, nid, lru_shrinker_id(lru)); in memcg_drain_list_lru_node()
558 static void memcg_drain_list_lru(struct list_lru *lru, in memcg_drain_list_lru() argument
563 if (!list_lru_memcg_aware(lru)) in memcg_drain_list_lru()
567 memcg_drain_list_lru_node(lru, i, src_idx, dst_memcg); in memcg_drain_list_lru()
572 struct list_lru *lru; in memcg_drain_all_list_lrus() local
575 list_for_each_entry(lru, &list_lrus, list) in memcg_drain_all_list_lrus()
576 memcg_drain_list_lru(lru, src_idx, dst_memcg); in memcg_drain_all_list_lrus()
580 static int memcg_init_list_lru(struct list_lru *lru, bool memcg_aware) in memcg_init_list_lru() argument
585 static void memcg_destroy_list_lru(struct list_lru *lru) in memcg_destroy_list_lru() argument
590 int __list_lru_init(struct list_lru *lru, bool memcg_aware, in __list_lru_init() argument
598 lru->shrinker_id = shrinker->id; in __list_lru_init()
600 lru->shrinker_id = -1; in __list_lru_init()
604 lru->node = kcalloc(nr_node_ids, sizeof(*lru->node), GFP_KERNEL); in __list_lru_init()
605 if (!lru->node) in __list_lru_init()
609 spin_lock_init(&lru->node[i].lock); in __list_lru_init()
611 lockdep_set_class(&lru->node[i].lock, key); in __list_lru_init()
612 init_one_lru(&lru->node[i].lru); in __list_lru_init()
615 err = memcg_init_list_lru(lru, memcg_aware); in __list_lru_init()
617 kfree(lru->node); in __list_lru_init()
619 lru->node = NULL; in __list_lru_init()
623 list_lru_register(lru); in __list_lru_init()
630 void list_lru_destroy(struct list_lru *lru) in list_lru_destroy() argument
633 if (!lru->node) in list_lru_destroy()
638 list_lru_unregister(lru); in list_lru_destroy()
640 memcg_destroy_list_lru(lru); in list_lru_destroy()
641 kfree(lru->node); in list_lru_destroy()
642 lru->node = NULL; in list_lru_destroy()
645 lru->shrinker_id = -1; in list_lru_destroy()