diff options
Diffstat (limited to 'include/linux/kexec.h')
| -rw-r--r-- | include/linux/kexec.h | 75 |
1 files changed, 53 insertions, 22 deletions
diff --git a/include/linux/kexec.h b/include/linux/kexec.h index 0d7d6a1b172f..37c5f7261142 100644 --- a/include/linux/kexec.h +++ b/include/linux/kexec.h | |||
| @@ -1,8 +1,58 @@ | |||
| 1 | #ifndef LINUX_KEXEC_H | 1 | #ifndef LINUX_KEXEC_H |
| 2 | #define LINUX_KEXEC_H | 2 | #define LINUX_KEXEC_H |
| 3 | 3 | ||
| 4 | #ifdef CONFIG_KEXEC | 4 | /* kexec system call - It loads the new kernel to boot into. |
| 5 | * kexec does not sync, or unmount filesystems so if you need | ||
| 6 | * that to happen you need to do that yourself. | ||
| 7 | */ | ||
| 8 | |||
| 5 | #include <linux/types.h> | 9 | #include <linux/types.h> |
| 10 | |||
| 11 | /* kexec flags for different usage scenarios */ | ||
| 12 | #define KEXEC_ON_CRASH 0x00000001 | ||
| 13 | #define KEXEC_PRESERVE_CONTEXT 0x00000002 | ||
| 14 | #define KEXEC_ARCH_MASK 0xffff0000 | ||
| 15 | |||
| 16 | /* These values match the ELF architecture values. | ||
| 17 | * Unless there is a good reason that should continue to be the case. | ||
| 18 | */ | ||
| 19 | #define KEXEC_ARCH_DEFAULT ( 0 << 16) | ||
| 20 | #define KEXEC_ARCH_386 ( 3 << 16) | ||
| 21 | #define KEXEC_ARCH_X86_64 (62 << 16) | ||
| 22 | #define KEXEC_ARCH_PPC (20 << 16) | ||
| 23 | #define KEXEC_ARCH_PPC64 (21 << 16) | ||
| 24 | #define KEXEC_ARCH_IA_64 (50 << 16) | ||
| 25 | #define KEXEC_ARCH_ARM (40 << 16) | ||
| 26 | #define KEXEC_ARCH_S390 (22 << 16) | ||
| 27 | #define KEXEC_ARCH_SH (42 << 16) | ||
| 28 | #define KEXEC_ARCH_MIPS_LE (10 << 16) | ||
| 29 | #define KEXEC_ARCH_MIPS ( 8 << 16) | ||
| 30 | |||
| 31 | /* The artificial cap on the number of segments passed to kexec_load. */ | ||
| 32 | #define KEXEC_SEGMENT_MAX 16 | ||
| 33 | |||
| 34 | #ifndef __KERNEL__ | ||
| 35 | /* | ||
| 36 | * This structure is used to hold the arguments that are used when | ||
| 37 | * loading kernel binaries. | ||
| 38 | */ | ||
| 39 | struct kexec_segment { | ||
| 40 | const void *buf; | ||
| 41 | size_t bufsz; | ||
| 42 | const void *mem; | ||
| 43 | size_t memsz; | ||
| 44 | }; | ||
| 45 | |||
| 46 | /* Load a new kernel image as described by the kexec_segment array | ||
| 47 | * consisting of passed number of segments at the entry-point address. | ||
| 48 | * The flags allow different useage types. | ||
| 49 | */ | ||
| 50 | extern int kexec_load(void *, size_t, struct kexec_segment *, | ||
| 51 | unsigned long int); | ||
| 52 | #endif /* __KERNEL__ */ | ||
| 53 | |||
| 54 | #ifdef __KERNEL__ | ||
| 55 | #ifdef CONFIG_KEXEC | ||
| 6 | #include <linux/list.h> | 56 | #include <linux/list.h> |
| 7 | #include <linux/linkage.h> | 57 | #include <linux/linkage.h> |
| 8 | #include <linux/compat.h> | 58 | #include <linux/compat.h> |
| @@ -67,11 +117,10 @@ typedef unsigned long kimage_entry_t; | |||
| 67 | #define IND_DONE 0x4 | 117 | #define IND_DONE 0x4 |
| 68 | #define IND_SOURCE 0x8 | 118 | #define IND_SOURCE 0x8 |
| 69 | 119 | ||
| 70 | #define KEXEC_SEGMENT_MAX 16 | ||
| 71 | struct kexec_segment { | 120 | struct kexec_segment { |
| 72 | void __user *buf; | 121 | void __user *buf; |
| 73 | size_t bufsz; | 122 | size_t bufsz; |
| 74 | unsigned long mem; /* User space sees this as a (void *) ... */ | 123 | unsigned long mem; |
| 75 | size_t memsz; | 124 | size_t memsz; |
| 76 | }; | 125 | }; |
| 77 | 126 | ||
| @@ -175,25 +224,6 @@ extern struct kimage *kexec_crash_image; | |||
| 175 | #define kexec_flush_icache_page(page) | 224 | #define kexec_flush_icache_page(page) |
| 176 | #endif | 225 | #endif |
| 177 | 226 | ||
| 178 | #define KEXEC_ON_CRASH 0x00000001 | ||
| 179 | #define KEXEC_PRESERVE_CONTEXT 0x00000002 | ||
| 180 | #define KEXEC_ARCH_MASK 0xffff0000 | ||
| 181 | |||
| 182 | /* These values match the ELF architecture values. | ||
| 183 | * Unless there is a good reason that should continue to be the case. | ||
| 184 | */ | ||
| 185 | #define KEXEC_ARCH_DEFAULT ( 0 << 16) | ||
| 186 | #define KEXEC_ARCH_386 ( 3 << 16) | ||
| 187 | #define KEXEC_ARCH_X86_64 (62 << 16) | ||
| 188 | #define KEXEC_ARCH_PPC (20 << 16) | ||
| 189 | #define KEXEC_ARCH_PPC64 (21 << 16) | ||
| 190 | #define KEXEC_ARCH_IA_64 (50 << 16) | ||
| 191 | #define KEXEC_ARCH_ARM (40 << 16) | ||
| 192 | #define KEXEC_ARCH_S390 (22 << 16) | ||
| 193 | #define KEXEC_ARCH_SH (42 << 16) | ||
| 194 | #define KEXEC_ARCH_MIPS_LE (10 << 16) | ||
| 195 | #define KEXEC_ARCH_MIPS ( 8 << 16) | ||
| 196 | |||
| 197 | /* List of defined/legal kexec flags */ | 227 | /* List of defined/legal kexec flags */ |
| 198 | #ifndef CONFIG_KEXEC_JUMP | 228 | #ifndef CONFIG_KEXEC_JUMP |
| 199 | #define KEXEC_FLAGS KEXEC_ON_CRASH | 229 | #define KEXEC_FLAGS KEXEC_ON_CRASH |
| @@ -228,4 +258,5 @@ struct task_struct; | |||
| 228 | static inline void crash_kexec(struct pt_regs *regs) { } | 258 | static inline void crash_kexec(struct pt_regs *regs) { } |
| 229 | static inline int kexec_should_crash(struct task_struct *p) { return 0; } | 259 | static inline int kexec_should_crash(struct task_struct *p) { return 0; } |
| 230 | #endif /* CONFIG_KEXEC */ | 260 | #endif /* CONFIG_KEXEC */ |
| 261 | #endif /* __KERNEL__ */ | ||
| 231 | #endif /* LINUX_KEXEC_H */ | 262 | #endif /* LINUX_KEXEC_H */ |
