diff options
author | Russell King <rmk@dyn-67.arm.linux.org.uk> | 2007-02-18 11:31:14 +0000 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2007-02-18 11:31:14 +0000 |
commit | 3b0eb4a195a124567cd0dd6f700f8388def542c6 (patch) | |
tree | a5302057b2d2bdfb2072cb2ff0df9e1c0990345c /arch/arm/kernel | |
parent | 8213084125eed3c5efbc5e13739b93dfedb88590 (diff) | |
parent | 588ef7693574cfbcb228f48d5478c2b39a9b0c9f (diff) | |
download | op-kernel-dev-3b0eb4a195a124567cd0dd6f700f8388def542c6.zip op-kernel-dev-3b0eb4a195a124567cd0dd6f700f8388def542c6.tar.gz |
Merge the easy part of the IOP branch
Diffstat (limited to 'arch/arm/kernel')
-rw-r--r-- | arch/arm/kernel/traps.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/arch/arm/kernel/traps.c b/arch/arm/kernel/traps.c index 329609b..2409560 100644 --- a/arch/arm/kernel/traps.c +++ b/arch/arm/kernel/traps.c @@ -282,7 +282,10 @@ asmlinkage void do_undefinstr(struct pt_regs *regs) regs->ARM_pc -= correction; pc = (void __user *)instruction_pointer(regs); - if (thumb_mode(regs)) { + + if (processor_mode(regs) == SVC_MODE) { + instr = *(u32 *) pc; + } else if (thumb_mode(regs)) { get_user(instr, (u16 __user *)pc); } else { get_user(instr, (u32 __user *)pc); |