df996b933def3c8dcdfd8ce3d3961b5768d6dda4
[sfrench/cifs-2.6.git] / include / asm-powerpc / kdebug.h
1 #ifndef _ASM_POWERPC_KDEBUG_H
2 #define _ASM_POWERPC_KDEBUG_H
3 #ifdef __KERNEL__
4
5 /* nearly identical to x86_64/i386 code */
6
7 #include <linux/notifier.h>
8
9 struct pt_regs;
10
11 struct die_args {
12         struct pt_regs *regs;
13         const char *str;
14         long err;
15         int trapnr;
16         int signr;
17 };
18
19 extern int register_die_notifier(struct notifier_block *);
20 extern int unregister_die_notifier(struct notifier_block *);
21
22 /*
23  * These are only here because kprobes.c wants them to implement a
24  * blatant layering violation.  Will hopefully go away soon once all
25  * architectures are updated.
26  */
27 static inline int register_page_fault_notifier(struct notifier_block *nb)
28 {
29         return 0;
30 }
31 static inline int unregister_page_fault_notifier(struct notifier_block *nb)
32 {
33         return 0;
34 }
35 extern struct atomic_notifier_head powerpc_die_chain;
36
37 /* Grossly misnamed. */
38 enum die_val {
39         DIE_OOPS = 1,
40         DIE_IABR_MATCH,
41         DIE_DABR_MATCH,
42         DIE_BPT,
43         DIE_SSTEP,
44 };
45
46 static inline int notify_die(enum die_val val,char *str,struct pt_regs *regs,long err,int trap, int sig)
47 {
48         struct die_args args = { .regs=regs, .str=str, .err=err, .trapnr=trap,.signr=sig };
49         return atomic_notifier_call_chain(&powerpc_die_chain, val, &args);
50 }
51
52 #endif /* __KERNEL__ */
53 #endif /* _ASM_POWERPC_KDEBUG_H */