|
@@ -502,8 +502,9 @@ fail:
|
|
|
}
|
|
|
|
|
|
static void memcg_drain_list_lru_node(struct list_lru_node *nlru,
|
|
|
- int src_idx, int dst_idx)
|
|
|
+ int src_idx, struct mem_cgroup *dst_memcg)
|
|
|
{
|
|
|
+ int dst_idx = dst_memcg->kmemcg_id;
|
|
|
struct list_lru_one *src, *dst;
|
|
|
|
|
|
/*
|
|
@@ -523,7 +524,7 @@ static void memcg_drain_list_lru_node(struct list_lru_node *nlru,
|
|
|
}
|
|
|
|
|
|
static void memcg_drain_list_lru(struct list_lru *lru,
|
|
|
- int src_idx, int dst_idx)
|
|
|
+ int src_idx, struct mem_cgroup *dst_memcg)
|
|
|
{
|
|
|
int i;
|
|
|
|
|
@@ -531,16 +532,16 @@ static void memcg_drain_list_lru(struct list_lru *lru,
|
|
|
return;
|
|
|
|
|
|
for_each_node(i)
|
|
|
- memcg_drain_list_lru_node(&lru->node[i], src_idx, dst_idx);
|
|
|
+ memcg_drain_list_lru_node(&lru->node[i], src_idx, dst_memcg);
|
|
|
}
|
|
|
|
|
|
-void memcg_drain_all_list_lrus(int src_idx, int dst_idx)
|
|
|
+void memcg_drain_all_list_lrus(int src_idx, struct mem_cgroup *dst_memcg)
|
|
|
{
|
|
|
struct list_lru *lru;
|
|
|
|
|
|
mutex_lock(&list_lrus_mutex);
|
|
|
list_for_each_entry(lru, &list_lrus, list)
|
|
|
- memcg_drain_list_lru(lru, src_idx, dst_idx);
|
|
|
+ memcg_drain_list_lru(lru, src_idx, dst_memcg);
|
|
|
mutex_unlock(&list_lrus_mutex);
|
|
|
}
|
|
|
#else
|