diff options
-rw-r--r-- | arch/i386/kernel/traps.c | 16 | ||||
-rw-r--r-- | arch/x86_64/kernel/traps.c | 21 |
2 files changed, 23 insertions, 14 deletions
diff --git a/arch/i386/kernel/traps.c b/arch/i386/kernel/traps.c index fe9c5e8e7e6..fe81d89c50d 100644 --- a/arch/i386/kernel/traps.c +++ b/arch/i386/kernel/traps.c | |||
@@ -173,6 +173,8 @@ dump_trace_unwind(struct unwind_frame_info *info, void *data) | |||
173 | return n; | 173 | return n; |
174 | } | 174 | } |
175 | 175 | ||
176 | #define MSG(msg) ops->warning(data, msg) | ||
177 | |||
176 | void dump_trace(struct task_struct *task, struct pt_regs *regs, | 178 | void dump_trace(struct task_struct *task, struct pt_regs *regs, |
177 | unsigned long *stack, | 179 | unsigned long *stack, |
178 | struct stacktrace_ops *ops, void *data) | 180 | struct stacktrace_ops *ops, void *data) |
@@ -191,29 +193,31 @@ void dump_trace(struct task_struct *task, struct pt_regs *regs, | |||
191 | if (unwind_init_frame_info(&info, task, regs) == 0) | 193 | if (unwind_init_frame_info(&info, task, regs) == 0) |
192 | unw_ret = dump_trace_unwind(&info, &oad); | 194 | unw_ret = dump_trace_unwind(&info, &oad); |
193 | } else if (task == current) | 195 | } else if (task == current) |
194 | unw_ret = unwind_init_running(&info, dump_trace_unwind, &oad); | 196 | unw_ret = unwind_init_running(&info, dump_trace_unwind, |
197 | &oad); | ||
195 | else { | 198 | else { |
196 | if (unwind_init_blocked(&info, task) == 0) | 199 | if (unwind_init_blocked(&info, task) == 0) |
197 | unw_ret = dump_trace_unwind(&info, &oad); | 200 | unw_ret = dump_trace_unwind(&info, &oad); |
198 | } | 201 | } |
199 | if (unw_ret > 0) { | 202 | if (unw_ret > 0) { |
200 | if (call_trace == 1 && !arch_unw_user_mode(&info)) { | 203 | if (call_trace == 1 && !arch_unw_user_mode(&info)) { |
201 | ops->warning_symbol(data, "DWARF2 unwinder stuck at %s\n", | 204 | ops->warning_symbol(data, |
205 | "DWARF2 unwinder stuck at %s\n", | ||
202 | UNW_PC(&info)); | 206 | UNW_PC(&info)); |
203 | if (UNW_SP(&info) >= PAGE_OFFSET) { | 207 | if (UNW_SP(&info) >= PAGE_OFFSET) { |
204 | ops->warning(data, "Leftover inexact backtrace:\n"); | 208 | MSG("Leftover inexact backtrace:\n"); |
205 | stack = (void *)UNW_SP(&info); | 209 | stack = (void *)UNW_SP(&info); |
206 | if (!stack) | 210 | if (!stack) |
207 | return; | 211 | return; |
208 | ebp = UNW_FP(&info); | 212 | ebp = UNW_FP(&info); |
209 | } else | 213 | } else |
210 | ops->warning(data, "Full inexact backtrace again:\n"); | 214 | MSG("Full inexact backtrace again:\n"); |
211 | } else if (call_trace >= 1) | 215 | } else if (call_trace >= 1) |
212 | return; | 216 | return; |
213 | else | 217 | else |
214 | ops->warning(data, "Full inexact backtrace again:\n"); | 218 | MSG("Full inexact backtrace again:\n"); |
215 | } else | 219 | } else |
216 | ops->warning(data, "Inexact backtrace:\n"); | 220 | MSG("Inexact backtrace:\n"); |
217 | } | 221 | } |
218 | if (!stack) { | 222 | if (!stack) { |
219 | unsigned long dummy; | 223 | unsigned long dummy; |
diff --git a/arch/x86_64/kernel/traps.c b/arch/x86_64/kernel/traps.c index 0d65b22f229..d3f43c958ca 100644 --- a/arch/x86_64/kernel/traps.c +++ b/arch/x86_64/kernel/traps.c | |||
@@ -235,6 +235,8 @@ static int dump_trace_unwind(struct unwind_frame_info *info, void *context) | |||
235 | return n; | 235 | return n; |
236 | } | 236 | } |
237 | 237 | ||
238 | #define MSG(txt) ops->warning(data, txt) | ||
239 | |||
238 | /* | 240 | /* |
239 | * x86-64 can have upto three kernel stacks: | 241 | * x86-64 can have upto three kernel stacks: |
240 | * process stack | 242 | * process stack |
@@ -248,11 +250,12 @@ static inline int valid_stack_ptr(struct thread_info *tinfo, void *p) | |||
248 | return p > t && p < t + THREAD_SIZE - 3; | 250 | return p > t && p < t + THREAD_SIZE - 3; |
249 | } | 251 | } |
250 | 252 | ||
251 | void dump_trace(struct task_struct *tsk, struct pt_regs *regs, unsigned long * stack, | 253 | void dump_trace(struct task_struct *tsk, struct pt_regs *regs, |
254 | unsigned long *stack, | ||
252 | struct stacktrace_ops *ops, void *data) | 255 | struct stacktrace_ops *ops, void *data) |
253 | { | 256 | { |
254 | const unsigned cpu = smp_processor_id(); | 257 | const unsigned cpu = smp_processor_id(); |
255 | unsigned long *irqstack_end = (unsigned long *)cpu_pda(cpu)->irqstackptr; | 258 | unsigned long *irqstack_end = (unsigned long*)cpu_pda(cpu)->irqstackptr; |
256 | unsigned used = 0; | 259 | unsigned used = 0; |
257 | struct thread_info *tinfo; | 260 | struct thread_info *tinfo; |
258 | 261 | ||
@@ -268,28 +271,30 @@ void dump_trace(struct task_struct *tsk, struct pt_regs *regs, unsigned long * s | |||
268 | if (unwind_init_frame_info(&info, tsk, regs) == 0) | 271 | if (unwind_init_frame_info(&info, tsk, regs) == 0) |
269 | unw_ret = dump_trace_unwind(&info, &oad); | 272 | unw_ret = dump_trace_unwind(&info, &oad); |
270 | } else if (tsk == current) | 273 | } else if (tsk == current) |
271 | unw_ret = unwind_init_running(&info, dump_trace_unwind, &oad); | 274 | unw_ret = unwind_init_running(&info, dump_trace_unwind, |
275 | &oad); | ||
272 | else { | 276 | else { |
273 | if (unwind_init_blocked(&info, tsk) == 0) | 277 | if (unwind_init_blocked(&info, tsk) == 0) |
274 | unw_ret = dump_trace_unwind(&info, &oad); | 278 | unw_ret = dump_trace_unwind(&info, &oad); |
275 | } | 279 | } |
276 | if (unw_ret > 0) { | 280 | if (unw_ret > 0) { |
277 | if (call_trace == 1 && !arch_unw_user_mode(&info)) { | 281 | if (call_trace == 1 && !arch_unw_user_mode(&info)) { |
278 | ops->warning_symbol(data, "DWARF2 unwinder stuck at %s\n", | 282 | ops->warning_symbol(data, |
283 | "DWARF2 unwinder stuck at %s\n", | ||
279 | UNW_PC(&info)); | 284 | UNW_PC(&info)); |
280 | if ((long)UNW_SP(&info) < 0) { | 285 | if ((long)UNW_SP(&info) < 0) { |
281 | ops->warning(data, "Leftover inexact backtrace:\n"); | 286 | MSG("Leftover inexact backtrace:"); |
282 | stack = (unsigned long *)UNW_SP(&info); | 287 | stack = (unsigned long *)UNW_SP(&info); |
283 | if (!stack) | 288 | if (!stack) |
284 | return; | 289 | return; |
285 | } else | 290 | } else |
286 | ops->warning(data, "Full inexact backtrace again:\n"); | 291 | MSG("Full inexact backtrace again:\n"); |
287 | } else if (call_trace >= 1) | 292 | } else if (call_trace >= 1) |
288 | return; | 293 | return; |
289 | else | 294 | else |
290 | ops->warning(data, "Full inexact backtrace again:\n"); | 295 | MSG("Full inexact backtrace again:\n"); |
291 | } else | 296 | } else |
292 | ops->warning(data, "Inexact backtrace:\n"); | 297 | MSG("Inexact backtrace:\n"); |
293 | } | 298 | } |
294 | if (!stack) { | 299 | if (!stack) { |
295 | unsigned long dummy; | 300 | unsigned long dummy; |