tile: query dynamic DEBUG_PAGEALLOC setting
authorJoonsoo Kim <[email protected]>
Thu, 17 Mar 2016 21:18:02 +0000 (14:18 -0700)
committerLinus Torvalds <[email protected]>
Thu, 17 Mar 2016 22:09:34 +0000 (15:09 -0700)
We can disable debug_pagealloc processing even if the code is compiled
with CONFIG_DEBUG_PAGEALLOC.  This patch changes the code to query
whether it is enabled or not in runtime.

Signed-off-by: Joonsoo Kim <[email protected]>
Cc: Benjamin Herrenschmidt <[email protected]>
Acked-by: Chris Metcalf <[email protected]>
Cc: Christian Borntraeger <[email protected]>
Cc: Christoph Lameter <[email protected]>
Cc: David Rientjes <[email protected]>
Cc: Pekka Enberg <[email protected]>
Cc: Takashi Iwai <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
arch/tile/mm/init.c

index d4e1fc41d06db21a475b1bdbd6508df5b7f5ab8a..a0582b7f41d3357b4db0507df4a7153a028b0fe7 100644 (file)
@@ -896,17 +896,15 @@ void __init pgtable_cache_init(void)
                panic("pgtable_cache_init(): Cannot create pgd cache");
 }
 
-#ifdef CONFIG_DEBUG_PAGEALLOC
-static long __write_once initfree;
-#else
 static long __write_once initfree = 1;
-#endif
+static bool __write_once set_initfree_done;
 
 /* Select whether to free (1) or mark unusable (0) the __init pages. */
 static int __init set_initfree(char *str)
 {
        long val;
        if (kstrtol(str, 0, &val) == 0) {
+               set_initfree_done = true;
                initfree = val;
                pr_info("initfree: %s free init pages\n",
                        initfree ? "will" : "won't");
@@ -919,6 +917,11 @@ static void free_init_pages(char *what, unsigned long begin, unsigned long end)
 {
        unsigned long addr = (unsigned long) begin;
 
+       /* Prefer user request first */
+       if (!set_initfree_done) {
+               if (debug_pagealloc_enabled())
+                       initfree = 0;
+       }
        if (kdata_huge && !initfree) {
                pr_warn("Warning: ignoring initfree=0: incompatible with kdata=huge\n");
                initfree = 1;