diff options
author | Grygorii Strashko <grygorii.strashko@ti.com> | 2014-01-21 18:50:05 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-01-21 19:19:46 -0500 |
commit | fd615c4e671979e3e362df537d6be38f8d27aa80 (patch) | |
tree | 3c72bd2da41be2a04122d49ccae003318c6d3fff /mm/memblock.c | |
parent | 5b6e529521d35e1bcaa0fe43456d1bbb335cae5d (diff) |
mm/memblock: debug: don't free reserved array if !ARCH_DISCARD_MEMBLOCK
Now the Nobootmem allocator will always try to free memory allocated for
reserved memory regions (free_low_memory_core_early()) without taking
into to account current memblock debugging configuration
(CONFIG_ARCH_DISCARD_MEMBLOCK and CONFIG_DEBUG_FS state).
As result if:
- CONFIG_DEBUG_FS defined
- CONFIG_ARCH_DISCARD_MEMBLOCK not defined;
- reserved memory regions array have been resized during boot
then:
- memory allocated for reserved memory regions array will be freed to
buddy allocator;
- debug_fs entry "sys/kernel/debug/memblock/reserved" will show garbage
instead of state of memory reservations. like:
0: 0x98393bc0..0x9a393bbf
1: 0xff120000..0xff11ffff
2: 0x00000000..0xffffffff
Hence, do not free memory allocated for reserved memory regions if
defined(CONFIG_DEBUG_FS) && !defined(CONFIG_ARCH_DISCARD_MEMBLOCK).
Signed-off-by: Grygorii Strashko <grygorii.strashko@ti.com>
Signed-off-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
Reviewed-by: Tejun Heo <tj@kernel.org>
Cc: Yinghai Lu <yinghai@kernel.org>
Cc: "Rafael J. Wysocki" <rjw@sisk.pl>
Cc: Arnd Bergmann <arnd@arndb.de>
Cc: Christoph Lameter <cl@linux-foundation.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Johannes Weiner <hannes@cmpxchg.org>
Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Cc: Michal Hocko <mhocko@suse.cz>
Cc: Paul Walmsley <paul@pwsan.com>
Cc: Pavel Machek <pavel@ucw.cz>
Cc: Russell King <linux@arm.linux.org.uk>
Cc: Tony Lindgren <tony@atomide.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/memblock.c')
-rw-r--r-- | mm/memblock.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/mm/memblock.c b/mm/memblock.c index 6a2a48a122a9..de4d9c352fd6 100644 --- a/mm/memblock.c +++ b/mm/memblock.c | |||
@@ -269,6 +269,19 @@ phys_addr_t __init_memblock get_allocated_memblock_reserved_regions_info( | |||
269 | if (memblock.reserved.regions == memblock_reserved_init_regions) | 269 | if (memblock.reserved.regions == memblock_reserved_init_regions) |
270 | return 0; | 270 | return 0; |
271 | 271 | ||
272 | /* | ||
273 | * Don't allow nobootmem allocator to free reserved memory regions | ||
274 | * array if | ||
275 | * - CONFIG_DEBUG_FS is enabled; | ||
276 | * - CONFIG_ARCH_DISCARD_MEMBLOCK is not enabled; | ||
277 | * - reserved memory regions array have been resized during boot. | ||
278 | * Otherwise debug_fs entry "sys/kernel/debug/memblock/reserved" | ||
279 | * will show garbage instead of state of memory reservations. | ||
280 | */ | ||
281 | if (IS_ENABLED(CONFIG_DEBUG_FS) && | ||
282 | !IS_ENABLED(CONFIG_ARCH_DISCARD_MEMBLOCK)) | ||
283 | return 0; | ||
284 | |||
272 | *addr = __pa(memblock.reserved.regions); | 285 | *addr = __pa(memblock.reserved.regions); |
273 | 286 | ||
274 | return PAGE_ALIGN(sizeof(struct memblock_region) * | 287 | return PAGE_ALIGN(sizeof(struct memblock_region) * |