The patch titled Notify page fault call chain for powerpc has been added to the -mm tree. Its filename is notify-page-fault-call-chain-for-powerpc.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this From: Anil S Keshavamurthy <anil.s.keshavamurthy@xxxxxxxxx> Overloading of page fault notification with the notify_die() has performance issues(since the only interested components for page fault is kprobes and/or kdb) and hence this patch introduces the new notifier call chain exclusively for page fault notifications their by avoiding notifying unnecessary components in the do_page_fault() code path. Signed-off-by: Anil S Keshavamurthy <anil.s.keshavamurthy@xxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- arch/powerpc/mm/fault.c | 36 ++++++++++++++++++++++++++++++++- include/asm-powerpc/kdebug.h | 2 + 2 files changed, 37 insertions(+), 1 deletion(-) diff -puN arch/powerpc/mm/fault.c~notify-page-fault-call-chain-for-powerpc arch/powerpc/mm/fault.c --- devel/arch/powerpc/mm/fault.c~notify-page-fault-call-chain-for-powerpc 2006-04-20 23:30:03.000000000 -0700 +++ devel-akpm/arch/powerpc/mm/fault.c 2006-04-20 23:30:03.000000000 -0700 @@ -40,6 +40,40 @@ #include <asm/kdebug.h> #include <asm/siginfo.h> +#ifdef CONFIG_KPROBES +ATOMIC_NOTIFIER_HEAD(notify_page_fault_chain); + +/* Hook to register for page fault notifications */ +int register_page_fault_notifier(struct notifier_block *nb) +{ + return atomic_notifier_chain_register(¬ify_page_fault_chain, nb); +} + +int unregister_page_fault_notifier(struct notifier_block *nb) +{ + return atomic_notifier_chain_unregister(¬ify_page_fault_chain, nb); +} + +static inline int notify_page_fault(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(¬ify_page_fault_chain, val, &args); +} +#else +static inline int notify_page_fault(enum die_val val, const char *str, + struct pt_regs *regs, long err, int trap, int sig) +{ + return NOTIFY_DONE; +} +#endif + /* * Check whether the instruction at regs->nip is a store using * an update addressing form which will update r1. @@ -142,7 +176,7 @@ int __kprobes do_page_fault(struct pt_re is_write = error_code & ESR_DST; #endif /* CONFIG_4xx || CONFIG_BOOKE */ - if (notify_die(DIE_PAGE_FAULT, "page_fault", regs, error_code, + if (notify_page_fault(DIE_PAGE_FAULT, "page_fault", regs, error_code, 11, SIGSEGV) == NOTIFY_STOP) return 0; diff -puN include/asm-powerpc/kdebug.h~notify-page-fault-call-chain-for-powerpc include/asm-powerpc/kdebug.h --- devel/include/asm-powerpc/kdebug.h~notify-page-fault-call-chain-for-powerpc 2006-04-20 23:30:03.000000000 -0700 +++ devel-akpm/include/asm-powerpc/kdebug.h 2006-04-20 23:30:03.000000000 -0700 @@ -18,6 +18,8 @@ struct die_args { 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 powerpc_die_chain; /* Grossly misnamed. */ _ Patches currently in -mm which might be from anil.s.keshavamurthy@xxxxxxxxx are notify-page-fault-call-chain-for-x86_64.patch notify-page-fault-call-chain-for-i386.patch notify-page-fault-call-chain-for-ia64.patch notify-page-fault-call-chain-for-powerpc.patch notify-page-fault-call-chain-for-sparc64.patch kprobes-registers-for-notify-page-fault.patch notify-page-fault-call-chain.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html