From 7f445ac7d5e5241a43c114ebf5831a8bd40baa7c Mon Sep 17 00:00:00 2001 From: Ravi kumar Veeramally Date: Fri, 10 Jan 2014 16:11:48 +0200 Subject: [PATCH] android/pan: Implement PAN enable HAL api at daemon side --- android/pan.c | 30 ++++++++++++++++++++++++++---- 1 file changed, 26 insertions(+), 4 deletions(-) diff --git a/android/pan.c b/android/pan.c index 21a46b467..9f99ed96b 100644 --- a/android/pan.c +++ b/android/pan.c @@ -576,18 +576,40 @@ static void bt_pan_enable(const void *buf, uint16_t len) { const struct hal_cmd_pan_enable *cmd = buf; uint8_t status; + int err; + + DBG(""); + + if (local_role == cmd->local_role) { + status = HAL_STATUS_SUCCESS; + goto reply; + } + + /* destroy existing server */ + destroy_nap_device(); switch (cmd->local_role) { - case HAL_PAN_ROLE_PANU: case HAL_PAN_ROLE_NAP: - DBG("Not Implemented"); - status = HAL_STATUS_FAILED; break; + case HAL_PAN_ROLE_NONE: + status = HAL_STATUS_SUCCESS; + goto reply; default: status = HAL_STATUS_UNSUPPORTED; - break; + goto reply; } + local_role = cmd->local_role; + err = register_nap_server(); + if (err < 0) { + status = HAL_STATUS_FAILED; + destroy_nap_device(); + goto reply; + } + + status = HAL_STATUS_SUCCESS; + +reply: ipc_send_rsp(HAL_SERVICE_ID_PAN, HAL_OP_PAN_ENABLE, status); } -- 2.47.3