vserver 1.9.5.x5
[linux-2.6.git] / include / asm-x86_64 / kdebug.h
1 #ifndef _X86_64_KDEBUG_H
2 #define _X86_64_KDEBUG_H 1
3
4 #include <linux/notifier.h>
5
6 struct pt_regs;
7
8 struct die_args { 
9         struct pt_regs *regs;
10         const char *str;
11         long err; 
12         int trapnr;
13         int signr;
14 }; 
15
16 /* Note - you should never unregister because that can race with NMIs.
17    If you really want to do it first unregister - then synchronize_kernel - then free. 
18   */
19 int register_die_notifier(struct notifier_block *nb);
20 extern struct notifier_block *die_chain;
21 /* Grossly misnamed. */
22 enum die_val { 
23         DIE_OOPS = 1,
24         DIE_INT3,
25         DIE_DEBUG,
26         DIE_DEBUGSTEP,
27         DIE_PANIC,
28         DIE_NMI,
29         DIE_DIE,
30         DIE_NMIWATCHDOG,
31         DIE_KERNELDEBUG,
32         DIE_TRAP,
33         DIE_GPF,
34         DIE_CALL,
35         DIE_NMI_IPI,
36         DIE_PAGE_FAULT,
37 }; 
38         
39 static inline int notify_die(enum die_val val,char *str,struct pt_regs *regs,long err,int trap, int sig)
40
41         struct die_args args = { .regs=regs, .str=str, .err=err, .trapnr=trap,.signr=sig }; 
42         return notifier_call_chain(&die_chain, val, &args); 
43
44
45 extern int printk_address(unsigned long address);
46 extern void die(const char *,struct pt_regs *,long);
47 extern void __die(const char *,struct pt_regs *,long);
48 extern void show_registers(struct pt_regs *regs);
49 extern void dump_pagetable(unsigned long);
50 extern void oops_begin(void);
51 extern void oops_end(void);
52
53 #endif