forked from Minki/linux
ARM: kprobes: Migrate ARM space_1111 to decoding tables
Signed-off-by: Jon Medhurst <tixy@yxit.co.uk> Acked-by: Nicolas Pitre <nicolas.pitre@linaro.org>
This commit is contained in:
parent
bb1085f827
commit
9a5c1284a3
@ -896,41 +896,35 @@ prep_emulate_rdhi16rdlo12rs8rm0_wflags(kprobe_opcode_t insn,
|
||||
* number of tests needed.
|
||||
*/
|
||||
|
||||
static enum kprobe_insn __kprobes
|
||||
space_1111(kprobe_opcode_t insn, struct arch_specific_insn *asi)
|
||||
{
|
||||
/* memory hint : 1111 0100 x001 xxxx xxxx xxxx xxxx xxxx : */
|
||||
/* PLDI : 1111 0100 x101 xxxx xxxx xxxx xxxx xxxx : */
|
||||
/* PLDW : 1111 0101 x001 xxxx xxxx xxxx xxxx xxxx : */
|
||||
/* PLD : 1111 0101 x101 xxxx xxxx xxxx xxxx xxxx : */
|
||||
if ((insn & 0xfe300000) == 0xf4100000) {
|
||||
asi->insn_handler = emulate_nop;
|
||||
return INSN_GOOD_NO_SLOT;
|
||||
}
|
||||
static const union decode_item arm_1111_table[] = {
|
||||
/* Unconditional instructions */
|
||||
|
||||
/* BLX(1) : 1111 101x xxxx xxxx xxxx xxxx xxxx xxxx : */
|
||||
if ((insn & 0xfe000000) == 0xfa000000) {
|
||||
asi->insn_handler = simulate_blx1;
|
||||
return INSN_GOOD_NO_SLOT;
|
||||
}
|
||||
/* memory hint 1111 0100 x001 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* PLDI (immediate) 1111 0100 x101 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* PLDW (immediate) 1111 0101 x001 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* PLD (immediate) 1111 0101 x101 xxxx xxxx xxxx xxxx xxxx */
|
||||
DECODE_SIMULATE (0xfe300000, 0xf4100000, kprobe_simulate_nop),
|
||||
|
||||
/* CPS : 1111 0001 0000 xxx0 xxxx xxxx xx0x xxxx */
|
||||
/* SETEND: 1111 0001 0000 0001 xxxx xxxx 0000 xxxx */
|
||||
/* BLX (immediate) 1111 101x xxxx xxxx xxxx xxxx xxxx xxxx */
|
||||
DECODE_SIMULATE (0xfe000000, 0xfa000000, simulate_blx1),
|
||||
|
||||
/* SRS : 1111 100x x1x0 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* RFE : 1111 100x x0x1 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* CPS 1111 0001 0000 xxx0 xxxx xxxx xx0x xxxx */
|
||||
/* SETEND 1111 0001 0000 0001 xxxx xxxx 0000 xxxx */
|
||||
/* SRS 1111 100x x1x0 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* RFE 1111 100x x0x1 xxxx xxxx xxxx xxxx xxxx */
|
||||
|
||||
/* Coprocessor instructions... */
|
||||
/* MCRR2 : 1111 1100 0100 xxxx xxxx xxxx xxxx xxxx : (Rd != Rn) */
|
||||
/* MRRC2 : 1111 1100 0101 xxxx xxxx xxxx xxxx xxxx : (Rd != Rn) */
|
||||
/* LDC2 : 1111 110x xxx1 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* STC2 : 1111 110x xxx0 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* CDP2 : 1111 1110 xxxx xxxx xxxx xxxx xxx0 xxxx */
|
||||
/* MCR2 : 1111 1110 xxx0 xxxx xxxx xxxx xxx1 xxxx */
|
||||
/* MRC2 : 1111 1110 xxx1 xxxx xxxx xxxx xxx1 xxxx */
|
||||
/* MCRR2 1111 1100 0100 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* MRRC2 1111 1100 0101 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* LDC2 1111 110x xxx1 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* STC2 1111 110x xxx0 xxxx xxxx xxxx xxxx xxxx */
|
||||
/* CDP2 1111 1110 xxxx xxxx xxxx xxxx xxx0 xxxx */
|
||||
/* MCR2 1111 1110 xxx0 xxxx xxxx xxxx xxx1 xxxx */
|
||||
/* MRC2 1111 1110 xxx1 xxxx xxxx xxxx xxx1 xxxx */
|
||||
|
||||
return INSN_REJECTED;
|
||||
}
|
||||
/* Other unallocated instructions... */
|
||||
DECODE_END
|
||||
};
|
||||
|
||||
static enum kprobe_insn __kprobes
|
||||
space_cccc_000x(kprobe_opcode_t insn, struct arch_specific_insn *asi)
|
||||
@ -1477,7 +1471,7 @@ arm_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi)
|
||||
|
||||
if ((insn & 0xf0000000) == 0xf0000000)
|
||||
|
||||
return space_1111(insn, asi);
|
||||
return kprobe_decode_insn(insn, asi, arm_1111_table, false);
|
||||
|
||||
else if ((insn & 0x0e000000) == 0x00000000)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user