Commit | Line | Data |
---|---|---|
e1df870d ME |
1 | #ifndef _ASM_POWERPC_KEXEC_H |
2 | #define _ASM_POWERPC_KEXEC_H | |
88ced031 | 3 | #ifdef __KERNEL__ |
e1df870d | 4 | |
674bfa48 | 5 | #if defined(CONFIG_FSL_BOOKE) || defined(CONFIG_44x) |
b3df895a SAS |
6 | |
7 | /* | |
8 | * On FSL-BookE we setup a 1:1 mapping which covers the first 2GiB of memory | |
9 | * and therefore we can only deal with memory within this range | |
10 | */ | |
23dcab8f KG |
11 | #define KEXEC_SOURCE_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL - 1) |
12 | #define KEXEC_DESTINATION_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL - 1) | |
13 | #define KEXEC_CONTROL_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL - 1) | |
b3df895a SAS |
14 | |
15 | #else | |
16 | ||
e1df870d ME |
17 | /* |
18 | * Maximum page that is mapped directly into kernel memory. | |
19 | * XXX: Since we copy virt we can use any page we allocate | |
20 | */ | |
21 | #define KEXEC_SOURCE_MEMORY_LIMIT (-1UL) | |
22 | ||
23 | /* | |
24 | * Maximum address we can reach in physical address mode. | |
25 | * XXX: I want to allow initrd in highmem. Otherwise set to rmo on LPAR. | |
26 | */ | |
27 | #define KEXEC_DESTINATION_MEMORY_LIMIT (-1UL) | |
28 | ||
29 | /* Maximum address we can use for the control code buffer */ | |
30 | #ifdef __powerpc64__ | |
31 | #define KEXEC_CONTROL_MEMORY_LIMIT (-1UL) | |
32 | #else | |
33 | /* TASK_SIZE, probably left over from use_mm ?? */ | |
34 | #define KEXEC_CONTROL_MEMORY_LIMIT TASK_SIZE | |
35 | #endif | |
b3df895a | 36 | #endif |
e1df870d | 37 | |
163f6876 | 38 | #define KEXEC_CONTROL_PAGE_SIZE 4096 |
e1df870d ME |
39 | |
40 | /* The native architecture */ | |
41 | #ifdef __powerpc64__ | |
42 | #define KEXEC_ARCH KEXEC_ARCH_PPC64 | |
43 | #else | |
44 | #define KEXEC_ARCH KEXEC_ARCH_PPC | |
45 | #endif | |
46 | ||
1fc711f7 MN |
47 | #define KEXEC_STATE_NONE 0 |
48 | #define KEXEC_STATE_IRQS_OFF 1 | |
49 | #define KEXEC_STATE_REAL_MODE 2 | |
50 | ||
2babf5c2 | 51 | #ifndef __ASSEMBLY__ |
73753313 | 52 | #include <asm/reg.h> |
2babf5c2 | 53 | |
aee10c61 AB |
54 | typedef void (*crash_shutdown_t)(void); |
55 | ||
cc532915 ME |
56 | #ifdef CONFIG_KEXEC |
57 | ||
8385a6a3 HM |
58 | /* |
59 | * This function is responsible for capturing register states if coming | |
60 | * via panic or invoking dump using sysrq-trigger. | |
61 | */ | |
62 | static inline void crash_setup_regs(struct pt_regs *newregs, | |
63 | struct pt_regs *oldregs) | |
64 | { | |
65 | if (oldregs) | |
66 | memcpy(newregs, oldregs, sizeof(*newregs)); | |
73753313 AV |
67 | else |
68 | ppc_save_regs(newregs); | |
73753313 | 69 | } |
8385a6a3 | 70 | |
e1df870d ME |
71 | extern void kexec_smp_wait(void); /* get and clear naca physid, wait for |
72 | master to copy new code to 0 */ | |
cc532915 ME |
73 | extern int crashing_cpu; |
74 | extern void crash_send_ipi(void (*crash_ipi_callback)(struct pt_regs *)); | |
e1df870d | 75 | |
3d1229d6 | 76 | struct kimage; |
cc532915 | 77 | struct pt_regs; |
3d1229d6 ME |
78 | extern void default_machine_kexec(struct kimage *image); |
79 | extern int default_machine_kexec_prepare(struct kimage *image); | |
cc532915 | 80 | extern void default_machine_crash_shutdown(struct pt_regs *regs); |
496b010e MN |
81 | extern int crash_shutdown_register(crash_shutdown_t handler); |
82 | extern int crash_shutdown_unregister(crash_shutdown_t handler); | |
cc532915 | 83 | |
39931e41 | 84 | extern void machine_kexec_simple(struct kimage *image); |
c0ce7d08 | 85 | extern void crash_kexec_secondary(struct pt_regs *regs); |
2babf5c2 | 86 | extern int overlaps_crashkernel(unsigned long start, unsigned long size); |
35dd5432 | 87 | extern void reserve_crashkernel(void); |
c71635d2 | 88 | extern void machine_kexec_mask_interrupts(void); |
2babf5c2 ME |
89 | |
90 | #else /* !CONFIG_KEXEC */ | |
c0ce7d08 | 91 | static inline void crash_kexec_secondary(struct pt_regs *regs) { } |
2babf5c2 ME |
92 | |
93 | static inline int overlaps_crashkernel(unsigned long start, unsigned long size) | |
94 | { | |
95 | return 0; | |
96 | } | |
39931e41 | 97 | |
35dd5432 ME |
98 | static inline void reserve_crashkernel(void) { ; } |
99 | ||
aee10c61 AB |
100 | static inline int crash_shutdown_register(crash_shutdown_t handler) |
101 | { | |
102 | return 0; | |
103 | } | |
104 | ||
105 | static inline int crash_shutdown_unregister(crash_shutdown_t handler) | |
106 | { | |
107 | return 0; | |
108 | } | |
109 | ||
8385a6a3 | 110 | #endif /* CONFIG_KEXEC */ |
2babf5c2 | 111 | #endif /* ! __ASSEMBLY__ */ |
88ced031 | 112 | #endif /* __KERNEL__ */ |
e1df870d | 113 | #endif /* _ASM_POWERPC_KEXEC_H */ |