kexec.h 6.2 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 131 132 133
#define VMCOREINFO_OSRELEASE(name) \
	vmcoreinfo_append_str("OSRELEASE=%s\n", #name)
#define VMCOREINFO_PAGESIZE(value) \
	vmcoreinfo_append_str("PAGESIZE=%ld\n", value)
134
#define VMCOREINFO_SYMBOL(name) \
K
Ken'ichi Ohmichi 已提交
135
	vmcoreinfo_append_str("SYMBOL(%s)=%lx\n", #name, (unsigned long)&name)
136
#define VMCOREINFO_SIZE(name) \
137 138
	vmcoreinfo_append_str("SIZE(%s)=%lu\n", #name, \
			      (unsigned long)sizeof(name))
139 140 141
#define VMCOREINFO_STRUCT_SIZE(name) \
	vmcoreinfo_append_str("SIZE(%s)=%lu\n", #name, \
			      (unsigned long)sizeof(struct name))
142
#define VMCOREINFO_OFFSET(name, field) \
143
	vmcoreinfo_append_str("OFFSET(%s.%s)=%lu\n", #name, #field, \
144
			      (unsigned long)offsetof(struct name, field))
145
#define VMCOREINFO_LENGTH(name, value) \
146
	vmcoreinfo_append_str("LENGTH(%s)=%lu\n", #name, (unsigned long)value)
147
#define VMCOREINFO_NUMBER(name) \
148
	vmcoreinfo_append_str("NUMBER(%s)=%ld\n", #name, (long)name)
149
#define VMCOREINFO_CONFIG(name) \
K
Ken'ichi Ohmichi 已提交
150 151
	vmcoreinfo_append_str("CONFIG_%s=y\n", #name)

152
extern struct kimage *kexec_image;
153
extern struct kimage *kexec_crash_image;
154

Z
Zou Nan hai 已提交
155 156 157 158
#ifndef kexec_flush_icache_page
#define kexec_flush_icache_page(page)
#endif

159 160 161 162 163 164 165 166 167 168 169 170
#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 已提交
171
#define KEXEC_ARCH_ARM     (40 << 16)
H
Heiko Carstens 已提交
172
#define KEXEC_ARCH_S390    (22 << 16)
K
kogiidena 已提交
173
#define KEXEC_ARCH_SH      (42 << 16)
N
Nicolas Schichan 已提交
174 175
#define KEXEC_ARCH_MIPS_LE (10 << 16)
#define KEXEC_ARCH_MIPS    ( 8 << 16)
176 177 178

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

K
Ken'ichi Ohmichi 已提交
179 180 181 182 183 184
#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)

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

B
Bernhard Walle 已提交
194 195
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 已提交
196

197
#else /* !CONFIG_KEXEC */
198 199 200 201
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; }
202 203
#endif /* CONFIG_KEXEC */
#endif /* LINUX_KEXEC_H */