diff options
| author | Linus Torvalds <torvalds@g5.osdl.org> | 2006-10-02 11:18:43 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-10-02 11:18:43 -0400 |
| commit | 12dce6263d43daeb4e16fa4eb964c1c99fa4fa2e (patch) | |
| tree | e70a514e5fec67be191e12eba508db8ced967a4b /include/asm-mips/stacktrace.h | |
| parent | 3f2e05e90e0846c42626e3d272454f26be34a1bc (diff) | |
| parent | 04b314b2c3732bb5aa752fdbb3076de16decdab6 (diff) | |
Merge branch 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus
* 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus:
[MIPS] Remove unused galileo-boars header files
[MIPS] Rename SERIAL_PORT_DEFNS for EV64120
[MIPS] Add UART IRQ number for EV64120
[MIPS] Remove excite_flash.c
[MIPS] Update i8259 resources.
[MIPS] Make unwind_stack() can dig into interrupted context
[MIPS] Stacktrace build-fix and improvement
[MIPS] QEMU: Add support for little endian mips
[MIPS] Remove __flush_icache_page
[MIPS] lockdep: update defconfigs
[MIPS] lockdep: Add STACKTRACE_SUPPORT and enable LOCKDEP_SUPPORT
[MIPS] lockdep: fix TRACE_IRQFLAGS_SUPPORT
Diffstat (limited to 'include/asm-mips/stacktrace.h')
| -rw-r--r-- | include/asm-mips/stacktrace.h | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/include/asm-mips/stacktrace.h b/include/asm-mips/stacktrace.h new file mode 100644 index 000000000000..07f873351a86 --- /dev/null +++ b/include/asm-mips/stacktrace.h | |||
| @@ -0,0 +1,44 @@ | |||
| 1 | #ifndef _ASM_STACKTRACE_H | ||
| 2 | #define _ASM_STACKTRACE_H | ||
| 3 | |||
| 4 | #include <asm/ptrace.h> | ||
| 5 | |||
| 6 | #ifdef CONFIG_KALLSYMS | ||
| 7 | extern int raw_show_trace; | ||
| 8 | extern unsigned long unwind_stack(struct task_struct *task, unsigned long *sp, | ||
| 9 | unsigned long pc, unsigned long *ra); | ||
| 10 | #else | ||
| 11 | #define raw_show_trace 1 | ||
| 12 | #define unwind_stack(task, sp, pc, ra) 0 | ||
| 13 | #endif | ||
| 14 | |||
| 15 | static __always_inline void prepare_frametrace(struct pt_regs *regs) | ||
| 16 | { | ||
| 17 | #ifndef CONFIG_KALLSYMS | ||
| 18 | /* | ||
| 19 | * Remove any garbage that may be in regs (specially func | ||
| 20 | * addresses) to avoid show_raw_backtrace() to report them | ||
| 21 | */ | ||
| 22 | memset(regs, 0, sizeof(*regs)); | ||
| 23 | #endif | ||
| 24 | __asm__ __volatile__( | ||
| 25 | ".set push\n\t" | ||
| 26 | ".set noat\n\t" | ||
| 27 | #ifdef CONFIG_64BIT | ||
| 28 | "1: dla $1, 1b\n\t" | ||
| 29 | "sd $1, %0\n\t" | ||
| 30 | "sd $29, %1\n\t" | ||
| 31 | "sd $31, %2\n\t" | ||
| 32 | #else | ||
| 33 | "1: la $1, 1b\n\t" | ||
| 34 | "sw $1, %0\n\t" | ||
| 35 | "sw $29, %1\n\t" | ||
| 36 | "sw $31, %2\n\t" | ||
| 37 | #endif | ||
| 38 | ".set pop\n\t" | ||
| 39 | : "=m" (regs->cp0_epc), | ||
| 40 | "=m" (regs->regs[29]), "=m" (regs->regs[31]) | ||
| 41 | : : "memory"); | ||
| 42 | } | ||
| 43 | |||
| 44 | #endif /* _ASM_STACKTRACE_H */ | ||
