From: Pavel Dovgalyuk <pavel.dovga...@ispras.ru> This patch adds a plugin for logging addresses of all executed instructions, making a complete instruction-level trace.
Signed-off-by: Pavel Dovgalyuk <pavel.dovga...@ispras.ru> --- plugins/exec-log/Makefile | 19 +++++++++++++++++++ plugins/exec-log/exec-log.c | 18 ++++++++++++++++++ 2 files changed, 37 insertions(+) create mode 100644 plugins/exec-log/Makefile create mode 100644 plugins/exec-log/exec-log.c diff --git a/plugins/exec-log/Makefile b/plugins/exec-log/Makefile new file mode 100644 index 0000000..86374f4 --- /dev/null +++ b/plugins/exec-log/Makefile @@ -0,0 +1,19 @@ +CFLAGS += -I../include -fno-PIE -fPIC -O3 +LDFLAGS += -shared +# TODO: Windows +DSOSUF := .so + +NAME:= exec-log +BIN := $(NAME)$(DSOSUF) + +FILES := exec-log.o + +%.o: %.c + $(CC) -c -o $@ $< $(CFLAGS) + +all: $(FILES) + $(CC) $(LDFLAGS) -o $(BIN) $(FILES) + +clean: + rm $(FILES) + rm $(BIN) diff --git a/plugins/exec-log/exec-log.c b/plugins/exec-log/exec-log.c new file mode 100644 index 0000000..7fc7975 --- /dev/null +++ b/plugins/exec-log/exec-log.c @@ -0,0 +1,18 @@ +#include <stdint.h> +#include <stdio.h> +#include "plugins.h" + +bool plugin_init(const char *args) +{ + return true; +} + +bool plugin_needs_before_insn(uint64_t pc, void *cpu) +{ + return true; +} + +void plugin_before_insn(uint64_t pc, void *cpu) +{ + qemulib_log("executing instruction at %lx\n", pc); +}