From 7e1faaf64d9d362da70a3f4b4c1fca517fad7862 Mon Sep 17 00:00:00 2001 From: Ganesh Ganapathi Batta Date: Fri, 27 Apr 2012 11:41:19 -0700 Subject: Assign proper fail reasons to status parameter while sending Auth Complete event when Authentication fails Change-Id: I0102762b8bfa06b8d99227c431be881269c14961 --- btif/src/btif_dm.c | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) (limited to 'btif/src/btif_dm.c') diff --git a/btif/src/btif_dm.c b/btif/src/btif_dm.c index 55300d5..df4998d 100644 --- a/btif/src/btif_dm.c +++ b/btif/src/btif_dm.c @@ -641,7 +641,6 @@ static void btif_dm_auth_cmpl_evt (tBTA_DM_AUTH_CMPL *p_auth_cmpl) __FUNCTION__, p_auth_cmpl->key_type, pairing_cb.is_temp); } } - if (p_auth_cmpl->success) { status = BT_STATUS_SUCCESS; @@ -650,7 +649,25 @@ static void btif_dm_auth_cmpl_evt (tBTA_DM_AUTH_CMPL *p_auth_cmpl) /* Trigger SDP on the device */ btif_dm_get_remote_services(&bd_addr); } + else + { + /*Map the HCI fail reason to bt status */ + switch(p_auth_cmpl->fail_reason) + { + case HCI_ERR_PAGE_TIMEOUT: + case HCI_ERR_CONNECTION_TOUT: + status = BT_STATUS_RMT_DEV_DOWN; + break; + case HCI_ERR_AUTH_FAILURE: + status = BT_STATUS_AUTH_FAILURE; + break; + + default: + status = BT_STATUS_FAIL; + } + + } bond_state_changed(status, &bd_addr, state); } -- cgit v1.1