about summary refs log tree commit diff
path: root/qemu_mode/hooking_bridge/inc
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2024-07-01 08:55:00 +0200
committerGitHub <noreply@github.com>2024-07-01 08:55:00 +0200
commite27e3622d465778aba4e75dc623bf1348c46785d (patch)
tree4a1108a4ffe96db28a31b5fcda1b49c65c806551 /qemu_mode/hooking_bridge/inc
parenta7f928ac31bd75d91f93631790d95a86d13e134f (diff)
parentb169629dbd1cd0b78b541c7fa8eccf6a6a7394b1 (diff)
downloadafl++-e27e3622d465778aba4e75dc623bf1348c46785d.tar.gz
Merge pull request #2140 from CowBoy4mH3LL/dev
Adding of QEMU hooking bridge
Diffstat (limited to 'qemu_mode/hooking_bridge/inc')
-rw-r--r--qemu_mode/hooking_bridge/inc/common.h11
-rw-r--r--qemu_mode/hooking_bridge/inc/exports.h29
2 files changed, 40 insertions, 0 deletions
diff --git a/qemu_mode/hooking_bridge/inc/common.h b/qemu_mode/hooking_bridge/inc/common.h
new file mode 100644
index 00000000..f2260977
--- /dev/null
+++ b/qemu_mode/hooking_bridge/inc/common.h
@@ -0,0 +1,11 @@
+#ifndef COMMON_H
+#define COMMON_H
+
+#include <qemu/qemu-plugin.h>
+
+void patch_finish_cb(void *userdata);
+void patch_block_trans_cb(struct qemu_plugin_tb *tb);
+void patch_vpu_init_cb(unsigned int vcpu_index);
+void patch_init(char *hook_library);
+
+#endif
\ No newline at end of file
diff --git a/qemu_mode/hooking_bridge/inc/exports.h b/qemu_mode/hooking_bridge/inc/exports.h
new file mode 100644
index 00000000..186976f4
--- /dev/null
+++ b/qemu_mode/hooking_bridge/inc/exports.h
@@ -0,0 +1,29 @@
+#ifndef API_H
+#define API_H
+
+//# EXPORTS
+// Returns 0 on success
+int r_mem(unsigned long long addr, unsigned long long len, void *dest);
+// // Returns 0 on success
+int w_mem(unsigned long long addr, unsigned long long len, void *src);
+// Returns num of bytes read; 
+int r_reg(unsigned char reg, void *dest);
+// // Returns num of bytes written
+int w_reg(unsigned char reg, char *src);
+
+
+//NOTE hook function must be named hook_<16 hex character at_addr>
+//NOTE must define function `struct conf* configure()`
+struct conf{
+    unsigned char IP_reg_num;
+    unsigned long long entry_addr;
+    unsigned long long* hooks;
+    unsigned long long num_hooks;
+}conf;
+
+struct ret{
+    unsigned long long addr;
+    char remove_bp;
+};
+
+#endif
\ No newline at end of file