diff options
author | Kirill A. Shutemov <kirill@shutemov.name> | 2010-07-22 08:16:49 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2010-07-27 05:43:49 -0400 |
commit | 3dc91aff9c3ef54b15cdaf32f61f973489fe69eb (patch) | |
tree | 6ce52b2b5ea6cb1b0317142ecf06b04d52bc1d34 /arch/arm | |
parent | c1ba6ba3dd4c127dd1b14125ac7feed43d974436 (diff) |
ARM: 6252/1: Use SIGBUS for unaligned access instead of SIGILL
POSIX specify to use signal SIGBUS with code BUS_ADRALN for invalid
address alignment.
Signed-off-by: Kirill A. Shutemov <kirill@shutemov.name>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm')
-rw-r--r-- | arch/arm/mm/alignment.c | 4 | ||||
-rw-r--r-- | arch/arm/mm/fault.c | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/arch/arm/mm/alignment.c b/arch/arm/mm/alignment.c index 6f98c358989a..53a609680c10 100644 --- a/arch/arm/mm/alignment.c +++ b/arch/arm/mm/alignment.c | |||
@@ -924,8 +924,8 @@ static int __init alignment_init(void) | |||
924 | ai_usermode = UM_FIXUP; | 924 | ai_usermode = UM_FIXUP; |
925 | } | 925 | } |
926 | 926 | ||
927 | hook_fault_code(1, do_alignment, SIGILL, "alignment exception"); | 927 | hook_fault_code(1, do_alignment, SIGBUS, "alignment exception"); |
928 | hook_fault_code(3, do_alignment, SIGILL, "alignment exception"); | 928 | hook_fault_code(3, do_alignment, SIGBUS, "alignment exception"); |
929 | 929 | ||
930 | return 0; | 930 | return 0; |
931 | } | 931 | } |
diff --git a/arch/arm/mm/fault.c b/arch/arm/mm/fault.c index cbfb2edcf7d1..ce6f3a422c81 100644 --- a/arch/arm/mm/fault.c +++ b/arch/arm/mm/fault.c | |||
@@ -463,9 +463,9 @@ static struct fsr_info { | |||
463 | * defines these to be "precise" aborts. | 463 | * defines these to be "precise" aborts. |
464 | */ | 464 | */ |
465 | { do_bad, SIGSEGV, 0, "vector exception" }, | 465 | { do_bad, SIGSEGV, 0, "vector exception" }, |
466 | { do_bad, SIGILL, BUS_ADRALN, "alignment exception" }, | 466 | { do_bad, SIGBUS, BUS_ADRALN, "alignment exception" }, |
467 | { do_bad, SIGKILL, 0, "terminal exception" }, | 467 | { do_bad, SIGKILL, 0, "terminal exception" }, |
468 | { do_bad, SIGILL, BUS_ADRALN, "alignment exception" }, | 468 | { do_bad, SIGBUS, BUS_ADRALN, "alignment exception" }, |
469 | /* Do we need runtime check ? */ | 469 | /* Do we need runtime check ? */ |
470 | #if __LINUX_ARM_ARCH__ < 6 | 470 | #if __LINUX_ARM_ARCH__ < 6 |
471 | { do_bad, SIGBUS, 0, "external abort on linefetch" }, | 471 | { do_bad, SIGBUS, 0, "external abort on linefetch" }, |