diff options
author | Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp> | 2007-10-17 02:27:27 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-17 11:42:54 -0400 |
commit | fd59d231f81cb02870b9cf15f456a897f3669b4e (patch) | |
tree | 5713c13bd678774f1ba3c42bfff5008c1812deae /include | |
parent | 0e647c04f665e9b3451a1ebe8252b38ffe0207c8 (diff) |
Add vmcoreinfo
This patch set frees the restriction that makedumpfile users should install a
vmlinux file (including the debugging information) into each system.
makedumpfile command is the dump filtering feature for kdump. It creates a
small dumpfile by filtering unnecessary pages for the analysis. To
distinguish unnecessary pages, it needs a vmlinux file including the debugging
information. These days, the debugging package becomes a huge file, and it is
hard to install it into each system.
To solve the problem, kdump developers discussed it at lkml and kexec-ml. As
the result, we reached the conclusion that necessary information for dump
filtering (called "vmcoreinfo") should be embedded into the first kernel file
and it should be accessed through /proc/vmcore during the second kernel.
(http://www.uwsg.iu.edu/hypermail/linux/kernel/0707.0/1806.html)
Dan Aloni created the patch set for the above implementation.
(http://www.uwsg.iu.edu/hypermail/linux/kernel/0707.1/1053.html)
And I updated it for multi architectures and memory models.
(http://lists.infradead.org/pipermail/kexec/2007-August/000479.html)
Signed-off-by: Dan Aloni <da-x@monatomic.org>
Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Bernhard Walle <bwalle@suse.de>
Signed-off-by: Daisuke Nishimura <nishimura@mxp.nes.nec.co.jp>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include')
-rw-r--r-- | include/asm-ia64/numa.h | 1 | ||||
-rw-r--r-- | include/linux/kexec.h | 26 |
2 files changed, 27 insertions, 0 deletions
diff --git a/include/asm-ia64/numa.h b/include/asm-ia64/numa.h index 7d5e2ccc37a0..6a8a27cfae3e 100644 --- a/include/asm-ia64/numa.h +++ b/include/asm-ia64/numa.h | |||
@@ -24,6 +24,7 @@ | |||
24 | 24 | ||
25 | extern u16 cpu_to_node_map[NR_CPUS] __cacheline_aligned; | 25 | extern u16 cpu_to_node_map[NR_CPUS] __cacheline_aligned; |
26 | extern cpumask_t node_to_cpu_mask[MAX_NUMNODES] __cacheline_aligned; | 26 | extern cpumask_t node_to_cpu_mask[MAX_NUMNODES] __cacheline_aligned; |
27 | extern pg_data_t *pgdat_list[MAX_NUMNODES]; | ||
27 | 28 | ||
28 | /* Stuff below this line could be architecture independent */ | 29 | /* Stuff below this line could be architecture independent */ |
29 | 30 | ||
diff --git a/include/linux/kexec.h b/include/linux/kexec.h index 8c2c7fcd58ce..99f2d6f0c83a 100644 --- a/include/linux/kexec.h +++ b/include/linux/kexec.h | |||
@@ -121,6 +121,23 @@ extern struct page *kimage_alloc_control_pages(struct kimage *image, | |||
121 | extern void crash_kexec(struct pt_regs *); | 121 | extern void crash_kexec(struct pt_regs *); |
122 | int kexec_should_crash(struct task_struct *); | 122 | int kexec_should_crash(struct task_struct *); |
123 | void crash_save_cpu(struct pt_regs *regs, int cpu); | 123 | void crash_save_cpu(struct pt_regs *regs, int cpu); |
124 | void crash_save_vmcoreinfo(void); | ||
125 | void arch_crash_save_vmcoreinfo(void); | ||
126 | void vmcoreinfo_append_str(const char *fmt, ...); | ||
127 | unsigned long paddr_vmcoreinfo_note(void); | ||
128 | |||
129 | #define SYMBOL(name) \ | ||
130 | vmcoreinfo_append_str("SYMBOL(%s)=%lx\n", #name, (unsigned long)&name) | ||
131 | #define SIZE(name) \ | ||
132 | vmcoreinfo_append_str("SIZE(%s)=%d\n", #name, sizeof(struct name)) | ||
133 | #define OFFSET(name, field) \ | ||
134 | vmcoreinfo_append_str("OFFSET(%s.%s)=%d\n", #name, #field, \ | ||
135 | &(((struct name *)0)->field)) | ||
136 | #define LENGTH(name, value) \ | ||
137 | vmcoreinfo_append_str("LENGTH(%s)=%d\n", #name, value) | ||
138 | #define CONFIG(name) \ | ||
139 | vmcoreinfo_append_str("CONFIG_%s=y\n", #name) | ||
140 | |||
124 | extern struct kimage *kexec_image; | 141 | extern struct kimage *kexec_image; |
125 | extern struct kimage *kexec_crash_image; | 142 | extern struct kimage *kexec_crash_image; |
126 | 143 | ||
@@ -148,11 +165,20 @@ extern struct kimage *kexec_crash_image; | |||
148 | 165 | ||
149 | #define KEXEC_FLAGS (KEXEC_ON_CRASH) /* List of defined/legal kexec flags */ | 166 | #define KEXEC_FLAGS (KEXEC_ON_CRASH) /* List of defined/legal kexec flags */ |
150 | 167 | ||
168 | #define VMCOREINFO_BYTES (4096) | ||
169 | #define VMCOREINFO_NOTE_NAME "VMCOREINFO" | ||
170 | #define VMCOREINFO_NOTE_NAME_BYTES ALIGN(sizeof(VMCOREINFO_NOTE_NAME), 4) | ||
171 | #define VMCOREINFO_NOTE_SIZE (KEXEC_NOTE_HEAD_BYTES*2 + VMCOREINFO_BYTES \ | ||
172 | + VMCOREINFO_NOTE_NAME_BYTES) | ||
173 | |||
151 | /* Location of a reserved region to hold the crash kernel. | 174 | /* Location of a reserved region to hold the crash kernel. |
152 | */ | 175 | */ |
153 | extern struct resource crashk_res; | 176 | extern struct resource crashk_res; |
154 | typedef u32 note_buf_t[KEXEC_NOTE_BYTES/4]; | 177 | typedef u32 note_buf_t[KEXEC_NOTE_BYTES/4]; |
155 | extern note_buf_t *crash_notes; | 178 | extern note_buf_t *crash_notes; |
179 | extern u32 vmcoreinfo_note[VMCOREINFO_NOTE_SIZE/4]; | ||
180 | extern unsigned int vmcoreinfo_size; | ||
181 | extern unsigned int vmcoreinfo_max_size; | ||
156 | 182 | ||
157 | 183 | ||
158 | #else /* !CONFIG_KEXEC */ | 184 | #else /* !CONFIG_KEXEC */ |