[PATCH 0/3] cgroup: nmi safe css_rstat_updated
From: Shakeel Butt
Date: Mon Jun 09 2025 - 18:57:05 EST
BPF programs can run in nmi context and may trigger memcg charged memory
allocation in such context. Recently linux added support to nmi safe
page allocation along with memcg charging of such allocations. However
the kmalloc/slab support and corresponding memcg charging is still
lacking,
To provide nmi safe support for memcg charging for kmalloc/slab
allocations, we need nmi safe memcg stats and for that we need nmi safe
css_rstat_updated() which adds the given cgroup state whose stats are
updated into the per-cpu per-ss update tree. This series took the aim to
make css_rstat_updated() nmi safe.
This series made css_rstat_updated by using per-cpu lockless lists whose
node in embedded in individual struct cgroup_subsys_state and the
per-cpu head is placed in struct cgroup_subsys. For rstat users without
cgroup_subsys, a global per-cpu lockless list head is created. The main
challenge to use lockless in this scenario was the potential multiple
inserters using the same lockless node of a cgroup_subsys_state which is
different from traditional users of lockless lists.
The multiple inserters using potentially same lockless node was resolved
by making one of them succeed on reset the lockless node and the winner
gets to insert the lockless node in the corresponding lockless list.
Changelog since v1:
- Based on Yosry's suggestion always use llist on the update side and
create the update tree on flush side
[v1] https://lore.kernel.org/cgroups/20250429061211.1295443-1-shakeel.butt@xxxxxxxxx/
Shakeel Butt (3):
cgroup: support to enable nmi-safe css_rstat_updated
cgroup: make css_rstat_updated nmi safe
memcg: cgroup: call memcg_rstat_updated irrespective of in_nmi()
include/linux/cgroup-defs.h | 4 ++
kernel/cgroup/rstat.c | 80 ++++++++++++++++++++++++++++++-------
mm/memcontrol.c | 10 ++---
3 files changed, 75 insertions(+), 19 deletions(-)
--
2.47.1