Commit 472912a2 authored by Tejun Heo's avatar Tejun Heo

memcg: generate file modified notifications on "memory.events"

cgroup core only recently grew generic notification support.  Wire up
"memory.events" so that it triggers a file modified event whenever its
content changes.

v2: Refreshed on top of mem_cgroup relocation.
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
Acked-by: default avatarMichal Hocko <mhocko@kernel.org>
Acked-by: default avatarJohannes Weiner <hannes@cmpxchg.org>
Cc: Li Zefan <lizefan@huawei.com>
parent 6f60eade
...@@ -213,6 +213,9 @@ struct mem_cgroup { ...@@ -213,6 +213,9 @@ struct mem_cgroup {
/* OOM-Killer disable */ /* OOM-Killer disable */
int oom_kill_disable; int oom_kill_disable;
/* handle for "memory.events" */
struct cgroup_file events_file;
/* protect arrays of thresholds */ /* protect arrays of thresholds */
struct mutex thresholds_lock; struct mutex thresholds_lock;
...@@ -286,6 +289,7 @@ static inline void mem_cgroup_events(struct mem_cgroup *memcg, ...@@ -286,6 +289,7 @@ static inline void mem_cgroup_events(struct mem_cgroup *memcg,
unsigned int nr) unsigned int nr)
{ {
this_cpu_add(memcg->stat->events[idx], nr); this_cpu_add(memcg->stat->events[idx], nr);
cgroup_file_notify(&memcg->events_file);
} }
bool mem_cgroup_low(struct mem_cgroup *root, struct mem_cgroup *memcg); bool mem_cgroup_low(struct mem_cgroup *root, struct mem_cgroup *memcg);
......
...@@ -5202,6 +5202,7 @@ static struct cftype memory_files[] = { ...@@ -5202,6 +5202,7 @@ static struct cftype memory_files[] = {
{ {
.name = "events", .name = "events",
.flags = CFTYPE_NOT_ON_ROOT, .flags = CFTYPE_NOT_ON_ROOT,
.file_offset = offsetof(struct mem_cgroup, events_file),
.seq_show = memory_events_show, .seq_show = memory_events_show,
}, },
{ } /* terminate */ { } /* terminate */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment