[Devel] [PATCH v3] mm: Add RCU read brackets into memcg_uncharge_kmem()
Kirill Tkhai
ktkhai at virtuozzo.com
Thu May 7 12:49:10 MSK 2020
Potentially, here can be last css refcnt, so we should
have stable memory to access parent pointer.
Signed-off-by: Kirill Tkhai <ktkhai at virtuozzo.com>
---
mm/memcontrol.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/mm/memcontrol.c b/mm/memcontrol.c
index 797cb8e6df6d..e82c59f6a984 100644
--- a/mm/memcontrol.c
+++ b/mm/memcontrol.c
@@ -3525,7 +3525,13 @@ void memcg_uncharge_kmem(struct mem_cgroup *memcg,
*
* The memory barrier imposed by test&clear is paired with the
* explicit one in memcg_kmem_mark_dead().
+ *
+ * We take RCU to remain memcg memory stable for parent dereferencing.
+ * Parent's memory is stable even in case of page_counter_uncharge()
+ * has decremented its last charged memory, because child dentry owns
+ * parents's dentry refcnt.
*/
+ rcu_read_lock();
if (memcg_kmem_test_and_clear_dead(memcg))
css_put(&memcg->css);
@@ -3541,6 +3547,7 @@ void memcg_uncharge_kmem(struct mem_cgroup *memcg,
else
break;
}
+ rcu_read_unlock();
}
int __memcg_charge_slab(struct kmem_cache *s, gfp_t gfp, unsigned int nr_pages)
More information about the Devel
mailing list