From: Eder Ruiz Maria Date: Sun, 21 Jul 2013 00:17:16 +0000 (-0400) Subject: emulator: Add support for delete a hook X-Git-Tag: android-x86-4.4-r3~7832 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=653a17cc3bbeaae5917ef5061e5592f0fcb1e5ea;p=android-x86%2Fexternal-bluetooth-bluez.git emulator: Add support for delete a hook --- diff --git a/emulator/btdev.c b/emulator/btdev.c index 30022d1c6..b8ac8f61c 100644 --- a/emulator/btdev.c +++ b/emulator/btdev.c @@ -1746,3 +1746,28 @@ int btdev_add_hook(struct btdev *btdev, enum btdev_hook_type type, return -1; } + +bool btdev_del_hook(struct btdev *btdev, enum btdev_hook_type type, + uint16_t opcode) +{ + int i; + + if (!btdev) + return false; + + for (i = 0; i < MAX_HOOK_ENTRIES; i++) { + if (btdev->hook_list[i] == NULL) + continue; + + if (btdev->hook_list[i]->type != type || + btdev->hook_list[i]->opcode != opcode) + continue; + + free(btdev->hook_list[i]); + btdev->hook_list[i] = NULL; + + return true; + } + + return false; +} diff --git a/emulator/btdev.h b/emulator/btdev.h index 085093f40..5118a4a0d 100644 --- a/emulator/btdev.h +++ b/emulator/btdev.h @@ -89,3 +89,6 @@ void btdev_receive_h4(struct btdev *btdev, const void *data, uint16_t len); int btdev_add_hook(struct btdev *btdev, enum btdev_hook_type type, uint16_t opcode, btdev_hook_func handler, void *user_data); + +bool btdev_del_hook(struct btdev *btdev, enum btdev_hook_type type, + uint16_t opcode); diff --git a/src/shared/hciemu.c b/src/shared/hciemu.c index 76fd449a4..f5648a583 100644 --- a/src/shared/hciemu.c +++ b/src/shared/hciemu.c @@ -419,3 +419,31 @@ int hciemu_add_hook(struct hciemu *hciemu, enum hciemu_hook_type type, return btdev_add_hook(hciemu->master_dev, hook_type, opcode, function, user_data); } + +bool hciemu_del_hook(struct hciemu *hciemu, enum hciemu_hook_type type, + uint16_t opcode) +{ + enum btdev_hook_type hook_type; + + if (!hciemu) + return false; + + switch (type) { + case HCIEMU_HOOK_PRE_CMD: + hook_type = BTDEV_HOOK_PRE_CMD; + break; + case HCIEMU_HOOK_POST_CMD: + hook_type = BTDEV_HOOK_POST_CMD; + break; + case HCIEMU_HOOK_PRE_EVT: + hook_type = BTDEV_HOOK_PRE_EVT; + break; + case HCIEMU_HOOK_POST_EVT: + hook_type = BTDEV_HOOK_POST_EVT; + break; + default: + return false; + } + + return btdev_del_hook(hciemu->master_dev, hook_type, opcode); +} diff --git a/src/shared/hciemu.h b/src/shared/hciemu.h index 899acb01f..7f1783110 100644 --- a/src/shared/hciemu.h +++ b/src/shared/hciemu.h @@ -63,3 +63,6 @@ bool hciemu_add_master_post_command_hook(struct hciemu *hciemu, int hciemu_add_hook(struct hciemu *hciemu, enum hciemu_hook_type type, uint16_t opcode, hciemu_hook_func_t function, void *user_data); + +bool hciemu_del_hook(struct hciemu *hciemu, enum hciemu_hook_type type, + uint16_t opcode);