summaryrefslogtreecommitdiff
path: root/android/hal-health.c
diff options
context:
space:
mode:
authorRavi kumar Veeramally <ravikumar.veeramally@linux.intel.com>2014-03-14 15:30:57 +0200
committerSzymon Janc <szymon.janc@tieto.com>2014-03-17 14:52:59 +0100
commita852264f4accc9552a08cf274c31de10522b25b5 (patch)
tree4cb6cd48c9d6cddd2c4158d8154cf9f2bba6ad20 /android/hal-health.c
parenta49823593712a225eaa985c7ae3a3951635b1237 (diff)
downloadbluez-a852264f4accc9552a08cf274c31de10522b25b5.tar.gz
android/hal-health: Add HDP .connect_channel method
Diffstat (limited to 'android/hal-health.c')
-rw-r--r--android/hal-health.c32
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
};