config TASK_SIZE
        hex "Size of user task space" if TASK_SIZE_BOOL
        default "0x80000000" if PPC_8xx
+       default "0xb0000000" if PPC_BOOK3S_32 && STRICT_KERNEL_RWX
        default "0xc0000000"
 endmenu
 
 
  */
 #define VMALLOC_OFFSET (0x1000000) /* 16M */
 
-/*
- * With CONFIG_STRICT_KERNEL_RWX, kernel segments are set NX. But when modules
- * are used, NX cannot be set on VMALLOC space. So vmalloc VM space and linear
- * memory shall not share segments.
- */
-#if defined(CONFIG_STRICT_KERNEL_RWX) && defined(CONFIG_MODULES)
-#define VMALLOC_START ((ALIGN((long)high_memory, 256L << 20) + VMALLOC_OFFSET) & \
-                      ~(VMALLOC_OFFSET - 1))
-#else
 #define VMALLOC_START ((((long)high_memory + VMALLOC_OFFSET) & ~(VMALLOC_OFFSET-1)))
-#endif
 
 #ifdef CONFIG_KASAN_VMALLOC
 #define VMALLOC_END    ALIGN_DOWN(ioremap_bot, PAGE_SIZE << KASAN_SHADOW_SCALE_SHIFT)
 #define VMALLOC_END    ioremap_bot
 #endif
 
+#ifdef CONFIG_STRICT_KERNEL_RWX
+#define MODULES_END    ALIGN_DOWN(PAGE_OFFSET, SZ_256M)
+#define MODULES_VADDR  (MODULES_END - SZ_256M)
+#endif
+
 #ifndef __ASSEMBLY__
 #include <linux/sched.h>
 #include <linux/threads.h>
 
 
 static struct addr_marker address_markers[] = {
        { 0,    "Start of kernel VM" },
+#ifdef MODULES_VADDR
+       { 0,    "modules start" },
+       { 0,    "modules end" },
+#endif
        { 0,    "vmalloc() Area" },
        { 0,    "vmalloc() End" },
 #ifdef CONFIG_PPC64
        address_markers[i++].start_address = PAGE_OFFSET;
 #else
        address_markers[i++].start_address = TASK_SIZE;
+#endif
+#ifdef MODULES_VADDR
+       address_markers[i++].start_address = MODULES_VADDR;
+       address_markers[i++].start_address = MODULES_END;
 #endif
        address_markers[i++].start_address = VMALLOC_START;
        address_markers[i++].start_address = VMALLOC_END;