kexec.h 6.0 KB
Newer Older
1 2 3 4 5 6 7 8
#ifndef LINUX_KEXEC_H
#define LINUX_KEXEC_H

#ifdef CONFIG_KEXEC
#include <linux/types.h>
#include <linux/list.h>
#include <linux/linkage.h>
#include <linux/compat.h>
9
#include <linux/ioport.h>
10 11
#include <linux/elfcore.h>
#include <linux/elf.h>
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
#include <asm/kexec.h>

/* Verify architecture specific macros are defined */

#ifndef KEXEC_SOURCE_MEMORY_LIMIT
#error KEXEC_SOURCE_MEMORY_LIMIT not defined
#endif

#ifndef KEXEC_DESTINATION_MEMORY_LIMIT
#error KEXEC_DESTINATION_MEMORY_LIMIT not defined
#endif

#ifndef KEXEC_CONTROL_MEMORY_LIMIT
#error KEXEC_CONTROL_MEMORY_LIMIT not defined
#endif

#ifndef KEXEC_CONTROL_CODE_SIZE
#error KEXEC_CONTROL_CODE_SIZE not defined
#endif

#ifndef KEXEC_ARCH
#error KEXEC_ARCH not defined
#endif

36 37 38 39 40 41 42 43 44 45 46 47 48
#define KEXEC_NOTE_HEAD_BYTES ALIGN(sizeof(struct elf_note), 4)
#define KEXEC_CORE_NOTE_NAME "CORE"
#define KEXEC_CORE_NOTE_NAME_BYTES ALIGN(sizeof(KEXEC_CORE_NOTE_NAME), 4)
#define KEXEC_CORE_NOTE_DESC_BYTES ALIGN(sizeof(struct elf_prstatus), 4)
/*
 * The per-cpu notes area is a list of notes terminated by a "NULL"
 * note header.  For kdump, the code in vmcore.c runs in the context
 * of the second kernel to combine them into one note.
 */
#define KEXEC_NOTE_BYTES ( (KEXEC_NOTE_HEAD_BYTES * 2) +		\
			    KEXEC_CORE_NOTE_NAME_BYTES +		\
			    KEXEC_CORE_NOTE_DESC_BYTES )

49 50 51 52 53 54 55 56 57 58 59
/*
 * This structure is used to hold the arguments that are used when loading
 * kernel binaries.
 */

typedef unsigned long kimage_entry_t;
#define IND_DESTINATION  0x1
#define IND_INDIRECTION  0x2
#define IND_DONE         0x4
#define IND_SOURCE       0x8

60
#define KEXEC_SEGMENT_MAX 16
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
struct kexec_segment {
	void __user *buf;
	size_t bufsz;
	unsigned long mem;	/* User space sees this as a (void *) ... */
	size_t memsz;
};

#ifdef CONFIG_COMPAT
struct compat_kexec_segment {
	compat_uptr_t buf;
	compat_size_t bufsz;
	compat_ulong_t mem;	/* User space sees this as a (void *) ... */
	compat_size_t memsz;
};
#endif

struct kimage {
	kimage_entry_t head;
	kimage_entry_t *entry;
	kimage_entry_t *last_entry;

	unsigned long destination;

	unsigned long start;
	struct page *control_code_page;

	unsigned long nr_segments;
	struct kexec_segment segment[KEXEC_SEGMENT_MAX];

	struct list_head control_pages;
	struct list_head dest_pages;
	struct list_head unuseable_pages;

	/* Address of next control page to allocate for crash kernels. */
	unsigned long control_page;

	/* Flags to indicate special processing */
	unsigned int type : 1;
#define KEXEC_TYPE_DEFAULT 0
#define KEXEC_TYPE_CRASH   1
};



/* kexec interface functions */
extern NORET_TYPE void machine_kexec(struct kimage *image) ATTRIB_NORET;
extern int machine_kexec_prepare(struct kimage *image);
extern void machine_kexec_cleanup(struct kimage *image);
extern asmlinkage long sys_kexec_load(unsigned long entry,
M
Maneesh Soni 已提交
110 111 112
					unsigned long nr_segments,
					struct kexec_segment __user *segments,
					unsigned long flags);
113 114
#ifdef CONFIG_COMPAT
extern asmlinkage long compat_sys_kexec_load(unsigned long entry,
M
Maneesh Soni 已提交
115 116 117
				unsigned long nr_segments,
				struct compat_kexec_segment __user *segments,
				unsigned long flags);
118
#endif
M
Maneesh Soni 已提交
119 120
extern struct page *kimage_alloc_control_pages(struct kimage *image,
						unsigned int order);
121 122
extern void crash_kexec(struct pt_regs *);
int kexec_should_crash(struct task_struct *);
123
void crash_save_cpu(struct pt_regs *regs, int cpu);
K
Ken'ichi Ohmichi 已提交
124 125
void crash_save_vmcoreinfo(void);
void arch_crash_save_vmcoreinfo(void);
126 127
void vmcoreinfo_append_str(const char *fmt, ...)
	__attribute__ ((format (printf, 1, 2)));
K
Ken'ichi Ohmichi 已提交
128 129
unsigned long paddr_vmcoreinfo_note(void);

130
#define VMCOREINFO_SYMBOL(name) \
K
Ken'ichi Ohmichi 已提交
131
	vmcoreinfo_append_str("SYMBOL(%s)=%lx\n", #name, (unsigned long)&name)
132
#define VMCOREINFO_SIZE(name) \
133 134
	vmcoreinfo_append_str("SIZE(%s)=%lu\n", #name, \
			      (unsigned long)sizeof(name))
135 136 137
#define VMCOREINFO_STRUCT_SIZE(name) \
	vmcoreinfo_append_str("SIZE(%s)=%lu\n", #name, \
			      (unsigned long)sizeof(struct name))
138
#define VMCOREINFO_OFFSET(name, field) \
139 140
	vmcoreinfo_append_str("OFFSET(%s.%s)=%lu\n", #name, #field, \
			      (unsigned long)&(((struct name *)0)->field))
141
#define VMCOREINFO_LENGTH(name, value) \
142
	vmcoreinfo_append_str("LENGTH(%s)=%lu\n", #name, (unsigned long)value)
143
#define VMCOREINFO_NUMBER(name) \
144
	vmcoreinfo_append_str("NUMBER(%s)=%ld\n", #name, (long)name)
145
#define VMCOREINFO_CONFIG(name) \
K
Ken'ichi Ohmichi 已提交
146 147
	vmcoreinfo_append_str("CONFIG_%s=y\n", #name)

148
extern struct kimage *kexec_image;
149
extern struct kimage *kexec_crash_image;
150

Z
Zou Nan hai 已提交
151 152 153 154
#ifndef kexec_flush_icache_page
#define kexec_flush_icache_page(page)
#endif

155 156 157 158 159 160 161 162 163 164 165 166
#define KEXEC_ON_CRASH  0x00000001
#define KEXEC_ARCH_MASK 0xffff0000

/* These values match the ELF architecture values.
 * Unless there is a good reason that should continue to be the case.
 */
#define KEXEC_ARCH_DEFAULT ( 0 << 16)
#define KEXEC_ARCH_386     ( 3 << 16)
#define KEXEC_ARCH_X86_64  (62 << 16)
#define KEXEC_ARCH_PPC     (20 << 16)
#define KEXEC_ARCH_PPC64   (21 << 16)
#define KEXEC_ARCH_IA_64   (50 << 16)
R
Richard Purdie 已提交
167
#define KEXEC_ARCH_ARM     (40 << 16)
H
Heiko Carstens 已提交
168
#define KEXEC_ARCH_S390    (22 << 16)
K
kogiidena 已提交
169
#define KEXEC_ARCH_SH      (42 << 16)
N
Nicolas Schichan 已提交
170 171
#define KEXEC_ARCH_MIPS_LE (10 << 16)
#define KEXEC_ARCH_MIPS    ( 8 << 16)
172 173 174

#define KEXEC_FLAGS    (KEXEC_ON_CRASH)  /* List of defined/legal kexec flags */

K
Ken'ichi Ohmichi 已提交
175 176 177 178 179 180
#define VMCOREINFO_BYTES           (4096)
#define VMCOREINFO_NOTE_NAME       "VMCOREINFO"
#define VMCOREINFO_NOTE_NAME_BYTES ALIGN(sizeof(VMCOREINFO_NOTE_NAME), 4)
#define VMCOREINFO_NOTE_SIZE       (KEXEC_NOTE_HEAD_BYTES*2 + VMCOREINFO_BYTES \
				    + VMCOREINFO_NOTE_NAME_BYTES)

181 182 183
/* Location of a reserved region to hold the crash kernel.
 */
extern struct resource crashk_res;
184
typedef u32 note_buf_t[KEXEC_NOTE_BYTES/4];
185
extern note_buf_t *crash_notes;
K
Ken'ichi Ohmichi 已提交
186
extern u32 vmcoreinfo_note[VMCOREINFO_NOTE_SIZE/4];
187 188
extern size_t vmcoreinfo_size;
extern size_t vmcoreinfo_max_size;
189

B
Bernhard Walle 已提交
190 191
int __init parse_crashkernel(char *cmdline, unsigned long long system_ram,
		unsigned long long *crash_size, unsigned long long *crash_base);
Z
Zou Nan hai 已提交
192

193
#else /* !CONFIG_KEXEC */
194 195 196 197
struct pt_regs;
struct task_struct;
static inline void crash_kexec(struct pt_regs *regs) { }
static inline int kexec_should_crash(struct task_struct *p) { return 0; }
198 199
#endif /* CONFIG_KEXEC */
#endif /* LINUX_KEXEC_H */