powerpc/kconfig: define CONFIG_DATA_SHIFT and CONFIG_ETEXT_SHIFT
authorChristophe Leroy <christophe.leroy@c-s.fr>
Thu, 21 Feb 2019 19:08:47 +0000 (19:08 +0000)
committerMichael Ellerman <mpe@ellerman.id.au>
Sat, 23 Feb 2019 10:04:32 +0000 (21:04 +1100)
CONFIG_STRICT_KERNEL_RWX requires a special alignment
for DATA for some subarches. Today it is just defined
as an #ifdef in vmlinux.lds.S

In order to get more flexibility, this patch moves the
definition of this alignment in Kconfig

On some subarches, CONFIG_STRICT_KERNEL_RWX will
require a special alignment of _etext.

This patch also adds a configuration item for it in Kconfig

Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/Kconfig
arch/powerpc/kernel/vmlinux.lds.S

index 0f933797c376669d4737fdd1c8af261b623ab6ba..14223363a33db9bcffc3bc2715b677398c50fd76 100644 (file)
@@ -721,6 +721,15 @@ config THREAD_SHIFT
          Used to define the stack size. The default is almost always what you
          want. Only change this if you know what you are doing.
 
+config ETEXT_SHIFT
+       int
+       default PPC_PAGE_SHIFT
+
+config DATA_SHIFT
+       int
+       default 24 if STRICT_KERNEL_RWX && PPC64
+       default PPC_PAGE_SHIFT
+
 config FORCE_MAX_ZONEORDER
        int "Maximum zone order"
        range 8 9 if PPC64 && PPC_64K_PAGES
index c3efb972c8c1cbc0e39b0a9618058b673ed76d0a..060a1acd7c6d77de65de007ede891d4486bdf521 100644 (file)
 #include <asm/cache.h>
 #include <asm/thread_info.h>
 
-#if defined(CONFIG_STRICT_KERNEL_RWX) && !defined(CONFIG_PPC32)
-#define STRICT_ALIGN_SIZE      (1 << 24)
-#else
-#define STRICT_ALIGN_SIZE      PAGE_SIZE
-#endif
+#define STRICT_ALIGN_SIZE      (1 << CONFIG_DATA_SHIFT)
+#define ETEXT_ALIGN_SIZE       (1 << CONFIG_ETEXT_SHIFT)
 
 ENTRY(_stext)
 
@@ -131,7 +128,7 @@ SECTIONS
 
        } :kernel
 
-       . = ALIGN(PAGE_SIZE);
+       . = ALIGN(ETEXT_ALIGN_SIZE);
        _etext = .;
        PROVIDE32 (etext = .);