diff options
author | Igor Mammedov <imammedo@redhat.com> | 2011-11-02 16:38:21 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-11-02 19:07:00 -0400 |
commit | 0a619e58703b86d53d07e938eade9a91a4a863c6 (patch) | |
tree | 0579cebdbdbb90507db04b320acb4191f8a86f2e /mm/memcontrol.c | |
parent | 715a5ee82ab3c07430f748630044354132add5ad (diff) |
memcg: do not expose uninitialized mem_cgroup_per_node to world
If somebody is touching data too early, it might be easier to diagnose a
problem when dereferencing NULL at mem->info.nodeinfo[node] than trying to
understand why mem_cgroup_per_zone is [un|partly]initialized.
Signed-off-by: Igor Mammedov <imammedo@redhat.com>
Acked-by: Michal Hocko <mhocko@suse.cz>
Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/memcontrol.c')
-rw-r--r-- | mm/memcontrol.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/mm/memcontrol.c b/mm/memcontrol.c index c02d87028b9f..f6c4beb4db56 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c | |||
@@ -4742,7 +4742,6 @@ static int alloc_mem_cgroup_per_zone_info(struct mem_cgroup *memcg, int node) | |||
4742 | if (!pn) | 4742 | if (!pn) |
4743 | return 1; | 4743 | return 1; |
4744 | 4744 | ||
4745 | memcg->info.nodeinfo[node] = pn; | ||
4746 | for (zone = 0; zone < MAX_NR_ZONES; zone++) { | 4745 | for (zone = 0; zone < MAX_NR_ZONES; zone++) { |
4747 | mz = &pn->zoneinfo[zone]; | 4746 | mz = &pn->zoneinfo[zone]; |
4748 | for_each_lru(l) | 4747 | for_each_lru(l) |
@@ -4751,6 +4750,7 @@ static int alloc_mem_cgroup_per_zone_info(struct mem_cgroup *memcg, int node) | |||
4751 | mz->on_tree = false; | 4750 | mz->on_tree = false; |
4752 | mz->mem = memcg; | 4751 | mz->mem = memcg; |
4753 | } | 4752 | } |
4753 | memcg->info.nodeinfo[node] = pn; | ||
4754 | return 0; | 4754 | return 0; |
4755 | } | 4755 | } |
4756 | 4756 | ||