From 8fb40a9c236e58b002e447b1c8ac124732a9dd8a Mon Sep 17 00:00:00 2001 From: comex Date: Fri, 16 Jan 2015 03:24:12 -0500 Subject: jump dis - seemingly working(!) --- lib/dis-arm-multi.inc.h | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 lib/dis-arm-multi.inc.h (limited to 'lib/dis-arm-multi.inc.h') diff --git a/lib/dis-arm-multi.inc.h b/lib/dis-arm-multi.inc.h new file mode 100644 index 0000000..56cde35 --- /dev/null +++ b/lib/dis-arm-multi.inc.h @@ -0,0 +1,16 @@ +#include "dis-thumb.inc.h" +#include "dis-thumb2.inc.h" +#include "dis-arm.inc.h" + +static INLINE void P(dis)(tdis_ctx ctx) { + if (ctx->pc_low_bit) { + uint16_t op = *(uint16_t *) ctx->ptr; + bool is_32 = (op >> 13 & 7) == 7 && (op >> 11 & 3) != 0; + if (is_32) + return P(dis_thumb2)(ctx); + else + return P(dis_thumb)(ctx); + } else { + return P(dis_arm)(ctx); + } +} -- cgit v1.2.3