Merge branch 'master' into noglib

This commit is contained in:
Nguyen Anh Quynh 2016-12-22 12:13:34 +08:00
commit 93044e39f1
2 changed files with 11 additions and 10 deletions

View file

@ -279,6 +279,7 @@ dist:
git archive --format=zip --prefix=unicorn-$(DIST_VERSION)/ $(TAG) > unicorn-$(DIST_VERSION).zip git archive --format=zip --prefix=unicorn-$(DIST_VERSION)/ $(TAG) > unicorn-$(DIST_VERSION).zip
# run "make header" whenever qemu/header_gen.py is modified
header: header:
$(eval TARGETS := m68k arm aarch64 mips mipsel mips64 mips64el\ $(eval TARGETS := m68k arm aarch64 mips mipsel mips64 mips64el\
powerpc sparc sparc64 x86_64) powerpc sparc sparc64 x86_64)

16
uc.c
View file

@ -1069,20 +1069,20 @@ uc_err uc_hook_add(uc_engine *uc, uc_hook *hh, int type, void *callback,
UNICORN_EXPORT UNICORN_EXPORT
uc_err uc_hook_del(uc_engine *uc, uc_hook hh) uc_err uc_hook_del(uc_engine *uc, uc_hook hh)
{ {
int i = 0; int i;
struct hook *hook = (struct hook *)hh; struct hook *hook = (struct hook *)hh;
int type = hook->type; // we can't dereference hook->type if hook is invalid
// so for now we need to iterate over all possible types to remove the hook
while ((type >> i) > 0 && i < UC_HOOK_MAX) { // which is less efficient
if ((type >> i) & 1) { // an optimization would be to align the hook pointer
if (list_remove(&uc->hook[i], (void *)hh)) { // and store the type mask in the hook pointer.
for (i = 0; i < UC_HOOK_MAX; i++) {
if (list_remove(&uc->hook[i], (void *)hook)) {
if (--hook->refs == 0) { if (--hook->refs == 0) {
free(hook); free(hook);
} }
} }
} }
i++;
}
return UC_ERR_OK; return UC_ERR_OK;
} }