diff options
| -rw-r--r-- | arch/powerpc/Kconfig | 2 | ||||
| -rw-r--r-- | arch/powerpc/include/asm/kdump.h | 13 | ||||
| -rw-r--r-- | arch/powerpc/kernel/setup_32.c | 2 |
3 files changed, 16 insertions, 1 deletions
diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index be4f99b7cbbb..f7f5448f863d 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig | |||
| @@ -326,7 +326,7 @@ config KEXEC | |||
| 326 | 326 | ||
| 327 | config CRASH_DUMP | 327 | config CRASH_DUMP |
| 328 | bool "Build a kdump crash kernel" | 328 | bool "Build a kdump crash kernel" |
| 329 | depends on PPC_MULTIPLATFORM && PPC64 && RELOCATABLE | 329 | depends on (PPC64 && RELOCATABLE) || 6xx |
| 330 | help | 330 | help |
| 331 | Build a kernel suitable for use as a kdump capture kernel. | 331 | Build a kernel suitable for use as a kdump capture kernel. |
| 332 | The same kernel binary can be used as production kernel and dump | 332 | The same kernel binary can be used as production kernel and dump |
diff --git a/arch/powerpc/include/asm/kdump.h b/arch/powerpc/include/asm/kdump.h index b07ebb9784d3..5ebfe5d3c61f 100644 --- a/arch/powerpc/include/asm/kdump.h +++ b/arch/powerpc/include/asm/kdump.h | |||
| @@ -1,6 +1,8 @@ | |||
| 1 | #ifndef _PPC64_KDUMP_H | 1 | #ifndef _PPC64_KDUMP_H |
| 2 | #define _PPC64_KDUMP_H | 2 | #define _PPC64_KDUMP_H |
| 3 | 3 | ||
| 4 | #include <asm/page.h> | ||
| 5 | |||
| 4 | /* Kdump kernel runs at 32 MB, change at your peril. */ | 6 | /* Kdump kernel runs at 32 MB, change at your peril. */ |
| 5 | #define KDUMP_KERNELBASE 0x2000000 | 7 | #define KDUMP_KERNELBASE 0x2000000 |
| 6 | 8 | ||
| @@ -11,8 +13,19 @@ | |||
| 11 | 13 | ||
| 12 | #ifdef CONFIG_CRASH_DUMP | 14 | #ifdef CONFIG_CRASH_DUMP |
| 13 | 15 | ||
| 16 | /* | ||
| 17 | * On PPC64 translation is disabled during trampoline setup, so we use | ||
| 18 | * physical addresses. Though on PPC32 translation is already enabled, | ||
| 19 | * so we can't do the same. Luckily create_trampoline() creates relative | ||
| 20 | * branches, so we can just add the PAGE_OFFSET and don't worry about it. | ||
| 21 | */ | ||
| 22 | #ifdef __powerpc64__ | ||
| 14 | #define KDUMP_TRAMPOLINE_START 0x0100 | 23 | #define KDUMP_TRAMPOLINE_START 0x0100 |
| 15 | #define KDUMP_TRAMPOLINE_END 0x3000 | 24 | #define KDUMP_TRAMPOLINE_END 0x3000 |
| 25 | #else | ||
| 26 | #define KDUMP_TRAMPOLINE_START (0x0100 + PAGE_OFFSET) | ||
| 27 | #define KDUMP_TRAMPOLINE_END (0x3000 + PAGE_OFFSET) | ||
| 28 | #endif /* __powerpc64__ */ | ||
| 16 | 29 | ||
| 17 | #define KDUMP_MIN_TCE_ENTRIES 2048 | 30 | #define KDUMP_MIN_TCE_ENTRIES 2048 |
| 18 | 31 | ||
diff --git a/arch/powerpc/kernel/setup_32.c b/arch/powerpc/kernel/setup_32.c index d72ef39f2b37..9e1ca745d8f0 100644 --- a/arch/powerpc/kernel/setup_32.c +++ b/arch/powerpc/kernel/setup_32.c | |||
| @@ -126,6 +126,8 @@ notrace void __init machine_init(unsigned long dt_ptr) | |||
| 126 | 126 | ||
| 127 | probe_machine(); | 127 | probe_machine(); |
| 128 | 128 | ||
| 129 | setup_kdump_trampoline(); | ||
| 130 | |||
| 129 | #ifdef CONFIG_6xx | 131 | #ifdef CONFIG_6xx |
| 130 | if (cpu_has_feature(CPU_FTR_CAN_DOZE) || | 132 | if (cpu_has_feature(CPU_FTR_CAN_DOZE) || |
| 131 | cpu_has_feature(CPU_FTR_CAN_NAP)) | 133 | cpu_has_feature(CPU_FTR_CAN_NAP)) |
