| #ifndef _I386_KDEBUG_H |
| #define _I386_KDEBUG_H 1 |
| |
| /* |
| * Aug-05 2004 Ported by Prasanna S Panchamukhi <prasanna@in.ibm.com> |
| * from x86_64 architecture. |
| */ |
| #include <linux/notifier.h> |
| |
| struct pt_regs; |
| |
| struct die_args { |
| struct pt_regs *regs; |
| const char *str; |
| long err; |
| int trapnr; |
| int signr; |
| }; |
| |
| /* Note - you should never unregister because that can race with NMIs. |
| If you really want to do it first unregister - then synchronize_sched - then free. |
| */ |
| int register_die_notifier(struct notifier_block *nb); |
| extern struct notifier_block *i386die_chain; |
| |
| |
| /* Grossly misnamed. */ |
| enum die_val { |
| DIE_OOPS = 1, |
| DIE_INT3, |
| DIE_DEBUG, |
| DIE_PANIC, |
| DIE_NMI, |
| DIE_DIE, |
| DIE_NMIWATCHDOG, |
| DIE_KERNELDEBUG, |
| DIE_TRAP, |
| DIE_GPF, |
| DIE_CALL, |
| DIE_NMI_IPI, |
| DIE_PAGE_FAULT, |
| }; |
| |
| static inline int notify_die(enum die_val val, const char *str, |
| struct pt_regs *regs, long err, int trap, int sig) |
| { |
| struct die_args args = { |
| .regs = regs, |
| .str = str, |
| .err = err, |
| .trapnr = trap, |
| .signr = sig |
| }; |
| return notifier_call_chain(&i386die_chain, val, &args); |
| } |
| |
| #endif |