2006-09-20 21:58:39 +08:00
|
|
|
#ifndef _S390_KDEBUG_H
|
|
|
|
#define _S390_KDEBUG_H
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Feb 2006 Ported to s390 <grundym@us.ibm.com>
|
|
|
|
*/
|
|
|
|
#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.
|
|
|
|
*/
|
|
|
|
extern int register_die_notifier(struct notifier_block *);
|
|
|
|
extern int unregister_die_notifier(struct notifier_block *);
|
|
|
|
extern int register_page_fault_notifier(struct notifier_block *);
|
|
|
|
extern int unregister_page_fault_notifier(struct notifier_block *);
|
|
|
|
extern struct atomic_notifier_head s390die_chain;
|
|
|
|
|
|
|
|
enum die_val {
|
|
|
|
DIE_OOPS = 1,
|
|
|
|
DIE_BPT,
|
|
|
|
DIE_SSTEP,
|
|
|
|
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 atomic_notifier_call_chain(&s390die_chain, val, &args);
|
|
|
|
}
|
|
|
|
|
2007-02-06 04:16:47 +08:00
|
|
|
extern void die(const char *, struct pt_regs *, long);
|
|
|
|
|
2006-09-20 21:58:39 +08:00
|
|
|
#endif
|