diff options
author | Jiang Liu <liuj97@gmail.com> | 2013-07-03 18:03:27 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-07-03 19:07:34 -0400 |
commit | cdd91a77043ba81585236ef61f65c18222b212e6 (patch) | |
tree | 691019276383309e84cb2ebee37e1fc6fd3a500f /mm | |
parent | 0c988534737a358fdff42fcce78f0ff1a12dbfc5 (diff) |
mm: report available pages as "MemTotal" for each NUMA node
As reported by https://bugzilla.kernel.org/show_bug.cgi?id=53501,
"MemTotal" from /proc/meminfo means memory pages managed by the buddy
system (managed_pages), but "MemTotal" from /sys/.../node/nodex/meminfo
means physical pages present (present_pages) within the NUMA node.
There's a difference between managed_pages and present_pages due to
bootmem allocator and reserved pages.
And Documentation/filesystems/proc.txt says
MemTotal: Total usable ram (i.e. physical ram minus a few reserved
bits and the kernel binary code)
So change /sys/.../node/nodex/meminfo to report available pages within
the node as "MemTotal".
Signed-off-by: Jiang Liu <jiang.liu@huawei.com>
Reported-by: <sworddragon2@aol.com>
Cc: Mel Gorman <mel@csn.ul.ie>
Cc: Minchan Kim <minchan@kernel.org>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: "Michael S. Tsirkin" <mst@redhat.com>
Cc: Arnd Bergmann <arnd@arndb.de>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Chris Metcalf <cmetcalf@tilera.com>
Cc: David Howells <dhowells@redhat.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jeremy Fitzhardinge <jeremy@goop.org>
Cc: Jianguo Wu <wujianguo@huawei.com>
Cc: Joonsoo Kim <js1304@gmail.com>
Cc: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Cc: Marek Szyprowski <m.szyprowski@samsung.com>
Cc: Michel Lespinasse <walken@google.com>
Cc: Rik van Riel <riel@redhat.com>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Tang Chen <tangchen@cn.fujitsu.com>
Cc: Tejun Heo <tj@kernel.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Wen Congyang <wency@cn.fujitsu.com>
Cc: Will Deacon <will.deacon@arm.com>
Cc: Yasuaki Ishimatsu <isimatu.yasuaki@jp.fujitsu.com>
Cc: Yinghai Lu <yinghai@kernel.org>
Cc: Russell King <rmk@arm.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/page_alloc.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 1481439ee2e4..d9445c4f5fd7 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
@@ -2904,9 +2904,13 @@ EXPORT_SYMBOL(si_meminfo); | |||
2904 | #ifdef CONFIG_NUMA | 2904 | #ifdef CONFIG_NUMA |
2905 | void si_meminfo_node(struct sysinfo *val, int nid) | 2905 | void si_meminfo_node(struct sysinfo *val, int nid) |
2906 | { | 2906 | { |
2907 | int zone_type; /* needs to be signed */ | ||
2908 | unsigned long managed_pages = 0; | ||
2907 | pg_data_t *pgdat = NODE_DATA(nid); | 2909 | pg_data_t *pgdat = NODE_DATA(nid); |
2908 | 2910 | ||
2909 | val->totalram = pgdat->node_present_pages; | 2911 | for (zone_type = 0; zone_type < MAX_NR_ZONES; zone_type++) |
2912 | managed_pages += pgdat->node_zones[zone_type].managed_pages; | ||
2913 | val->totalram = managed_pages; | ||
2910 | val->freeram = node_page_state(nid, NR_FREE_PAGES); | 2914 | val->freeram = node_page_state(nid, NR_FREE_PAGES); |
2911 | #ifdef CONFIG_HIGHMEM | 2915 | #ifdef CONFIG_HIGHMEM |
2912 | val->totalhigh = pgdat->node_zones[ZONE_HIGHMEM].managed_pages; | 2916 | val->totalhigh = pgdat->node_zones[ZONE_HIGHMEM].managed_pages; |