summaryrefslogtreecommitdiff
path: root/arch/powerpc/lib
diff options
context:
space:
mode:
authorOliver O'Halloran <oohall@gmail.com>2016-02-16 17:31:53 +1100
committerMichael Ellerman <mpe@ellerman.id.au>2016-05-11 21:54:08 +1000
commit66707836062db62756b395d1fb16ab02ff162862 (patch)
tree6bc7ce574c571f2542e9b47fc8a4a2df388f8fd2 /arch/powerpc/lib
parentdd21731022faf43c1250050e5d28d11add599149 (diff)
downloadlwn-66707836062db62756b395d1fb16ab02ff162862.tar.gz
lwn-66707836062db62756b395d1fb16ab02ff162862.zip
powerpc/sstep: Fix emulation fall-through
There is a switch fallthough in instr_analyze() which can cause an invalid instruction to be emulated as a different, valid, instruction. The rld* (opcode 30) case extracts a sub-opcode from bits 3:1 of the instruction word. However, the only valid values of this field are 001 and 000. These cases are correctly handled, but the others are not which causes execution to fall through into case 31. Breaking out of the switch causes the instruction to be marked as unknown and allows the caller to deal with the invalid instruction in a manner consistent with other invalid instructions. Signed-off-by: Oliver O'Halloran <oohall@gmail.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Diffstat (limited to 'arch/powerpc/lib')
-rw-r--r--arch/powerpc/lib/sstep.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/powerpc/lib/sstep.c b/arch/powerpc/lib/sstep.c
index 6d34310f1141..3362299b1859 100644
--- a/arch/powerpc/lib/sstep.c
+++ b/arch/powerpc/lib/sstep.c
@@ -925,6 +925,7 @@ int __kprobes analyse_instr(struct instruction_op *op, struct pt_regs *regs,
}
}
#endif
+ break; /* illegal instruction */
case 31:
switch ((instr >> 1) & 0x3ff) {