mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-08 06:44:35 +08:00
9f90b997de
Call the kprobes pagefault handler directly instead of going through the complex notifier chain. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Paul Mackerras <paulus@samba.org>
54 lines
1.2 KiB
C
54 lines
1.2 KiB
C
#ifndef _ASM_POWERPC_KDEBUG_H
|
|
#define _ASM_POWERPC_KDEBUG_H
|
|
#ifdef __KERNEL__
|
|
|
|
/* nearly identical to x86_64/i386 code */
|
|
|
|
#include <linux/notifier.h>
|
|
|
|
struct pt_regs;
|
|
|
|
struct die_args {
|
|
struct pt_regs *regs;
|
|
const char *str;
|
|
long err;
|
|
int trapnr;
|
|
int signr;
|
|
};
|
|
|
|
extern int register_die_notifier(struct notifier_block *);
|
|
extern int unregister_die_notifier(struct notifier_block *);
|
|
|
|
/*
|
|
* These are only here because kprobes.c wants them to implement a
|
|
* blatant layering violation. Will hopefully go away soon once all
|
|
* architectures are updated.
|
|
*/
|
|
static inline int register_page_fault_notifier(struct notifier_block *nb)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline int unregister_page_fault_notifier(struct notifier_block *nb)
|
|
{
|
|
return 0;
|
|
}
|
|
extern struct atomic_notifier_head powerpc_die_chain;
|
|
|
|
/* Grossly misnamed. */
|
|
enum die_val {
|
|
DIE_OOPS = 1,
|
|
DIE_IABR_MATCH,
|
|
DIE_DABR_MATCH,
|
|
DIE_BPT,
|
|
DIE_SSTEP,
|
|
};
|
|
|
|
static inline int notify_die(enum die_val val,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(&powerpc_die_chain, val, &args);
|
|
}
|
|
|
|
#endif /* __KERNEL__ */
|
|
#endif /* _ASM_POWERPC_KDEBUG_H */
|