From: Andrei Emeltchenko <andrei.emeltchenko@xxxxxxxxx> Send HAL_EV_ACL_STATE_CHANGED event to HAL through IPC. --- android/adapter.c | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/android/adapter.c b/android/adapter.c index 4ddd68b..df56452 100644 --- a/android/adapter.c +++ b/android/adapter.c @@ -620,6 +620,29 @@ static void mgmt_device_found_event(uint16_t index, uint16_t length, confirm_name, eir, eir_len); } +static void mgmt_device_connected_event(uint16_t index, uint16_t length, + const void *param, void *user_data) +{ + const struct mgmt_ev_device_connected *ev = param; + struct hal_ev_acl_state_changed hal_ev; + + if (length < sizeof(*ev)) { + error("Too short %s (%u bytes)", __func__, length); + return; + } + + /* TODO: Update device */ + + /* TODO: Check Set bonding state */ + + hal_ev.status = HAL_STATUS_SUCCESS; + hal_ev.state = HAL_ACL_STATE_CONNECTED; + bdaddr2android(&ev->addr.bdaddr, &hal_ev.bdaddr); + + ipc_send(notification_io, HAL_SERVICE_ID_BLUETOOTH, + HAL_EV_ACL_STATE_CHANGED, sizeof(hal_ev), &hal_ev, -1); +} + static void register_mgmt_handlers(void) { mgmt_register(adapter->mgmt, MGMT_EV_NEW_SETTINGS, adapter->index, @@ -657,6 +680,9 @@ static void register_mgmt_handlers(void) mgmt_register(adapter->mgmt, MGMT_EV_DEVICE_FOUND, adapter->index, mgmt_device_found_event, NULL, NULL); + + mgmt_register(adapter->mgmt, MGMT_EV_DEVICE_CONNECTED, adapter->index, + mgmt_device_connected_event, NULL, NULL); } static void load_link_keys_complete(uint8_t status, uint16_t length, -- 1.7.10.4 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html