Commit 0d32e7d1 authored by Jon Medhurst's avatar Jon Medhurst Committed by Tixy

ARM: kprobes: Migrate ARM space_cccc_100x to decoding tables

Signed-off-by: default avatarJon Medhurst <tixy@yxit.co.uk>
Acked-by: default avatarNicolas Pitre <nicolas.pitre@linaro.org>
parent 56d8fbdd
...@@ -1434,25 +1434,18 @@ static const union decode_item arm_cccc_01xx_table[] = { ...@@ -1434,25 +1434,18 @@ static const union decode_item arm_cccc_01xx_table[] = {
DECODE_END DECODE_END
}; };
static enum kprobe_insn __kprobes static const union decode_item arm_cccc_100x_table[] = {
space_cccc_100x(kprobe_opcode_t insn, struct arch_specific_insn *asi) /* Block data transfer instructions */
{
/* LDM(2) : cccc 100x x101 xxxx 0xxx xxxx xxxx xxxx */
/* LDM(3) : cccc 100x x1x1 xxxx 1xxx xxxx xxxx xxxx */
if ((insn & 0x0e708000) == 0x85000000 ||
(insn & 0x0e508000) == 0x85010000)
return INSN_REJECTED;
/* LDM(1) : cccc 100x x0x1 xxxx xxxx xxxx xxxx xxxx */ /* LDM cccc 100x x0x1 xxxx xxxx xxxx xxxx xxxx */
/* STM(1) : cccc 100x x0x0 xxxx xxxx xxxx xxxx xxxx */ /* STM cccc 100x x0x0 xxxx xxxx xxxx xxxx xxxx */
DECODE_CUSTOM (0x0e400000, 0x08000000, kprobe_decode_ldmstm),
/* /* STM (user registers) cccc 100x x1x0 xxxx xxxx xxxx xxxx xxxx */
* Make the instruction unconditional because the new emulation /* LDM (user registers) cccc 100x x1x1 xxxx 0xxx xxxx xxxx xxxx */
* functions don't bother to setup the PSR context. /* LDM (exception ret) cccc 100x x1x1 xxxx 1xxx xxxx xxxx xxxx */
*/ DECODE_END
insn = (insn | 0xe0000000) & ~0x10000000; };
return kprobe_decode_ldmstm(insn, asi);
}
static enum kprobe_insn __kprobes static enum kprobe_insn __kprobes
space_cccc_101x(kprobe_opcode_t insn, struct arch_specific_insn *asi) space_cccc_101x(kprobe_opcode_t insn, struct arch_specific_insn *asi)
...@@ -1531,7 +1524,7 @@ arm_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi) ...@@ -1531,7 +1524,7 @@ arm_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi)
else if ((insn & 0x0e000000) == 0x08000000) else if ((insn & 0x0e000000) == 0x08000000)
return space_cccc_100x(insn, asi); return kprobe_decode_insn(insn, asi, arm_cccc_100x_table, false);
else if ((insn & 0x0e000000) == 0x0a000000) else if ((insn & 0x0e000000) == 0x0a000000)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment