Return-Path: From: Ravi kumar Veeramally To: linux-bluetooth@vger.kernel.org Cc: Ravi kumar Veeramally Subject: [PATCH_v6 3/4] android/pan: Implement PAN enable HAL api at daemon side Date: Fri, 10 Jan 2014 15:50:39 +0200 Message-Id: <1389361840-5021-4-git-send-email-ravikumar.veeramally@linux.intel.com> In-Reply-To: <1389361840-5021-1-git-send-email-ravikumar.veeramally@linux.intel.com> References: <1389361840-5021-1-git-send-email-ravikumar.veeramally@linux.intel.com> Sender: linux-bluetooth-owner@vger.kernel.org List-ID: --- android/pan.c | 30 ++++++++++++++++++++++++++---- 1 file changed, 26 insertions(+), 4 deletions(-) diff --git a/android/pan.c b/android/pan.c index d683945..a733d22 100644 --- a/android/pan.c +++ b/android/pan.c @@ -574,18 +574,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); } -- 1.8.3.2