diff options
author | Ravi kumar Veeramally <ravikumar.veeramally@linux.intel.com> | 2014-03-14 15:30:57 +0200 |
---|---|---|
committer | Szymon Janc <szymon.janc@tieto.com> | 2014-03-17 14:52:59 +0100 |
commit | a852264f4accc9552a08cf274c31de10522b25b5 (patch) | |
tree | 4cb6cd48c9d6cddd2c4158d8154cf9f2bba6ad20 /android/hal-health.c | |
parent | a49823593712a225eaa985c7ae3a3951635b1237 (diff) | |
download | bluez-a852264f4accc9552a08cf274c31de10522b25b5.tar.gz |
android/hal-health: Add HDP .connect_channel method
Diffstat (limited to 'android/hal-health.c')
-rw-r--r-- | android/hal-health.c | 32 |
1 files changed, 31 insertions, 1 deletions
diff --git a/android/hal-health.c b/android/hal-health.c index 2dfba8039..e2ccc957b 100644 --- a/android/hal-health.c +++ b/android/hal-health.c @@ -53,6 +53,36 @@ static bt_status_t unregister_application(int app_id) sizeof(cmd), &cmd, 0, NULL, NULL); } +static bt_status_t connect_channel(int app_id, bt_bdaddr_t *bd_addr, + int mdep_cfg_index, int *channel_id) +{ + struct hal_cmd_health_connect_channel cmd; + struct hal_rsp_health_connect_channel rsp; + size_t len = sizeof(rsp); + bt_status_t status; + + DBG(""); + + if (!interface_ready()) + return BT_STATUS_NOT_READY; + + if (!bd_addr || !channel_id) + return BT_STATUS_PARM_INVALID; + + cmd.app_id = app_id; + cmd.mdep_index = mdep_cfg_index; + memcpy(cmd.bdaddr, bd_addr, sizeof(cmd.bdaddr)); + + status = hal_ipc_cmd(HAL_SERVICE_ID_HEALTH, + HAL_OP_HEALTH_CONNECT_CHANNEL, + sizeof(cmd), &cmd, &len, &rsp, NULL); + + if (status == HAL_STATUS_SUCCESS) + *channel_id = rsp.channel_id; + + return status; +} + static bt_status_t init(bthl_callbacks_t *callbacks) { struct hal_cmd_register_module cmd; @@ -106,7 +136,7 @@ static bthl_interface_t health_if = { .init = init, .register_application = NULL, .unregister_application = unregister_application, - .connect_channel = NULL, + .connect_channel = connect_channel, .destroy_channel = NULL, .cleanup = cleanup }; |