Commit 2ce5d033 authored by Jon Medhurst's avatar Jon Medhurst Committed by Tixy

ARM: kprobes: Migrate ARM space_cccc_0110__1 to decoding tables

Signed-off-by: default avatarJon Medhurst <tixy@yxit.co.uk>
Acked-by: default avatarNicolas Pitre <nicolas.pitre@linaro.org>
parent 0e44e9a0
...@@ -1281,132 +1281,97 @@ static const union decode_item arm_cccc_001x_table[] = { ...@@ -1281,132 +1281,97 @@ static const union decode_item arm_cccc_001x_table[] = {
DECODE_END DECODE_END
}; };
static enum kprobe_insn __kprobes static const union decode_item arm_cccc_0110_____xxx1_table[] = {
space_cccc_0110__1(kprobe_opcode_t insn, struct arch_specific_insn *asi) /* Media instructions */
{
/* SEL : cccc 0110 1000 xxxx xxxx xxxx 1011 xxxx GE: !!! */ /* SEL cccc 0110 1000 xxxx xxxx xxxx 1011 xxxx */
if ((insn & 0x0ff000f0) == 0x068000b0) { DECODE_EMULATEX (0x0ff000f0, 0x068000b0, emulate_rd12rn16rm0_rwflags_nopc,
if (is_r15(insn, 12)) REGS(NOPC, NOPC, 0, 0, NOPC)),
return INSN_REJECTED; /* Rd is PC */
insn &= 0xfff00ff0; /* Rd = r0, Rn = r0 */ /* SSAT cccc 0110 101x xxxx xxxx xxxx xx01 xxxx */
insn |= 0x00000001; /* Rm = r1 */ /* USAT cccc 0110 111x xxxx xxxx xxxx xx01 xxxx */
asi->insn[0] = insn; DECODE_OR(0x0fa00030, 0x06a00010),
asi->insn_handler = emulate_sel; /* SSAT16 cccc 0110 1010 xxxx xxxx xxxx 0011 xxxx */
return INSN_GOOD; /* USAT16 cccc 0110 1110 xxxx xxxx xxxx 0011 xxxx */
} DECODE_EMULATEX (0x0fb000f0, 0x06a00030, emulate_rd12rn16rm0_rwflags_nopc,
REGS(0, NOPC, 0, 0, NOPC)),
/* SSAT : cccc 0110 101x xxxx xxxx xxxx xx01 xxxx :Q */
/* USAT : cccc 0110 111x xxxx xxxx xxxx xx01 xxxx :Q */ /* REV cccc 0110 1011 xxxx xxxx xxxx 0011 xxxx */
/* SSAT16 : cccc 0110 1010 xxxx xxxx xxxx 0011 xxxx :Q */ /* REV16 cccc 0110 1011 xxxx xxxx xxxx 1011 xxxx */
/* USAT16 : cccc 0110 1110 xxxx xxxx xxxx 0011 xxxx :Q */ /* RBIT cccc 0110 1111 xxxx xxxx xxxx 0011 xxxx */
if ((insn & 0x0fa00030) == 0x06a00010 || /* REVSH cccc 0110 1111 xxxx xxxx xxxx 1011 xxxx */
(insn & 0x0fb000f0) == 0x06a00030) { DECODE_CUSTOM (0x0fb00070, 0x06b00030, prep_emulate_rd12rm0),
if (is_r15(insn, 12))
return INSN_REJECTED; /* Rd is PC */ /* ??? cccc 0110 0x00 xxxx xxxx xxxx xxx1 xxxx */
insn &= 0xffff0ff0; /* Rd = r0, Rm = r0 */ DECODE_REJECT (0x0fb00010, 0x06000010),
asi->insn[0] = insn; /* ??? cccc 0110 0xxx xxxx xxxx xxxx 1011 xxxx */
asi->insn_handler = emulate_sat; DECODE_REJECT (0x0f8000f0, 0x060000b0),
return INSN_GOOD; /* ??? cccc 0110 0xxx xxxx xxxx xxxx 1101 xxxx */
} DECODE_REJECT (0x0f8000f0, 0x060000d0),
/* SADD16 cccc 0110 0001 xxxx xxxx xxxx 0001 xxxx */
/* REV : cccc 0110 1011 xxxx xxxx xxxx 0011 xxxx */ /* SADDSUBX cccc 0110 0001 xxxx xxxx xxxx 0011 xxxx */
/* REV16 : cccc 0110 1011 xxxx xxxx xxxx 1011 xxxx */ /* SSUBADDX cccc 0110 0001 xxxx xxxx xxxx 0101 xxxx */
/* RBIT : cccc 0110 1111 xxxx xxxx xxxx 0011 xxxx */ /* SSUB16 cccc 0110 0001 xxxx xxxx xxxx 0111 xxxx */
/* REVSH : cccc 0110 1111 xxxx xxxx xxxx 1011 xxxx */ /* SADD8 cccc 0110 0001 xxxx xxxx xxxx 1001 xxxx */
if ((insn & 0x0ff00070) == 0x06b00030 || /* SSUB8 cccc 0110 0001 xxxx xxxx xxxx 1111 xxxx */
(insn & 0x0ff00070) == 0x06f00030) /* QADD16 cccc 0110 0010 xxxx xxxx xxxx 0001 xxxx */
return prep_emulate_rd12rm0(insn, asi); /* QADDSUBX cccc 0110 0010 xxxx xxxx xxxx 0011 xxxx */
/* QSUBADDX cccc 0110 0010 xxxx xxxx xxxx 0101 xxxx */
/* ??? : cccc 0110 0000 xxxx xxxx xxxx xxx1 xxxx : */ /* QSUB16 cccc 0110 0010 xxxx xxxx xxxx 0111 xxxx */
/* SADD16 : cccc 0110 0001 xxxx xxxx xxxx 0001 xxxx :GE */ /* QADD8 cccc 0110 0010 xxxx xxxx xxxx 1001 xxxx */
/* SADDSUBX : cccc 0110 0001 xxxx xxxx xxxx 0011 xxxx :GE */ /* QSUB8 cccc 0110 0010 xxxx xxxx xxxx 1111 xxxx */
/* SSUBADDX : cccc 0110 0001 xxxx xxxx xxxx 0101 xxxx :GE */ /* SHADD16 cccc 0110 0011 xxxx xxxx xxxx 0001 xxxx */
/* SSUB16 : cccc 0110 0001 xxxx xxxx xxxx 0111 xxxx :GE */ /* SHADDSUBX cccc 0110 0011 xxxx xxxx xxxx 0011 xxxx */
/* SADD8 : cccc 0110 0001 xxxx xxxx xxxx 1001 xxxx :GE */ /* SHSUBADDX cccc 0110 0011 xxxx xxxx xxxx 0101 xxxx */
/* ??? : cccc 0110 0001 xxxx xxxx xxxx 1011 xxxx : */ /* SHSUB16 cccc 0110 0011 xxxx xxxx xxxx 0111 xxxx */
/* ??? : cccc 0110 0001 xxxx xxxx xxxx 1101 xxxx : */ /* SHADD8 cccc 0110 0011 xxxx xxxx xxxx 1001 xxxx */
/* SSUB8 : cccc 0110 0001 xxxx xxxx xxxx 1111 xxxx :GE */ /* SHSUB8 cccc 0110 0011 xxxx xxxx xxxx 1111 xxxx */
/* QADD16 : cccc 0110 0010 xxxx xxxx xxxx 0001 xxxx : */ /* UADD16 cccc 0110 0101 xxxx xxxx xxxx 0001 xxxx */
/* QADDSUBX : cccc 0110 0010 xxxx xxxx xxxx 0011 xxxx : */ /* UADDSUBX cccc 0110 0101 xxxx xxxx xxxx 0011 xxxx */
/* QSUBADDX : cccc 0110 0010 xxxx xxxx xxxx 0101 xxxx : */ /* USUBADDX cccc 0110 0101 xxxx xxxx xxxx 0101 xxxx */
/* QSUB16 : cccc 0110 0010 xxxx xxxx xxxx 0111 xxxx : */ /* USUB16 cccc 0110 0101 xxxx xxxx xxxx 0111 xxxx */
/* QADD8 : cccc 0110 0010 xxxx xxxx xxxx 1001 xxxx : */ /* UADD8 cccc 0110 0101 xxxx xxxx xxxx 1001 xxxx */
/* ??? : cccc 0110 0010 xxxx xxxx xxxx 1011 xxxx : */ /* USUB8 cccc 0110 0101 xxxx xxxx xxxx 1111 xxxx */
/* ??? : cccc 0110 0010 xxxx xxxx xxxx 1101 xxxx : */ /* UQADD16 cccc 0110 0110 xxxx xxxx xxxx 0001 xxxx */
/* QSUB8 : cccc 0110 0010 xxxx xxxx xxxx 1111 xxxx : */ /* UQADDSUBX cccc 0110 0110 xxxx xxxx xxxx 0011 xxxx */
/* SHADD16 : cccc 0110 0011 xxxx xxxx xxxx 0001 xxxx : */ /* UQSUBADDX cccc 0110 0110 xxxx xxxx xxxx 0101 xxxx */
/* SHADDSUBX : cccc 0110 0011 xxxx xxxx xxxx 0011 xxxx : */ /* UQSUB16 cccc 0110 0110 xxxx xxxx xxxx 0111 xxxx */
/* SHSUBADDX : cccc 0110 0011 xxxx xxxx xxxx 0101 xxxx : */ /* UQADD8 cccc 0110 0110 xxxx xxxx xxxx 1001 xxxx */
/* SHSUB16 : cccc 0110 0011 xxxx xxxx xxxx 0111 xxxx : */ /* UQSUB8 cccc 0110 0110 xxxx xxxx xxxx 1111 xxxx */
/* SHADD8 : cccc 0110 0011 xxxx xxxx xxxx 1001 xxxx : */ /* UHADD16 cccc 0110 0111 xxxx xxxx xxxx 0001 xxxx */
/* ??? : cccc 0110 0011 xxxx xxxx xxxx 1011 xxxx : */ /* UHADDSUBX cccc 0110 0111 xxxx xxxx xxxx 0011 xxxx */
/* ??? : cccc 0110 0011 xxxx xxxx xxxx 1101 xxxx : */ /* UHSUBADDX cccc 0110 0111 xxxx xxxx xxxx 0101 xxxx */
/* SHSUB8 : cccc 0110 0011 xxxx xxxx xxxx 1111 xxxx : */ /* UHSUB16 cccc 0110 0111 xxxx xxxx xxxx 0111 xxxx */
/* ??? : cccc 0110 0100 xxxx xxxx xxxx xxx1 xxxx : */ /* UHADD8 cccc 0110 0111 xxxx xxxx xxxx 1001 xxxx */
/* UADD16 : cccc 0110 0101 xxxx xxxx xxxx 0001 xxxx :GE */ /* UHSUB8 cccc 0110 0111 xxxx xxxx xxxx 1111 xxxx */
/* UADDSUBX : cccc 0110 0101 xxxx xxxx xxxx 0011 xxxx :GE */ DECODE_CUSTOM (0x0f800010, 0x06000010, prep_emulate_rd12rn16rm0_wflags),
/* USUBADDX : cccc 0110 0101 xxxx xxxx xxxx 0101 xxxx :GE */
/* USUB16 : cccc 0110 0101 xxxx xxxx xxxx 0111 xxxx :GE */ /* PKHBT cccc 0110 1000 xxxx xxxx xxxx x001 xxxx */
/* UADD8 : cccc 0110 0101 xxxx xxxx xxxx 1001 xxxx :GE */ /* PKHTB cccc 0110 1000 xxxx xxxx xxxx x101 xxxx */
/* ??? : cccc 0110 0101 xxxx xxxx xxxx 1011 xxxx : */ DECODE_CUSTOM (0x0ff00030, 0x06800010, prep_emulate_rd12rn16rm0_wflags),
/* ??? : cccc 0110 0101 xxxx xxxx xxxx 1101 xxxx : */
/* USUB8 : cccc 0110 0101 xxxx xxxx xxxx 1111 xxxx :GE */ /* ??? cccc 0110 1001 xxxx xxxx xxxx 0111 xxxx */
/* UQADD16 : cccc 0110 0110 xxxx xxxx xxxx 0001 xxxx : */ /* ??? cccc 0110 1101 xxxx xxxx xxxx 0111 xxxx */
/* UQADDSUBX : cccc 0110 0110 xxxx xxxx xxxx 0011 xxxx : */ DECODE_REJECT (0x0fb000f0, 0x06900070),
/* UQSUBADDX : cccc 0110 0110 xxxx xxxx xxxx 0101 xxxx : */
/* UQSUB16 : cccc 0110 0110 xxxx xxxx xxxx 0111 xxxx : */ /* SXTB16 cccc 0110 1000 1111 xxxx xxxx 0111 xxxx */
/* UQADD8 : cccc 0110 0110 xxxx xxxx xxxx 1001 xxxx : */ /* SXTB cccc 0110 1010 1111 xxxx xxxx 0111 xxxx */
/* ??? : cccc 0110 0110 xxxx xxxx xxxx 1011 xxxx : */ /* SXTH cccc 0110 1011 1111 xxxx xxxx 0111 xxxx */
/* ??? : cccc 0110 0110 xxxx xxxx xxxx 1101 xxxx : */ /* UXTB16 cccc 0110 1100 1111 xxxx xxxx 0111 xxxx */
/* UQSUB8 : cccc 0110 0110 xxxx xxxx xxxx 1111 xxxx : */ /* UXTB cccc 0110 1110 1111 xxxx xxxx 0111 xxxx */
/* UHADD16 : cccc 0110 0111 xxxx xxxx xxxx 0001 xxxx : */ /* UXTH cccc 0110 1111 1111 xxxx xxxx 0111 xxxx */
/* UHADDSUBX : cccc 0110 0111 xxxx xxxx xxxx 0011 xxxx : */ DECODE_CUSTOM (0x0f8f00f0, 0x068f0070, prep_emulate_rd12rm0),
/* UHSUBADDX : cccc 0110 0111 xxxx xxxx xxxx 0101 xxxx : */
/* UHSUB16 : cccc 0110 0111 xxxx xxxx xxxx 0111 xxxx : */ /* SXTAB16 cccc 0110 1000 xxxx xxxx xxxx 0111 xxxx */
/* UHADD8 : cccc 0110 0111 xxxx xxxx xxxx 1001 xxxx : */ /* SXTAB cccc 0110 1010 xxxx xxxx xxxx 0111 xxxx */
/* ??? : cccc 0110 0111 xxxx xxxx xxxx 1011 xxxx : */ /* SXTAH cccc 0110 1011 xxxx xxxx xxxx 0111 xxxx */
/* ??? : cccc 0110 0111 xxxx xxxx xxxx 1101 xxxx : */ /* UXTAB16 cccc 0110 1100 xxxx xxxx xxxx 0111 xxxx */
/* UHSUB8 : cccc 0110 0111 xxxx xxxx xxxx 1111 xxxx : */ /* UXTAB cccc 0110 1110 xxxx xxxx xxxx 0111 xxxx */
if ((insn & 0x0f800010) == 0x06000010) { /* UXTAH cccc 0110 1111 xxxx xxxx xxxx 0111 xxxx */
if ((insn & 0x00300000) == 0x00000000 || DECODE_CUSTOM (0x0f8000f0, 0x06800070, prep_emulate_rd12rn16rm0_wflags),
(insn & 0x000000e0) == 0x000000a0 ||
(insn & 0x000000e0) == 0x000000c0)
return INSN_REJECTED; /* Unallocated space */
return prep_emulate_rd12rn16rm0_wflags(insn, asi);
}
/* PKHBT : cccc 0110 1000 xxxx xxxx xxxx x001 xxxx : */
/* PKHTB : cccc 0110 1000 xxxx xxxx xxxx x101 xxxx : */
if ((insn & 0x0ff00030) == 0x06800010)
return prep_emulate_rd12rn16rm0_wflags(insn, asi);
/* SXTAB16 : cccc 0110 1000 xxxx xxxx xxxx 0111 xxxx : */
/* SXTB16 : cccc 0110 1000 1111 xxxx xxxx 0111 xxxx : */
/* ??? : cccc 0110 1001 xxxx xxxx xxxx 0111 xxxx : */
/* SXTAB : cccc 0110 1010 xxxx xxxx xxxx 0111 xxxx : */
/* SXTB : cccc 0110 1010 1111 xxxx xxxx 0111 xxxx : */
/* SXTAH : cccc 0110 1011 xxxx xxxx xxxx 0111 xxxx : */
/* SXTH : cccc 0110 1011 1111 xxxx xxxx 0111 xxxx : */
/* UXTAB16 : cccc 0110 1100 xxxx xxxx xxxx 0111 xxxx : */
/* UXTB16 : cccc 0110 1100 1111 xxxx xxxx 0111 xxxx : */
/* ??? : cccc 0110 1101 xxxx xxxx xxxx 0111 xxxx : */
/* UXTAB : cccc 0110 1110 xxxx xxxx xxxx 0111 xxxx : */
/* UXTB : cccc 0110 1110 1111 xxxx xxxx 0111 xxxx : */
/* UXTAH : cccc 0110 1111 xxxx xxxx xxxx 0111 xxxx : */
/* UXTH : cccc 0110 1111 1111 xxxx xxxx 0111 xxxx : */
if ((insn & 0x0f8000f0) == 0x06800070) {
if ((insn & 0x00300000) == 0x00100000)
return INSN_REJECTED; /* Unallocated space */
if ((insn & 0x000f0000) == 0x000f0000)
return prep_emulate_rd12rm0(insn, asi);
else
return prep_emulate_rd12rn16rm0_wflags(insn, asi);
}
/* Other instruction encodings aren't yet defined */ DECODE_END
return INSN_REJECTED; };
}
static enum kprobe_insn __kprobes static enum kprobe_insn __kprobes
space_cccc_0111__1(kprobe_opcode_t insn, struct arch_specific_insn *asi) space_cccc_0111__1(kprobe_opcode_t insn, struct arch_specific_insn *asi)
...@@ -1563,7 +1528,7 @@ arm_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi) ...@@ -1563,7 +1528,7 @@ arm_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi)
else if ((insn & 0x0f000010) == 0x06000010) else if ((insn & 0x0f000010) == 0x06000010)
return space_cccc_0110__1(insn, asi); return kprobe_decode_insn(insn, asi, arm_cccc_0110_____xxx1_table, false);
else if ((insn & 0x0f000010) == 0x07000010) else if ((insn & 0x0f000010) == 0x07000010)
......
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