From: Szymon Janc Date: Tue, 12 Nov 2013 23:48:16 +0000 (+0000) Subject: android/hidhost: Use adapter address provided on register X-Git-Tag: android-x86-4.4-r3~6852 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=a332daeba9235d8bd419dc6b81b23215131355ca;p=android-x86%2Fexternal-bluetooth-bluez.git android/hidhost: Use adapter address provided on register There is no need to use bt_adapter_get_address every time local address is needed. --- diff --git a/android/hidhost.c b/android/hidhost.c index bb9330e46..f5a607c22 100644 --- a/android/hidhost.c +++ b/android/hidhost.c @@ -47,7 +47,6 @@ #include "hal-msg.h" #include "ipc.h" #include "hidhost.h" -#include "adapter.h" #include "utils.h" #define L2CAP_PSM_HIDP_CTRL 0x11 @@ -77,6 +76,8 @@ /* HID Virtual Cable Unplug */ #define HID_VIRTUAL_CABLE_UNPLUG 0x05 +static bdaddr_t adapter_addr; + static int notification_sk = -1; static GIOChannel *ctrl_io = NULL; static GIOChannel *intr_io = NULL; @@ -586,7 +587,6 @@ static void control_connect_cb(GIOChannel *chan, GError *conn_err, { struct hid_device *dev = user_data; GError *err = NULL; - const bdaddr_t *src = bt_adapter_get_address(); DBG(""); @@ -598,7 +598,7 @@ static void control_connect_cb(GIOChannel *chan, GError *conn_err, /* Connect to the HID interrupt channel */ dev->intr_io = bt_io_connect(interrupt_connect_cb, dev, NULL, &err, - BT_IO_OPT_SOURCE_BDADDR, src, + BT_IO_OPT_SOURCE_BDADDR, &adapter_addr, BT_IO_OPT_DEST_BDADDR, &dev->dst, BT_IO_OPT_PSM, L2CAP_PSM_HIDP_INTR, BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW, @@ -624,7 +624,6 @@ static void hid_sdp_search_cb(sdp_list_t *recs, int err, gpointer data) struct hid_device *dev = data; sdp_list_t *list; GError *gerr = NULL; - const bdaddr_t *src = bt_adapter_get_address(); DBG(""); @@ -698,7 +697,7 @@ static void hid_sdp_search_cb(sdp_list_t *recs, int err, gpointer data) } dev->ctrl_io = bt_io_connect(control_connect_cb, dev, NULL, &gerr, - BT_IO_OPT_SOURCE_BDADDR, src, + BT_IO_OPT_SOURCE_BDADDR, &adapter_addr, BT_IO_OPT_DEST_BDADDR, &dev->dst, BT_IO_OPT_PSM, L2CAP_PSM_HIDP_CTRL, BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW, @@ -723,7 +722,6 @@ static uint8_t bt_hid_connect(struct hal_cmd_hidhost_connect *cmd, char addr[18]; bdaddr_t dst; GSList *l; - const bdaddr_t *src = bt_adapter_get_address(); uuid_t uuid; DBG(""); @@ -745,8 +743,8 @@ static uint8_t bt_hid_connect(struct hal_cmd_hidhost_connect *cmd, DBG("connecting to %s", addr); bt_string2uuid(&uuid, HID_UUID); - if (bt_search_service(src, &dev->dst, &uuid, hid_sdp_search_cb, dev, - NULL) < 0) { + if (bt_search_service(&adapter_addr, &dev->dst, &uuid, + hid_sdp_search_cb, dev, NULL) < 0) { error("Failed to search sdp details"); hid_device_free(dev); return HAL_STATUS_FAILED; @@ -1189,12 +1187,13 @@ static void connect_cb(GIOChannel *chan, GError *err, gpointer user_data) bool bt_hid_register(int sk, const bdaddr_t *addr) { GError *err = NULL; - const bdaddr_t *src = bt_adapter_get_address(); DBG(""); + bacpy(&adapter_addr, addr); + ctrl_io = bt_io_listen(connect_cb, NULL, NULL, NULL, &err, - BT_IO_OPT_SOURCE_BDADDR, src, + BT_IO_OPT_SOURCE_BDADDR, &adapter_addr, BT_IO_OPT_PSM, L2CAP_PSM_HIDP_CTRL, BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW, BT_IO_OPT_INVALID); @@ -1205,7 +1204,7 @@ bool bt_hid_register(int sk, const bdaddr_t *addr) } intr_io = bt_io_listen(connect_cb, NULL, NULL, NULL, &err, - BT_IO_OPT_SOURCE_BDADDR, src, + BT_IO_OPT_SOURCE_BDADDR, &adapter_addr, BT_IO_OPT_PSM, L2CAP_PSM_HIDP_INTR, BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW, BT_IO_OPT_INVALID);