aboutsummaryrefslogtreecommitdiff
path: root/frida_mode/src/instrument/instrument_debug.c
diff options
context:
space:
mode:
Diffstat (limited to 'frida_mode/src/instrument/instrument_debug.c')
-rw-r--r--frida_mode/src/instrument/instrument_debug.c58
1 files changed, 32 insertions, 26 deletions
diff --git a/frida_mode/src/instrument/instrument_debug.c b/frida_mode/src/instrument/instrument_debug.c
index f8c1df77..0ce26a1c 100644
--- a/frida_mode/src/instrument/instrument_debug.c
+++ b/frida_mode/src/instrument/instrument_debug.c
@@ -7,6 +7,7 @@
#include "debug.h"
+#include "instrument.h"
#include "util.h"
static int debugging_fd = -1;
@@ -31,44 +32,50 @@ static void instrument_debug(char *format, ...) {
}
-static void instrument_disasm(guint8 *code, guint size) {
+static void instrument_disasm(guint8 *start, guint8 *end) {
csh capstone;
cs_err err;
+ uint16_t size;
cs_insn *insn;
- size_t count, i;
+ size_t count = 0;
+ size_t i;
+ uint16_t len;
err = cs_open(GUM_DEFAULT_CS_ARCH,
GUM_DEFAULT_CS_MODE | GUM_DEFAULT_CS_ENDIAN, &capstone);
g_assert(err == CS_ERR_OK);
- count = cs_disasm(capstone, code, size, GPOINTER_TO_SIZE(code), 0, &insn);
- g_assert(insn != NULL);
+ size = GPOINTER_TO_SIZE(end) - GPOINTER_TO_SIZE(start);
- for (i = 0; i != count; i++) {
+ for (guint8 *curr = start; curr < end; curr += len, size -= len, len = 0) {
- instrument_debug("\t0x%" G_GINT64_MODIFIER "x\t%s %s\n", insn[i].address,
- insn[i].mnemonic, insn[i].op_str);
+ count = cs_disasm(capstone, curr, size, GPOINTER_TO_SIZE(curr), 0, &insn);
+ if (insn == NULL) {
- }
+ instrument_debug("\t0x%" G_GINT64_MODIFIER "x\t* 0x%016" G_GSIZE_MODIFIER
+ "x\n",
+ curr, *(size_t *)curr);
- cs_free(insn, count);
+ len += sizeof(size_t);
+ continue;
- cs_close(&capstone);
+ }
-}
+ for (i = 0; i != count; i++) {
+
+ instrument_debug("\t0x%" G_GINT64_MODIFIER "x\t%s %s\n", insn[i].address,
+ insn[i].mnemonic, insn[i].op_str);
+
+ len += insn[i].size;
-static gpointer instrument_cur(GumStalkerOutput *output) {
+ }
-#if defined(__i386__) || defined(__x86_64__)
- return gum_x86_writer_cur(output->writer.x86);
-#elif defined(__aarch64__)
- return gum_arm64_writer_cur(output->writer.arm64);
-#elif defined(__arm__)
- return gum_arm_writer_cur(output->writer.arm);
-#else
- #error "Unsupported architecture"
-#endif
+ }
+
+ cs_free(insn, count);
+
+ cs_close(&capstone);
}
@@ -111,7 +118,7 @@ void instrument_debug_instruction(uint64_t address, uint16_t size) {
if (likely(debugging_fd < 0)) { return; }
uint8_t *start = (uint8_t *)GSIZE_TO_POINTER(address);
- instrument_disasm(start, size);
+ instrument_disasm(start, start + size);
}
@@ -119,11 +126,10 @@ void instrument_debug_end(GumStalkerOutput *output) {
if (likely(debugging_fd < 0)) { return; }
gpointer instrument_gen_end = instrument_cur(output);
- uint16_t size = GPOINTER_TO_SIZE(instrument_gen_end) -
- GPOINTER_TO_SIZE(instrument_gen_start);
- instrument_debug("\nGenerated block %p\n", instrument_gen_start);
- instrument_disasm(instrument_gen_start, size);
+ instrument_debug("\nGenerated block %p-%p\n", instrument_gen_start,
+ instrument_gen_end);
+ instrument_disasm(instrument_gen_start, instrument_gen_end);
}