|
@@ -16,9 +16,6 @@
|
|
#include "kprobes.h"
|
|
#include "kprobes.h"
|
|
#include "probes-thumb.h"
|
|
#include "probes-thumb.h"
|
|
|
|
|
|
-/* These emulation encodings are functionally equivalent... */
|
|
|
|
-#define t32_emulate_rd8rn16rm0ra12_noflags \
|
|
|
|
- t32_emulate_rdlo12rdhi8rn16rm0_noflags
|
|
|
|
|
|
|
|
static const union decode_item t32_table_1110_100x_x0xx[] = {
|
|
static const union decode_item t32_table_1110_100x_x0xx[] = {
|
|
/* Load/store multiple instructions */
|
|
/* Load/store multiple instructions */
|
|
@@ -44,7 +41,7 @@ static const union decode_item t32_table_1110_100x_x0xx[] = {
|
|
/* LDMIA 1110 1000 10x1 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDMIA 1110 1000 10x1 xxxx xxxx xxxx xxxx xxxx */
|
|
/* STMDB 1110 1001 00x0 xxxx xxxx xxxx xxxx xxxx */
|
|
/* STMDB 1110 1001 00x0 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDMDB 1110 1001 00x1 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDMDB 1110 1001 00x1 xxxx xxxx xxxx xxxx xxxx */
|
|
- DECODE_CUSTOM (0xfe400000, 0xe8000000, t32_decode_ldmstm),
|
|
|
|
|
|
+ DECODE_CUSTOM (0xfe400000, 0xe8000000, PROBES_T32_LDMSTM),
|
|
|
|
|
|
DECODE_END
|
|
DECODE_END
|
|
};
|
|
};
|
|
@@ -57,12 +54,12 @@ static const union decode_item t32_table_1110_100x_x1xx[] = {
|
|
DECODE_OR (0xff600000, 0xe8600000),
|
|
DECODE_OR (0xff600000, 0xe8600000),
|
|
/* STRD (immediate) 1110 1001 x1x0 xxxx xxxx xxxx xxxx xxxx */
|
|
/* STRD (immediate) 1110 1001 x1x0 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDRD (immediate) 1110 1001 x1x1 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDRD (immediate) 1110 1001 x1x1 xxxx xxxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xff400000, 0xe9400000, t32_emulate_ldrdstrd,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff400000, 0xe9400000, PROBES_T32_LDRDSTRD,
|
|
REGS(NOPCWB, NOSPPC, NOSPPC, 0, 0)),
|
|
REGS(NOPCWB, NOSPPC, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* TBB 1110 1000 1101 xxxx xxxx xxxx 0000 xxxx */
|
|
/* TBB 1110 1000 1101 xxxx xxxx xxxx 0000 xxxx */
|
|
/* TBH 1110 1000 1101 xxxx xxxx xxxx 0001 xxxx */
|
|
/* TBH 1110 1000 1101 xxxx xxxx xxxx 0001 xxxx */
|
|
- DECODE_SIMULATEX(0xfff000e0, 0xe8d00000, t32_simulate_table_branch,
|
|
|
|
|
|
+ DECODE_SIMULATEX(0xfff000e0, 0xe8d00000, PROBES_T32_TABLE_BRANCH,
|
|
REGS(NOSP, 0, 0, 0, NOSPPC)),
|
|
REGS(NOSP, 0, 0, 0, NOSPPC)),
|
|
|
|
|
|
/* STREX 1110 1000 0100 xxxx xxxx xxxx xxxx xxxx */
|
|
/* STREX 1110 1000 0100 xxxx xxxx xxxx xxxx xxxx */
|
|
@@ -82,18 +79,18 @@ static const union decode_item t32_table_1110_101x[] = {
|
|
|
|
|
|
/* TST 1110 1010 0001 xxxx xxxx 1111 xxxx xxxx */
|
|
/* TST 1110 1010 0001 xxxx xxxx 1111 xxxx xxxx */
|
|
/* TEQ 1110 1010 1001 xxxx xxxx 1111 xxxx xxxx */
|
|
/* TEQ 1110 1010 1001 xxxx xxxx 1111 xxxx xxxx */
|
|
- DECODE_EMULATEX (0xff700f00, 0xea100f00, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff700f00, 0xea100f00, PROBES_T32_TST,
|
|
REGS(NOSPPC, 0, 0, 0, NOSPPC)),
|
|
REGS(NOSPPC, 0, 0, 0, NOSPPC)),
|
|
|
|
|
|
/* CMN 1110 1011 0001 xxxx xxxx 1111 xxxx xxxx */
|
|
/* CMN 1110 1011 0001 xxxx xxxx 1111 xxxx xxxx */
|
|
DECODE_OR (0xfff00f00, 0xeb100f00),
|
|
DECODE_OR (0xfff00f00, 0xeb100f00),
|
|
/* CMP 1110 1011 1011 xxxx xxxx 1111 xxxx xxxx */
|
|
/* CMP 1110 1011 1011 xxxx xxxx 1111 xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfff00f00, 0xebb00f00, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfff00f00, 0xebb00f00, PROBES_T32_TST,
|
|
REGS(NOPC, 0, 0, 0, NOSPPC)),
|
|
REGS(NOPC, 0, 0, 0, NOSPPC)),
|
|
|
|
|
|
/* MOV 1110 1010 010x 1111 xxxx xxxx xxxx xxxx */
|
|
/* MOV 1110 1010 010x 1111 xxxx xxxx xxxx xxxx */
|
|
/* MVN 1110 1010 011x 1111 xxxx xxxx xxxx xxxx */
|
|
/* MVN 1110 1010 011x 1111 xxxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xffcf0000, 0xea4f0000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xffcf0000, 0xea4f0000, PROBES_T32_MOV,
|
|
REGS(0, 0, NOSPPC, 0, NOSPPC)),
|
|
REGS(0, 0, NOSPPC, 0, NOSPPC)),
|
|
|
|
|
|
/* ??? 1110 1010 101x xxxx xxxx xxxx xxxx xxxx */
|
|
/* ??? 1110 1010 101x xxxx xxxx xxxx xxxx xxxx */
|
|
@@ -108,7 +105,7 @@ static const union decode_item t32_table_1110_101x[] = {
|
|
|
|
|
|
/* ADD/SUB SP, SP, Rm, LSL #0..3 */
|
|
/* ADD/SUB SP, SP, Rm, LSL #0..3 */
|
|
/* 1110 1011 x0xx 1101 x000 1101 xx00 xxxx */
|
|
/* 1110 1011 x0xx 1101 x000 1101 xx00 xxxx */
|
|
- DECODE_EMULATEX (0xff4f7f30, 0xeb0d0d00, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff4f7f30, 0xeb0d0d00, PROBES_T32_ADDSUB,
|
|
REGS(SP, 0, SP, 0, NOSPPC)),
|
|
REGS(SP, 0, SP, 0, NOSPPC)),
|
|
|
|
|
|
/* ADD/SUB SP, SP, Rm, shift */
|
|
/* ADD/SUB SP, SP, Rm, shift */
|
|
@@ -117,7 +114,7 @@ static const union decode_item t32_table_1110_101x[] = {
|
|
|
|
|
|
/* ADD/SUB Rd, SP, Rm, shift */
|
|
/* ADD/SUB Rd, SP, Rm, shift */
|
|
/* 1110 1011 x0xx 1101 xxxx xxxx xxxx xxxx */
|
|
/* 1110 1011 x0xx 1101 xxxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xff4f0000, 0xeb0d0000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff4f0000, 0xeb0d0000, PROBES_T32_ADDSUB,
|
|
REGS(SP, 0, NOPC, 0, NOSPPC)),
|
|
REGS(SP, 0, NOPC, 0, NOSPPC)),
|
|
|
|
|
|
/* AND 1110 1010 000x xxxx xxxx xxxx xxxx xxxx */
|
|
/* AND 1110 1010 000x xxxx xxxx xxxx xxxx xxxx */
|
|
@@ -131,7 +128,7 @@ static const union decode_item t32_table_1110_101x[] = {
|
|
/* SBC 1110 1011 011x xxxx xxxx xxxx xxxx xxxx */
|
|
/* SBC 1110 1011 011x xxxx xxxx xxxx xxxx xxxx */
|
|
/* SUB 1110 1011 101x xxxx xxxx xxxx xxxx xxxx */
|
|
/* SUB 1110 1011 101x xxxx xxxx xxxx xxxx xxxx */
|
|
/* RSB 1110 1011 110x xxxx xxxx xxxx xxxx xxxx */
|
|
/* RSB 1110 1011 110x xxxx xxxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfe000000, 0xea000000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfe000000, 0xea000000, PROBES_T32_LOGICAL,
|
|
REGS(NOSPPC, 0, NOSPPC, 0, NOSPPC)),
|
|
REGS(NOSPPC, 0, NOSPPC, 0, NOSPPC)),
|
|
|
|
|
|
DECODE_END
|
|
DECODE_END
|
|
@@ -142,18 +139,18 @@ static const union decode_item t32_table_1111_0x0x___0[] = {
|
|
|
|
|
|
/* TST 1111 0x00 0001 xxxx 0xxx 1111 xxxx xxxx */
|
|
/* TST 1111 0x00 0001 xxxx 0xxx 1111 xxxx xxxx */
|
|
/* TEQ 1111 0x00 1001 xxxx 0xxx 1111 xxxx xxxx */
|
|
/* TEQ 1111 0x00 1001 xxxx 0xxx 1111 xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfb708f00, 0xf0100f00, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfb708f00, 0xf0100f00, PROBES_T32_TST,
|
|
REGS(NOSPPC, 0, 0, 0, 0)),
|
|
REGS(NOSPPC, 0, 0, 0, 0)),
|
|
|
|
|
|
/* CMN 1111 0x01 0001 xxxx 0xxx 1111 xxxx xxxx */
|
|
/* CMN 1111 0x01 0001 xxxx 0xxx 1111 xxxx xxxx */
|
|
DECODE_OR (0xfbf08f00, 0xf1100f00),
|
|
DECODE_OR (0xfbf08f00, 0xf1100f00),
|
|
/* CMP 1111 0x01 1011 xxxx 0xxx 1111 xxxx xxxx */
|
|
/* CMP 1111 0x01 1011 xxxx 0xxx 1111 xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfbf08f00, 0xf1b00f00, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfbf08f00, 0xf1b00f00, PROBES_T32_CMP,
|
|
REGS(NOPC, 0, 0, 0, 0)),
|
|
REGS(NOPC, 0, 0, 0, 0)),
|
|
|
|
|
|
/* MOV 1111 0x00 010x 1111 0xxx xxxx xxxx xxxx */
|
|
/* MOV 1111 0x00 010x 1111 0xxx xxxx xxxx xxxx */
|
|
/* MVN 1111 0x00 011x 1111 0xxx xxxx xxxx xxxx */
|
|
/* MVN 1111 0x00 011x 1111 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfbcf8000, 0xf04f0000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfbcf8000, 0xf04f0000, PROBES_T32_MOV,
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* ??? 1111 0x00 101x xxxx 0xxx xxxx xxxx xxxx */
|
|
/* ??? 1111 0x00 101x xxxx 0xxx xxxx xxxx xxxx */
|
|
@@ -170,7 +167,7 @@ static const union decode_item t32_table_1111_0x0x___0[] = {
|
|
|
|
|
|
/* ADD Rd, SP, #imm 1111 0x01 000x 1101 0xxx xxxx xxxx xxxx */
|
|
/* ADD Rd, SP, #imm 1111 0x01 000x 1101 0xxx xxxx xxxx xxxx */
|
|
/* SUB Rd, SP, #imm 1111 0x01 101x 1101 0xxx xxxx xxxx xxxx */
|
|
/* SUB Rd, SP, #imm 1111 0x01 101x 1101 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfb4f8000, 0xf10d0000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfb4f8000, 0xf10d0000, PROBES_T32_ADDSUB,
|
|
REGS(SP, 0, NOPC, 0, 0)),
|
|
REGS(SP, 0, NOPC, 0, 0)),
|
|
|
|
|
|
/* AND 1111 0x00 000x xxxx 0xxx xxxx xxxx xxxx */
|
|
/* AND 1111 0x00 000x xxxx 0xxx xxxx xxxx xxxx */
|
|
@@ -183,7 +180,7 @@ static const union decode_item t32_table_1111_0x0x___0[] = {
|
|
/* SBC 1111 0x01 011x xxxx 0xxx xxxx xxxx xxxx */
|
|
/* SBC 1111 0x01 011x xxxx 0xxx xxxx xxxx xxxx */
|
|
/* SUB 1111 0x01 101x xxxx 0xxx xxxx xxxx xxxx */
|
|
/* SUB 1111 0x01 101x xxxx 0xxx xxxx xxxx xxxx */
|
|
/* RSB 1111 0x01 110x xxxx 0xxx xxxx xxxx xxxx */
|
|
/* RSB 1111 0x01 110x xxxx 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfa008000, 0xf0000000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfa008000, 0xf0000000, PROBES_T32_LOGICAL,
|
|
REGS(NOSPPC, 0, NOSPPC, 0, 0)),
|
|
REGS(NOSPPC, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
DECODE_END
|
|
DECODE_END
|
|
@@ -195,44 +192,44 @@ static const union decode_item t32_table_1111_0x1x___0[] = {
|
|
/* ADDW Rd, PC, #imm 1111 0x10 0000 1111 0xxx xxxx xxxx xxxx */
|
|
/* ADDW Rd, PC, #imm 1111 0x10 0000 1111 0xxx xxxx xxxx xxxx */
|
|
DECODE_OR (0xfbff8000, 0xf20f0000),
|
|
DECODE_OR (0xfbff8000, 0xf20f0000),
|
|
/* SUBW Rd, PC, #imm 1111 0x10 1010 1111 0xxx xxxx xxxx xxxx */
|
|
/* SUBW Rd, PC, #imm 1111 0x10 1010 1111 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfbff8000, 0xf2af0000, t32_emulate_rd8pc16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfbff8000, 0xf2af0000, PROBES_T32_ADDWSUBW_PC,
|
|
REGS(PC, 0, NOSPPC, 0, 0)),
|
|
REGS(PC, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* ADDW SP, SP, #imm 1111 0x10 0000 1101 0xxx 1101 xxxx xxxx */
|
|
/* ADDW SP, SP, #imm 1111 0x10 0000 1101 0xxx 1101 xxxx xxxx */
|
|
DECODE_OR (0xfbff8f00, 0xf20d0d00),
|
|
DECODE_OR (0xfbff8f00, 0xf20d0d00),
|
|
/* SUBW SP, SP, #imm 1111 0x10 1010 1101 0xxx 1101 xxxx xxxx */
|
|
/* SUBW SP, SP, #imm 1111 0x10 1010 1101 0xxx 1101 xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfbff8f00, 0xf2ad0d00, t32_emulate_rd8rn16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfbff8f00, 0xf2ad0d00, PROBES_T32_ADDWSUBW,
|
|
REGS(SP, 0, SP, 0, 0)),
|
|
REGS(SP, 0, SP, 0, 0)),
|
|
|
|
|
|
/* ADDW 1111 0x10 0000 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* ADDW 1111 0x10 0000 xxxx 0xxx xxxx xxxx xxxx */
|
|
DECODE_OR (0xfbf08000, 0xf2000000),
|
|
DECODE_OR (0xfbf08000, 0xf2000000),
|
|
/* SUBW 1111 0x10 1010 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* SUBW 1111 0x10 1010 xxxx 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfbf08000, 0xf2a00000, t32_emulate_rd8rn16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfbf08000, 0xf2a00000, PROBES_T32_ADDWSUBW,
|
|
REGS(NOPCX, 0, NOSPPC, 0, 0)),
|
|
REGS(NOPCX, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* MOVW 1111 0x10 0100 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* MOVW 1111 0x10 0100 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* MOVT 1111 0x10 1100 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* MOVT 1111 0x10 1100 xxxx 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfb708000, 0xf2400000, t32_emulate_rd8rn16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfb708000, 0xf2400000, PROBES_T32_MOVW,
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* SSAT16 1111 0x11 0010 xxxx 0000 xxxx 00xx xxxx */
|
|
/* SSAT16 1111 0x11 0010 xxxx 0000 xxxx 00xx xxxx */
|
|
/* SSAT 1111 0x11 00x0 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* SSAT 1111 0x11 00x0 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* USAT16 1111 0x11 1010 xxxx 0000 xxxx 00xx xxxx */
|
|
/* USAT16 1111 0x11 1010 xxxx 0000 xxxx 00xx xxxx */
|
|
/* USAT 1111 0x11 10x0 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* USAT 1111 0x11 10x0 xxxx 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfb508000, 0xf3000000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfb508000, 0xf3000000, PROBES_T32_SAT,
|
|
REGS(NOSPPC, 0, NOSPPC, 0, 0)),
|
|
REGS(NOSPPC, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* SFBX 1111 0x11 0100 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* SFBX 1111 0x11 0100 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* UFBX 1111 0x11 1100 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* UFBX 1111 0x11 1100 xxxx 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfb708000, 0xf3400000, t32_emulate_rd8rn16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfb708000, 0xf3400000, PROBES_T32_BITFIELD,
|
|
REGS(NOSPPC, 0, NOSPPC, 0, 0)),
|
|
REGS(NOSPPC, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* BFC 1111 0x11 0110 1111 0xxx xxxx xxxx xxxx */
|
|
/* BFC 1111 0x11 0110 1111 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfbff8000, 0xf36f0000, t32_emulate_rd8rn16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfbff8000, 0xf36f0000, PROBES_T32_BITFIELD,
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/* BFI 1111 0x11 0110 xxxx 0xxx xxxx xxxx xxxx */
|
|
/* BFI 1111 0x11 0110 xxxx 0xxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfbf08000, 0xf3600000, t32_emulate_rd8rn16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfbf08000, 0xf3600000, PROBES_T32_BITFIELD,
|
|
REGS(NOSPPCX, 0, NOSPPC, 0, 0)),
|
|
REGS(NOSPPCX, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
DECODE_END
|
|
DECODE_END
|
|
@@ -244,14 +241,14 @@ static const union decode_item t32_table_1111_0xxx___1[] = {
|
|
/* YIELD 1111 0011 1010 xxxx 10x0 x000 0000 0001 */
|
|
/* YIELD 1111 0011 1010 xxxx 10x0 x000 0000 0001 */
|
|
DECODE_OR (0xfff0d7ff, 0xf3a08001),
|
|
DECODE_OR (0xfff0d7ff, 0xf3a08001),
|
|
/* SEV 1111 0011 1010 xxxx 10x0 x000 0000 0100 */
|
|
/* SEV 1111 0011 1010 xxxx 10x0 x000 0000 0100 */
|
|
- DECODE_EMULATE (0xfff0d7ff, 0xf3a08004, kprobe_emulate_none),
|
|
|
|
|
|
+ DECODE_EMULATE (0xfff0d7ff, 0xf3a08004, PROBES_T32_SEV),
|
|
/* NOP 1111 0011 1010 xxxx 10x0 x000 0000 0000 */
|
|
/* NOP 1111 0011 1010 xxxx 10x0 x000 0000 0000 */
|
|
/* WFE 1111 0011 1010 xxxx 10x0 x000 0000 0010 */
|
|
/* WFE 1111 0011 1010 xxxx 10x0 x000 0000 0010 */
|
|
/* WFI 1111 0011 1010 xxxx 10x0 x000 0000 0011 */
|
|
/* WFI 1111 0011 1010 xxxx 10x0 x000 0000 0011 */
|
|
- DECODE_SIMULATE (0xfff0d7fc, 0xf3a08000, kprobe_simulate_nop),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xfff0d7fc, 0xf3a08000, PROBES_T32_WFE),
|
|
|
|
|
|
/* MRS Rd, CPSR 1111 0011 1110 xxxx 10x0 xxxx xxxx xxxx */
|
|
/* MRS Rd, CPSR 1111 0011 1110 xxxx 10x0 xxxx xxxx xxxx */
|
|
- DECODE_SIMULATEX(0xfff0d000, 0xf3e08000, t32_simulate_mrs,
|
|
|
|
|
|
+ DECODE_SIMULATEX(0xfff0d000, 0xf3e08000, PROBES_T32_MRS,
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
REGS(0, 0, NOSPPC, 0, 0)),
|
|
|
|
|
|
/*
|
|
/*
|
|
@@ -273,13 +270,13 @@ static const union decode_item t32_table_1111_0xxx___1[] = {
|
|
DECODE_REJECT (0xfb80d000, 0xf3808000),
|
|
DECODE_REJECT (0xfb80d000, 0xf3808000),
|
|
|
|
|
|
/* Bcc 1111 0xxx xxxx xxxx 10x0 xxxx xxxx xxxx */
|
|
/* Bcc 1111 0xxx xxxx xxxx 10x0 xxxx xxxx xxxx */
|
|
- DECODE_CUSTOM (0xf800d000, 0xf0008000, t32_decode_cond_branch),
|
|
|
|
|
|
+ DECODE_CUSTOM (0xf800d000, 0xf0008000, PROBES_T32_BRANCH_COND),
|
|
|
|
|
|
/* BLX 1111 0xxx xxxx xxxx 11x0 xxxx xxxx xxx0 */
|
|
/* BLX 1111 0xxx xxxx xxxx 11x0 xxxx xxxx xxx0 */
|
|
DECODE_OR (0xf800d001, 0xf000c000),
|
|
DECODE_OR (0xf800d001, 0xf000c000),
|
|
/* B 1111 0xxx xxxx xxxx 10x1 xxxx xxxx xxxx */
|
|
/* B 1111 0xxx xxxx xxxx 10x1 xxxx xxxx xxxx */
|
|
/* BL 1111 0xxx xxxx xxxx 11x1 xxxx xxxx xxxx */
|
|
/* BL 1111 0xxx xxxx xxxx 11x1 xxxx xxxx xxxx */
|
|
- DECODE_SIMULATE (0xf8009000, 0xf0009000, t32_simulate_branch),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xf8009000, 0xf0009000, PROBES_T32_BRANCH),
|
|
|
|
|
|
DECODE_END
|
|
DECODE_END
|
|
};
|
|
};
|
|
@@ -289,7 +286,7 @@ static const union decode_item t32_table_1111_100x_x0x1__1111[] = {
|
|
|
|
|
|
/* PLD (literal) 1111 1000 x001 1111 1111 xxxx xxxx xxxx */
|
|
/* PLD (literal) 1111 1000 x001 1111 1111 xxxx xxxx xxxx */
|
|
/* PLI (literal) 1111 1001 x001 1111 1111 xxxx xxxx xxxx */
|
|
/* PLI (literal) 1111 1001 x001 1111 1111 xxxx xxxx xxxx */
|
|
- DECODE_SIMULATE (0xfe7ff000, 0xf81ff000, kprobe_simulate_nop),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xfe7ff000, 0xf81ff000, PROBES_T32_PLDI),
|
|
|
|
|
|
/* PLD{W} (immediate) 1111 1000 10x1 xxxx 1111 xxxx xxxx xxxx */
|
|
/* PLD{W} (immediate) 1111 1000 10x1 xxxx 1111 xxxx xxxx xxxx */
|
|
DECODE_OR (0xffd0f000, 0xf890f000),
|
|
DECODE_OR (0xffd0f000, 0xf890f000),
|
|
@@ -298,13 +295,13 @@ static const union decode_item t32_table_1111_100x_x0x1__1111[] = {
|
|
/* PLI (immediate) 1111 1001 1001 xxxx 1111 xxxx xxxx xxxx */
|
|
/* PLI (immediate) 1111 1001 1001 xxxx 1111 xxxx xxxx xxxx */
|
|
DECODE_OR (0xfff0f000, 0xf990f000),
|
|
DECODE_OR (0xfff0f000, 0xf990f000),
|
|
/* PLI (immediate) 1111 1001 0001 xxxx 1111 1100 xxxx xxxx */
|
|
/* PLI (immediate) 1111 1001 0001 xxxx 1111 1100 xxxx xxxx */
|
|
- DECODE_SIMULATEX(0xfff0ff00, 0xf910fc00, kprobe_simulate_nop,
|
|
|
|
|
|
+ DECODE_SIMULATEX(0xfff0ff00, 0xf910fc00, PROBES_T32_PLDI,
|
|
REGS(NOPCX, 0, 0, 0, 0)),
|
|
REGS(NOPCX, 0, 0, 0, 0)),
|
|
|
|
|
|
/* PLD{W} (register) 1111 1000 00x1 xxxx 1111 0000 00xx xxxx */
|
|
/* PLD{W} (register) 1111 1000 00x1 xxxx 1111 0000 00xx xxxx */
|
|
DECODE_OR (0xffd0ffc0, 0xf810f000),
|
|
DECODE_OR (0xffd0ffc0, 0xf810f000),
|
|
/* PLI (register) 1111 1001 0001 xxxx 1111 0000 00xx xxxx */
|
|
/* PLI (register) 1111 1001 0001 xxxx 1111 0000 00xx xxxx */
|
|
- DECODE_SIMULATEX(0xfff0ffc0, 0xf910f000, kprobe_simulate_nop,
|
|
|
|
|
|
+ DECODE_SIMULATEX(0xfff0ffc0, 0xf910f000, PROBES_T32_PLDI,
|
|
REGS(NOPCX, 0, 0, 0, NOSPPC)),
|
|
REGS(NOPCX, 0, 0, 0, NOSPPC)),
|
|
|
|
|
|
/* Other unallocated instructions... */
|
|
/* Other unallocated instructions... */
|
|
@@ -340,7 +337,7 @@ static const union decode_item t32_table_1111_100x[] = {
|
|
DECODE_REJECT (0xff10f000, 0xf800f000),
|
|
DECODE_REJECT (0xff10f000, 0xf800f000),
|
|
|
|
|
|
/* LDR (literal) 1111 1000 x101 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDR (literal) 1111 1000 x101 1111 xxxx xxxx xxxx xxxx */
|
|
- DECODE_SIMULATEX(0xff7f0000, 0xf85f0000, t32_simulate_ldr_literal,
|
|
|
|
|
|
+ DECODE_SIMULATEX(0xff7f0000, 0xf85f0000, PROBES_T32_LDR_LIT,
|
|
REGS(PC, ANY, 0, 0, 0)),
|
|
REGS(PC, ANY, 0, 0, 0)),
|
|
|
|
|
|
/* STR (immediate) 1111 1000 0100 xxxx xxxx 1xxx xxxx xxxx */
|
|
/* STR (immediate) 1111 1000 0100 xxxx xxxx 1xxx xxxx xxxx */
|
|
@@ -348,19 +345,19 @@ static const union decode_item t32_table_1111_100x[] = {
|
|
DECODE_OR (0xffe00800, 0xf8400800),
|
|
DECODE_OR (0xffe00800, 0xf8400800),
|
|
/* STR (immediate) 1111 1000 1100 xxxx xxxx xxxx xxxx xxxx */
|
|
/* STR (immediate) 1111 1000 1100 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDR (immediate) 1111 1000 1101 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDR (immediate) 1111 1000 1101 xxxx xxxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xffe00000, 0xf8c00000, t32_emulate_ldrstr,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xffe00000, 0xf8c00000, PROBES_T32_LDRSTR,
|
|
REGS(NOPCX, ANY, 0, 0, 0)),
|
|
REGS(NOPCX, ANY, 0, 0, 0)),
|
|
|
|
|
|
/* STR (register) 1111 1000 0100 xxxx xxxx 0000 00xx xxxx */
|
|
/* STR (register) 1111 1000 0100 xxxx xxxx 0000 00xx xxxx */
|
|
/* LDR (register) 1111 1000 0101 xxxx xxxx 0000 00xx xxxx */
|
|
/* LDR (register) 1111 1000 0101 xxxx xxxx 0000 00xx xxxx */
|
|
- DECODE_EMULATEX (0xffe00fc0, 0xf8400000, t32_emulate_ldrstr,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xffe00fc0, 0xf8400000, PROBES_T32_LDRSTR,
|
|
REGS(NOPCX, ANY, 0, 0, NOSPPC)),
|
|
REGS(NOPCX, ANY, 0, 0, NOSPPC)),
|
|
|
|
|
|
/* LDRB (literal) 1111 1000 x001 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDRB (literal) 1111 1000 x001 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDRSB (literal) 1111 1001 x001 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDRSB (literal) 1111 1001 x001 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDRH (literal) 1111 1000 x011 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDRH (literal) 1111 1000 x011 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDRSH (literal) 1111 1001 x011 1111 xxxx xxxx xxxx xxxx */
|
|
/* LDRSH (literal) 1111 1001 x011 1111 xxxx xxxx xxxx xxxx */
|
|
- DECODE_SIMULATEX(0xfe5f0000, 0xf81f0000, t32_simulate_ldr_literal,
|
|
|
|
|
|
+ DECODE_SIMULATEX(0xfe5f0000, 0xf81f0000, PROBES_T32_LDR_LIT,
|
|
REGS(PC, NOSPPCX, 0, 0, 0)),
|
|
REGS(PC, NOSPPCX, 0, 0, 0)),
|
|
|
|
|
|
/* STRB (immediate) 1111 1000 0000 xxxx xxxx 1xxx xxxx xxxx */
|
|
/* STRB (immediate) 1111 1000 0000 xxxx xxxx 1xxx xxxx xxxx */
|
|
@@ -376,7 +373,7 @@ static const union decode_item t32_table_1111_100x[] = {
|
|
/* LDRSB (immediate) 1111 1001 1001 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDRSB (immediate) 1111 1001 1001 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDRH (immediate) 1111 1000 1011 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDRH (immediate) 1111 1000 1011 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDRSH (immediate) 1111 1001 1011 xxxx xxxx xxxx xxxx xxxx */
|
|
/* LDRSH (immediate) 1111 1001 1011 xxxx xxxx xxxx xxxx xxxx */
|
|
- DECODE_EMULATEX (0xfec00000, 0xf8800000, t32_emulate_ldrstr,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfec00000, 0xf8800000, PROBES_T32_LDRSTR,
|
|
REGS(NOPCX, NOSPPCX, 0, 0, 0)),
|
|
REGS(NOPCX, NOSPPCX, 0, 0, 0)),
|
|
|
|
|
|
/* STRB (register) 1111 1000 0000 xxxx xxxx 0000 00xx xxxx */
|
|
/* STRB (register) 1111 1000 0000 xxxx xxxx 0000 00xx xxxx */
|
|
@@ -385,7 +382,7 @@ static const union decode_item t32_table_1111_100x[] = {
|
|
/* LDRSB (register) 1111 1001 0001 xxxx xxxx 0000 00xx xxxx */
|
|
/* LDRSB (register) 1111 1001 0001 xxxx xxxx 0000 00xx xxxx */
|
|
/* LDRH (register) 1111 1000 0011 xxxx xxxx 0000 00xx xxxx */
|
|
/* LDRH (register) 1111 1000 0011 xxxx xxxx 0000 00xx xxxx */
|
|
/* LDRSH (register) 1111 1001 0011 xxxx xxxx 0000 00xx xxxx */
|
|
/* LDRSH (register) 1111 1001 0011 xxxx xxxx 0000 00xx xxxx */
|
|
- DECODE_EMULATEX (0xfe800fc0, 0xf8000000, t32_emulate_ldrstr,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfe800fc0, 0xf8000000, PROBES_T32_LDRSTR,
|
|
REGS(NOPCX, NOSPPCX, 0, 0, NOSPPC)),
|
|
REGS(NOPCX, NOSPPCX, 0, 0, NOSPPC)),
|
|
|
|
|
|
/* Other unallocated instructions... */
|
|
/* Other unallocated instructions... */
|
|
@@ -404,7 +401,7 @@ static const union decode_item t32_table_1111_1010___1111[] = {
|
|
/* UXTB16 1111 1010 0011 1111 1111 xxxx 1xxx xxxx */
|
|
/* UXTB16 1111 1010 0011 1111 1111 xxxx 1xxx xxxx */
|
|
/* SXTB 1111 1010 0100 1111 1111 xxxx 1xxx xxxx */
|
|
/* SXTB 1111 1010 0100 1111 1111 xxxx 1xxx xxxx */
|
|
/* UXTB 1111 1010 0101 1111 1111 xxxx 1xxx xxxx */
|
|
/* UXTB 1111 1010 0101 1111 1111 xxxx 1xxx xxxx */
|
|
- DECODE_EMULATEX (0xff8ff080, 0xfa0ff080, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff8ff080, 0xfa0ff080, PROBES_T32_SIGN_EXTEND,
|
|
REGS(0, 0, NOSPPC, 0, NOSPPC)),
|
|
REGS(0, 0, NOSPPC, 0, NOSPPC)),
|
|
|
|
|
|
|
|
|
|
@@ -477,7 +474,7 @@ static const union decode_item t32_table_1111_1010___1111[] = {
|
|
/* LSR 1111 1010 001x xxxx 1111 xxxx 0000 xxxx */
|
|
/* LSR 1111 1010 001x xxxx 1111 xxxx 0000 xxxx */
|
|
/* ASR 1111 1010 010x xxxx 1111 xxxx 0000 xxxx */
|
|
/* ASR 1111 1010 010x xxxx 1111 xxxx 0000 xxxx */
|
|
/* ROR 1111 1010 011x xxxx 1111 xxxx 0000 xxxx */
|
|
/* ROR 1111 1010 011x xxxx 1111 xxxx 0000 xxxx */
|
|
- DECODE_EMULATEX (0xff80f0f0, 0xfa00f000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff80f0f0, 0xfa00f000, PROBES_T32_MEDIA,
|
|
REGS(NOSPPC, 0, NOSPPC, 0, NOSPPC)),
|
|
REGS(NOSPPC, 0, NOSPPC, 0, NOSPPC)),
|
|
|
|
|
|
/* CLZ 1111 1010 1010 xxxx 1111 xxxx 1000 xxxx */
|
|
/* CLZ 1111 1010 1010 xxxx 1111 xxxx 1000 xxxx */
|
|
@@ -487,7 +484,7 @@ static const union decode_item t32_table_1111_1010___1111[] = {
|
|
/* REV16 1111 1010 1001 xxxx 1111 xxxx 1001 xxxx */
|
|
/* REV16 1111 1010 1001 xxxx 1111 xxxx 1001 xxxx */
|
|
/* RBIT 1111 1010 1001 xxxx 1111 xxxx 1010 xxxx */
|
|
/* RBIT 1111 1010 1001 xxxx 1111 xxxx 1010 xxxx */
|
|
/* REVSH 1111 1010 1001 xxxx 1111 xxxx 1011 xxxx */
|
|
/* REVSH 1111 1010 1001 xxxx 1111 xxxx 1011 xxxx */
|
|
- DECODE_EMULATEX (0xfff0f0c0, 0xfa90f080, t32_emulate_rd8rn16_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xfff0f0c0, 0xfa90f080, PROBES_T32_REVERSE,
|
|
REGS(NOSPPC, 0, NOSPPC, 0, SAMEAS16)),
|
|
REGS(NOSPPC, 0, NOSPPC, 0, SAMEAS16)),
|
|
|
|
|
|
/* Other unallocated instructions... */
|
|
/* Other unallocated instructions... */
|
|
@@ -510,7 +507,7 @@ static const union decode_item t32_table_1111_1011_0[] = {
|
|
/* SMUSD{X} 1111 1011 0100 xxxx 1111 xxxx 000x xxxx */
|
|
/* SMUSD{X} 1111 1011 0100 xxxx 1111 xxxx 000x xxxx */
|
|
/* SMMUL{R} 1111 1011 0101 xxxx 1111 xxxx 000x xxxx */
|
|
/* SMMUL{R} 1111 1011 0101 xxxx 1111 xxxx 000x xxxx */
|
|
/* USAD8 1111 1011 0111 xxxx 1111 xxxx 0000 xxxx */
|
|
/* USAD8 1111 1011 0111 xxxx 1111 xxxx 0000 xxxx */
|
|
- DECODE_EMULATEX (0xff80f0e0, 0xfb00f000, t32_emulate_rd8rn16rm0_rwflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff80f0e0, 0xfb00f000, PROBES_T32_MUL_ADD,
|
|
REGS(NOSPPC, 0, NOSPPC, 0, NOSPPC)),
|
|
REGS(NOSPPC, 0, NOSPPC, 0, NOSPPC)),
|
|
|
|
|
|
/* ??? 1111 1011 0111 xxxx xxxx xxxx 0001 xxxx */
|
|
/* ??? 1111 1011 0111 xxxx xxxx xxxx 0001 xxxx */
|
|
@@ -526,7 +523,7 @@ static const union decode_item t32_table_1111_1011_0[] = {
|
|
/* SMMLA{R} 1111 1011 0101 xxxx xxxx xxxx 000x xxxx */
|
|
/* SMMLA{R} 1111 1011 0101 xxxx xxxx xxxx 000x xxxx */
|
|
/* SMMLS{R} 1111 1011 0110 xxxx xxxx xxxx 000x xxxx */
|
|
/* SMMLS{R} 1111 1011 0110 xxxx xxxx xxxx 000x xxxx */
|
|
/* USADA8 1111 1011 0111 xxxx xxxx xxxx 0000 xxxx */
|
|
/* USADA8 1111 1011 0111 xxxx xxxx xxxx 0000 xxxx */
|
|
- DECODE_EMULATEX (0xff8000c0, 0xfb000000, t32_emulate_rd8rn16rm0ra12_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff8000c0, 0xfb000000, PROBES_T32_MUL_ADD2,
|
|
REGS(NOSPPC, NOSPPCX, NOSPPC, 0, NOSPPC)),
|
|
REGS(NOSPPC, NOSPPCX, NOSPPC, 0, NOSPPC)),
|
|
|
|
|
|
/* Other unallocated instructions... */
|
|
/* Other unallocated instructions... */
|
|
@@ -547,7 +544,7 @@ static const union decode_item t32_table_1111_1011_1[] = {
|
|
/* UMULL 1111 1011 1010 xxxx xxxx xxxx 0000 xxxx */
|
|
/* UMULL 1111 1011 1010 xxxx xxxx xxxx 0000 xxxx */
|
|
/* SMLAL 1111 1011 1100 xxxx xxxx xxxx 0000 xxxx */
|
|
/* SMLAL 1111 1011 1100 xxxx xxxx xxxx 0000 xxxx */
|
|
/* UMLAL 1111 1011 1110 xxxx xxxx xxxx 0000 xxxx */
|
|
/* UMLAL 1111 1011 1110 xxxx xxxx xxxx 0000 xxxx */
|
|
- DECODE_EMULATEX (0xff9000f0, 0xfb800000, t32_emulate_rdlo12rdhi8rn16rm0_noflags,
|
|
|
|
|
|
+ DECODE_EMULATEX (0xff9000f0, 0xfb800000, PROBES_T32_MUL_ADD_LONG,
|
|
REGS(NOSPPC, NOSPPC, NOSPPC, 0, NOSPPC)),
|
|
REGS(NOSPPC, NOSPPC, NOSPPC, 0, NOSPPC)),
|
|
|
|
|
|
/* SDIV 1111 1011 1001 xxxx xxxx xxxx 1111 xxxx */
|
|
/* SDIV 1111 1011 1001 xxxx xxxx xxxx 1111 xxxx */
|
|
@@ -653,11 +650,11 @@ static const union decode_item t16_table_1011[] = {
|
|
|
|
|
|
/* ADD (SP plus immediate) 1011 0000 0xxx xxxx */
|
|
/* ADD (SP plus immediate) 1011 0000 0xxx xxxx */
|
|
/* SUB (SP minus immediate) 1011 0000 1xxx xxxx */
|
|
/* SUB (SP minus immediate) 1011 0000 1xxx xxxx */
|
|
- DECODE_SIMULATE (0xff00, 0xb000, t16_simulate_add_sp_imm),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xff00, 0xb000, PROBES_T16_ADD_SP),
|
|
|
|
|
|
/* CBZ 1011 00x1 xxxx xxxx */
|
|
/* CBZ 1011 00x1 xxxx xxxx */
|
|
/* CBNZ 1011 10x1 xxxx xxxx */
|
|
/* CBNZ 1011 10x1 xxxx xxxx */
|
|
- DECODE_SIMULATE (0xf500, 0xb100, t16_simulate_cbz),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xf500, 0xb100, PROBES_T16_CBZ),
|
|
|
|
|
|
/* SXTH 1011 0010 00xx xxxx */
|
|
/* SXTH 1011 0010 00xx xxxx */
|
|
/* SXTB 1011 0010 01xx xxxx */
|
|
/* SXTB 1011 0010 01xx xxxx */
|
|
@@ -668,12 +665,12 @@ static const union decode_item t16_table_1011[] = {
|
|
/* ??? 1011 1010 10xx xxxx */
|
|
/* ??? 1011 1010 10xx xxxx */
|
|
/* REVSH 1011 1010 11xx xxxx */
|
|
/* REVSH 1011 1010 11xx xxxx */
|
|
DECODE_REJECT (0xffc0, 0xba80),
|
|
DECODE_REJECT (0xffc0, 0xba80),
|
|
- DECODE_EMULATE (0xf500, 0xb000, t16_emulate_loregs_rwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xf500, 0xb000, PROBES_T16_SIGN_EXTEND),
|
|
|
|
|
|
/* PUSH 1011 010x xxxx xxxx */
|
|
/* PUSH 1011 010x xxxx xxxx */
|
|
- DECODE_CUSTOM (0xfe00, 0xb400, t16_decode_push),
|
|
|
|
|
|
+ DECODE_CUSTOM (0xfe00, 0xb400, PROBES_T16_PUSH),
|
|
/* POP 1011 110x xxxx xxxx */
|
|
/* POP 1011 110x xxxx xxxx */
|
|
- DECODE_CUSTOM (0xfe00, 0xbc00, t16_decode_pop),
|
|
|
|
|
|
+ DECODE_CUSTOM (0xfe00, 0xbc00, PROBES_T16_POP),
|
|
|
|
|
|
/*
|
|
/*
|
|
* If-Then, and hints
|
|
* If-Then, and hints
|
|
@@ -683,15 +680,15 @@ static const union decode_item t16_table_1011[] = {
|
|
/* YIELD 1011 1111 0001 0000 */
|
|
/* YIELD 1011 1111 0001 0000 */
|
|
DECODE_OR (0xffff, 0xbf10),
|
|
DECODE_OR (0xffff, 0xbf10),
|
|
/* SEV 1011 1111 0100 0000 */
|
|
/* SEV 1011 1111 0100 0000 */
|
|
- DECODE_EMULATE (0xffff, 0xbf40, kprobe_emulate_none),
|
|
|
|
|
|
+ DECODE_EMULATE (0xffff, 0xbf40, PROBES_T16_SEV),
|
|
/* NOP 1011 1111 0000 0000 */
|
|
/* NOP 1011 1111 0000 0000 */
|
|
/* WFE 1011 1111 0010 0000 */
|
|
/* WFE 1011 1111 0010 0000 */
|
|
/* WFI 1011 1111 0011 0000 */
|
|
/* WFI 1011 1111 0011 0000 */
|
|
- DECODE_SIMULATE (0xffcf, 0xbf00, kprobe_simulate_nop),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xffcf, 0xbf00, PROBES_T16_WFE),
|
|
/* Unassigned hints 1011 1111 xxxx 0000 */
|
|
/* Unassigned hints 1011 1111 xxxx 0000 */
|
|
DECODE_REJECT (0xff0f, 0xbf00),
|
|
DECODE_REJECT (0xff0f, 0xbf00),
|
|
/* IT 1011 1111 xxxx xxxx */
|
|
/* IT 1011 1111 xxxx xxxx */
|
|
- DECODE_CUSTOM (0xff00, 0xbf00, t16_decode_it),
|
|
|
|
|
|
+ DECODE_CUSTOM (0xff00, 0xbf00, PROBES_T16_IT),
|
|
|
|
|
|
/* SETEND 1011 0110 010x xxxx */
|
|
/* SETEND 1011 0110 010x xxxx */
|
|
/* CPS 1011 0110 011x xxxx */
|
|
/* CPS 1011 0110 011x xxxx */
|
|
@@ -708,7 +705,7 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
*/
|
|
*/
|
|
|
|
|
|
/* CMP (immediate) 0010 1xxx xxxx xxxx */
|
|
/* CMP (immediate) 0010 1xxx xxxx xxxx */
|
|
- DECODE_EMULATE (0xf800, 0x2800, t16_emulate_loregs_rwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xf800, 0x2800, PROBES_T16_CMP),
|
|
|
|
|
|
/* ADD (register) 0001 100x xxxx xxxx */
|
|
/* ADD (register) 0001 100x xxxx xxxx */
|
|
/* SUB (register) 0001 101x xxxx xxxx */
|
|
/* SUB (register) 0001 101x xxxx xxxx */
|
|
@@ -720,7 +717,7 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
/* MOV (immediate) 0010 0xxx xxxx xxxx */
|
|
/* MOV (immediate) 0010 0xxx xxxx xxxx */
|
|
/* ADD (immediate, Thumb) 0011 0xxx xxxx xxxx */
|
|
/* ADD (immediate, Thumb) 0011 0xxx xxxx xxxx */
|
|
/* SUB (immediate, Thumb) 0011 1xxx xxxx xxxx */
|
|
/* SUB (immediate, Thumb) 0011 1xxx xxxx xxxx */
|
|
- DECODE_EMULATE (0xc000, 0x0000, t16_emulate_loregs_noitrwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xc000, 0x0000, PROBES_T16_ADDSUB),
|
|
|
|
|
|
/*
|
|
/*
|
|
* 16-bit Thumb data-processing instructions
|
|
* 16-bit Thumb data-processing instructions
|
|
@@ -728,10 +725,10 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
*/
|
|
*/
|
|
|
|
|
|
/* TST (register) 0100 0010 00xx xxxx */
|
|
/* TST (register) 0100 0010 00xx xxxx */
|
|
- DECODE_EMULATE (0xffc0, 0x4200, t16_emulate_loregs_rwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xffc0, 0x4200, PROBES_T16_CMP),
|
|
/* CMP (register) 0100 0010 10xx xxxx */
|
|
/* CMP (register) 0100 0010 10xx xxxx */
|
|
/* CMN (register) 0100 0010 11xx xxxx */
|
|
/* CMN (register) 0100 0010 11xx xxxx */
|
|
- DECODE_EMULATE (0xff80, 0x4280, t16_emulate_loregs_rwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xff80, 0x4280, PROBES_T16_CMP),
|
|
/* AND (register) 0100 0000 00xx xxxx */
|
|
/* AND (register) 0100 0000 00xx xxxx */
|
|
/* EOR (register) 0100 0000 01xx xxxx */
|
|
/* EOR (register) 0100 0000 01xx xxxx */
|
|
/* LSL (register) 0100 0000 10xx xxxx */
|
|
/* LSL (register) 0100 0000 10xx xxxx */
|
|
@@ -745,7 +742,7 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
/* MUL 0100 0011 00xx xxxx */
|
|
/* MUL 0100 0011 00xx xxxx */
|
|
/* BIC (register) 0100 0011 10xx xxxx */
|
|
/* BIC (register) 0100 0011 10xx xxxx */
|
|
/* MVN (register) 0100 0011 10xx xxxx */
|
|
/* MVN (register) 0100 0011 10xx xxxx */
|
|
- DECODE_EMULATE (0xfc00, 0x4000, t16_emulate_loregs_noitrwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xfc00, 0x4000, PROBES_T16_LOGICAL),
|
|
|
|
|
|
/*
|
|
/*
|
|
* Special data instructions and branch and exchange
|
|
* Special data instructions and branch and exchange
|
|
@@ -757,7 +754,7 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
|
|
|
|
/* BX (register) 0100 0111 0xxx xxxx */
|
|
/* BX (register) 0100 0111 0xxx xxxx */
|
|
/* BLX (register) 0100 0111 1xxx xxxx */
|
|
/* BLX (register) 0100 0111 1xxx xxxx */
|
|
- DECODE_SIMULATE (0xff00, 0x4700, t16_simulate_bxblx),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xff00, 0x4700, PROBES_T16_BLX),
|
|
|
|
|
|
/* ADD pc, pc 0100 0100 1111 1111 */
|
|
/* ADD pc, pc 0100 0100 1111 1111 */
|
|
DECODE_REJECT (0xffff, 0x44ff),
|
|
DECODE_REJECT (0xffff, 0x44ff),
|
|
@@ -765,13 +762,13 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
/* ADD (register) 0100 0100 xxxx xxxx */
|
|
/* ADD (register) 0100 0100 xxxx xxxx */
|
|
/* CMP (register) 0100 0101 xxxx xxxx */
|
|
/* CMP (register) 0100 0101 xxxx xxxx */
|
|
/* MOV (register) 0100 0110 xxxx xxxx */
|
|
/* MOV (register) 0100 0110 xxxx xxxx */
|
|
- DECODE_CUSTOM (0xfc00, 0x4400, t16_decode_hiregs),
|
|
|
|
|
|
+ DECODE_CUSTOM (0xfc00, 0x4400, PROBES_T16_HIREGOPS),
|
|
|
|
|
|
/*
|
|
/*
|
|
* Load from Literal Pool
|
|
* Load from Literal Pool
|
|
* LDR (literal) 0100 1xxx xxxx xxxx
|
|
* LDR (literal) 0100 1xxx xxxx xxxx
|
|
*/
|
|
*/
|
|
- DECODE_SIMULATE (0xf800, 0x4800, t16_simulate_ldr_literal),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xf800, 0x4800, PROBES_T16_LDR_LIT),
|
|
|
|
|
|
/*
|
|
/*
|
|
* 16-bit Thumb Load/store instructions
|
|
* 16-bit Thumb Load/store instructions
|
|
@@ -792,20 +789,20 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
/* LDR (immediate, Thumb) 0110 1xxx xxxx xxxx */
|
|
/* LDR (immediate, Thumb) 0110 1xxx xxxx xxxx */
|
|
/* STRB (immediate, Thumb) 0111 0xxx xxxx xxxx */
|
|
/* STRB (immediate, Thumb) 0111 0xxx xxxx xxxx */
|
|
/* LDRB (immediate, Thumb) 0111 1xxx xxxx xxxx */
|
|
/* LDRB (immediate, Thumb) 0111 1xxx xxxx xxxx */
|
|
- DECODE_EMULATE (0xc000, 0x4000, t16_emulate_loregs_rwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xc000, 0x4000, PROBES_T16_LDRHSTRH),
|
|
/* STRH (immediate, Thumb) 1000 0xxx xxxx xxxx */
|
|
/* STRH (immediate, Thumb) 1000 0xxx xxxx xxxx */
|
|
/* LDRH (immediate, Thumb) 1000 1xxx xxxx xxxx */
|
|
/* LDRH (immediate, Thumb) 1000 1xxx xxxx xxxx */
|
|
- DECODE_EMULATE (0xf000, 0x8000, t16_emulate_loregs_rwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xf000, 0x8000, PROBES_T16_LDRHSTRH),
|
|
/* STR (immediate, Thumb) 1001 0xxx xxxx xxxx */
|
|
/* STR (immediate, Thumb) 1001 0xxx xxxx xxxx */
|
|
/* LDR (immediate, Thumb) 1001 1xxx xxxx xxxx */
|
|
/* LDR (immediate, Thumb) 1001 1xxx xxxx xxxx */
|
|
- DECODE_SIMULATE (0xf000, 0x9000, t16_simulate_ldrstr_sp_relative),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xf000, 0x9000, PROBES_T16_LDRSTR),
|
|
|
|
|
|
/*
|
|
/*
|
|
* Generate PC-/SP-relative address
|
|
* Generate PC-/SP-relative address
|
|
* ADR (literal) 1010 0xxx xxxx xxxx
|
|
* ADR (literal) 1010 0xxx xxxx xxxx
|
|
* ADD (SP plus immediate) 1010 1xxx xxxx xxxx
|
|
* ADD (SP plus immediate) 1010 1xxx xxxx xxxx
|
|
*/
|
|
*/
|
|
- DECODE_SIMULATE (0xf000, 0xa000, t16_simulate_reladr),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xf000, 0xa000, PROBES_T16_ADR),
|
|
|
|
|
|
/*
|
|
/*
|
|
* Miscellaneous 16-bit instructions
|
|
* Miscellaneous 16-bit instructions
|
|
@@ -815,7 +812,7 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
|
|
|
|
/* STM 1100 0xxx xxxx xxxx */
|
|
/* STM 1100 0xxx xxxx xxxx */
|
|
/* LDM 1100 1xxx xxxx xxxx */
|
|
/* LDM 1100 1xxx xxxx xxxx */
|
|
- DECODE_EMULATE (0xf000, 0xc000, t16_emulate_loregs_rwflags),
|
|
|
|
|
|
+ DECODE_EMULATE (0xf000, 0xc000, PROBES_T16_LDMSTM),
|
|
|
|
|
|
/*
|
|
/*
|
|
* Conditional branch, and Supervisor Call
|
|
* Conditional branch, and Supervisor Call
|
|
@@ -826,13 +823,13 @@ const union decode_item kprobe_decode_thumb16_table[] = {
|
|
DECODE_REJECT (0xfe00, 0xde00),
|
|
DECODE_REJECT (0xfe00, 0xde00),
|
|
|
|
|
|
/* Conditional branch 1101 xxxx xxxx xxxx */
|
|
/* Conditional branch 1101 xxxx xxxx xxxx */
|
|
- DECODE_CUSTOM (0xf000, 0xd000, t16_decode_cond_branch),
|
|
|
|
|
|
+ DECODE_CUSTOM (0xf000, 0xd000, PROBES_T16_BRANCH_COND),
|
|
|
|
|
|
/*
|
|
/*
|
|
* Unconditional branch
|
|
* Unconditional branch
|
|
* B 1110 0xxx xxxx xxxx
|
|
* B 1110 0xxx xxxx xxxx
|
|
*/
|
|
*/
|
|
- DECODE_SIMULATE (0xf800, 0xe000, t16_simulate_branch),
|
|
|
|
|
|
+ DECODE_SIMULATE (0xf800, 0xe000, PROBES_T16_BRANCH),
|
|
|
|
|
|
DECODE_END
|
|
DECODE_END
|
|
};
|
|
};
|
|
@@ -862,17 +859,21 @@ static void __kprobes thumb32_singlestep(struct kprobe *p, struct pt_regs *regs)
|
|
}
|
|
}
|
|
|
|
|
|
enum kprobe_insn __kprobes
|
|
enum kprobe_insn __kprobes
|
|
-thumb16_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi)
|
|
|
|
|
|
+thumb16_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi,
|
|
|
|
+ const union decode_action *actions)
|
|
{
|
|
{
|
|
asi->insn_singlestep = thumb16_singlestep;
|
|
asi->insn_singlestep = thumb16_singlestep;
|
|
asi->insn_check_cc = thumb_check_cc;
|
|
asi->insn_check_cc = thumb_check_cc;
|
|
- return kprobe_decode_insn(insn, asi, kprobe_decode_thumb16_table, true);
|
|
|
|
|
|
+ return kprobe_decode_insn(insn, asi, kprobe_decode_thumb16_table, true,
|
|
|
|
+ actions);
|
|
}
|
|
}
|
|
|
|
|
|
enum kprobe_insn __kprobes
|
|
enum kprobe_insn __kprobes
|
|
-thumb32_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi)
|
|
|
|
|
|
+thumb32_kprobe_decode_insn(kprobe_opcode_t insn, struct arch_specific_insn *asi,
|
|
|
|
+ const union decode_action *actions)
|
|
{
|
|
{
|
|
asi->insn_singlestep = thumb32_singlestep;
|
|
asi->insn_singlestep = thumb32_singlestep;
|
|
asi->insn_check_cc = thumb_check_cc;
|
|
asi->insn_check_cc = thumb_check_cc;
|
|
- return kprobe_decode_insn(insn, asi, kprobe_decode_thumb32_table, true);
|
|
|
|
|
|
+ return kprobe_decode_insn(insn, asi, kprobe_decode_thumb32_table, true,
|
|
|
|
+ actions);
|
|
}
|
|
}
|