ARM: kprobes: Fix emulation of PLD instructions

The PLD instructions wasn't being decoded correctly and the emulation
code wasn't adjusting PC correctly.

As the PLD instruction is only a performance hint we emulate it as a
simple nop, and we can broaden the instruction decoding to take into
account newer PLI and PLDW instructions.

Signed-off-by: Jon Medhurst <tixy@yxit.co.uk>
Signed-off-by: Nicolas Pitre <nicolas.pitre@linaro.org>
This commit is contained in:
Jon Medhurst 2011-04-18 08:53:57 +01:00 committed by Nicolas Pitre
parent f0aeb8bff0
commit 41713d1396
1 changed files with 8 additions and 13 deletions

View File

@ -657,14 +657,8 @@ static void __kprobes emulate_none(struct kprobe *p, struct pt_regs *regs)
insnslot_0arg_rflags(regs->ARM_cpsr, i_fn); insnslot_0arg_rflags(regs->ARM_cpsr, i_fn);
} }
static void __kprobes emulate_rn16(struct kprobe *p, struct pt_regs *regs) static void __kprobes emulate_nop(struct kprobe *p, struct pt_regs *regs)
{ {
insn_1arg_fn_t *i_fn = (insn_1arg_fn_t *)&p->ainsn.insn[0];
kprobe_opcode_t insn = p->opcode;
int rn = (insn >> 16) & 0xf;
long rnv = regs->uregs[rn];
insnslot_1arg_rflags(rnv, regs->ARM_cpsr, i_fn);
} }
static void __kprobes emulate_rd12rm0(struct kprobe *p, struct pt_regs *regs) static void __kprobes emulate_rd12rm0(struct kprobe *p, struct pt_regs *regs)
@ -941,12 +935,13 @@ space_1111(kprobe_opcode_t insn, struct arch_specific_insn *asi)
(insn & 0xfe5f0f00) == 0xf84d0500) (insn & 0xfe5f0f00) == 0xf84d0500)
return INSN_REJECTED; return INSN_REJECTED;
/* PLD : 1111 01x1 x101 xxxx xxxx xxxx xxxx xxxx : */ /* memory hint : 1111 0100 x001 xxxx xxxx xxxx xxxx xxxx : */
if ((insn & 0xfd700000) == 0xf4500000) { /* PLDI : 1111 0100 x101 xxxx xxxx xxxx xxxx xxxx : */
insn &= 0xfff0ffff; /* Rn = r0 */ /* PLDW : 1111 0101 x001 xxxx xxxx xxxx xxxx xxxx : */
asi->insn[0] = insn; /* PLD : 1111 0101 x101 xxxx xxxx xxxx xxxx xxxx : */
asi->insn_handler = emulate_rn16; if ((insn & 0xfe300000) == 0xf4100000) {
return INSN_GOOD; asi->insn_handler = emulate_nop;
return INSN_GOOD_NO_SLOT;
} }
/* BLX(1) : 1111 101x xxxx xxxx xxxx xxxx xxxx xxxx : */ /* BLX(1) : 1111 101x xxxx xxxx xxxx xxxx xxxx xxxx : */