From 3c10d4e0152775b4a07cb7ef226a2eab31ac8546 Mon Sep 17 00:00:00 2001 From: Luiz Augusto von Dentz Date: Mon, 28 Oct 2013 14:09:06 +0200 Subject: [PATCH] android/hal-pan: Add implementation of .disconnect --- android/hal-msg.h | 5 +++++ android/hal-pan.c | 8 +++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/android/hal-msg.h b/android/hal-msg.h index 65f60dcbe..bba031cd5 100644 --- a/android/hal-msg.h +++ b/android/hal-msg.h @@ -309,6 +309,11 @@ struct hal_cmd_pan_connect { uint8_t remote_role; } __attribute__((packed)); +#define HAL_OP_PAN_DISCONNECT 0x04 +struct hal_cmd_pan_disconnect { + uint8_t bdaddr[6]; +} __attribute__((packed)); + /* Notifications and confirmations */ diff --git a/android/hal-pan.c b/android/hal-pan.c index 3e23eb557..cacc6c0da 100644 --- a/android/hal-pan.c +++ b/android/hal-pan.c @@ -85,15 +85,17 @@ static bt_status_t pan_connect(const bt_bdaddr_t *bd_addr, int local_role, static bt_status_t pan_disconnect(const bt_bdaddr_t *bd_addr) { + struct hal_cmd_pan_disconnect cmd; + DBG(""); if (!interface_ready()) return BT_STATUS_NOT_READY; - if (!bd_addr) - return BT_STATUS_PARM_INVALID; + memcpy(cmd.bdaddr, bd_addr, sizeof(cmd.bdaddr)); - return BT_STATUS_UNSUPPORTED; + return hal_ipc_cmd(HAL_SERVICE_ID_PAN, HAL_OP_PAN_DISCONNECT, + sizeof(cmd), &cmd, 0, NULL, NULL); } static bt_status_t pan_init(const btpan_callbacks_t *callbacks)