powerpc/mm: Ensure "special" zones are empty
authorOliver O'Halloran <oohall@gmail.com>
Wed, 11 May 2016 09:22:18 +0000 (19:22 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Thu, 16 Jun 2016 06:03:21 +0000 (16:03 +1000)
The mm zone mechanism was traditionally used by arch specific code to
partition memory into allocation zones. However there are several zones
that are managed by the mm subsystem rather than the architecture. Most
architectures set the max PFN of these special zones to zero, however on
powerpc we set them to ~0ul. This, in conjunction with a bug in
free_area_init_nodes() results in all of system memory being placed in
ZONE_DEVICE when enabled. Device memory cannot be used for regular kernel
memory allocations so this will cause a kernel panic at boot. Given the
planned addition of more mm managed zones (ZONE_CMA) we should aim to be
consistent with every other architecture and set the max PFN for these
zones to zero.

Signed-off-by: Oliver O'Halloran <oohall@gmail.com>
Reviewed-by: Balbir Singh <bsingharora@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/mm/mem.c

index 2fd57fa48429bd60e0c0605dee812ae9870c41ed..9eac9d46f54b0d8eed5f5c9bb23451d0cfb664f4 100644 (file)
@@ -239,8 +239,14 @@ static int __init mark_nonram_nosave(void)
 
 static bool zone_limits_final;
 
+/*
+ * The memory zones past TOP_ZONE are managed by generic mm code.
+ * These should be set to zero since that's what every other
+ * architecture does.
+ */
 static unsigned long max_zone_pfns[MAX_NR_ZONES] = {
-       [0 ... MAX_NR_ZONES - 1] = ~0UL
+       [0            ... TOP_ZONE        ] = ~0UL,
+       [TOP_ZONE + 1 ... MAX_NR_ZONES - 1] = 0
 };
 
 /*