1
0
Fork 0
mirror of https://github.com/yuzu-emu/unicorn.git synced 2025-01-11 11:45:39 +00:00

on some hook events, uc_hook_add() should not allow more than 1 handler. this add UC_ERR_HOOK_EXIST error type

This commit is contained in:
Nguyen Anh Quynh 2015-10-10 18:01:47 +08:00
parent 5b24c24e82
commit b1d41d414b
6 changed files with 46 additions and 10 deletions
bindings
go/unicorn
java/unicorn
python/unicorn
include/unicorn
tests/regress
uc.c

View file

@ -52,6 +52,7 @@ const (
ERR_READ_UNALIGNED = 16 ERR_READ_UNALIGNED = 16
ERR_WRITE_UNALIGNED = 17 ERR_WRITE_UNALIGNED = 17
ERR_FETCH_UNALIGNED = 18 ERR_FETCH_UNALIGNED = 18
ERR_HOOK_EXIST = 19
MEM_READ = 16 MEM_READ = 16
MEM_WRITE = 17 MEM_WRITE = 17
MEM_FETCH = 18 MEM_FETCH = 18

View file

@ -54,6 +54,7 @@ public interface UnicornConst {
public static final int UC_ERR_READ_UNALIGNED = 16; public static final int UC_ERR_READ_UNALIGNED = 16;
public static final int UC_ERR_WRITE_UNALIGNED = 17; public static final int UC_ERR_WRITE_UNALIGNED = 17;
public static final int UC_ERR_FETCH_UNALIGNED = 18; public static final int UC_ERR_FETCH_UNALIGNED = 18;
public static final int UC_ERR_HOOK_EXIST = 19;
public static final int UC_MEM_READ = 16; public static final int UC_MEM_READ = 16;
public static final int UC_MEM_WRITE = 17; public static final int UC_MEM_WRITE = 17;
public static final int UC_MEM_FETCH = 18; public static final int UC_MEM_FETCH = 18;

View file

@ -50,6 +50,7 @@ UC_ERR_ARG = 15
UC_ERR_READ_UNALIGNED = 16 UC_ERR_READ_UNALIGNED = 16
UC_ERR_WRITE_UNALIGNED = 17 UC_ERR_WRITE_UNALIGNED = 17
UC_ERR_FETCH_UNALIGNED = 18 UC_ERR_FETCH_UNALIGNED = 18
UC_ERR_HOOK_EXIST = 19
UC_MEM_READ = 16 UC_MEM_READ = 16
UC_MEM_WRITE = 17 UC_MEM_WRITE = 17
UC_MEM_FETCH = 18 UC_MEM_FETCH = 18

View file

@ -124,6 +124,7 @@ typedef enum uc_err {
UC_ERR_READ_UNALIGNED, // Unaligned read UC_ERR_READ_UNALIGNED, // Unaligned read
UC_ERR_WRITE_UNALIGNED, // Unaligned write UC_ERR_WRITE_UNALIGNED, // Unaligned write
UC_ERR_FETCH_UNALIGNED, // Unaligned fetch UC_ERR_FETCH_UNALIGNED, // Unaligned fetch
UC_ERR_HOOK_EXIST, // hook for this event already existed
} uc_err; } uc_err;

View file

@ -9,5 +9,8 @@ def hook_mem_read_unmapped(mu, access, address, size, value, user_data):
mu = unicorn.Uc(unicorn.UC_ARCH_X86, unicorn.UC_MODE_32) mu = unicorn.Uc(unicorn.UC_ARCH_X86, unicorn.UC_MODE_32)
for x in range(0, 1000): try:
mu.hook_add(unicorn.UC_HOOK_MEM_READ_UNMAPPED, hook_mem_read_unmapped, None) for x in range(0, 1000):
mu.hook_add(unicorn.UC_HOOK_MEM_READ_UNMAPPED, hook_mem_read_unmapped, None)
except unicorn.UcError as e:
print("ERROR: %s" % e)

45
uc.c
View file

@ -89,13 +89,14 @@ const char *uc_strerror(uc_err code)
return "Fetch from non-executable memory (UC_ERR_FETCH_PROT)"; return "Fetch from non-executable memory (UC_ERR_FETCH_PROT)";
case UC_ERR_ARG: case UC_ERR_ARG:
return "Invalid argumet (UC_ERR_ARG)"; return "Invalid argumet (UC_ERR_ARG)";
case UC_ERR_READ_UNALIGNED: case UC_ERR_READ_UNALIGNED:
return "Read from unaligned memory (UC_ERR_READ_UNALIGNED)"; return "Read from unaligned memory (UC_ERR_READ_UNALIGNED)";
case UC_ERR_WRITE_UNALIGNED: case UC_ERR_WRITE_UNALIGNED:
return "Write to unaligned memory (UC_ERR_WRITE_UNALIGNED)"; return "Write to unaligned memory (UC_ERR_WRITE_UNALIGNED)";
case UC_ERR_FETCH_UNALIGNED: case UC_ERR_FETCH_UNALIGNED:
return "Fetch from unaligned memory (UC_ERR_FETCH_UNALIGNED)"; return "Fetch from unaligned memory (UC_ERR_FETCH_UNALIGNED)";
case UC_ERR_HOOK_EXIST:
return "Hook for this type event already existed (UC_ERR_HOOK_EXIST)";
} }
} }
@ -538,7 +539,7 @@ static int _hook_code(uc_engine *uc, int type, uint64_t begin, uint64_t end,
i = hook_add(uc, type, begin, end, callback, user_data); i = hook_add(uc, type, begin, end, callback, user_data);
if (i == 0) if (i == 0)
return UC_ERR_NOMEM; // FIXME return UC_ERR_NOMEM;
*hh = i; *hh = i;
@ -554,7 +555,7 @@ static uc_err _hook_mem_access(uc_engine *uc, uc_hook_type type,
i = hook_add(uc, type, begin, end, callback, user_data); i = hook_add(uc, type, begin, end, callback, user_data);
if (i == 0) if (i == 0)
return UC_ERR_NOMEM; // FIXME return UC_ERR_NOMEM;
*hh = i; *hh = i;
@ -833,7 +834,24 @@ static uc_err _hook_mem_invalid(struct uc_struct* uc, int type, uc_cb_eventmem_t
{ {
size_t i; size_t i;
// FIXME: only one event handler at the same time // only one event handler at the same time
if ((type & UC_HOOK_MEM_READ_UNMAPPED) != 0 && (uc->hook_mem_read_idx != 0))
return UC_ERR_HOOK_EXIST;
if ((type & UC_HOOK_MEM_READ_PROT) != 0 && (uc->hook_mem_read_prot_idx != 0))
return UC_ERR_HOOK_EXIST;
if ((type & UC_HOOK_MEM_WRITE_UNMAPPED) != 0 && (uc->hook_mem_write_idx != 0))
return UC_ERR_HOOK_EXIST;
if ((type & UC_HOOK_MEM_WRITE_PROT) != 0 && (uc->hook_mem_write_prot_idx != 0))
return UC_ERR_HOOK_EXIST;
if ((type & UC_HOOK_MEM_FETCH_UNMAPPED) != 0 && (uc->hook_mem_fetch_idx != 0))
return UC_ERR_HOOK_EXIST;
if ((type & UC_HOOK_MEM_FETCH_PROT) != 0 && (uc->hook_mem_fetch_prot_idx != 0))
return UC_ERR_HOOK_EXIST;
i = hook_find_new(uc); i = hook_find_new(uc);
if (i) { if (i) {
@ -863,7 +881,9 @@ static uc_err _hook_intr(struct uc_struct* uc, void *callback,
{ {
size_t i; size_t i;
// FIXME: only one event handler at the same time // only one event handler at the same time
if (uc->hook_intr_idx)
return UC_ERR_HOOK_EXIST;
i = hook_find_new(uc); i = hook_find_new(uc);
if (i) { if (i) {
@ -888,7 +908,10 @@ static uc_err _hook_insn(struct uc_struct *uc, unsigned int insn_id, void *callb
switch(insn_id) { switch(insn_id) {
default: break; default: break;
case UC_X86_INS_OUT: case UC_X86_INS_OUT:
// FIXME: only one event handler at the same time // only one event handler at the same time
if (uc->hook_out_idx)
return UC_ERR_HOOK_EXIST;
i = hook_find_new(uc); i = hook_find_new(uc);
if (i) { if (i) {
uc->hook_callbacks[i].callback = callback; uc->hook_callbacks[i].callback = callback;
@ -899,7 +922,10 @@ static uc_err _hook_insn(struct uc_struct *uc, unsigned int insn_id, void *callb
} else } else
return UC_ERR_NOMEM; return UC_ERR_NOMEM;
case UC_X86_INS_IN: case UC_X86_INS_IN:
// FIXME: only one event handler at the same time // only one event handler at the same time
if (uc->hook_in_idx)
return UC_ERR_HOOK_EXIST;
i = hook_find_new(uc); i = hook_find_new(uc);
if (i) { if (i) {
uc->hook_callbacks[i].callback = callback; uc->hook_callbacks[i].callback = callback;
@ -911,7 +937,10 @@ static uc_err _hook_insn(struct uc_struct *uc, unsigned int insn_id, void *callb
return UC_ERR_NOMEM; return UC_ERR_NOMEM;
case UC_X86_INS_SYSCALL: case UC_X86_INS_SYSCALL:
case UC_X86_INS_SYSENTER: case UC_X86_INS_SYSENTER:
// FIXME: only one event handler at the same time // only one event handler at the same time
if (uc->hook_syscall_idx)
return UC_ERR_HOOK_EXIST;
i = hook_find_new(uc); i = hook_find_new(uc);
if (i) { if (i) {
uc->hook_callbacks[i].callback = callback; uc->hook_callbacks[i].callback = callback;