diff options
Diffstat (limited to 'include/asm-powerpc/kdebug.h')
| -rw-r--r-- | include/asm-powerpc/kdebug.h | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/include/asm-powerpc/kdebug.h b/include/asm-powerpc/kdebug.h new file mode 100644 index 000000000000..9dcbac674811 --- /dev/null +++ b/include/asm-powerpc/kdebug.h | |||
| @@ -0,0 +1,42 @@ | |||
| 1 | #ifndef _ASM_POWERPC_KDEBUG_H | ||
| 2 | #define _ASM_POWERPC_KDEBUG_H | ||
| 3 | |||
| 4 | /* nearly identical to x86_64/i386 code */ | ||
| 5 | |||
| 6 | #include <linux/notifier.h> | ||
| 7 | |||
| 8 | struct pt_regs; | ||
| 9 | |||
| 10 | struct die_args { | ||
| 11 | struct pt_regs *regs; | ||
| 12 | const char *str; | ||
| 13 | long err; | ||
| 14 | int trapnr; | ||
| 15 | int signr; | ||
| 16 | }; | ||
| 17 | |||
| 18 | /* | ||
| 19 | Note - you should never unregister because that can race with NMIs. | ||
| 20 | If you really want to do it first unregister - then synchronize_sched - | ||
| 21 | then free. | ||
| 22 | */ | ||
| 23 | int register_die_notifier(struct notifier_block *nb); | ||
| 24 | extern struct notifier_block *powerpc_die_chain; | ||
| 25 | |||
| 26 | /* Grossly misnamed. */ | ||
| 27 | enum die_val { | ||
| 28 | DIE_OOPS = 1, | ||
| 29 | DIE_IABR_MATCH, | ||
| 30 | DIE_DABR_MATCH, | ||
| 31 | DIE_BPT, | ||
| 32 | DIE_SSTEP, | ||
| 33 | DIE_PAGE_FAULT, | ||
| 34 | }; | ||
| 35 | |||
| 36 | static inline int notify_die(enum die_val val,char *str,struct pt_regs *regs,long err,int trap, int sig) | ||
| 37 | { | ||
| 38 | struct die_args args = { .regs=regs, .str=str, .err=err, .trapnr=trap,.signr=sig }; | ||
| 39 | return notifier_call_chain(&powerpc_die_chain, val, &args); | ||
| 40 | } | ||
| 41 | |||
| 42 | #endif /* _ASM_POWERPC_KDEBUG_H */ | ||
