diff options
Diffstat (limited to 'arch/avr32/mm/fault.c')
| -rw-r--r-- | arch/avr32/mm/fault.c | 36 |
1 files changed, 12 insertions, 24 deletions
diff --git a/arch/avr32/mm/fault.c b/arch/avr32/mm/fault.c index 88b00b15970f..e011f1ce1875 100644 --- a/arch/avr32/mm/fault.c +++ b/arch/avr32/mm/fault.c | |||
| @@ -12,41 +12,30 @@ | |||
| 12 | #include <linux/mm.h> | 12 | #include <linux/mm.h> |
| 13 | #include <linux/module.h> | 13 | #include <linux/module.h> |
| 14 | #include <linux/pagemap.h> | 14 | #include <linux/pagemap.h> |
| 15 | |||
| 16 | #include <linux/kdebug.h> | 15 | #include <linux/kdebug.h> |
| 16 | #include <linux/kprobes.h> | ||
| 17 | |||
| 17 | #include <asm/mmu_context.h> | 18 | #include <asm/mmu_context.h> |
| 18 | #include <asm/sysreg.h> | 19 | #include <asm/sysreg.h> |
| 19 | #include <asm/tlb.h> | 20 | #include <asm/tlb.h> |
| 20 | #include <asm/uaccess.h> | 21 | #include <asm/uaccess.h> |
| 21 | 22 | ||
| 22 | #ifdef CONFIG_KPROBES | 23 | #ifdef CONFIG_KPROBES |
| 23 | ATOMIC_NOTIFIER_HEAD(notify_page_fault_chain); | 24 | static inline int notify_page_fault(struct pt_regs *regs, int trap) |
| 24 | |||
| 25 | /* Hook to register for page fault notifications */ | ||
| 26 | int register_page_fault_notifier(struct notifier_block *nb) | ||
| 27 | { | 25 | { |
| 28 | return atomic_notifier_chain_register(¬ify_page_fault_chain, nb); | 26 | int ret = 0; |
| 29 | } | ||
| 30 | 27 | ||
| 31 | int unregister_page_fault_notifier(struct notifier_block *nb) | 28 | if (!user_mode(regs)) { |
| 32 | { | 29 | if (kprobe_running() && kprobe_fault_handler(regs, trap)) |
| 33 | return atomic_notifier_chain_unregister(¬ify_page_fault_chain, nb); | 30 | ret = 1; |
| 34 | } | 31 | } |
| 35 | 32 | ||
| 36 | static inline int notify_page_fault(enum die_val val, struct pt_regs *regs, | 33 | return ret; |
| 37 | int trap, int sig) | ||
| 38 | { | ||
| 39 | struct die_args args = { | ||
| 40 | .regs = regs, | ||
| 41 | .trapnr = trap, | ||
| 42 | }; | ||
| 43 | return atomic_notifier_call_chain(¬ify_page_fault_chain, val, &args); | ||
| 44 | } | 34 | } |
| 45 | #else | 35 | #else |
| 46 | static inline int notify_page_fault(enum die_val val, struct pt_regs *regs, | 36 | static inline int notify_page_fault(struct pt_regs *regs, int trap) |
| 47 | int trap, int sig) | ||
| 48 | { | 37 | { |
| 49 | return NOTIFY_DONE; | 38 | return 0; |
| 50 | } | 39 | } |
| 51 | #endif | 40 | #endif |
| 52 | 41 | ||
| @@ -76,8 +65,7 @@ asmlinkage void do_page_fault(unsigned long ecr, struct pt_regs *regs) | |||
| 76 | long signr; | 65 | long signr; |
| 77 | int code; | 66 | int code; |
| 78 | 67 | ||
| 79 | if (notify_page_fault(DIE_PAGE_FAULT, regs, | 68 | if (notify_page_fault(regs, ecr)) |
| 80 | ecr, SIGSEGV) == NOTIFY_STOP) | ||
| 81 | return; | 69 | return; |
| 82 | 70 | ||
| 83 | address = sysreg_read(TLBEAR); | 71 | address = sysreg_read(TLBEAR); |
