diff options
author | van Hauser <vh@thc.org> | 2024-07-01 08:55:00 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-07-01 08:55:00 +0200 |
commit | e27e3622d465778aba4e75dc623bf1348c46785d (patch) | |
tree | 4a1108a4ffe96db28a31b5fcda1b49c65c806551 /qemu_mode/hooking_bridge/inc | |
parent | a7f928ac31bd75d91f93631790d95a86d13e134f (diff) | |
parent | b169629dbd1cd0b78b541c7fa8eccf6a6a7394b1 (diff) | |
download | afl++-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.h | 11 | ||||
-rw-r--r-- | qemu_mode/hooking_bridge/inc/exports.h | 29 |
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 |