From 17706aa42214addb95ee4aea5177a8784960dfc1 Mon Sep 17 00:00:00 2001 From: Harish Paryani Date: Wed, 7 Mar 2012 16:36:03 -0800 Subject: Disconnect before Unpair Change-Id: Ib28372748df21d36d371d308975758f60df7aa28 --- bta/dm/bta_dm_act.c | 60 ++++++++++++++++++++++++++++++++++++++++++--------- bta/dm/bta_dm_api.c | 24 +++++++++------------ bta/dm/bta_dm_int.h | 15 ++++++++++++- bta/dm/bta_dm_main.c | 2 ++ bta/include/bta_api.h | 1 + 5 files changed, 77 insertions(+), 25 deletions(-) mode change 100644 => 100755 bta/dm/bta_dm_act.c mode change 100644 => 100755 bta/dm/bta_dm_api.c mode change 100644 => 100755 bta/dm/bta_dm_int.h mode change 100644 => 100755 bta/dm/bta_dm_main.c mode change 100644 => 100755 bta/include/bta_api.h (limited to 'bta') diff --git a/bta/dm/bta_dm_act.c b/bta/dm/bta_dm_act.c old mode 100644 new mode 100755 index 0f1875a..30a77e3 --- a/bta/dm/bta_dm_act.c +++ b/bta/dm/bta_dm_act.c @@ -607,6 +607,42 @@ void bta_dm_tx_inqpower(tBTA_DM_MSG *p_data) /******************************************************************************* ** +** Function bta_dm_remove_device +** +** Description Removes device, Disconnects ACL link if required. +**** +*******************************************************************************/ +void bta_dm_remove_device (tBTA_DM_MSG *p_data) +{ + tBTA_DM_API_REMOVE_DEVICE *p_dev = &p_data->remove_dev; + int i; + + if (BTM_IsAclConnectionUp(p_dev->bd_addr)) + { + /* Take the link down first, and mark the device for removal when disconnected */ + btm_remove_acl( p_dev->bd_addr) ; + + for(i=0; ibd_addr)) + break; + } + + if(i < bta_dm_cb.device_list.count) + { + bta_dm_cb.device_list.peer_device[i].conn_state = BTA_DM_UNPAIRING; + } + } + else /* Ok to remove the device in application layer */ + { + BTM_SecDeleteDevice(p_dev->bd_addr); + if( bta_dm_cb.p_sec_cback ) + bta_dm_cb.p_sec_cback(BTA_DM_DEV_UNPAIRED_EVT, p_dev->bd_addr); + } +} + +/******************************************************************************* +** ** Function bta_dm_add_device ** ** Description This function adds a Link Key to an security database entry. @@ -3080,6 +3116,7 @@ void bta_dm_acl_change(tBTA_DM_MSG *p_data) BOOLEAN is_new = p_data->acl_change.is_new; BD_ADDR_PTR p_bda = p_data->acl_change.bd_addr; BOOLEAN need_policy_change = FALSE; + BOOLEAN issue_unpair_cb = FALSE; #if (defined(BTM_BUSY_LEVEL_CHANGE_INCLUDED) && BTM_BUSY_LEVEL_CHANGE_INCLUDED == TRUE) tBTA_DM_PEER_DEVICE *p_dev; @@ -3181,18 +3218,20 @@ void bta_dm_acl_change(tBTA_DM_MSG *p_data) if(bdcmp( bta_dm_cb.device_list.peer_device[i].peer_bdaddr, p_bda)) continue; - for(; ihdr.event = BTA_DM_API_REMOVE_DEVICE_EVT; + bdcpy(p_msg->bd_addr, bd_addr); + bta_sys_sendmsg(p_msg); } - else /* Ok to remove the device in application layer */ + else { - BTM_SecDeleteDevice(bd_addr); + return BTA_FAILURE; } - GKI_sched_unlock(); - if(device_ok_to_remove) - return BTA_SUCCESS; - else - return BTA_FAILURE; + return BTA_SUCCESS; } /******************************************************************************* diff --git a/bta/dm/bta_dm_int.h b/bta/dm/bta_dm_int.h old mode 100644 new mode 100755 index 5f1da2a..6d220e7 --- a/bta/dm/bta_dm_int.h +++ b/bta/dm/bta_dm_int.h @@ -74,6 +74,8 @@ enum BTA_DM_CI_RMT_OOB_EVT, #endif /* BTM_OOB_INCLUDED */ + BTA_DM_API_REMOVE_DEVICE_EVT, + #if BLE_INCLUDED == TRUE BTA_DM_API_ADD_BLEKEY_EVT, BTA_DM_API_ADD_BLEDEVICE_EVT, @@ -383,6 +385,13 @@ typedef struct BD_FEATURES features; } tBTA_DM_API_ADD_DEVICE; +/* data type for BTA_DM_API_REMOVE_ACL_EVT */ +typedef struct +{ + BT_HDR hdr; + BD_ADDR bd_addr; +} tBTA_DM_API_REMOVE_DEVICE; + /* data type for BTA_DM_API_EXECUTE_CBACK_EVT */ typedef struct { @@ -506,6 +515,8 @@ typedef union tBTA_DM_API_ADD_DEVICE add_dev; + tBTA_DM_API_REMOVE_DEVICE remove_dev; + tBTA_DM_API_SEARCH search; tBTA_DM_API_DISCOVER discover; @@ -575,7 +586,7 @@ typedef union #define BTA_DM_NOT_CONNECTED 0 #define BTA_DM_CONNECTED 1 - +#define BTA_DM_UNPAIRING 2 typedef UINT8 tBTA_DM_CONN_STATE; @@ -885,6 +896,8 @@ extern void bta_dm_signal_strength(tBTA_DM_MSG *p_data); extern void bta_dm_tx_inqpower(tBTA_DM_MSG *p_data); extern void bta_dm_acl_change(tBTA_DM_MSG *p_data); extern void bta_dm_add_device (tBTA_DM_MSG *p_data); +extern void bta_dm_remove_device (tBTA_DM_MSG *p_data); + extern void bta_dm_pm_btm_status(tBTA_DM_MSG *p_data); extern void bta_dm_pm_timer(tBTA_DM_MSG *p_data); diff --git a/bta/dm/bta_dm_main.c b/bta/dm/bta_dm_main.c old mode 100644 new mode 100755 index a3dd167..38bf0af --- a/bta/dm/bta_dm_main.c +++ b/bta/dm/bta_dm_main.c @@ -72,6 +72,8 @@ const tBTA_DM_ACTION bta_dm_action[] = bta_dm_ci_rmt_oob_act, /* 22 BTA_DM_CI_RMT_OOB_EVT */ #endif /* BTM_OOB_INCLUDED */ + bta_dm_remove_device, /* BTA_DM_API_REMOVE_DEVICE_EVT */ + #if BLE_INCLUDED == TRUE bta_dm_add_blekey, /* BTA_DM_API_ADD_BLEKEY_EVT */ bta_dm_add_ble_device, /* BTA_DM_API_ADD_BLEDEVICE_EVT */ diff --git a/bta/include/bta_api.h b/bta/include/bta_api.h old mode 100644 new mode 100755 index 8d7b71b..e8f5892 --- a/bta/include/bta_api.h +++ b/bta/include/bta_api.h @@ -402,6 +402,7 @@ typedef UINT8 tBTA_SIG_STRENGTH_MASK; // btla-specific ++ #define BTA_DM_BLE_AUTH_CMPL_EVT 22 /* BLE Auth complete */ // btla-specific -- +#define BTA_DM_DEV_UNPAIRED_EVT 23 typedef UINT8 tBTA_DM_SEC_EVT; -- cgit v1.1