diff options
author | Graf Yang <graf.yang@analog.com> | 2009-07-20 22:26:57 -0400 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2009-09-16 21:31:55 -0400 |
commit | 36b841288656b9b30b5d2add2fd136ac7eab5867 (patch) | |
tree | b3faec0b85a2814216c791de99435e74a43b6148 /arch/blackfin/kernel/traps.c | |
parent | 8fc4dd9e876cbda4dfe09ca85e4e1520b36dce77 (diff) |
Blackfin: fix MPU handling of invalid memory accesses
The protect_page() function was incorrectly setting up the hardware tables
based on possible access capabilities rather than the actual requested
values. This means we would grant more access to mmap-ed pages than we
should have. Once we fix this, we need to tweak the signal generated by
such accesses to aline ourselves with other ports. This allows the LTP
mmap0{5,6,7} cases to run properly.
Signed-off-by: Graf Yang <graf.yang@analog.com>
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Diffstat (limited to 'arch/blackfin/kernel/traps.c')
-rw-r--r-- | arch/blackfin/kernel/traps.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/blackfin/kernel/traps.c b/arch/blackfin/kernel/traps.c index 18c6cd4150f8..644e35e33553 100644 --- a/arch/blackfin/kernel/traps.c +++ b/arch/blackfin/kernel/traps.c | |||
@@ -411,7 +411,7 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
411 | /* 0x23 - Data CPLB protection violation, handled here */ | 411 | /* 0x23 - Data CPLB protection violation, handled here */ |
412 | case VEC_CPLB_VL: | 412 | case VEC_CPLB_VL: |
413 | info.si_code = ILL_CPLB_VI; | 413 | info.si_code = ILL_CPLB_VI; |
414 | sig = SIGBUS; | 414 | sig = SIGSEGV; |
415 | strerror = KERN_NOTICE EXC_0x23(KERN_NOTICE); | 415 | strerror = KERN_NOTICE EXC_0x23(KERN_NOTICE); |
416 | CHK_DEBUGGER_TRAP_MAYBE(); | 416 | CHK_DEBUGGER_TRAP_MAYBE(); |
417 | break; | 417 | break; |