blob: 9545b3670582a8860b187ae9a665f1f2cd105380 [file] [log] [blame]
The Android Open Source Project5738f832012-12-12 16:00:35 -08001/******************************************************************************
2 *
3 * Copyright (C) 2009-2012 Broadcom Corporation
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at:
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 ******************************************************************************/
18
19/************************************************************************************
20 *
21 * Filename: btif_dm.c
22 *
23 * Description: Contains Device Management (DM) related functionality
24 *
25 *
26 ***********************************************************************************/
Sharvil Nanavati44802762014-12-23 23:08:58 -080027
Chris Mantonf8027002015-03-12 09:22:48 -070028#define LOG_TAG "bt_btif_dm"
Sharvil Nanavati44802762014-12-23 23:08:58 -080029
Scott James Remnant933926c2015-04-02 15:22:14 -070030#include <signal.h>
The Android Open Source Project5738f832012-12-12 16:00:35 -080031#include <stdio.h>
32#include <stdlib.h>
Ian Coolidgec7503db2015-01-24 02:01:26 -080033#include <string.h>
Scott James Remnant933926c2015-04-02 15:22:14 -070034#include <sys/types.h>
The Android Open Source Project5738f832012-12-12 16:00:35 -080035#include <unistd.h>
36
37#include <hardware/bluetooth.h>
38
The Android Open Source Project5738f832012-12-12 16:00:35 -080039#include <cutils/properties.h>
40#include "gki.h"
41#include "btu.h"
Sharvil Nanavati95b74f22015-03-12 15:55:21 -070042#include "btcore/include/bdaddr.h"
The Android Open Source Project5738f832012-12-12 16:00:35 -080043#include "bta_api.h"
44#include "btif_api.h"
45#include "btif_util.h"
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -080046#include "btif_dm.h"
The Android Open Source Project5738f832012-12-12 16:00:35 -080047#include "btif_storage.h"
48#include "btif_hh.h"
49#include "btif_config.h"
Kim Schulz8372aa52015-03-25 10:39:40 +010050#include "btif_sdp.h"
The Android Open Source Project5738f832012-12-12 16:00:35 -080051
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -080052#include "bta_gatt_api.h"
Sharvil Nanavati44802762014-12-23 23:08:58 -080053#include "include/stack_config.h"
Chris Mantonf8027002015-03-12 09:22:48 -070054
Sharvil Nanavati44802762014-12-23 23:08:58 -080055#include "osi/include/log.h"
Andre Eisenbach31a64002014-10-14 14:29:19 -070056
57/******************************************************************************
58** Device specific workarounds
59******************************************************************************/
60
61/**
62 * The devices below have proven problematic during the pairing process, often
63 * requiring multiple retries to complete pairing. To avoid degrading the user
64 * experience for other devices, explicitely blacklist troubled devices here.
65 */
66static const UINT8 blacklist_pairing_retries[][3] = {
67 {0x9C, 0xDF, 0x03} // BMW car kits (Harman/Becker)
68};
69
70BOOLEAN blacklistPairingRetries(BD_ADDR bd_addr)
71{
72 const unsigned blacklist_size = sizeof(blacklist_pairing_retries)
73 / sizeof(blacklist_pairing_retries[0]);
74 for (unsigned i = 0; i != blacklist_size; ++i)
75 {
76 if (blacklist_pairing_retries[i][0] == bd_addr[0] &&
77 blacklist_pairing_retries[i][1] == bd_addr[1] &&
78 blacklist_pairing_retries[i][2] == bd_addr[2])
79 return TRUE;
80 }
81 return FALSE;
82}
83
The Android Open Source Project5738f832012-12-12 16:00:35 -080084/******************************************************************************
85** Constants & Macros
86******************************************************************************/
87
88#define COD_UNCLASSIFIED ((0x1F) << 8)
Priti Agheraebb1d752012-11-27 18:03:22 -080089#define COD_HID_KEYBOARD 0x0540
90#define COD_HID_POINTING 0x0580
91#define COD_HID_COMBO 0x05C0
92#define COD_HID_MAJOR 0x0500
93#define COD_AV_HEADSETS 0x0404
94#define COD_AV_HANDSFREE 0x0408
95#define COD_AV_HEADPHONES 0x0418
96#define COD_AV_PORTABLE_AUDIO 0x041C
97#define COD_AV_HIFI_AUDIO 0x0428
The Android Open Source Project5738f832012-12-12 16:00:35 -080098
99
100#define BTIF_DM_DEFAULT_INQ_MAX_RESULTS 0
101#define BTIF_DM_DEFAULT_INQ_MAX_DURATION 10
Ganesh Ganapathi Battaec7e2c82013-06-20 11:00:28 -0700102#define BTIF_DM_MAX_SDP_ATTEMPTS_AFTER_PAIRING 2
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800103
Andre Eisenbach31a64002014-10-14 14:29:19 -0700104#define NUM_TIMEOUT_RETRIES 5
105
Matthew Xie1e5109b2012-11-09 18:26:26 -0800106#define PROPERTY_PRODUCT_MODEL "ro.product.model"
Matthew Xiea30d95a2013-09-18 12:30:36 -0700107#define DEFAULT_LOCAL_NAME_MAX 31
Matthew Xie1e5109b2012-11-09 18:26:26 -0800108#if (DEFAULT_LOCAL_NAME_MAX > BTM_MAX_LOC_BD_NAME_LEN)
109 #error "default btif local name size exceeds stack supported length"
110#endif
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800111
Matthew Xie7f3e4292013-09-30 12:44:10 -0700112#if (defined(BTA_HOST_INTERLEAVE_SEARCH) && BTA_HOST_INTERLEAVE_SEARCH == TRUE)
113#define BTIF_DM_INTERLEAVE_DURATION_BR_ONE 2
114#define BTIF_DM_INTERLEAVE_DURATION_LE_ONE 2
115#define BTIF_DM_INTERLEAVE_DURATION_BR_TWO 3
116#define BTIF_DM_INTERLEAVE_DURATION_LE_TWO 4
117#endif
118
Priti Agherac0edf9f2014-06-26 11:23:51 -0700119#define MAX_SDP_BL_ENTRIES 3
120
Andre Eisenbach89363762015-01-26 13:49:36 -0800121#define BOND_TYPE_UNKNOWN 0
122#define BOND_TYPE_PERSISTENT 1
123#define BOND_TYPE_TEMPORARY 2
124
Andre Eisenbachdfb3b2f2015-02-05 20:00:45 -0800125#define ENCRYPTED_BREDR 2
126#define ENCRYPTED_LE 4
127
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800128typedef struct
129{
The Android Open Source Project5738f832012-12-12 16:00:35 -0800130 bt_bond_state_t state;
131 BD_ADDR bd_addr;
Chaojing Sune2805532015-04-22 13:40:21 -0700132 UINT8 bond_type;
133 UINT8 pin_code_len;
134 UINT8 is_ssp;
135 UINT8 auth_req;
136 UINT8 io_cap;
137 UINT8 autopair_attempts;
138 UINT8 timeout_retries;
139 UINT8 is_local_initiated;
140 UINT8 sdp_attempts;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800141#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
Chaojing Sune2805532015-04-22 13:40:21 -0700142 BOOLEAN is_le_only;
143 BOOLEAN is_le_nc; /* LE Numeric comparison */
144 BD_ADDR static_bdaddr;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800145 btif_dm_ble_cb_t ble;
146#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -0800147} btif_dm_pairing_cb_t;
148
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800149
150typedef struct
151{
152 UINT8 ir[BT_OCTET16_LEN];
153 UINT8 irk[BT_OCTET16_LEN];
154 UINT8 dhk[BT_OCTET16_LEN];
155}btif_dm_local_key_id_t;
156
157typedef struct
158{
159 BOOLEAN is_er_rcvd;
160 UINT8 er[BT_OCTET16_LEN];
161 BOOLEAN is_id_keys_rcvd;
162 btif_dm_local_key_id_t id_keys; /* ID kyes */
163
164}btif_dm_local_key_cb_t;
165
166typedef struct
167{
The Android Open Source Project5738f832012-12-12 16:00:35 -0800168 BD_ADDR bd_addr;
169 BD_NAME bd_name;
170} btif_dm_remote_name_t;
171
172typedef struct
173{
174 BT_OCTET16 sp_c;
175 BT_OCTET16 sp_r;
176 BD_ADDR oob_bdaddr; /* peer bdaddr*/
177} btif_dm_oob_cb_t;
Satya Callojie5ba8842014-07-03 17:18:02 -0700178
179typedef struct
180{
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -0700181 bt_bdaddr_t bdaddr;
182 UINT8 transport; /* 0=Unknown, 1=BR/EDR, 2=LE */
183} btif_dm_create_bond_cb_t;
184
185typedef struct
186{
Satya Callojie5ba8842014-07-03 17:18:02 -0700187 uint8_t status;
188 uint8_t ctrl_state;
189 uint64_t tx_time;
190 uint64_t rx_time;
191 uint64_t idle_time;
192 uint64_t energy_used;
193} btif_activity_energy_info_cb_t;
194
Priti Agherac0edf9f2014-06-26 11:23:51 -0700195typedef struct
196{
197 unsigned int manufact_id;
198}skip_sdp_entry_t;
199
The Android Open Source Project5738f832012-12-12 16:00:35 -0800200#define BTA_SERVICE_ID_TO_SERVICE_MASK(id) (1 << (id))
201
Priti Agherac0edf9f2014-06-26 11:23:51 -0700202#define MAX_SDP_BL_ENTRIES 3
203#define UUID_HUMAN_INTERFACE_DEVICE "00001124-0000-1000-8000-00805f9b34fb"
204
205static skip_sdp_entry_t sdp_blacklist[] = {{76}}; //Apple Mouse and Keyboard
206
The Android Open Source Project5738f832012-12-12 16:00:35 -0800207/* This flag will be true if HCI_Inquiry is in progress */
208static BOOLEAN btif_dm_inquiry_in_progress = FALSE;
209
Priti Agherac0edf9f2014-06-26 11:23:51 -0700210
211
Matthew Xie1e5109b2012-11-09 18:26:26 -0800212/************************************************************************************
213** Static variables
214************************************************************************************/
215static char btif_default_local_name[DEFAULT_LOCAL_NAME_MAX+1] = {'\0'};
216
The Android Open Source Project5738f832012-12-12 16:00:35 -0800217/******************************************************************************
218** Static functions
219******************************************************************************/
220static btif_dm_pairing_cb_t pairing_cb;
221static btif_dm_oob_cb_t oob_cb;
222static void btif_dm_generic_evt(UINT16 event, char* p_param);
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -0700223static void btif_dm_cb_create_bond(bt_bdaddr_t *bd_addr, tBTA_TRANSPORT transport);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800224static void btif_dm_cb_hid_remote_name(tBTM_REMOTE_DEV_NAME *p_remote_name);
225static void btif_update_remote_properties(BD_ADDR bd_addr, BD_NAME bd_name,
226 DEV_CLASS dev_class, tBT_DEVICE_TYPE dev_type);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800227#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
228static btif_dm_local_key_cb_t ble_local_key_cb;
229static void btif_dm_ble_key_notif_evt(tBTA_DM_SP_KEY_NOTIF *p_ssp_key_notif);
230static void btif_dm_ble_auth_cmpl_evt (tBTA_DM_AUTH_CMPL *p_auth_cmpl);
231static void btif_dm_ble_passkey_req_evt(tBTA_DM_PIN_REQ *p_pin_req);
Satya Calloji444a8da2015-03-06 10:38:22 -0800232static void btif_dm_ble_key_nc_req_evt(tBTA_DM_SP_KEY_NOTIF *p_notif_req) ;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800233#endif
Satya Calloji6e2d9db2014-07-08 16:18:58 -0700234
235static void bte_scan_filt_param_cfg_evt(UINT8 action_type,
236 tBTA_DM_BLE_PF_AVBL_SPACE avbl_space,
237 tBTA_DM_BLE_REF_VALUE ref_value, tBTA_STATUS status);
238
Matthew Xie1e5109b2012-11-09 18:26:26 -0800239static char* btif_get_default_local_name();
The Android Open Source Project5738f832012-12-12 16:00:35 -0800240/******************************************************************************
241** Externs
242******************************************************************************/
243extern UINT16 bta_service_id_to_uuid_lkup_tbl [BTA_MAX_SERVICE_ID];
244extern bt_status_t btif_hf_execute_service(BOOLEAN b_enable);
245extern bt_status_t btif_av_execute_service(BOOLEAN b_enable);
Rakesh Iyer9c8dfac2015-04-08 12:25:37 -0700246extern bt_status_t btif_av_sink_execute_service(BOOLEAN b_enable);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800247extern bt_status_t btif_hh_execute_service(BOOLEAN b_enable);
Hemant Gupta10256872013-08-19 18:33:01 +0530248extern bt_status_t btif_hf_client_execute_service(BOOLEAN b_enable);
Kim Schulz8372aa52015-03-25 10:39:40 +0100249extern bt_status_t btif_sdp_execute_service(BOOLEAN b_enable);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800250extern int btif_hh_connect(bt_bdaddr_t *bd_addr);
Andre Eisenbach2e7fa682013-08-08 15:42:48 -0700251extern void bta_gatt_convert_uuid16_to_uuid128(UINT8 uuid_128[LEN_UUID_128], UINT16 uuid_16);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800252
253
254/******************************************************************************
255** Functions
256******************************************************************************/
257
258bt_status_t btif_in_execute_service_request(tBTA_SERVICE_ID service_id,
259 BOOLEAN b_enable)
260{
Kim Schulz8372aa52015-03-25 10:39:40 +0100261 BTIF_TRACE_DEBUG("%s service_id: %d", __FUNCTION__, service_id);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800262 /* Check the service_ID and invoke the profile's BT state changed API */
263 switch (service_id)
264 {
265 case BTA_HFP_SERVICE_ID:
266 case BTA_HSP_SERVICE_ID:
267 {
268 btif_hf_execute_service(b_enable);
269 }break;
Sharvil Nanavati9609cee2014-10-15 18:30:49 -0700270 case BTA_A2DP_SOURCE_SERVICE_ID:
The Android Open Source Project5738f832012-12-12 16:00:35 -0800271 {
272 btif_av_execute_service(b_enable);
273 }break;
Rakesh Iyer9c8dfac2015-04-08 12:25:37 -0700274 case BTA_A2DP_SINK_SERVICE_ID:
275 {
276 btif_av_sink_execute_service(b_enable);
277 }break;
The Android Open Source Project5738f832012-12-12 16:00:35 -0800278 case BTA_HID_SERVICE_ID:
279 {
280 btif_hh_execute_service(b_enable);
281 }break;
Hemant Gupta10256872013-08-19 18:33:01 +0530282 case BTA_HFP_HS_SERVICE_ID:
283 {
284 btif_hf_client_execute_service(b_enable);
285 }break;
Kim Schulz8372aa52015-03-25 10:39:40 +0100286 case BTA_SDP_SERVICE_ID:
Hemant Gupta2dc99992014-04-18 12:54:08 +0530287 {
Kim Schulz8372aa52015-03-25 10:39:40 +0100288 btif_sdp_execute_service(b_enable);
Hemant Gupta2dc99992014-04-18 12:54:08 +0530289 }break;
The Android Open Source Project5738f832012-12-12 16:00:35 -0800290 default:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700291 BTIF_TRACE_ERROR("%s: Unknown service being enabled", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800292 return BT_STATUS_FAIL;
293 }
294 return BT_STATUS_SUCCESS;
295}
296
297/*******************************************************************************
298**
299** Function check_eir_remote_name
300**
301** Description Check if remote name is in the EIR data
302**
303** Returns TRUE if remote name found
304** Populate p_remote_name, if provided and remote name found
305**
306*******************************************************************************/
307static BOOLEAN check_eir_remote_name(tBTA_DM_SEARCH *p_search_data,
308 UINT8 *p_remote_name, UINT8 *p_remote_name_len)
309{
310 UINT8 *p_eir_remote_name = NULL;
311 UINT8 remote_name_len = 0;
312
313 /* Check EIR for remote name and services */
314 if (p_search_data->inq_res.p_eir)
315 {
Zach Johnsona50fc882014-10-30 21:02:58 -0700316 p_eir_remote_name = BTM_CheckEirData(p_search_data->inq_res.p_eir,
The Android Open Source Project5738f832012-12-12 16:00:35 -0800317 BTM_EIR_COMPLETE_LOCAL_NAME_TYPE, &remote_name_len);
318 if (!p_eir_remote_name)
319 {
Zach Johnsona50fc882014-10-30 21:02:58 -0700320 p_eir_remote_name = BTM_CheckEirData(p_search_data->inq_res.p_eir,
The Android Open Source Project5738f832012-12-12 16:00:35 -0800321 BTM_EIR_SHORTENED_LOCAL_NAME_TYPE, &remote_name_len);
322 }
323
324 if (p_eir_remote_name)
325 {
326 if (remote_name_len > BD_NAME_LEN)
327 remote_name_len = BD_NAME_LEN;
328
329 if (p_remote_name && p_remote_name_len)
330 {
331 memcpy(p_remote_name, p_eir_remote_name, remote_name_len);
332 *(p_remote_name + remote_name_len) = 0;
333 *p_remote_name_len = remote_name_len;
334 }
335
336 return TRUE;
337 }
338 }
339
340 return FALSE;
341
342}
343
344/*******************************************************************************
345**
346** Function check_cached_remote_name
347**
348** Description Check if remote name is in the NVRAM cache
349**
350** Returns TRUE if remote name found
351** Populate p_remote_name, if provided and remote name found
352**
353*******************************************************************************/
354static BOOLEAN check_cached_remote_name(tBTA_DM_SEARCH *p_search_data,
355 UINT8 *p_remote_name, UINT8 *p_remote_name_len)
356{
357 bt_bdname_t bdname;
358 bt_bdaddr_t remote_bdaddr;
359 bt_property_t prop_name;
360
361 /* check if we already have it in our btif_storage cache */
362 bdcpy(remote_bdaddr.address, p_search_data->inq_res.bd_addr);
363 BTIF_STORAGE_FILL_PROPERTY(&prop_name, BT_PROPERTY_BDNAME,
364 sizeof(bt_bdname_t), &bdname);
365 if (btif_storage_get_remote_device_property(
366 &remote_bdaddr, &prop_name) == BT_STATUS_SUCCESS)
367 {
368 if (p_remote_name && p_remote_name_len)
369 {
370 strcpy((char *)p_remote_name, (char *)bdname.name);
371 *p_remote_name_len = strlen((char *)p_remote_name);
372 }
373 return TRUE;
374 }
375
376 return FALSE;
377}
378
379BOOLEAN check_cod(const bt_bdaddr_t *remote_bdaddr, uint32_t cod)
380{
381 uint32_t remote_cod;
382 bt_property_t prop_name;
383
384 /* check if we already have it in our btif_storage cache */
385 BTIF_STORAGE_FILL_PROPERTY(&prop_name, BT_PROPERTY_CLASS_OF_DEVICE,
386 sizeof(uint32_t), &remote_cod);
387 if (btif_storage_get_remote_device_property((bt_bdaddr_t *)remote_bdaddr, &prop_name) == BT_STATUS_SUCCESS)
388 {
Chris Mantonf8027002015-03-12 09:22:48 -0700389 LOG_INFO("%s remote_cod = 0x%08x cod = 0x%08x", __func__, remote_cod, cod);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800390 if ((remote_cod & 0x7ff) == cod)
391 return TRUE;
392 }
393
394 return FALSE;
395}
396
Priti Agheraebb1d752012-11-27 18:03:22 -0800397BOOLEAN check_cod_hid(const bt_bdaddr_t *remote_bdaddr, uint32_t cod)
398{
399 uint32_t remote_cod;
400 bt_property_t prop_name;
401
402 /* check if we already have it in our btif_storage cache */
403 BTIF_STORAGE_FILL_PROPERTY(&prop_name, BT_PROPERTY_CLASS_OF_DEVICE,
404 sizeof(uint32_t), &remote_cod);
405 if (btif_storage_get_remote_device_property((bt_bdaddr_t *)remote_bdaddr,
406 &prop_name) == BT_STATUS_SUCCESS)
407 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700408 BTIF_TRACE_DEBUG("%s: remote_cod = 0x%06x", __FUNCTION__, remote_cod);
Priti Agheraebb1d752012-11-27 18:03:22 -0800409 if ((remote_cod & 0x700) == cod)
410 return TRUE;
411 }
Andre Eisenbach2e7fa682013-08-08 15:42:48 -0700412 return FALSE;
413}
Priti Agheraebb1d752012-11-27 18:03:22 -0800414
Andre Eisenbach2e7fa682013-08-08 15:42:48 -0700415BOOLEAN check_hid_le(const bt_bdaddr_t *remote_bdaddr)
416{
417 uint32_t remote_dev_type;
418 bt_property_t prop_name;
419
420 /* check if we already have it in our btif_storage cache */
421 BTIF_STORAGE_FILL_PROPERTY(&prop_name,BT_PROPERTY_TYPE_OF_DEVICE,
422 sizeof(uint32_t), &remote_dev_type);
423 if (btif_storage_get_remote_device_property((bt_bdaddr_t *)remote_bdaddr,
424 &prop_name) == BT_STATUS_SUCCESS)
425 {
426 if (remote_dev_type == BT_DEVICE_DEVTYPE_BLE)
427 {
428 bdstr_t bdstr;
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -0700429 bdaddr_to_string(remote_bdaddr, bdstr, sizeof(bdstr));
Sharvil Nanavati9d52f882014-08-19 09:50:18 -0700430 if(btif_config_exist(bdstr, "HidAppId"))
Andre Eisenbach2e7fa682013-08-08 15:42:48 -0700431 return TRUE;
432 }
433 }
Priti Agheraebb1d752012-11-27 18:03:22 -0800434 return FALSE;
435}
436
Priti Agherac0edf9f2014-06-26 11:23:51 -0700437/*****************************************************************************
438**
439** Function check_sdp_bl
440**
441** Description Checks if a given device is blacklisted to skip sdp
442**
443** Parameters skip_sdp_entry
444**
445** Returns TRUE if the device is present in blacklist, else FALSE
446**
447*******************************************************************************/
448BOOLEAN check_sdp_bl(const bt_bdaddr_t *remote_bdaddr)
449{
Priti Agherac0edf9f2014-06-26 11:23:51 -0700450 UINT16 manufacturer = 0;
451 UINT8 lmp_ver = 0;
452 UINT16 lmp_subver = 0;
Priti Agherac0edf9f2014-06-26 11:23:51 -0700453 bt_property_t prop_name;
454 bt_remote_version_t info;
Priti Agherac0edf9f2014-06-26 11:23:51 -0700455
456
457 if (remote_bdaddr == NULL)
458 return FALSE;
459
460/* fetch additional info about remote device used in iop query */
Sharvil Nanavatif1c764f2015-02-23 17:31:48 -0800461 BTM_ReadRemoteVersion(*(BD_ADDR*)remote_bdaddr, &lmp_ver,
Priti Agherac0edf9f2014-06-26 11:23:51 -0700462 &manufacturer, &lmp_subver);
463
464
465
466 /* if not available yet, try fetching from config database */
467 BTIF_STORAGE_FILL_PROPERTY(&prop_name, BT_PROPERTY_REMOTE_VERSION_INFO,
468 sizeof(bt_remote_version_t), &info);
469
470 if (btif_storage_get_remote_device_property((bt_bdaddr_t *)remote_bdaddr,
471 &prop_name) != BT_STATUS_SUCCESS)
472 {
473
474 return FALSE;
475 }
476 manufacturer = info.manufacturer;
477
478 for (int i = 0; i < MAX_SDP_BL_ENTRIES; i++)
479 {
480 if (manufacturer == sdp_blacklist[i].manufact_id)
481 return TRUE;
482 }
483 return FALSE;
484}
485
486
The Android Open Source Project5738f832012-12-12 16:00:35 -0800487static void bond_state_changed(bt_status_t status, bt_bdaddr_t *bd_addr, bt_bond_state_t state)
488{
Chaojing Sune2805532015-04-22 13:40:21 -0700489 // Send bonding state only once - based on outgoing/incoming we may receive duplicates
490 if ((pairing_cb.state == state) && (state == BT_BOND_STATE_BONDING))
491 {
492 // Cross key pairing so send callback for static address
493 if (pairing_cb.static_bdaddr != NULL)
494 HAL_CBACK(bt_hal_cbacks, bond_state_changed_cb, status, bd_addr, state);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800495 return;
Chaojing Sune2805532015-04-22 13:40:21 -0700496 }
The Android Open Source Project5738f832012-12-12 16:00:35 -0800497
Andre Eisenbach89363762015-01-26 13:49:36 -0800498 if (pairing_cb.bond_type == BOND_TYPE_TEMPORARY)
Chaojing Sune2805532015-04-22 13:40:21 -0700499 state = BT_BOND_STATE_NONE;
500
501 BTIF_TRACE_DEBUG("%s: state=%d, prev_state=%d, sdp_attempts = %d", __func__,
502 state, pairing_cb.state, pairing_cb.sdp_attempts);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800503
504 HAL_CBACK(bt_hal_cbacks, bond_state_changed_cb, status, bd_addr, state);
505
506 if (state == BT_BOND_STATE_BONDING)
507 {
508 pairing_cb.state = state;
509 bdcpy(pairing_cb.bd_addr, bd_addr->address);
Chaojing Sune2805532015-04-22 13:40:21 -0700510 } else {
511 if (!pairing_cb.sdp_attempts)
512 memset(&pairing_cb, 0, sizeof(pairing_cb));
513 else
514 BTIF_TRACE_DEBUG("%s: BR-EDR service discovery active", __func__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800515 }
The Android Open Source Project5738f832012-12-12 16:00:35 -0800516}
517
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800518/* store remote version in bt config to always have access
519 to it post pairing*/
520static void btif_update_remote_version_property(bt_bdaddr_t *p_bd)
521{
522 bt_property_t property;
523 UINT8 lmp_ver = 0;
524 UINT16 lmp_subver = 0;
525 UINT16 mfct_set = 0;
526 tBTM_STATUS btm_status;
527 bt_remote_version_t info;
528 bt_status_t status;
529 bdstr_t bdstr;
530
531 btm_status = BTM_ReadRemoteVersion(*(BD_ADDR*)p_bd, &lmp_ver,
532 &mfct_set, &lmp_subver);
533
Sharvil Nanavati44802762014-12-23 23:08:58 -0800534 LOG_DEBUG("remote version info [%s]: %x, %x, %x", bdaddr_to_string(p_bd, bdstr, sizeof(bdstr)),
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800535 lmp_ver, mfct_set, lmp_subver);
536
537 if (btm_status == BTM_SUCCESS)
538 {
Chaojing Sune2805532015-04-22 13:40:21 -0700539 // Always update cache to ensure we have availability whenever BTM API is not populated
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800540 info.manufacturer = mfct_set;
541 info.sub_ver = lmp_subver;
542 info.version = lmp_ver;
543 BTIF_STORAGE_FILL_PROPERTY(&property,
544 BT_PROPERTY_REMOTE_VERSION_INFO, sizeof(bt_remote_version_t),
545 &info);
546 status = btif_storage_set_remote_device_property(p_bd, &property);
547 ASSERTC(status == BT_STATUS_SUCCESS, "failed to save remote version", status);
548 }
549}
550
The Android Open Source Project5738f832012-12-12 16:00:35 -0800551
552static void btif_update_remote_properties(BD_ADDR bd_addr, BD_NAME bd_name,
553 DEV_CLASS dev_class, tBT_DEVICE_TYPE device_type)
554{
555 int num_properties = 0;
556 bt_property_t properties[3];
557 bt_bdaddr_t bdaddr;
558 bt_status_t status;
559 UINT32 cod;
560 bt_device_type_t dev_type;
561
562 memset(properties, 0, sizeof(properties));
563 bdcpy(bdaddr.address, bd_addr);
564
565 /* remote name */
566 if (strlen((const char *) bd_name))
567 {
568 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
569 BT_PROPERTY_BDNAME, strlen((char *)bd_name), bd_name);
570 status = btif_storage_set_remote_device_property(&bdaddr, &properties[num_properties]);
571 ASSERTC(status == BT_STATUS_SUCCESS, "failed to save remote device name", status);
572 num_properties++;
573 }
574
575 /* class of device */
576 cod = devclass2uint(dev_class);
Chris Mantonf8027002015-03-12 09:22:48 -0700577 BTIF_TRACE_DEBUG("%s cod is 0x%06x", __func__, cod);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800578 if ( cod == 0) {
Hemant Gupta87b7cce2013-11-28 13:07:10 +0530579 /* Try to retrieve cod from storage */
Chris Mantonf8027002015-03-12 09:22:48 -0700580 BTIF_TRACE_DEBUG("%s cod is 0, checking cod from storage", __func__);
Hemant Gupta87b7cce2013-11-28 13:07:10 +0530581 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
582 BT_PROPERTY_CLASS_OF_DEVICE, sizeof(cod), &cod);
583 status = btif_storage_get_remote_device_property(&bdaddr, &properties[num_properties]);
Chris Mantonf8027002015-03-12 09:22:48 -0700584 BTIF_TRACE_DEBUG("%s cod retrieved from storage is 0x%06x", __func__, cod);
Hemant Gupta87b7cce2013-11-28 13:07:10 +0530585 if ( cod == 0) {
Chris Mantonf8027002015-03-12 09:22:48 -0700586 BTIF_TRACE_DEBUG("%s cod is again 0, set as unclassified", __func__);
Hemant Gupta87b7cce2013-11-28 13:07:10 +0530587 cod = COD_UNCLASSIFIED;
588 }
The Android Open Source Project5738f832012-12-12 16:00:35 -0800589 }
590
591 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
592 BT_PROPERTY_CLASS_OF_DEVICE, sizeof(cod), &cod);
593 status = btif_storage_set_remote_device_property(&bdaddr, &properties[num_properties]);
594 ASSERTC(status == BT_STATUS_SUCCESS, "failed to save remote device class", status);
595 num_properties++;
596
597 /* device type */
Chaojing Sune2805532015-04-22 13:40:21 -0700598 bt_property_t prop_name;
599 uint8_t remote_dev_type;
600 BTIF_STORAGE_FILL_PROPERTY(&prop_name, BT_PROPERTY_TYPE_OF_DEVICE,
601 sizeof(uint8_t), &remote_dev_type);
602 if (btif_storage_get_remote_device_property(&bdaddr, &prop_name) == BT_STATUS_SUCCESS)
603 dev_type = remote_dev_type | device_type;
604 else
605 dev_type = device_type;
606
The Android Open Source Project5738f832012-12-12 16:00:35 -0800607 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
608 BT_PROPERTY_TYPE_OF_DEVICE, sizeof(dev_type), &dev_type);
609 status = btif_storage_set_remote_device_property(&bdaddr, &properties[num_properties]);
610 ASSERTC(status == BT_STATUS_SUCCESS, "failed to save remote device type", status);
611 num_properties++;
612
613 HAL_CBACK(bt_hal_cbacks, remote_device_properties_cb,
614 status, &bdaddr, num_properties, properties);
615}
The Android Open Source Project5738f832012-12-12 16:00:35 -0800616
617/*******************************************************************************
618**
619** Function btif_dm_cb_hid_remote_name
620**
621** Description Remote name callback for HID device. Called in btif context
622** Special handling for HID devices
623**
624** Returns void
625**
626*******************************************************************************/
627static void btif_dm_cb_hid_remote_name(tBTM_REMOTE_DEV_NAME *p_remote_name)
628{
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700629 BTIF_TRACE_DEBUG("%s: status=%d pairing_cb.state=%d", __FUNCTION__, p_remote_name->status, pairing_cb.state);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800630 if (pairing_cb.state == BT_BOND_STATE_BONDING)
631 {
632 bt_bdaddr_t remote_bd;
633
634 bdcpy(remote_bd.address, pairing_cb.bd_addr);
635
636 if (p_remote_name->status == BTM_SUCCESS)
637 {
638 bond_state_changed(BT_STATUS_SUCCESS, &remote_bd, BT_BOND_STATE_BONDED);
639 }
640 else
641 bond_state_changed(BT_STATUS_FAIL, &remote_bd, BT_BOND_STATE_NONE);
642 }
643}
644
The Android Open Source Project5738f832012-12-12 16:00:35 -0800645/*******************************************************************************
646**
647** Function btif_dm_cb_create_bond
648**
649** Description Create bond initiated from the BTIF thread context
650** Special handling for HID devices
651**
652** Returns void
653**
654*******************************************************************************/
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -0700655static void btif_dm_cb_create_bond(bt_bdaddr_t *bd_addr, tBTA_TRANSPORT transport)
The Android Open Source Project5738f832012-12-12 16:00:35 -0800656{
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800657 BOOLEAN is_hid = check_cod(bd_addr, COD_HID_POINTING);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800658 bond_state_changed(BT_STATUS_SUCCESS, bd_addr, BT_BOND_STATE_BONDING);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800659
Thomas.TT_Lin2772dac2014-07-18 12:10:59 +0800660#if BLE_INCLUDED == TRUE
661 int device_type;
662 int addr_type;
663 bdstr_t bdstr;
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -0700664 bdaddr_to_string(bd_addr, bdstr, sizeof(bdstr));
Matthew Xie64c54792014-09-16 00:55:03 -0700665 if (transport == BT_TRANSPORT_LE)
666 {
Sharvil Nanavati9d52f882014-08-19 09:50:18 -0700667 if (!btif_config_get_int((char const *)&bdstr,"DevType", &device_type))
Matthew Xie64c54792014-09-16 00:55:03 -0700668 {
Sharvil Nanavati9d52f882014-08-19 09:50:18 -0700669 btif_config_set_int(bdstr, "DevType", BT_DEVICE_TYPE_BLE);
Matthew Xie64c54792014-09-16 00:55:03 -0700670 }
671 if (btif_storage_get_remote_addr_type(bd_addr, &addr_type) != BT_STATUS_SUCCESS)
672 {
673 btif_storage_set_remote_addr_type(bd_addr, BLE_ADDR_PUBLIC);
674 }
675 }
Sharvil Nanavati9d52f882014-08-19 09:50:18 -0700676 if((btif_config_get_int((char const *)&bdstr,"DevType", &device_type) &&
Thomas.TT_Lin2772dac2014-07-18 12:10:59 +0800677 (btif_storage_get_remote_addr_type(bd_addr, &addr_type) == BT_STATUS_SUCCESS) &&
Chaojing Sune2805532015-04-22 13:40:21 -0700678 (device_type & BT_DEVICE_TYPE_BLE) == BT_DEVICE_TYPE_BLE) || (transport == BT_TRANSPORT_LE))
Thomas.TT_Lin2772dac2014-07-18 12:10:59 +0800679 {
Chaojing Sune2805532015-04-22 13:40:21 -0700680 BTA_DmAddBleDevice(bd_addr->address, addr_type, device_type);
Thomas.TT_Lin2772dac2014-07-18 12:10:59 +0800681 }
682#endif
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800683
Thomas.TT_Lin2772dac2014-07-18 12:10:59 +0800684#if BLE_INCLUDED == TRUE
Chaojing Sune2805532015-04-22 13:40:21 -0700685 if(is_hid && (device_type & BT_DEVICE_TYPE_BLE) == 0)
Thomas.TT_Lin2772dac2014-07-18 12:10:59 +0800686#else
687 if(is_hid)
688#endif
689 {
690 int status;
691 status = btif_hh_connect(bd_addr);
692 if(status != BT_STATUS_SUCCESS)
693 bond_state_changed(status, bd_addr, BT_BOND_STATE_NONE);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800694 }
695 else
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800696 {
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -0700697 BTA_DmBondByTransport((UINT8 *)bd_addr->address, transport);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800698 }
699 /* Track originator of bond creation */
700 pairing_cb.is_local_initiated = TRUE;
The Android Open Source Project5738f832012-12-12 16:00:35 -0800701
702}
703
704/*******************************************************************************
705**
706** Function btif_dm_cb_remove_bond
707**
708** Description remove bond initiated from the BTIF thread context
709** Special handling for HID devices
710**
711** Returns void
712**
713*******************************************************************************/
714void btif_dm_cb_remove_bond(bt_bdaddr_t *bd_addr)
715{
The Android Open Source Project5738f832012-12-12 16:00:35 -0800716 /*special handling for HID devices */
Ganesh Ganapathi Batta390c94d2013-05-15 17:58:35 -0700717 /* VUP needs to be sent if its a HID Device. The HID HOST module will check if there
718 is a valid hid connection with this bd_addr. If yes VUP will be issued.*/
719#if (defined(BTA_HH_INCLUDED) && (BTA_HH_INCLUDED == TRUE))
720 if (btif_hh_virtual_unplug(bd_addr) != BT_STATUS_SUCCESS)
721#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -0800722 {
Chaojing Sune2805532015-04-22 13:40:21 -0700723 BTIF_TRACE_DEBUG("%s: Removing HH device", __func__);
Ganesh Ganapathi Batta390c94d2013-05-15 17:58:35 -0700724 BTA_DmRemoveDevice((UINT8 *)bd_addr->address);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800725 }
726}
727
728/*******************************************************************************
729**
Andre Eisenbach249f6002014-06-18 12:20:37 -0700730** Function btif_dm_get_connection_state
731**
732** Description Returns whether the remote device is currently connected
Andre Eisenbachdfb3b2f2015-02-05 20:00:45 -0800733** and whether encryption is active for the connection
Andre Eisenbach249f6002014-06-18 12:20:37 -0700734**
Andre Eisenbachdfb3b2f2015-02-05 20:00:45 -0800735** Returns 0 if not connected; 1 if connected and > 1 if connection is
736** encrypted
Andre Eisenbach249f6002014-06-18 12:20:37 -0700737**
738*******************************************************************************/
739uint16_t btif_dm_get_connection_state(const bt_bdaddr_t *bd_addr)
740{
Andre Eisenbachdfb3b2f2015-02-05 20:00:45 -0800741 uint8_t *bda = (uint8_t*)bd_addr->address;
742 uint16_t rc = BTA_DmGetConnectionState(bda);
743
744 if (rc != 0)
745 {
746 uint8_t flags = 0;
747
748 BTM_GetSecurityFlagsByTransport(bda, &flags, BT_TRANSPORT_BR_EDR);
749 BTIF_TRACE_DEBUG("%s: security flags (BR/EDR)=0x%02x", __FUNCTION__, flags);
750 if (flags & BTM_SEC_FLAG_ENCRYPTED)
751 rc |= ENCRYPTED_BREDR;
752
753 BTM_GetSecurityFlagsByTransport(bda, &flags, BT_TRANSPORT_LE);
754 BTIF_TRACE_DEBUG("%s: security flags (LE)=0x%02x", __FUNCTION__, flags);
755 if (flags & BTM_SEC_FLAG_ENCRYPTED)
756 rc |= ENCRYPTED_LE;
757 }
758
759 return rc;
Andre Eisenbach249f6002014-06-18 12:20:37 -0700760}
761
762/*******************************************************************************
763**
The Android Open Source Project5738f832012-12-12 16:00:35 -0800764** Function search_devices_copy_cb
765**
766** Description Deep copy callback for search devices event
767**
768** Returns void
769**
770*******************************************************************************/
771static void search_devices_copy_cb(UINT16 event, char *p_dest, char *p_src)
772{
773 tBTA_DM_SEARCH *p_dest_data = (tBTA_DM_SEARCH *) p_dest;
774 tBTA_DM_SEARCH *p_src_data = (tBTA_DM_SEARCH *) p_src;
775
776 if (!p_src)
777 return;
778
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700779 BTIF_TRACE_DEBUG("%s: event=%s", __FUNCTION__, dump_dm_search_event(event));
The Android Open Source Project5738f832012-12-12 16:00:35 -0800780 memcpy(p_dest_data, p_src_data, sizeof(tBTA_DM_SEARCH));
781 switch (event)
782 {
783 case BTA_DM_INQ_RES_EVT:
784 {
785 if (p_src_data->inq_res.p_eir)
786 {
787 p_dest_data->inq_res.p_eir = (UINT8 *)(p_dest + sizeof(tBTA_DM_SEARCH));
788 memcpy(p_dest_data->inq_res.p_eir, p_src_data->inq_res.p_eir, HCI_EXT_INQ_RESPONSE_LEN);
789 }
790 }
791 break;
792
793 case BTA_DM_DISC_RES_EVT:
794 {
795 if (p_src_data->disc_res.raw_data_size && p_src_data->disc_res.p_raw_data)
796 {
797 p_dest_data->disc_res.p_raw_data = (UINT8 *)(p_dest + sizeof(tBTA_DM_SEARCH));
798 memcpy(p_dest_data->disc_res.p_raw_data,
799 p_src_data->disc_res.p_raw_data, p_src_data->disc_res.raw_data_size);
800 }
801 }
802 break;
803 }
804}
805
806static void search_services_copy_cb(UINT16 event, char *p_dest, char *p_src)
807{
808 tBTA_DM_SEARCH *p_dest_data = (tBTA_DM_SEARCH *) p_dest;
809 tBTA_DM_SEARCH *p_src_data = (tBTA_DM_SEARCH *) p_src;
810
811 if (!p_src)
812 return;
813 memcpy(p_dest_data, p_src_data, sizeof(tBTA_DM_SEARCH));
814 switch (event)
815 {
816 case BTA_DM_DISC_RES_EVT:
817 {
Kausik Sinnaswamy95664a92013-05-03 15:02:50 +0530818 if (p_src_data->disc_res.result == BTA_SUCCESS)
The Android Open Source Project5738f832012-12-12 16:00:35 -0800819 {
Kausik Sinnaswamy95664a92013-05-03 15:02:50 +0530820 if (p_src_data->disc_res.num_uuids > 0)
821 {
822 p_dest_data->disc_res.p_uuid_list =
823 (UINT8*)(p_dest + sizeof(tBTA_DM_SEARCH));
824 memcpy(p_dest_data->disc_res.p_uuid_list, p_src_data->disc_res.p_uuid_list,
825 p_src_data->disc_res.num_uuids*MAX_UUID_SIZE);
826 GKI_freebuf(p_src_data->disc_res.p_uuid_list);
827 }
828 if (p_src_data->disc_res.p_raw_data != NULL)
829 {
830 GKI_freebuf(p_src_data->disc_res.p_raw_data);
831 }
The Android Open Source Project5738f832012-12-12 16:00:35 -0800832 }
833 } break;
834 }
835}
836/******************************************************************************
837**
838** BTIF DM callback events
839**
840*****************************************************************************/
841
842/*******************************************************************************
843**
844** Function btif_dm_pin_req_evt
845**
846** Description Executes pin request event in btif context
847**
848** Returns void
849**
850*******************************************************************************/
851static void btif_dm_pin_req_evt(tBTA_DM_PIN_REQ *p_pin_req)
852{
853 bt_bdaddr_t bd_addr;
854 bt_bdname_t bd_name;
855 UINT32 cod;
856 bt_pin_code_t pin_code;
Matthew Xie86f97ed2014-11-10 10:24:46 -0800857 int dev_type;
The Android Open Source Project5738f832012-12-12 16:00:35 -0800858
859 /* Remote properties update */
Matthew Xie86f97ed2014-11-10 10:24:46 -0800860 if (!btif_get_device_type(p_pin_req->bd_addr, &dev_type))
861 {
862 dev_type = BT_DEVICE_TYPE_BREDR;
863 }
The Android Open Source Project5738f832012-12-12 16:00:35 -0800864 btif_update_remote_properties(p_pin_req->bd_addr, p_pin_req->bd_name,
Matthew Xie86f97ed2014-11-10 10:24:46 -0800865 p_pin_req->dev_class, (tBT_DEVICE_TYPE) dev_type);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800866
867 bdcpy(bd_addr.address, p_pin_req->bd_addr);
868 memcpy(bd_name.name, p_pin_req->bd_name, BD_NAME_LEN);
869
870 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
871
872 cod = devclass2uint(p_pin_req->dev_class);
873
Chris Mantonf8027002015-03-12 09:22:48 -0700874 if (cod == 0) {
875 BTIF_TRACE_DEBUG("%s cod is 0, set as unclassified", __func__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800876 cod = COD_UNCLASSIFIED;
877 }
878
879 /* check for auto pair possiblity only if bond was initiated by local device */
880 if (pairing_cb.is_local_initiated)
881 {
882 if (check_cod(&bd_addr, COD_AV_HEADSETS) ||
883 check_cod(&bd_addr, COD_AV_HANDSFREE) ||
884 check_cod(&bd_addr, COD_AV_HEADPHONES) ||
885 check_cod(&bd_addr, COD_AV_PORTABLE_AUDIO) ||
886 check_cod(&bd_addr, COD_AV_HIFI_AUDIO) ||
887 check_cod(&bd_addr, COD_HID_POINTING))
888 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700889 BTIF_TRACE_DEBUG("%s()cod matches for auto pair", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800890 /* Check if this device can be auto paired */
891 if ((btif_storage_is_device_autopair_blacklisted(&bd_addr) == FALSE) &&
892 (pairing_cb.autopair_attempts == 0))
893 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700894 BTIF_TRACE_DEBUG("%s() Attempting auto pair", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800895 pin_code.pin[0] = 0x30;
896 pin_code.pin[1] = 0x30;
897 pin_code.pin[2] = 0x30;
898 pin_code.pin[3] = 0x30;
899
900 pairing_cb.autopair_attempts++;
901 BTA_DmPinReply( (UINT8*)bd_addr.address, TRUE, 4, pin_code.pin);
902 return;
903 }
904 }
905 else if (check_cod(&bd_addr, COD_HID_KEYBOARD) ||
906 check_cod(&bd_addr, COD_HID_COMBO))
907 {
908 if(( btif_storage_is_fixed_pin_zeros_keyboard (&bd_addr) == TRUE) &&
909 (pairing_cb.autopair_attempts == 0))
910 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700911 BTIF_TRACE_DEBUG("%s() Attempting auto pair", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800912 pin_code.pin[0] = 0x30;
913 pin_code.pin[1] = 0x30;
914 pin_code.pin[2] = 0x30;
915 pin_code.pin[3] = 0x30;
916
917 pairing_cb.autopair_attempts++;
918 BTA_DmPinReply( (UINT8*)bd_addr.address, TRUE, 4, pin_code.pin);
919 return;
920 }
921 }
922 }
923 HAL_CBACK(bt_hal_cbacks, pin_request_cb,
924 &bd_addr, &bd_name, cod);
925}
926
927/*******************************************************************************
928**
929** Function btif_dm_ssp_cfm_req_evt
930**
931** Description Executes SSP confirm request event in btif context
932**
933** Returns void
934**
935*******************************************************************************/
936static void btif_dm_ssp_cfm_req_evt(tBTA_DM_SP_CFM_REQ *p_ssp_cfm_req)
937{
938 bt_bdaddr_t bd_addr;
939 bt_bdname_t bd_name;
940 UINT32 cod;
941 BOOLEAN is_incoming = !(pairing_cb.state == BT_BOND_STATE_BONDING);
Matthew Xie86f97ed2014-11-10 10:24:46 -0800942 int dev_type;
The Android Open Source Project5738f832012-12-12 16:00:35 -0800943
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700944 BTIF_TRACE_DEBUG("%s", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800945
946 /* Remote properties update */
Matthew Xie86f97ed2014-11-10 10:24:46 -0800947 if (!btif_get_device_type(p_ssp_cfm_req->bd_addr, &dev_type))
948 {
949 dev_type = BT_DEVICE_TYPE_BREDR;
950 }
The Android Open Source Project5738f832012-12-12 16:00:35 -0800951 btif_update_remote_properties(p_ssp_cfm_req->bd_addr, p_ssp_cfm_req->bd_name,
Matthew Xie86f97ed2014-11-10 10:24:46 -0800952 p_ssp_cfm_req->dev_class, (tBT_DEVICE_TYPE) dev_type);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800953
954 bdcpy(bd_addr.address, p_ssp_cfm_req->bd_addr);
955 memcpy(bd_name.name, p_ssp_cfm_req->bd_name, BD_NAME_LEN);
956
957 /* Set the pairing_cb based on the local & remote authentication requirements */
958 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
959
960 /* if just_works and bonding bit is not set treat this as temporary */
961 if (p_ssp_cfm_req->just_works && !(p_ssp_cfm_req->loc_auth_req & BTM_AUTH_BONDS) &&
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -0800962 !(p_ssp_cfm_req->rmt_auth_req & BTM_AUTH_BONDS) &&
963 !(check_cod((bt_bdaddr_t*)&p_ssp_cfm_req->bd_addr, COD_HID_POINTING)))
Andre Eisenbach89363762015-01-26 13:49:36 -0800964 pairing_cb.bond_type = BOND_TYPE_TEMPORARY;
The Android Open Source Project5738f832012-12-12 16:00:35 -0800965 else
Andre Eisenbach89363762015-01-26 13:49:36 -0800966 pairing_cb.bond_type = BOND_TYPE_PERSISTENT;
The Android Open Source Project5738f832012-12-12 16:00:35 -0800967
968 pairing_cb.is_ssp = TRUE;
969
970 /* If JustWorks auto-accept */
971 if (p_ssp_cfm_req->just_works)
972 {
973 /* Pairing consent for JustWorks needed if:
974 * 1. Incoming pairing is detected AND
975 * 2. local IO capabilities are DisplayYesNo AND
976 * 3. remote IO capabiltiies are DisplayOnly or NoInputNoOutput;
977 */
978 if ((is_incoming) && ((p_ssp_cfm_req->loc_io_caps == 0x01) &&
979 (p_ssp_cfm_req->rmt_io_caps == 0x00 || p_ssp_cfm_req->rmt_io_caps == 0x03)))
980 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700981 BTIF_TRACE_EVENT("%s: User consent needed for incoming pairing request. loc_io_caps: %d, rmt_io_caps: %d",
The Android Open Source Project5738f832012-12-12 16:00:35 -0800982 __FUNCTION__, p_ssp_cfm_req->loc_io_caps, p_ssp_cfm_req->rmt_io_caps);
983 }
984 else
985 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -0700986 BTIF_TRACE_EVENT("%s: Auto-accept JustWorks pairing", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800987 btif_dm_ssp_reply(&bd_addr, BT_SSP_VARIANT_CONSENT, TRUE, 0);
988 return;
989 }
990 }
991
992 cod = devclass2uint(p_ssp_cfm_req->dev_class);
993
Chris Mantonf8027002015-03-12 09:22:48 -0700994 if (cod == 0) {
995 LOG_DEBUG("%s cod is 0, set as unclassified", __func__);
The Android Open Source Project5738f832012-12-12 16:00:35 -0800996 cod = COD_UNCLASSIFIED;
997 }
998
Ganesh Ganapathi Battaec7e2c82013-06-20 11:00:28 -0700999 pairing_cb.sdp_attempts = 0;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001000 HAL_CBACK(bt_hal_cbacks, ssp_request_cb, &bd_addr, &bd_name, cod,
1001 (p_ssp_cfm_req->just_works ? BT_SSP_VARIANT_CONSENT : BT_SSP_VARIANT_PASSKEY_CONFIRMATION),
1002 p_ssp_cfm_req->num_val);
1003}
1004
1005static void btif_dm_ssp_key_notif_evt(tBTA_DM_SP_KEY_NOTIF *p_ssp_key_notif)
1006{
1007 bt_bdaddr_t bd_addr;
1008 bt_bdname_t bd_name;
1009 UINT32 cod;
Matthew Xie86f97ed2014-11-10 10:24:46 -08001010 int dev_type;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001011
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001012 BTIF_TRACE_DEBUG("%s", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001013
1014 /* Remote properties update */
Matthew Xie86f97ed2014-11-10 10:24:46 -08001015 if (!btif_get_device_type(p_ssp_key_notif->bd_addr, &dev_type))
1016 {
1017 dev_type = BT_DEVICE_TYPE_BREDR;
1018 }
The Android Open Source Project5738f832012-12-12 16:00:35 -08001019 btif_update_remote_properties(p_ssp_key_notif->bd_addr, p_ssp_key_notif->bd_name,
Matthew Xie86f97ed2014-11-10 10:24:46 -08001020 p_ssp_key_notif->dev_class, (tBT_DEVICE_TYPE) dev_type);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001021
1022 bdcpy(bd_addr.address, p_ssp_key_notif->bd_addr);
1023 memcpy(bd_name.name, p_ssp_key_notif->bd_name, BD_NAME_LEN);
1024
1025 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
1026 pairing_cb.is_ssp = TRUE;
1027 cod = devclass2uint(p_ssp_key_notif->dev_class);
1028
Chris Mantonf8027002015-03-12 09:22:48 -07001029 if (cod == 0) {
1030 LOG_DEBUG("%s cod is 0, set as unclassified", __func__);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001031 cod = COD_UNCLASSIFIED;
1032 }
1033
1034 HAL_CBACK(bt_hal_cbacks, ssp_request_cb, &bd_addr, &bd_name,
1035 cod, BT_SSP_VARIANT_PASSKEY_NOTIFICATION,
1036 p_ssp_key_notif->passkey);
1037}
1038/*******************************************************************************
1039**
1040** Function btif_dm_auth_cmpl_evt
1041**
1042** Description Executes authentication complete event in btif context
1043**
1044** Returns void
1045**
1046*******************************************************************************/
1047static void btif_dm_auth_cmpl_evt (tBTA_DM_AUTH_CMPL *p_auth_cmpl)
1048{
1049 /* Save link key, if not temporary */
1050 bt_bdaddr_t bd_addr;
1051 bt_status_t status = BT_STATUS_FAIL;
1052 bt_bond_state_t state = BT_BOND_STATE_NONE;
Priti Agherac0edf9f2014-06-26 11:23:51 -07001053 BOOLEAN skip_sdp = FALSE;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001054
Chaojing Sune2805532015-04-22 13:40:21 -07001055 BTIF_TRACE_DEBUG("%s: bond state=%d", __func__, pairing_cb.state);
1056
The Android Open Source Project5738f832012-12-12 16:00:35 -08001057 bdcpy(bd_addr.address, p_auth_cmpl->bd_addr);
1058 if ( (p_auth_cmpl->success == TRUE) && (p_auth_cmpl->key_present) )
1059 {
1060 if ((p_auth_cmpl->key_type < HCI_LKEY_TYPE_DEBUG_COMB) || (p_auth_cmpl->key_type == HCI_LKEY_TYPE_AUTH_COMB) ||
Andre Eisenbach89363762015-01-26 13:49:36 -08001061 (p_auth_cmpl->key_type == HCI_LKEY_TYPE_CHANGED_COMB) || pairing_cb.bond_type == BOND_TYPE_PERSISTENT)
The Android Open Source Project5738f832012-12-12 16:00:35 -08001062 {
1063 bt_status_t ret;
Andre Eisenbach89363762015-01-26 13:49:36 -08001064 BTIF_TRACE_DEBUG("%s: Storing link key. key_type=0x%x, bond_type=%d",
1065 __FUNCTION__, p_auth_cmpl->key_type, pairing_cb.bond_type);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001066 ret = btif_storage_add_bonded_device(&bd_addr,
1067 p_auth_cmpl->key, p_auth_cmpl->key_type,
1068 pairing_cb.pin_code_len);
1069 ASSERTC(ret == BT_STATUS_SUCCESS, "storing link key failed", ret);
1070 }
1071 else
1072 {
Andre Eisenbach89363762015-01-26 13:49:36 -08001073 BTIF_TRACE_DEBUG("%s: Temporary key. Not storing. key_type=0x%x, bond_type=%d",
1074 __FUNCTION__, p_auth_cmpl->key_type, pairing_cb.bond_type);
1075 if(pairing_cb.bond_type == BOND_TYPE_TEMPORARY)
Hemant Guptab820aec2013-12-24 19:59:57 +05301076 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001077 BTIF_TRACE_DEBUG("%s: sending BT_BOND_STATE_NONE for Temp pairing",
Hemant Guptab820aec2013-12-24 19:59:57 +05301078 __FUNCTION__);
1079 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_NONE);
1080 return;
1081 }
The Android Open Source Project5738f832012-12-12 16:00:35 -08001082 }
1083 }
Priti Agherac0edf9f2014-06-26 11:23:51 -07001084
1085 // Skip SDP for certain HID Devices
The Android Open Source Project5738f832012-12-12 16:00:35 -08001086 if (p_auth_cmpl->success)
1087 {
Chaojing Sune2805532015-04-22 13:40:21 -07001088 btif_storage_set_remote_addr_type(&bd_addr, p_auth_cmpl->addr_type);
1089 btif_update_remote_properties(p_auth_cmpl->bd_addr,
1090 p_auth_cmpl->bd_name, NULL, p_auth_cmpl->dev_type);
Andre Eisenbach31a64002014-10-14 14:29:19 -07001091 pairing_cb.timeout_retries = 0;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001092 status = BT_STATUS_SUCCESS;
1093 state = BT_BOND_STATE_BONDED;
Priti Agherac0edf9f2014-06-26 11:23:51 -07001094 bdcpy(bd_addr.address, p_auth_cmpl->bd_addr);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001095
Priti Agherac0edf9f2014-06-26 11:23:51 -07001096 if (check_sdp_bl(&bd_addr) && check_cod_hid(&bd_addr, COD_HID_MAJOR))
1097 {
Sharvil Nanavati44802762014-12-23 23:08:58 -08001098 LOG_WARN("%s:skip SDP", __FUNCTION__);
Priti Agherac0edf9f2014-06-26 11:23:51 -07001099 skip_sdp = TRUE;
1100 }
1101 if(!pairing_cb.is_local_initiated && skip_sdp)
1102 {
1103 bond_state_changed(status, &bd_addr, state);
Ganesh Ganapathi Battae17bf002013-02-15 17:52:29 -08001104
Sharvil Nanavati44802762014-12-23 23:08:58 -08001105 LOG_WARN("%s: Incoming HID Connection",__FUNCTION__);
Priti Agherac0edf9f2014-06-26 11:23:51 -07001106 bt_property_t prop;
1107 bt_bdaddr_t bd_addr;
1108 bt_uuid_t uuid;
1109 char uuid_str[128] = UUID_HUMAN_INTERFACE_DEVICE;
Ganesh Ganapathi Battae17bf002013-02-15 17:52:29 -08001110
Priti Agherac0edf9f2014-06-26 11:23:51 -07001111 string_to_uuid(uuid_str, &uuid);
1112
1113 prop.type = BT_PROPERTY_UUIDS;
1114 prop.val = uuid.uu;
1115 prop.len = MAX_UUID_SIZE;
1116
1117 /* Send the event to the BTIF */
1118 HAL_CBACK(bt_hal_cbacks, remote_device_properties_cb,
1119 BT_STATUS_SUCCESS, &bd_addr, 1, &prop);
1120 }
1121 else
1122 {
1123 /* Trigger SDP on the device */
1124 pairing_cb.sdp_attempts = 1;;
Chaojing Sune2805532015-04-22 13:40:21 -07001125 /* If bonded due to cross-key, save the static address too*/
1126 if(pairing_cb.state == BT_BOND_STATE_BONDING &&
1127 (bdcmp(p_auth_cmpl->bd_addr, pairing_cb.bd_addr) != 0))
1128 {
1129 BTIF_TRACE_DEBUG("%s: bonding initiated due to cross key, adding static address",
1130 __func__);
1131 bdcpy(pairing_cb.static_bdaddr, p_auth_cmpl->bd_addr);
1132 }
Priti Agherac0edf9f2014-06-26 11:23:51 -07001133
1134 if(btif_dm_inquiry_in_progress)
1135 btif_dm_cancel_discovery();
1136
1137 btif_dm_get_remote_services(&bd_addr);
Chaojing Sune2805532015-04-22 13:40:21 -07001138 }
1139 // Do not call bond_state_changed_cb yet. Wait until remote service discovery is complete
The Android Open Source Project5738f832012-12-12 16:00:35 -08001140 }
1141 else
1142 {
Chaojing Sune2805532015-04-22 13:40:21 -07001143 // Map the HCI fail reason to bt status
The Android Open Source Project5738f832012-12-12 16:00:35 -08001144 switch(p_auth_cmpl->fail_reason)
1145 {
1146 case HCI_ERR_PAGE_TIMEOUT:
Andre Eisenbach31a64002014-10-14 14:29:19 -07001147 if (blacklistPairingRetries(bd_addr.address) && pairing_cb.timeout_retries)
1148 {
1149 BTIF_TRACE_WARNING("%s() - Pairing timeout; retrying (%d) ...", __FUNCTION__, pairing_cb.timeout_retries);
1150 --pairing_cb.timeout_retries;
1151 btif_dm_cb_create_bond (&bd_addr, BTA_TRANSPORT_UNKNOWN);
1152 return;
1153 }
1154 /* Fall-through */
The Android Open Source Project5738f832012-12-12 16:00:35 -08001155 case HCI_ERR_CONNECTION_TOUT:
1156 status = BT_STATUS_RMT_DEV_DOWN;
1157 break;
1158
Hemant Guptaaef7a672013-07-31 19:00:12 +05301159 case HCI_ERR_PAIRING_NOT_ALLOWED:
1160 status = BT_STATUS_AUTH_REJECTED;
1161 break;
1162
Hemant Guptab4801442014-01-07 18:11:15 +05301163 case HCI_ERR_LMP_RESPONSE_TIMEOUT:
1164 status = BT_STATUS_AUTH_FAILURE;
1165 break;
1166
The Android Open Source Project5738f832012-12-12 16:00:35 -08001167 /* map the auth failure codes, so we can retry pairing if necessary */
1168 case HCI_ERR_AUTH_FAILURE:
Hemant Gupta59a88ec2014-03-19 19:01:35 +05301169 case HCI_ERR_KEY_MISSING:
Zhihai Xua7ea8092013-11-27 14:10:53 +05301170 btif_storage_remove_bonded_device(&bd_addr);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001171 case HCI_ERR_HOST_REJECT_SECURITY:
1172 case HCI_ERR_ENCRY_MODE_NOT_ACCEPTABLE:
1173 case HCI_ERR_UNIT_KEY_USED:
1174 case HCI_ERR_PAIRING_WITH_UNIT_KEY_NOT_SUPPORTED:
1175 case HCI_ERR_INSUFFCIENT_SECURITY:
Hemant Gupta87b7cce2013-11-28 13:07:10 +05301176 case HCI_ERR_PEER_USER:
1177 case HCI_ERR_UNSPECIFIED:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001178 BTIF_TRACE_DEBUG(" %s() Authentication fail reason %d",
Hemant Gupta87b7cce2013-11-28 13:07:10 +05301179 __FUNCTION__, p_auth_cmpl->fail_reason);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001180 if (pairing_cb.autopair_attempts == 1)
1181 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001182 BTIF_TRACE_DEBUG("%s(): Adding device to blacklist ", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001183
1184 /* Add the device to dynamic black list only if this device belongs to Audio/pointing dev class */
1185 if (check_cod(&bd_addr, COD_AV_HEADSETS) ||
1186 check_cod(&bd_addr, COD_AV_HANDSFREE) ||
1187 check_cod(&bd_addr, COD_AV_HEADPHONES) ||
1188 check_cod(&bd_addr, COD_AV_PORTABLE_AUDIO) ||
1189 check_cod(&bd_addr, COD_AV_HIFI_AUDIO) ||
1190 check_cod(&bd_addr, COD_HID_POINTING))
1191 {
1192 btif_storage_add_device_to_autopair_blacklist (&bd_addr);
1193 }
1194 pairing_cb.autopair_attempts++;
1195
1196 /* Create the Bond once again */
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001197 BTIF_TRACE_DEBUG("%s() auto pair failed. Reinitiate Bond", __FUNCTION__);
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -07001198 btif_dm_cb_create_bond (&bd_addr, BTA_TRANSPORT_UNKNOWN);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001199 return;
1200 }
1201 else
1202 {
1203 /* if autopair attempts are more than 1, or not attempted */
1204 status = BT_STATUS_AUTH_FAILURE;
1205 }
1206 break;
1207
1208 default:
1209 status = BT_STATUS_FAIL;
1210 }
Zhihai Xu8d2128d2013-12-13 16:09:21 +05301211 /* Special Handling for HID Devices */
1212 if (check_cod(&bd_addr, COD_HID_POINTING)) {
1213 /* Remove Device as bonded in nvram as authentication failed */
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001214 BTIF_TRACE_DEBUG("%s(): removing hid pointing device from nvram", __FUNCTION__);
Zhihai Xu8d2128d2013-12-13 16:09:21 +05301215 btif_storage_remove_bonded_device(&bd_addr);
1216 }
The Android Open Source Project5738f832012-12-12 16:00:35 -08001217 bond_state_changed(status, &bd_addr, state);
1218 }
1219}
1220
1221/******************************************************************************
1222**
1223** Function btif_dm_search_devices_evt
1224**
1225** Description Executes search devices callback events in btif context
1226**
1227** Returns void
1228**
1229******************************************************************************/
1230static void btif_dm_search_devices_evt (UINT16 event, char *p_param)
1231{
1232 tBTA_DM_SEARCH *p_search_data;
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001233 BTIF_TRACE_EVENT("%s event=%s", __FUNCTION__, dump_dm_search_event(event));
The Android Open Source Project5738f832012-12-12 16:00:35 -08001234
1235 switch (event)
1236 {
1237 case BTA_DM_DISC_RES_EVT:
1238 {
1239 p_search_data = (tBTA_DM_SEARCH *)p_param;
1240 /* Remote name update */
1241 if (strlen((const char *) p_search_data->disc_res.bd_name))
1242 {
1243 bt_property_t properties[1];
1244 bt_bdaddr_t bdaddr;
1245 bt_status_t status;
1246
1247 properties[0].type = BT_PROPERTY_BDNAME;
1248 properties[0].val = p_search_data->disc_res.bd_name;
1249 properties[0].len = strlen((char *)p_search_data->disc_res.bd_name);
1250 bdcpy(bdaddr.address, p_search_data->disc_res.bd_addr);
1251
1252 status = btif_storage_set_remote_device_property(&bdaddr, &properties[0]);
1253 ASSERTC(status == BT_STATUS_SUCCESS, "failed to save remote device property", status);
1254 HAL_CBACK(bt_hal_cbacks, remote_device_properties_cb,
1255 status, &bdaddr, 1, properties);
1256 }
1257 /* TODO: Services? */
1258 }
1259 break;
1260
1261 case BTA_DM_INQ_RES_EVT:
1262 {
1263 /* inquiry result */
1264 UINT32 cod;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001265 bt_bdname_t bdname;
1266 bt_bdaddr_t bdaddr;
1267 UINT8 remote_name_len;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001268 tBTA_SERVICE_MASK services = 0;
1269 bdstr_t bdstr;
1270
1271 p_search_data = (tBTA_DM_SEARCH *)p_param;
1272 bdcpy(bdaddr.address, p_search_data->inq_res.bd_addr);
1273
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -07001274 BTIF_TRACE_DEBUG("%s() %s device_type = 0x%x\n", __FUNCTION__, bdaddr_to_string(&bdaddr, bdstr, sizeof(bdstr)),
The Android Open Source Project5738f832012-12-12 16:00:35 -08001275#if (BLE_INCLUDED == TRUE)
1276 p_search_data->inq_res.device_type);
1277#else
1278 BT_DEVICE_TYPE_BREDR);
1279#endif
1280 bdname.name[0] = 0;
1281
1282 cod = devclass2uint (p_search_data->inq_res.dev_class);
1283
Chris Mantonf8027002015-03-12 09:22:48 -07001284 if (cod == 0) {
1285 LOG_DEBUG("%s cod is 0, set as unclassified", __func__);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001286 cod = COD_UNCLASSIFIED;
1287 }
1288
1289 if (!check_eir_remote_name(p_search_data, bdname.name, &remote_name_len))
1290 check_cached_remote_name(p_search_data, bdname.name, &remote_name_len);
1291
1292 /* Check EIR for remote name and services */
1293 if (p_search_data->inq_res.p_eir)
1294 {
1295 BTA_GetEirService(p_search_data->inq_res.p_eir, &services);
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001296 BTIF_TRACE_DEBUG("%s()EIR BTA services = %08X", __FUNCTION__, (UINT32)services);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001297 /* TODO: Get the service list and check to see which uuids we got and send it back to the client. */
1298 }
1299
1300
1301 {
1302 bt_property_t properties[5];
1303 bt_device_type_t dev_type;
Andre Eisenbach5c44e452013-08-06 18:19:37 -07001304 UINT8 addr_type;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001305 uint32_t num_properties = 0;
1306 bt_status_t status;
1307
1308 memset(properties, 0, sizeof(properties));
1309 /* BD_ADDR */
1310 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
1311 BT_PROPERTY_BDADDR, sizeof(bdaddr), &bdaddr);
1312 num_properties++;
1313 /* BD_NAME */
1314 /* Don't send BDNAME if it is empty */
Andre Eisenbach5c44e452013-08-06 18:19:37 -07001315 if (bdname.name[0])
1316 {
The Android Open Source Project5738f832012-12-12 16:00:35 -08001317 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
1318 BT_PROPERTY_BDNAME,
1319 strlen((char *)bdname.name), &bdname);
1320 num_properties++;
1321 }
1322
1323 /* DEV_CLASS */
1324 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
1325 BT_PROPERTY_CLASS_OF_DEVICE, sizeof(cod), &cod);
1326 num_properties++;
1327 /* DEV_TYPE */
Andre Eisenbach5c44e452013-08-06 18:19:37 -07001328#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
The Android Open Source Project5738f832012-12-12 16:00:35 -08001329 /* FixMe: Assumption is that bluetooth.h and BTE enums match */
1330 dev_type = p_search_data->inq_res.device_type;
Andre Eisenbach5c44e452013-08-06 18:19:37 -07001331 addr_type = p_search_data->inq_res.ble_addr_type;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001332#else
1333 dev_type = BT_DEVICE_TYPE_BREDR;
1334#endif
1335 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
1336 BT_PROPERTY_TYPE_OF_DEVICE, sizeof(dev_type), &dev_type);
1337 num_properties++;
1338 /* RSSI */
1339 BTIF_STORAGE_FILL_PROPERTY(&properties[num_properties],
1340 BT_PROPERTY_REMOTE_RSSI, sizeof(int8_t),
1341 &(p_search_data->inq_res.rssi));
1342 num_properties++;
1343
1344 status = btif_storage_add_remote_device(&bdaddr, num_properties, properties);
1345 ASSERTC(status == BT_STATUS_SUCCESS, "failed to save remote device (inquiry)", status);
Andre Eisenbach5c44e452013-08-06 18:19:37 -07001346#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
1347 status = btif_storage_set_remote_addr_type(&bdaddr, addr_type);
Ganesh Ganapathi Batta8fe58872014-04-16 16:50:09 -07001348 if (( dev_type == BT_DEVICE_TYPE_DUMO)&&
1349 (p_search_data->inq_res.flag & BTA_BLE_DMT_CONTROLLER_SPT) &&
1350 (p_search_data->inq_res.flag & BTA_BLE_DMT_HOST_SPT))
1351 {
1352 btif_storage_set_dmt_support_type (&bdaddr, TRUE);
1353 }
Andre Eisenbach5c44e452013-08-06 18:19:37 -07001354 ASSERTC(status == BT_STATUS_SUCCESS, "failed to save remote addr type (inquiry)", status);
1355#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08001356 /* Callback to notify upper layer of device */
1357 HAL_CBACK(bt_hal_cbacks, device_found_cb,
1358 num_properties, properties);
1359 }
1360 }
1361 break;
1362
1363 case BTA_DM_INQ_CMPL_EVT:
1364 {
Satya Calloji6e2d9db2014-07-08 16:18:58 -07001365#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
1366 tBTA_DM_BLE_PF_FILT_PARAMS adv_filt_param;
1367 memset(&adv_filt_param, 0, sizeof(tBTA_DM_BLE_PF_FILT_PARAMS));
1368 BTA_DmBleScanFilterSetup(BTA_DM_BLE_SCAN_COND_DELETE, 0, &adv_filt_param, NULL,
1369 bte_scan_filt_param_cfg_evt, 0);
1370#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08001371 }
1372 break;
1373 case BTA_DM_DISC_CMPL_EVT:
1374 {
1375 HAL_CBACK(bt_hal_cbacks, discovery_state_changed_cb, BT_DISCOVERY_STOPPED);
1376 }
1377 break;
1378 case BTA_DM_SEARCH_CANCEL_CMPL_EVT:
1379 {
1380 /* if inquiry is not in progress and we get a cancel event, then
1381 * it means we are done with inquiry, but remote_name fetches are in
1382 * progress
1383 *
1384 * if inquiry is in progress, then we don't want to act on this cancel_cmpl_evt
1385 * but instead wait for the cancel_cmpl_evt via the Busy Level
1386 *
1387 */
1388 if (btif_dm_inquiry_in_progress == FALSE)
1389 {
Nitin Arora7b85efa2014-09-26 14:05:24 -07001390#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
1391 tBTA_DM_BLE_PF_FILT_PARAMS adv_filt_param;
1392 memset(&adv_filt_param, 0, sizeof(tBTA_DM_BLE_PF_FILT_PARAMS));
1393 BTA_DmBleScanFilterSetup(BTA_DM_BLE_SCAN_COND_DELETE, 0, &adv_filt_param, NULL,
1394 bte_scan_filt_param_cfg_evt, 0);
1395#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08001396 HAL_CBACK(bt_hal_cbacks, discovery_state_changed_cb, BT_DISCOVERY_STOPPED);
1397 }
1398 }
1399 break;
1400 }
1401}
1402
1403/*******************************************************************************
1404**
1405** Function btif_dm_search_services_evt
1406**
1407** Description Executes search services event in btif context
1408**
1409** Returns void
1410**
1411*******************************************************************************/
1412static void btif_dm_search_services_evt(UINT16 event, char *p_param)
1413{
1414 tBTA_DM_SEARCH *p_data = (tBTA_DM_SEARCH*)p_param;
1415
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001416 BTIF_TRACE_EVENT("%s: event = %d", __FUNCTION__, event);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001417 switch (event)
1418 {
1419 case BTA_DM_DISC_RES_EVT:
1420 {
The Android Open Source Project5738f832012-12-12 16:00:35 -08001421 bt_property_t prop;
Bernhard Rosenkränzer104e3f22014-11-12 21:53:08 +01001422 uint32_t i = 0;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001423 bt_bdaddr_t bd_addr;
1424 bt_status_t ret;
1425
1426 bdcpy(bd_addr.address, p_data->disc_res.bd_addr);
1427
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001428 BTIF_TRACE_DEBUG("%s:(result=0x%x, services 0x%x)", __FUNCTION__,
The Android Open Source Project5738f832012-12-12 16:00:35 -08001429 p_data->disc_res.result, p_data->disc_res.services);
Ganesh Ganapathi Battaec7e2c82013-06-20 11:00:28 -07001430 if ((p_data->disc_res.result != BTA_SUCCESS) &&
1431 (pairing_cb.state == BT_BOND_STATE_BONDING ) &&
1432 (pairing_cb.sdp_attempts < BTIF_DM_MAX_SDP_ATTEMPTS_AFTER_PAIRING))
1433 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001434 BTIF_TRACE_WARNING("%s:SDP failed after bonding re-attempting", __FUNCTION__);
Ganesh Ganapathi Battaec7e2c82013-06-20 11:00:28 -07001435 pairing_cb.sdp_attempts++;
1436 btif_dm_get_remote_services(&bd_addr);
1437 return;
1438 }
The Android Open Source Project5738f832012-12-12 16:00:35 -08001439 prop.type = BT_PROPERTY_UUIDS;
1440 prop.len = 0;
1441 if ((p_data->disc_res.result == BTA_SUCCESS) && (p_data->disc_res.num_uuids > 0))
1442 {
1443 prop.val = p_data->disc_res.p_uuid_list;
1444 prop.len = p_data->disc_res.num_uuids * MAX_UUID_SIZE;
1445 for (i=0; i < p_data->disc_res.num_uuids; i++)
1446 {
1447 char temp[256];
Chris Manton8ff3fea2015-01-07 13:59:14 -08001448 uuid_to_string_legacy((bt_uuid_t*)(p_data->disc_res.p_uuid_list + (i*MAX_UUID_SIZE)), temp);
Chris Mantonf8027002015-03-12 09:22:48 -07001449 LOG_INFO("%s index:%d uuid:%s", __func__, i, temp);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001450 }
1451 }
1452
1453 /* onUuidChanged requires getBondedDevices to be populated.
1454 ** bond_state_changed needs to be sent prior to remote_device_property
1455 */
1456 if ((pairing_cb.state == BT_BOND_STATE_BONDING) &&
Chaojing Sune2805532015-04-22 13:40:21 -07001457 ((bdcmp(p_data->disc_res.bd_addr, pairing_cb.bd_addr) == 0) ||
1458 (bdcmp(p_data->disc_res.bd_addr, pairing_cb.static_bdaddr) == 0)) &&
1459 pairing_cb.sdp_attempts > 0)
The Android Open Source Project5738f832012-12-12 16:00:35 -08001460 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001461 BTIF_TRACE_DEBUG("%s Remote Service SDP done. Call bond_state_changed_cb BONDED",
The Android Open Source Project5738f832012-12-12 16:00:35 -08001462 __FUNCTION__);
Ganesh Ganapathi Battaec7e2c82013-06-20 11:00:28 -07001463 pairing_cb.sdp_attempts = 0;
Chaojing Sune2805532015-04-22 13:40:21 -07001464
1465 // If bonding occured due to cross-key pairing, send bonding callback
1466 // for static address now
1467 if (bdcmp(p_data->disc_res.bd_addr, pairing_cb.static_bdaddr) == 0)
1468 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
1469
The Android Open Source Project5738f832012-12-12 16:00:35 -08001470 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDED);
1471 }
1472
Chaojing Sune2805532015-04-22 13:40:21 -07001473 if (p_data->disc_res.num_uuids != 0)
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001474 {
1475 /* Also write this to the NVRAM */
1476 ret = btif_storage_set_remote_device_property(&bd_addr, &prop);
1477 ASSERTC(ret == BT_STATUS_SUCCESS, "storing remote services failed", ret);
1478 /* Send the event to the BTIF */
1479 HAL_CBACK(bt_hal_cbacks, remote_device_properties_cb,
1480 BT_STATUS_SUCCESS, &bd_addr, 1, &prop);
1481 }
The Android Open Source Project5738f832012-12-12 16:00:35 -08001482 }
1483 break;
1484
1485 case BTA_DM_DISC_CMPL_EVT:
1486 /* fixme */
1487 break;
1488
Matthew Xie607e3b72013-08-15 19:30:48 -07001489#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001490 case BTA_DM_DISC_BLE_RES_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001491 BTIF_TRACE_DEBUG("%s:, services 0x%x)", __FUNCTION__,
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001492 p_data->disc_ble_res.service.uu.uuid16);
1493 bt_uuid_t uuid;
1494 int i = 0;
1495 int j = 15;
1496 if (p_data->disc_ble_res.service.uu.uuid16 == UUID_SERVCLASS_LE_HID)
1497 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001498 BTIF_TRACE_DEBUG("%s: Found HOGP UUID",__FUNCTION__);
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001499 bt_property_t prop;
1500 bt_bdaddr_t bd_addr;
1501 char temp[256];
Zhihai Xud7ee77b2013-11-05 18:06:54 -08001502 bt_status_t ret;
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001503
1504 bta_gatt_convert_uuid16_to_uuid128(uuid.uu,p_data->disc_ble_res.service.uu.uuid16);
1505
1506 while(i < j )
1507 {
1508 unsigned char c = uuid.uu[j];
1509 uuid.uu[j] = uuid.uu[i];
1510 uuid.uu[i] = c;
1511 i++;
1512 j--;
1513 }
1514
Chris Manton8ff3fea2015-01-07 13:59:14 -08001515 uuid_to_string_legacy(&uuid, temp);
Chris Mantonf8027002015-03-12 09:22:48 -07001516 LOG_INFO("%s uuid:%s", __func__, temp);
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001517
1518 bdcpy(bd_addr.address, p_data->disc_ble_res.bd_addr);
1519 prop.type = BT_PROPERTY_UUIDS;
1520 prop.val = uuid.uu;
1521 prop.len = MAX_UUID_SIZE;
1522
Zhihai Xud7ee77b2013-11-05 18:06:54 -08001523 /* Also write this to the NVRAM */
1524 ret = btif_storage_set_remote_device_property(&bd_addr, &prop);
1525 ASSERTC(ret == BT_STATUS_SUCCESS, "storing remote services failed", ret);
1526
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001527 /* Send the event to the BTIF */
1528 HAL_CBACK(bt_hal_cbacks, remote_device_properties_cb,
1529 BT_STATUS_SUCCESS, &bd_addr, 1, &prop);
1530
1531 }
1532 break;
Matthew Xie607e3b72013-08-15 19:30:48 -07001533#endif /* BLE_INCLUDED */
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001534
The Android Open Source Project5738f832012-12-12 16:00:35 -08001535 default:
1536 {
1537 ASSERTC(0, "unhandled search services event", event);
1538 }
1539 break;
1540 }
1541}
1542
1543/*******************************************************************************
1544**
1545** Function btif_dm_remote_service_record_evt
1546**
1547** Description Executes search service record event in btif context
1548**
1549** Returns void
1550**
1551*******************************************************************************/
1552static void btif_dm_remote_service_record_evt(UINT16 event, char *p_param)
1553{
1554 tBTA_DM_SEARCH *p_data = (tBTA_DM_SEARCH*)p_param;
1555
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001556 BTIF_TRACE_EVENT("%s: event = %d", __FUNCTION__, event);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001557 switch (event)
1558 {
1559 case BTA_DM_DISC_RES_EVT:
1560 {
1561 bt_service_record_t rec;
1562 bt_property_t prop;
The Android Open Source Project5738f832012-12-12 16:00:35 -08001563 bt_bdaddr_t bd_addr;
1564
1565 memset(&rec, 0, sizeof(bt_service_record_t));
1566 bdcpy(bd_addr.address, p_data->disc_res.bd_addr);
1567
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001568 BTIF_TRACE_DEBUG("%s:(result=0x%x, services 0x%x)", __FUNCTION__,
The Android Open Source Project5738f832012-12-12 16:00:35 -08001569 p_data->disc_res.result, p_data->disc_res.services);
1570 prop.type = BT_PROPERTY_SERVICE_RECORD;
1571 prop.val = (void*)&rec;
1572 prop.len = sizeof(rec);
1573
1574 /* disc_res.result is overloaded with SCN. Cannot check result */
1575 p_data->disc_res.services &= ~BTA_USER_SERVICE_MASK;
1576 /* TODO: Get the UUID as well */
1577 rec.channel = p_data->disc_res.result - 3;
1578 /* TODO: Need to get the service name using p_raw_data */
1579 rec.name[0] = 0;
1580
1581 HAL_CBACK(bt_hal_cbacks, remote_device_properties_cb,
1582 BT_STATUS_SUCCESS, &bd_addr, 1, &prop);
1583 }
1584 break;
1585
1586 default:
1587 {
1588 ASSERTC(0, "unhandled remote service record event", event);
1589 }
1590 break;
1591 }
1592}
1593
1594/*******************************************************************************
1595**
1596** Function btif_dm_upstreams_cback
1597**
1598** Description Executes UPSTREAMS events in btif context
1599**
1600** Returns void
1601**
1602*******************************************************************************/
1603static void btif_dm_upstreams_evt(UINT16 event, char* p_param)
1604{
The Android Open Source Project5738f832012-12-12 16:00:35 -08001605 tBTA_DM_SEC *p_data = (tBTA_DM_SEC*)p_param;
1606 tBTA_SERVICE_MASK service_mask;
1607 uint32_t i;
1608 bt_bdaddr_t bd_addr;
1609
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001610 BTIF_TRACE_EVENT("btif_dm_upstreams_cback ev: %s", dump_dm_event(event));
The Android Open Source Project5738f832012-12-12 16:00:35 -08001611
1612 switch (event)
1613 {
1614 case BTA_DM_ENABLE_EVT:
1615 {
1616 BD_NAME bdname;
1617 bt_status_t status;
1618 bt_property_t prop;
1619 prop.type = BT_PROPERTY_BDNAME;
1620 prop.len = BD_NAME_LEN;
1621 prop.val = (void*)bdname;
1622
1623 status = btif_storage_get_adapter_property(&prop);
Matthew Xie1e5109b2012-11-09 18:26:26 -08001624 if (status == BT_STATUS_SUCCESS)
The Android Open Source Project5738f832012-12-12 16:00:35 -08001625 {
1626 /* A name exists in the storage. Make this the device name */
1627 BTA_DmSetDeviceName((char*)prop.val);
1628 }
Matthew Xie1e5109b2012-11-09 18:26:26 -08001629 else
1630 {
1631 /* Storage does not have a name yet.
1632 * Use the default name and write it to the chip
1633 */
1634 BTA_DmSetDeviceName(btif_get_default_local_name());
1635 }
The Android Open Source Project5738f832012-12-12 16:00:35 -08001636
Andre Eisenbacha015a832014-09-11 14:09:40 -07001637#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
1638 /* Enable local privacy */
Andre Eisenbach3e0dc732014-10-24 09:55:34 -07001639 BTA_DmBleConfigLocalPrivacy(BLE_LOCAL_PRIVACY_ENABLED);
Andre Eisenbacha015a832014-09-11 14:09:40 -07001640#endif
1641
The Android Open Source Project5738f832012-12-12 16:00:35 -08001642 /* for each of the enabled services in the mask, trigger the profile
1643 * enable */
1644 service_mask = btif_get_enabled_services_mask();
1645 for (i=0; i <= BTA_MAX_SERVICE_ID; i++)
1646 {
1647 if (service_mask &
1648 (tBTA_SERVICE_MASK)(BTA_SERVICE_ID_TO_SERVICE_MASK(i)))
1649 {
1650 btif_in_execute_service_request(i, TRUE);
1651 }
1652 }
1653 /* clear control blocks */
1654 memset(&pairing_cb, 0, sizeof(btif_dm_pairing_cb_t));
1655
1656 /* This function will also trigger the adapter_properties_cb
1657 ** and bonded_devices_info_cb
1658 */
1659 btif_storage_load_bonded_devices();
1660
1661 btif_storage_load_autopair_device_list();
1662
Zach Johnson39110ec2014-10-06 13:15:00 -07001663 btif_enable_bluetooth_evt(p_data->enable.status);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001664 }
1665 break;
1666
1667 case BTA_DM_DISABLE_EVT:
1668 /* for each of the enabled services in the mask, trigger the profile
1669 * disable */
1670 service_mask = btif_get_enabled_services_mask();
1671 for (i=0; i <= BTA_MAX_SERVICE_ID; i++)
1672 {
1673 if (service_mask &
1674 (tBTA_SERVICE_MASK)(BTA_SERVICE_ID_TO_SERVICE_MASK(i)))
1675 {
1676 btif_in_execute_service_request(i, FALSE);
1677 }
1678 }
1679 btif_disable_bluetooth_evt();
1680 break;
1681
1682 case BTA_DM_PIN_REQ_EVT:
1683 btif_dm_pin_req_evt(&p_data->pin_req);
1684 break;
1685
1686 case BTA_DM_AUTH_CMPL_EVT:
1687 btif_dm_auth_cmpl_evt(&p_data->auth_cmpl);
1688 break;
1689
1690 case BTA_DM_BOND_CANCEL_CMPL_EVT:
1691 if (pairing_cb.state == BT_BOND_STATE_BONDING)
1692 {
1693 bdcpy(bd_addr.address, pairing_cb.bd_addr);
1694 bond_state_changed(p_data->bond_cancel_cmpl.result, &bd_addr, BT_BOND_STATE_NONE);
1695 }
1696 break;
1697
1698 case BTA_DM_SP_CFM_REQ_EVT:
1699 btif_dm_ssp_cfm_req_evt(&p_data->cfm_req);
1700 break;
1701 case BTA_DM_SP_KEY_NOTIF_EVT:
1702 btif_dm_ssp_key_notif_evt(&p_data->key_notif);
1703 break;
1704
1705 case BTA_DM_DEV_UNPAIRED_EVT:
1706 bdcpy(bd_addr.address, p_data->link_down.bd_addr);
1707
1708 /*special handling for HID devices */
1709 #if (defined(BTA_HH_INCLUDED) && (BTA_HH_INCLUDED == TRUE))
Ganesh Ganapathi Batta390c94d2013-05-15 17:58:35 -07001710 btif_hh_remove_device(bd_addr);
The Android Open Source Project5738f832012-12-12 16:00:35 -08001711 #endif
Andre Eisenbach2e7fa682013-08-08 15:42:48 -07001712 #if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
1713 btif_storage_remove_ble_bonding_keys(&bd_addr);
1714 #endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08001715 btif_storage_remove_bonded_device(&bd_addr);
1716 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_NONE);
1717 break;
1718
1719 case BTA_DM_BUSY_LEVEL_EVT:
1720 {
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001721
1722 if (p_data->busy_level.level_flags & BTM_BL_INQUIRY_PAGING_MASK)
The Android Open Source Project5738f832012-12-12 16:00:35 -08001723 {
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001724 if (p_data->busy_level.level_flags == BTM_BL_INQUIRY_STARTED)
The Android Open Source Project5738f832012-12-12 16:00:35 -08001725 {
1726 HAL_CBACK(bt_hal_cbacks, discovery_state_changed_cb,
1727 BT_DISCOVERY_STARTED);
1728 btif_dm_inquiry_in_progress = TRUE;
1729 }
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001730 else if (p_data->busy_level.level_flags == BTM_BL_INQUIRY_CANCELLED)
The Android Open Source Project5738f832012-12-12 16:00:35 -08001731 {
1732 HAL_CBACK(bt_hal_cbacks, discovery_state_changed_cb,
1733 BT_DISCOVERY_STOPPED);
1734 btif_dm_inquiry_in_progress = FALSE;
1735 }
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001736 else if (p_data->busy_level.level_flags == BTM_BL_INQUIRY_COMPLETE)
The Android Open Source Project5738f832012-12-12 16:00:35 -08001737 {
1738 btif_dm_inquiry_in_progress = FALSE;
1739 }
1740 }
1741 }break;
1742
1743 case BTA_DM_LINK_UP_EVT:
1744 bdcpy(bd_addr.address, p_data->link_up.bd_addr);
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001745 BTIF_TRACE_DEBUG("BTA_DM_LINK_UP_EVT. Sending BT_ACL_STATE_CONNECTED");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001746
1747 btif_update_remote_version_property(&bd_addr);
1748
The Android Open Source Project5738f832012-12-12 16:00:35 -08001749 HAL_CBACK(bt_hal_cbacks, acl_state_changed_cb, BT_STATUS_SUCCESS,
1750 &bd_addr, BT_ACL_STATE_CONNECTED);
1751 break;
1752
1753 case BTA_DM_LINK_DOWN_EVT:
1754 bdcpy(bd_addr.address, p_data->link_down.bd_addr);
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001755 BTIF_TRACE_DEBUG("BTA_DM_LINK_DOWN_EVT. Sending BT_ACL_STATE_DISCONNECTED");
The Android Open Source Project5738f832012-12-12 16:00:35 -08001756 HAL_CBACK(bt_hal_cbacks, acl_state_changed_cb, BT_STATUS_SUCCESS,
1757 &bd_addr, BT_ACL_STATE_DISCONNECTED);
1758 break;
1759
1760 case BTA_DM_HW_ERROR_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001761 BTIF_TRACE_ERROR("Received H/W Error. ");
The Android Open Source Project5738f832012-12-12 16:00:35 -08001762 /* Flush storage data */
1763 btif_config_flush();
1764 usleep(100000); /* 100milliseconds */
1765 /* Killing the process to force a restart as part of fault tolerance */
1766 kill(getpid(), SIGKILL);
1767 break;
1768
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001769#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
1770 case BTA_DM_BLE_KEY_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001771 BTIF_TRACE_DEBUG("BTA_DM_BLE_KEY_EVT key_type=0x%02x ", p_data->ble_key.key_type);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001772
1773 /* If this pairing is by-product of local initiated GATT client Read or Write,
1774 BTA would not have sent BTA_DM_BLE_SEC_REQ_EVT event and Bond state would not
1775 have setup properly. Setup pairing_cb and notify App about Bonding state now*/
1776 if (pairing_cb.state != BT_BOND_STATE_BONDING)
1777 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001778 BTIF_TRACE_DEBUG("Bond state not sent to App so far.Notify the app now");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001779 bond_state_changed(BT_STATUS_SUCCESS, (bt_bdaddr_t*)p_data->ble_key.bd_addr,
1780 BT_BOND_STATE_BONDING);
1781 }
1782 else if (memcmp (pairing_cb.bd_addr, p_data->ble_key.bd_addr, BD_ADDR_LEN)!=0)
1783 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001784 BTIF_TRACE_ERROR("BD mismatch discard BLE key_type=%d ",p_data->ble_key.key_type);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001785 break;
1786 }
1787
1788 switch (p_data->ble_key.key_type)
1789 {
1790 case BTA_LE_KEY_PENC:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001791 BTIF_TRACE_DEBUG("Rcv BTA_LE_KEY_PENC");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001792 pairing_cb.ble.is_penc_key_rcvd = TRUE;
Satya Calloji444a8da2015-03-06 10:38:22 -08001793 memcpy(pairing_cb.ble.penc_key.ltk,
1794 p_data->ble_key.p_key_value->penc_key.ltk, 16);
1795 memcpy(pairing_cb.ble.penc_key.rand,
1796 p_data->ble_key.p_key_value->penc_key.rand,8);
1797 pairing_cb.ble.penc_key.ediv = p_data->ble_key.p_key_value->penc_key.ediv;
1798 pairing_cb.ble.penc_key.sec_level =
1799 p_data->ble_key.p_key_value->penc_key.sec_level;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001800
1801 for (i=0; i<16; i++)
1802 {
Satya Calloji444a8da2015-03-06 10:38:22 -08001803 BTIF_TRACE_DEBUG("pairing_cb.ble.penc_key.ltk[%d]=0x%02x",
1804 i,pairing_cb.ble.penc_key.ltk[i]);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001805 }
1806 for (i=0; i<8; i++)
1807 {
Satya Calloji444a8da2015-03-06 10:38:22 -08001808 BTIF_TRACE_DEBUG("pairing_cb.ble.penc_key.rand[%d]=0x%02x",
1809 i,pairing_cb.ble.penc_key.rand[i]);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001810 }
Satya Calloji444a8da2015-03-06 10:38:22 -08001811 BTIF_TRACE_DEBUG("pairing_cb.ble.penc_key.ediv=0x%04x",
1812 pairing_cb.ble.penc_key.ediv);
1813 BTIF_TRACE_DEBUG("pairing_cb.ble.penc_key.sec_level=0x%02x",
1814 pairing_cb.ble.penc_key.sec_level);
1815 BTIF_TRACE_DEBUG("pairing_cb.ble.penc_key.key_size=0x%02x",
1816 pairing_cb.ble.penc_key.key_size);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001817 break;
1818
1819 case BTA_LE_KEY_PID:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001820 BTIF_TRACE_DEBUG("Rcv BTA_LE_KEY_PID");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001821 pairing_cb.ble.is_pid_key_rcvd = TRUE;
Satya Calloji444a8da2015-03-06 10:38:22 -08001822 pairing_cb.ble.pid_key.addr_type =
1823 p_data->ble_key.p_key_value->pid_key.addr_type;
1824 memcpy(pairing_cb.ble.pid_key.irk,
1825 p_data->ble_key.p_key_value->pid_key.irk, 16);
Andre Eisenbach5e808462014-10-21 12:37:53 -07001826 memcpy(pairing_cb.ble.pid_key.static_addr,
Satya Calloji444a8da2015-03-06 10:38:22 -08001827 p_data->ble_key.p_key_value->pid_key.static_addr,BD_ADDR_LEN);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001828 for (i=0; i<16; i++)
1829 {
Andre Eisenbach5e808462014-10-21 12:37:53 -07001830 BTIF_TRACE_DEBUG("pairing_cb.ble.pid_key.irk[%d]=0x%02x"
1831 ,i,pairing_cb.ble.pid_key.irk[i]);
1832 }
1833 for (i=0; i<BD_ADDR_LEN; i++)
1834 {
1835 BTIF_TRACE_DEBUG("piaring_cb.ble.pid_address[%d] = %x"
1836 ,i, pairing_cb.ble.pid_key.static_addr[i]);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001837 }
1838 break;
1839
1840 case BTA_LE_KEY_PCSRK:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001841 BTIF_TRACE_DEBUG("Rcv BTA_LE_KEY_PCSRK");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001842 pairing_cb.ble.is_pcsrk_key_rcvd = TRUE;
Satya Calloji444a8da2015-03-06 10:38:22 -08001843 pairing_cb.ble.pcsrk_key.counter =
1844 p_data->ble_key.p_key_value->pcsrk_key.counter;
1845 pairing_cb.ble.pcsrk_key.sec_level =
1846 p_data->ble_key.p_key_value->pcsrk_key.sec_level;
1847 memcpy(pairing_cb.ble.pcsrk_key.csrk,
1848 p_data->ble_key.p_key_value->pcsrk_key.csrk,16);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001849
1850 for (i=0; i<16; i++)
1851 {
Satya Calloji444a8da2015-03-06 10:38:22 -08001852 BTIF_TRACE_DEBUG("pairing_cb.ble.pcsrk_key.csrk[%d]=0x%02x",
1853 i,pairing_cb.ble.pcsrk_key.csrk[i]);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001854 }
Satya Calloji444a8da2015-03-06 10:38:22 -08001855 BTIF_TRACE_DEBUG("pairing_cb.ble.pcsrk_key.counter=0x%08x",
1856 pairing_cb.ble.pcsrk_key.counter);
1857 BTIF_TRACE_DEBUG("pairing_cb.ble.pcsrk_key.sec_level=0x%02x",
1858 pairing_cb.ble.pcsrk_key.sec_level);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001859 break;
1860
1861 case BTA_LE_KEY_LENC:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001862 BTIF_TRACE_DEBUG("Rcv BTA_LE_KEY_LENC");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001863 pairing_cb.ble.is_lenc_key_rcvd = TRUE;
Satya Calloji444a8da2015-03-06 10:38:22 -08001864 pairing_cb.ble.lenc_key.div = p_data->ble_key.p_key_value->lenc_key.div;
1865 pairing_cb.ble.lenc_key.key_size =
1866 p_data->ble_key.p_key_value->lenc_key.key_size;
1867 pairing_cb.ble.lenc_key.sec_level =
1868 p_data->ble_key.p_key_value->lenc_key.sec_level;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001869
Satya Calloji444a8da2015-03-06 10:38:22 -08001870 BTIF_TRACE_DEBUG("pairing_cb.ble.lenc_key.div=0x%04x",
1871 pairing_cb.ble.lenc_key.div);
1872 BTIF_TRACE_DEBUG("pairing_cb.ble.lenc_key.key_size=0x%02x",
1873 pairing_cb.ble.lenc_key.key_size);
1874 BTIF_TRACE_DEBUG("pairing_cb.ble.lenc_key.sec_level=0x%02x",
1875 pairing_cb.ble.lenc_key.sec_level);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001876 break;
1877
1878
1879
1880 case BTA_LE_KEY_LCSRK:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001881 BTIF_TRACE_DEBUG("Rcv BTA_LE_KEY_LCSRK");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001882 pairing_cb.ble.is_lcsrk_key_rcvd = TRUE;
Satya Calloji444a8da2015-03-06 10:38:22 -08001883 pairing_cb.ble.lcsrk_key.counter =
1884 p_data->ble_key.p_key_value->lcsrk_key.counter;
1885 pairing_cb.ble.lcsrk_key.div =
1886 p_data->ble_key.p_key_value->lcsrk_key.div;
1887 pairing_cb.ble.lcsrk_key.sec_level =
1888 p_data->ble_key.p_key_value->lcsrk_key.sec_level;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001889
Satya Calloji444a8da2015-03-06 10:38:22 -08001890 BTIF_TRACE_DEBUG("pairing_cb.ble.lcsrk_key.div=0x%04x",
1891 pairing_cb.ble.lcsrk_key.div);
1892 BTIF_TRACE_DEBUG("pairing_cb.ble.lcsrk_key.counter=0x%08x",
1893 pairing_cb.ble.lcsrk_key.counter);
1894 BTIF_TRACE_DEBUG("pairing_cb.ble.lcsrk_key.sec_level=0x%02x",
1895 pairing_cb.ble.lcsrk_key.sec_level);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001896
1897 break;
1898
Satya Calloji444a8da2015-03-06 10:38:22 -08001899 case BTA_LE_KEY_LID:
1900 BTIF_TRACE_DEBUG("Rcv BTA_LE_KEY_LID");
1901 pairing_cb.ble.is_lidk_key_rcvd = TRUE;
1902 break;
1903
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001904 default:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001905 BTIF_TRACE_ERROR("unknown BLE key type (0x%02x)", p_data->ble_key.key_type);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001906 break;
1907 }
1908
1909 break;
1910 case BTA_DM_BLE_SEC_REQ_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001911 BTIF_TRACE_DEBUG("BTA_DM_BLE_SEC_REQ_EVT. ");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001912 btif_dm_ble_sec_req_evt(&p_data->ble_req);
1913 break;
1914 case BTA_DM_BLE_PASSKEY_NOTIF_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001915 BTIF_TRACE_DEBUG("BTA_DM_BLE_PASSKEY_NOTIF_EVT. ");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001916 btif_dm_ble_key_notif_evt(&p_data->key_notif);
1917 break;
1918 case BTA_DM_BLE_PASSKEY_REQ_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001919 BTIF_TRACE_DEBUG("BTA_DM_BLE_PASSKEY_REQ_EVT. ");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001920 btif_dm_ble_passkey_req_evt(&p_data->pin_req);
1921 break;
Satya Calloji444a8da2015-03-06 10:38:22 -08001922 case BTA_DM_BLE_NC_REQ_EVT:
1923 BTIF_TRACE_DEBUG("BTA_DM_BLE_PASSKEY_REQ_EVT. ");
1924 btif_dm_ble_key_nc_req_evt(&p_data->key_notif);
1925 break;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001926 case BTA_DM_BLE_OOB_REQ_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001927 BTIF_TRACE_DEBUG("BTA_DM_BLE_OOB_REQ_EVT. ");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001928 break;
1929 case BTA_DM_BLE_LOCAL_IR_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001930 BTIF_TRACE_DEBUG("BTA_DM_BLE_LOCAL_IR_EVT. ");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001931 ble_local_key_cb.is_id_keys_rcvd = TRUE;
Satya Calloji444a8da2015-03-06 10:38:22 -08001932 memcpy(&ble_local_key_cb.id_keys.irk[0],
1933 &p_data->ble_id_keys.irk[0], sizeof(BT_OCTET16));
1934 memcpy(&ble_local_key_cb.id_keys.ir[0],
1935 &p_data->ble_id_keys.ir[0], sizeof(BT_OCTET16));
1936 memcpy(&ble_local_key_cb.id_keys.dhk[0],
1937 &p_data->ble_id_keys.dhk[0], sizeof(BT_OCTET16));
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001938 btif_storage_add_ble_local_key( (char *)&ble_local_key_cb.id_keys.irk[0],
1939 BTIF_DM_LE_LOCAL_KEY_IR,
1940 BT_OCTET16_LEN);
1941 btif_storage_add_ble_local_key( (char *)&ble_local_key_cb.id_keys.ir[0],
1942 BTIF_DM_LE_LOCAL_KEY_IRK,
1943 BT_OCTET16_LEN);
1944 btif_storage_add_ble_local_key( (char *)&ble_local_key_cb.id_keys.dhk[0],
1945 BTIF_DM_LE_LOCAL_KEY_DHK,
1946 BT_OCTET16_LEN);
1947 break;
1948 case BTA_DM_BLE_LOCAL_ER_EVT:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07001949 BTIF_TRACE_DEBUG("BTA_DM_BLE_LOCAL_ER_EVT. ");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001950 ble_local_key_cb.is_er_rcvd = TRUE;
1951 memcpy(&ble_local_key_cb.er[0], &p_data->ble_er[0], sizeof(BT_OCTET16));
1952 btif_storage_add_ble_local_key( (char *)&ble_local_key_cb.er[0],
1953 BTIF_DM_LE_LOCAL_KEY_ER,
1954 BT_OCTET16_LEN);
1955 break;
1956
1957 case BTA_DM_BLE_AUTH_CMPL_EVT:
Satya Calloji444a8da2015-03-06 10:38:22 -08001958 BTIF_TRACE_DEBUG("BTA_DM_BLE_AUTH_CMPL_EVT. ");
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08001959 btif_dm_ble_auth_cmpl_evt(&p_data->auth_cmpl);
1960 break;
Ganesh Ganapathi Batta9546abf2014-05-30 16:28:00 -07001961
1962 case BTA_DM_LE_FEATURES_READ:
1963 {
1964 tBTM_BLE_VSC_CB cmn_vsc_cb;
1965 bt_local_le_features_t local_le_features;
1966 char buf[512];
1967 bt_property_t prop;
1968 prop.type = BT_PROPERTY_LOCAL_LE_FEATURES;
1969 prop.val = (void*)buf;
1970 prop.len = sizeof(buf);
1971
1972 /* LE features are not stored in storage. Should be retrived from stack */
1973 BTM_BleGetVendorCapabilities(&cmn_vsc_cb);
1974 local_le_features.local_privacy_enabled = BTM_BleLocalPrivacyEnabled();
1975
1976 prop.len = sizeof (bt_local_le_features_t);
1977 if (cmn_vsc_cb.filter_support == 1)
1978 local_le_features.max_adv_filter_supported = cmn_vsc_cb.max_filter;
1979 else
1980 local_le_features.max_adv_filter_supported = 0;
1981 local_le_features.max_adv_instance = cmn_vsc_cb.adv_inst_max;
1982 local_le_features.max_irk_list_size = cmn_vsc_cb.max_irk_list_sz;
1983 local_le_features.rpa_offload_supported = cmn_vsc_cb.rpa_offloading;
Satya Callojiefaddcb2014-07-28 23:22:05 -07001984 local_le_features.activity_energy_info_supported = cmn_vsc_cb.energy_support;
Satya Callojif5387072015-02-09 17:40:52 -08001985 local_le_features.scan_result_storage_size = cmn_vsc_cb.tot_scan_results_strg;
1986 local_le_features.version_supported = cmn_vsc_cb.version_supported;
1987 local_le_features.total_trackable_advertisers =
1988 cmn_vsc_cb.total_trackable_advertisers;
Ganesh Ganapathi Batta9546abf2014-05-30 16:28:00 -07001989 memcpy(prop.val, &local_le_features, prop.len);
1990 HAL_CBACK(bt_hal_cbacks, adapter_properties_cb, BT_STATUS_SUCCESS, 1, &prop);
1991 break;
1992 }
Satya Callojie5ba8842014-07-03 17:18:02 -07001993
1994 case BTA_DM_ENER_INFO_READ:
1995 {
1996 btif_activity_energy_info_cb_t *p_ener_data = (btif_activity_energy_info_cb_t*) p_param;
1997 bt_activity_energy_info energy_info;
1998 energy_info.status = p_ener_data->status;
1999 energy_info.ctrl_state = p_ener_data->ctrl_state;
2000 energy_info.rx_time = p_ener_data->rx_time;
2001 energy_info.tx_time = p_ener_data->tx_time;
2002 energy_info.idle_time = p_ener_data->idle_time;
2003 energy_info.energy_used = p_ener_data->energy_used;
2004 HAL_CBACK(bt_hal_cbacks, energy_info_cb, &energy_info);
2005 break;
2006 }
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002007#endif
2008
The Android Open Source Project5738f832012-12-12 16:00:35 -08002009 case BTA_DM_AUTHORIZE_EVT:
2010 case BTA_DM_SIG_STRENGTH_EVT:
2011 case BTA_DM_SP_RMT_OOB_EVT:
2012 case BTA_DM_SP_KEYPRESS_EVT:
2013 case BTA_DM_ROLE_CHG_EVT:
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002014
The Android Open Source Project5738f832012-12-12 16:00:35 -08002015 default:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002016 BTIF_TRACE_WARNING( "btif_dm_cback : unhandled event (%d)", event );
The Android Open Source Project5738f832012-12-12 16:00:35 -08002017 break;
2018 }
2019} /* btui_security_cback() */
2020
2021
2022/*******************************************************************************
2023**
2024** Function btif_dm_generic_evt
2025**
2026** Description Executes non-BTA upstream events in BTIF context
2027**
2028** Returns void
2029**
2030*******************************************************************************/
2031static void btif_dm_generic_evt(UINT16 event, char* p_param)
2032{
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002033 BTIF_TRACE_EVENT("%s: event=%d", __FUNCTION__, event);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002034 switch(event)
2035 {
2036 case BTIF_DM_CB_DISCOVERY_STARTED:
2037 {
2038 HAL_CBACK(bt_hal_cbacks, discovery_state_changed_cb, BT_DISCOVERY_STARTED);
2039 }
2040 break;
2041
2042 case BTIF_DM_CB_CREATE_BOND:
2043 {
Andre Eisenbach31a64002014-10-14 14:29:19 -07002044 pairing_cb.timeout_retries = NUM_TIMEOUT_RETRIES;
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -07002045 btif_dm_create_bond_cb_t *create_bond_cb = (btif_dm_create_bond_cb_t*)p_param;
2046 btif_dm_cb_create_bond(&create_bond_cb->bdaddr, create_bond_cb->transport);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002047 }
2048 break;
2049
2050 case BTIF_DM_CB_REMOVE_BOND:
2051 {
2052 btif_dm_cb_remove_bond((bt_bdaddr_t *)p_param);
2053 }
2054 break;
2055
2056 case BTIF_DM_CB_HID_REMOTE_NAME:
2057 {
2058 btif_dm_cb_hid_remote_name((tBTM_REMOTE_DEV_NAME *)p_param);
2059 }
2060 break;
2061
2062 case BTIF_DM_CB_BOND_STATE_BONDING:
2063 {
2064 bond_state_changed(BT_STATUS_SUCCESS, (bt_bdaddr_t *)p_param, BT_BOND_STATE_BONDING);
2065 }
2066 break;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002067 case BTIF_DM_CB_LE_TX_TEST:
2068 case BTIF_DM_CB_LE_RX_TEST:
2069 {
2070 uint8_t status;
2071 STREAM_TO_UINT8(status, p_param);
2072 HAL_CBACK(bt_hal_cbacks, le_test_mode_cb,
2073 (status == 0) ? BT_STATUS_SUCCESS : BT_STATUS_FAIL, 0);
2074 }
2075 break;
2076 case BTIF_DM_CB_LE_TEST_END:
2077 {
2078 uint8_t status;
2079 uint16_t count = 0;
2080 STREAM_TO_UINT8(status, p_param);
2081 if (status == 0)
2082 STREAM_TO_UINT16(count, p_param);
2083 HAL_CBACK(bt_hal_cbacks, le_test_mode_cb,
2084 (status == 0) ? BT_STATUS_SUCCESS : BT_STATUS_FAIL, count);
2085 }
2086 break;
The Android Open Source Project5738f832012-12-12 16:00:35 -08002087 default:
2088 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002089 BTIF_TRACE_WARNING("%s : Unknown event 0x%x", __FUNCTION__, event);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002090 }
2091 break;
2092 }
2093}
2094
2095/*******************************************************************************
2096**
2097** Function bte_dm_evt
2098**
2099** Description Switches context from BTE to BTIF for all DM events
2100**
2101** Returns void
2102**
2103*******************************************************************************/
2104
2105void bte_dm_evt(tBTA_DM_SEC_EVT event, tBTA_DM_SEC *p_data)
2106{
2107 bt_status_t status;
2108
2109 /* switch context to btif task context (copy full union size for convenience) */
2110 status = btif_transfer_context(btif_dm_upstreams_evt, (uint16_t)event, (void*)p_data, sizeof(tBTA_DM_SEC), NULL);
2111
2112 /* catch any failed context transfers */
2113 ASSERTC(status == BT_STATUS_SUCCESS, "context transfer failed", status);
2114}
2115
2116/*******************************************************************************
2117**
2118** Function bte_search_devices_evt
2119**
2120** Description Switches context from BTE to BTIF for DM search events
2121**
2122** Returns void
2123**
2124*******************************************************************************/
2125static void bte_search_devices_evt(tBTA_DM_SEARCH_EVT event, tBTA_DM_SEARCH *p_data)
2126{
2127 UINT16 param_len = 0;
2128
2129 if (p_data)
2130 param_len += sizeof(tBTA_DM_SEARCH);
2131 /* Allocate buffer to hold the pointers (deep copy). The pointers will point to the end of the tBTA_DM_SEARCH */
2132 switch (event)
2133 {
2134 case BTA_DM_INQ_RES_EVT:
2135 {
2136 if (p_data->inq_res.p_eir)
2137 param_len += HCI_EXT_INQ_RESPONSE_LEN;
2138 }
2139 break;
2140
2141 case BTA_DM_DISC_RES_EVT:
2142 {
2143 if (p_data->disc_res.raw_data_size && p_data->disc_res.p_raw_data)
2144 param_len += p_data->disc_res.raw_data_size;
2145 }
2146 break;
2147 }
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002148 BTIF_TRACE_DEBUG("%s event=%s param_len=%d", __FUNCTION__, dump_dm_search_event(event), param_len);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002149
2150 /* if remote name is available in EIR, set teh flag so that stack doesnt trigger RNR */
2151 if (event == BTA_DM_INQ_RES_EVT)
2152 p_data->inq_res.remt_name_not_required = check_eir_remote_name(p_data, NULL, NULL);
2153
2154 btif_transfer_context (btif_dm_search_devices_evt , (UINT16) event, (void *)p_data, param_len,
2155 (param_len > sizeof(tBTA_DM_SEARCH)) ? search_devices_copy_cb : NULL);
2156}
2157
2158/*******************************************************************************
2159**
2160** Function bte_dm_search_services_evt
2161**
2162** Description Switches context from BTE to BTIF for DM search services
2163** event
2164**
2165** Returns void
2166**
2167*******************************************************************************/
2168static void bte_dm_search_services_evt(tBTA_DM_SEARCH_EVT event, tBTA_DM_SEARCH *p_data)
2169{
2170 UINT16 param_len = 0;
2171 if (p_data)
2172 param_len += sizeof(tBTA_DM_SEARCH);
2173 switch (event)
2174 {
2175 case BTA_DM_DISC_RES_EVT:
2176 {
2177 if ((p_data->disc_res.result == BTA_SUCCESS) && (p_data->disc_res.num_uuids > 0)) {
2178 param_len += (p_data->disc_res.num_uuids * MAX_UUID_SIZE);
2179 }
2180 } break;
2181 }
2182 /* TODO: The only other member that needs a deep copy is the p_raw_data. But not sure
2183 * if raw_data is needed. */
2184 btif_transfer_context(btif_dm_search_services_evt, event, (char*)p_data, param_len,
2185 (param_len > sizeof(tBTA_DM_SEARCH)) ? search_services_copy_cb : NULL);
2186}
2187
2188/*******************************************************************************
2189**
2190** Function bte_dm_remote_service_record_evt
2191**
2192** Description Switches context from BTE to BTIF for DM search service
2193** record event
2194**
2195** Returns void
2196**
2197*******************************************************************************/
2198static void bte_dm_remote_service_record_evt(tBTA_DM_SEARCH_EVT event, tBTA_DM_SEARCH *p_data)
2199{
2200 /* TODO: The only member that needs a deep copy is the p_raw_data. But not sure yet if this is needed. */
2201 btif_transfer_context(btif_dm_remote_service_record_evt, event, (char*)p_data, sizeof(tBTA_DM_SEARCH), NULL);
2202}
2203
Prerepa Viswanadham81b03192014-07-23 17:49:48 -07002204#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
Satya Callojie5ba8842014-07-03 17:18:02 -07002205/*******************************************************************************
2206**
2207** Function bta_energy_info_cb
2208**
2209** Description Switches context from BTE to BTIF for DM energy info event
2210**
2211** Returns void
2212**
2213*******************************************************************************/
2214static void bta_energy_info_cb(tBTA_DM_BLE_TX_TIME_MS tx_time, tBTA_DM_BLE_RX_TIME_MS rx_time,
2215 tBTA_DM_BLE_IDLE_TIME_MS idle_time,
2216 tBTA_DM_BLE_ENERGY_USED energy_used,
2217 tBTA_DM_CONTRL_STATE ctrl_state, tBTA_STATUS status)
2218{
2219 BTIF_TRACE_DEBUG("energy_info_cb-Status:%d,state=%d,tx_t=%ld, rx_t=%ld, idle_time=%ld,used=%ld",
2220 status, ctrl_state, tx_time, rx_time, idle_time, energy_used);
2221
2222 btif_activity_energy_info_cb_t btif_cb;
2223 btif_cb.status = status;
2224 btif_cb.ctrl_state = ctrl_state;
2225 btif_cb.tx_time = (uint64_t) tx_time;
2226 btif_cb.rx_time = (uint64_t) rx_time;
2227 btif_cb.idle_time =(uint64_t) idle_time;
2228 btif_cb.energy_used =(uint64_t) energy_used;
2229 btif_transfer_context(btif_dm_upstreams_evt, BTA_DM_ENER_INFO_READ,
2230 (char*) &btif_cb, sizeof(btif_activity_energy_info_cb_t), NULL);
2231}
Prerepa Viswanadham81b03192014-07-23 17:49:48 -07002232#endif
Satya Callojie5ba8842014-07-03 17:18:02 -07002233
Satya Calloji6e2d9db2014-07-08 16:18:58 -07002234/*******************************************************************************
2235**
2236** Function bte_scan_filt_param_cfg_evt
2237**
2238** Description Scan filter param config event
2239**
2240** Returns void
2241**
2242*******************************************************************************/
2243static void bte_scan_filt_param_cfg_evt(UINT8 action_type,
2244 tBTA_DM_BLE_PF_AVBL_SPACE avbl_space,
2245 tBTA_DM_BLE_REF_VALUE ref_value, tBTA_STATUS status)
2246{
2247 /* This event occurs on calling BTA_DmBleCfgFilterCondition internally,
2248 ** and that is why there is no HAL callback
2249 */
2250 if(BTA_SUCCESS != status)
2251 {
2252 BTIF_TRACE_ERROR("%s, %d", __FUNCTION__, status);
2253 }
2254 else
2255 {
2256 BTIF_TRACE_DEBUG("%s", __FUNCTION__);
2257 }
2258}
2259
The Android Open Source Project5738f832012-12-12 16:00:35 -08002260/*****************************************************************************
2261**
2262** btif api functions (no context switch)
2263**
2264*****************************************************************************/
2265
2266/*******************************************************************************
2267**
2268** Function btif_dm_start_discovery
2269**
2270** Description Start device discovery/inquiry
2271**
2272** Returns bt_status_t
2273**
2274*******************************************************************************/
2275bt_status_t btif_dm_start_discovery(void)
2276{
2277 tBTA_DM_INQ inq_params;
2278 tBTA_SERVICE_MASK services = 0;
Satya Calloji6e2d9db2014-07-08 16:18:58 -07002279 tBTA_DM_BLE_PF_FILT_PARAMS adv_filt_param;
The Android Open Source Project5738f832012-12-12 16:00:35 -08002280
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002281 BTIF_TRACE_EVENT("%s", __FUNCTION__);
Satya Calloji6e2d9db2014-07-08 16:18:58 -07002282
2283#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
2284 memset(&adv_filt_param, 0, sizeof(tBTA_DM_BLE_PF_FILT_PARAMS));
2285 /* Cleanup anything remaining on index 0 */
2286 BTA_DmBleScanFilterSetup(BTA_DM_BLE_SCAN_COND_DELETE, 0, &adv_filt_param, NULL,
2287 bte_scan_filt_param_cfg_evt, 0);
2288
2289 /* Add an allow-all filter on index 0*/
2290 adv_filt_param.dely_mode = IMMEDIATE_DELY_MODE;
2291 adv_filt_param.feat_seln = ALLOW_ALL_FILTER;
2292 adv_filt_param.filt_logic_type = BTA_DM_BLE_PF_FILT_LOGIC_OR;
2293 adv_filt_param.list_logic_type = BTA_DM_BLE_PF_LIST_LOGIC_OR;
2294 adv_filt_param.rssi_low_thres = LOWEST_RSSI_VALUE;
2295 adv_filt_param.rssi_high_thres = LOWEST_RSSI_VALUE;
2296 BTA_DmBleScanFilterSetup(BTA_DM_BLE_SCAN_COND_ADD, 0, &adv_filt_param, NULL,
2297 bte_scan_filt_param_cfg_evt, 0);
2298
The Android Open Source Project5738f832012-12-12 16:00:35 -08002299 /* TODO: Do we need to handle multiple inquiries at the same time? */
2300
2301 /* Set inquiry params and call API */
The Android Open Source Project5738f832012-12-12 16:00:35 -08002302 inq_params.mode = BTA_DM_GENERAL_INQUIRY|BTA_BLE_GENERAL_INQUIRY;
Matthew Xie7f3e4292013-09-30 12:44:10 -07002303#if (defined(BTA_HOST_INTERLEAVE_SEARCH) && BTA_HOST_INTERLEAVE_SEARCH == TRUE)
2304 inq_params.intl_duration[0]= BTIF_DM_INTERLEAVE_DURATION_BR_ONE;
2305 inq_params.intl_duration[1]= BTIF_DM_INTERLEAVE_DURATION_LE_ONE;
2306 inq_params.intl_duration[2]= BTIF_DM_INTERLEAVE_DURATION_BR_TWO;
2307 inq_params.intl_duration[3]= BTIF_DM_INTERLEAVE_DURATION_LE_TWO;
2308#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08002309#else
2310 inq_params.mode = BTA_DM_GENERAL_INQUIRY;
2311#endif
2312 inq_params.duration = BTIF_DM_DEFAULT_INQ_MAX_DURATION;
2313
2314 inq_params.max_resps = BTIF_DM_DEFAULT_INQ_MAX_RESULTS;
2315 inq_params.report_dup = TRUE;
2316
2317 inq_params.filter_type = BTA_DM_INQ_CLR;
2318 /* TODO: Filter device by BDA needs to be implemented here */
2319
2320 /* Will be enabled to TRUE once inquiry busy level has been received */
2321 btif_dm_inquiry_in_progress = FALSE;
2322 /* find nearby devices */
2323 BTA_DmSearch(&inq_params, services, bte_search_devices_evt);
2324
2325 return BT_STATUS_SUCCESS;
2326}
2327
2328/*******************************************************************************
2329**
2330** Function btif_dm_cancel_discovery
2331**
2332** Description Cancels search
2333**
2334** Returns bt_status_t
2335**
2336*******************************************************************************/
2337bt_status_t btif_dm_cancel_discovery(void)
2338{
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002339 BTIF_TRACE_EVENT("%s", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002340 BTA_DmSearchCancel();
2341 return BT_STATUS_SUCCESS;
2342}
2343
2344/*******************************************************************************
2345**
2346** Function btif_dm_create_bond
2347**
2348** Description Initiate bonding with the specified device
2349**
2350** Returns bt_status_t
2351**
2352*******************************************************************************/
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -07002353bt_status_t btif_dm_create_bond(const bt_bdaddr_t *bd_addr, int transport)
The Android Open Source Project5738f832012-12-12 16:00:35 -08002354{
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -07002355 btif_dm_create_bond_cb_t create_bond_cb;
2356 create_bond_cb.transport = transport;
2357 bdcpy(create_bond_cb.bdaddr.address, bd_addr->address);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002358
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -07002359 bdstr_t bdstr;
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -07002360 BTIF_TRACE_EVENT("%s: bd_addr=%s, transport=%d", __FUNCTION__, bdaddr_to_string(bd_addr, bdstr, sizeof(bdstr)), transport);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002361 if (pairing_cb.state != BT_BOND_STATE_NONE)
2362 return BT_STATUS_BUSY;
2363
2364 btif_transfer_context(btif_dm_generic_evt, BTIF_DM_CB_CREATE_BOND,
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -07002365 (char *)&create_bond_cb, sizeof(btif_dm_create_bond_cb_t), NULL);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002366
2367 return BT_STATUS_SUCCESS;
2368}
2369
2370/*******************************************************************************
2371**
2372** Function btif_dm_cancel_bond
2373**
2374** Description Initiate bonding with the specified device
2375**
2376** Returns bt_status_t
2377**
2378*******************************************************************************/
2379
2380bt_status_t btif_dm_cancel_bond(const bt_bdaddr_t *bd_addr)
2381{
2382 bdstr_t bdstr;
2383
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -07002384 BTIF_TRACE_EVENT("%s: bd_addr=%s", __FUNCTION__, bdaddr_to_string(bd_addr, bdstr, sizeof(bdstr)));
The Android Open Source Project5738f832012-12-12 16:00:35 -08002385
2386 /* TODO:
2387 ** 1. Restore scan modes
2388 ** 2. special handling for HID devices
2389 */
2390 if (pairing_cb.state == BT_BOND_STATE_BONDING)
2391 {
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002392
2393#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
2394
2395 if (pairing_cb.is_ssp)
2396 {
2397 if (pairing_cb.is_le_only)
2398 {
2399 BTA_DmBleSecurityGrant((UINT8 *)bd_addr->address,BTA_DM_SEC_PAIR_NOT_SPT);
2400 }
2401 else
Hemant Guptae1468692013-11-14 16:21:29 +05302402 {
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002403 BTA_DmConfirm( (UINT8 *)bd_addr->address, FALSE);
Hemant Guptae1468692013-11-14 16:21:29 +05302404 BTA_DmBondCancel ((UINT8 *)bd_addr->address);
2405 btif_storage_remove_bonded_device((bt_bdaddr_t *)bd_addr);
2406 }
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002407 }
2408 else
2409 {
2410 if (pairing_cb.is_le_only)
2411 {
2412 BTA_DmBondCancel ((UINT8 *)bd_addr->address);
2413 }
2414 else
2415 {
2416 BTA_DmPinReply( (UINT8 *)bd_addr->address, FALSE, 0, NULL);
2417 }
2418 /* Cancel bonding, in case it is in ACL connection setup state */
2419 BTA_DmBondCancel ((UINT8 *)bd_addr->address);
2420 }
2421
2422#else
The Android Open Source Project5738f832012-12-12 16:00:35 -08002423 if (pairing_cb.is_ssp)
2424 {
2425 BTA_DmConfirm( (UINT8 *)bd_addr->address, FALSE);
2426 }
2427 else
2428 {
2429 BTA_DmPinReply( (UINT8 *)bd_addr->address, FALSE, 0, NULL);
2430 }
2431 /* Cancel bonding, in case it is in ACL connection setup state */
2432 BTA_DmBondCancel ((UINT8 *)bd_addr->address);
2433 btif_storage_remove_bonded_device((bt_bdaddr_t *)bd_addr);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002434#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08002435 }
2436
2437 return BT_STATUS_SUCCESS;
2438}
2439
2440/*******************************************************************************
2441**
Kim Schulza9eb25c2013-09-30 10:55:52 +02002442** Function btif_dm_hh_open_failed
2443**
2444** Description informs the upper layers if the HH have failed during bonding
2445**
2446** Returns none
2447**
2448*******************************************************************************/
2449
2450void btif_dm_hh_open_failed(bt_bdaddr_t *bdaddr)
2451{
2452 if (pairing_cb.state == BT_BOND_STATE_BONDING &&
2453 bdcmp(bdaddr->address, pairing_cb.bd_addr) == 0)
2454 {
2455 bond_state_changed(BT_STATUS_FAIL, bdaddr, BT_BOND_STATE_NONE);
2456 }
2457}
2458
2459/*******************************************************************************
2460**
The Android Open Source Project5738f832012-12-12 16:00:35 -08002461** Function btif_dm_remove_bond
2462**
2463** Description Removes bonding with the specified device
2464**
2465** Returns bt_status_t
2466**
2467*******************************************************************************/
2468
2469bt_status_t btif_dm_remove_bond(const bt_bdaddr_t *bd_addr)
2470{
2471 bdstr_t bdstr;
2472
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -07002473 BTIF_TRACE_EVENT("%s: bd_addr=%s", __FUNCTION__, bdaddr_to_string(bd_addr, bdstr, sizeof(bdstr)));
The Android Open Source Project5738f832012-12-12 16:00:35 -08002474 btif_transfer_context(btif_dm_generic_evt, BTIF_DM_CB_REMOVE_BOND,
2475 (char *)bd_addr, sizeof(bt_bdaddr_t), NULL);
2476
2477 return BT_STATUS_SUCCESS;
2478}
2479
2480/*******************************************************************************
2481**
2482** Function btif_dm_pin_reply
2483**
2484** Description BT legacy pairing - PIN code reply
2485**
2486** Returns bt_status_t
2487**
2488*******************************************************************************/
2489
2490bt_status_t btif_dm_pin_reply( const bt_bdaddr_t *bd_addr, uint8_t accept,
2491 uint8_t pin_len, bt_pin_code_t *pin_code)
2492{
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002493 BTIF_TRACE_EVENT("%s: accept=%d", __FUNCTION__, accept);
Hemant Gupta831423e2014-01-08 12:42:13 +05302494 if (pin_code == NULL)
2495 return BT_STATUS_FAIL;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002496#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
The Android Open Source Project5738f832012-12-12 16:00:35 -08002497
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002498 if (pairing_cb.is_le_only)
2499 {
2500 int i;
2501 UINT32 passkey = 0;
2502 int multi[] = {100000, 10000, 1000, 100, 10,1};
2503 BD_ADDR remote_bd_addr;
2504 bdcpy(remote_bd_addr, bd_addr->address);
2505 for (i = 0; i < 6; i++)
2506 {
2507 passkey += (multi[i] * (pin_code->pin[i] - '0'));
2508 }
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002509 BTIF_TRACE_DEBUG("btif_dm_pin_reply: passkey: %d", passkey);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002510 BTA_DmBlePasskeyReply(remote_bd_addr, accept, passkey);
2511
2512 }
2513 else
2514 {
2515 BTA_DmPinReply( (UINT8 *)bd_addr->address, accept, pin_len, pin_code->pin);
2516 if (accept)
2517 pairing_cb.pin_code_len = pin_len;
2518 }
2519#else
The Android Open Source Project5738f832012-12-12 16:00:35 -08002520 BTA_DmPinReply( (UINT8 *)bd_addr->address, accept, pin_len, pin_code->pin);
2521
2522 if (accept)
2523 pairing_cb.pin_code_len = pin_len;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002524#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08002525 return BT_STATUS_SUCCESS;
2526}
2527
2528/*******************************************************************************
2529**
2530** Function btif_dm_ssp_reply
2531**
2532** Description BT SSP Reply - Just Works, Numeric Comparison & Passkey Entry
2533**
2534** Returns bt_status_t
2535**
2536*******************************************************************************/
The Android Open Source Project5738f832012-12-12 16:00:35 -08002537bt_status_t btif_dm_ssp_reply(const bt_bdaddr_t *bd_addr,
2538 bt_ssp_variant_t variant, uint8_t accept,
2539 uint32_t passkey)
2540{
Mike J. Chen5cd8bff2014-01-31 18:16:59 -08002541 UNUSED(passkey);
2542
The Android Open Source Project5738f832012-12-12 16:00:35 -08002543 if (variant == BT_SSP_VARIANT_PASSKEY_ENTRY)
2544 {
2545 /* This is not implemented in the stack.
2546 * For devices with display, this is not needed
2547 */
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002548 BTIF_TRACE_WARNING("%s: Not implemented", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002549 return BT_STATUS_FAIL;
2550 }
2551 /* BT_SSP_VARIANT_CONSENT & BT_SSP_VARIANT_PASSKEY_CONFIRMATION supported */
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002552 BTIF_TRACE_EVENT("%s: accept=%d", __FUNCTION__, accept);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002553#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
2554 if (pairing_cb.is_le_only)
2555 {
Satya Calloji7fb0da62015-01-29 20:40:17 -08002556 if(pairing_cb.is_le_nc)
2557 {
2558 BTA_DmBleConfirmReply((UINT8 *)bd_addr->address,accept);
2559 } else {
2560 if (accept)
2561 BTA_DmBleSecurityGrant((UINT8 *)bd_addr->address,BTA_DM_SEC_GRANTED);
2562 else
2563 BTA_DmBleSecurityGrant((UINT8 *)bd_addr->address,BTA_DM_SEC_PAIR_NOT_SPT);
2564 }
2565 } else {
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002566 BTA_DmConfirm( (UINT8 *)bd_addr->address, accept);
Satya Calloji7fb0da62015-01-29 20:40:17 -08002567 }
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002568#else
2569 BTA_DmConfirm( (UINT8 *)bd_addr->address, accept);
2570#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08002571 return BT_STATUS_SUCCESS;
2572}
2573
2574/*******************************************************************************
2575**
2576** Function btif_dm_get_adapter_property
2577**
2578** Description Queries the BTA for the adapter property
2579**
2580** Returns bt_status_t
2581**
2582*******************************************************************************/
2583bt_status_t btif_dm_get_adapter_property(bt_property_t *prop)
2584{
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002585 BTIF_TRACE_EVENT("%s: type=0x%x", __FUNCTION__, prop->type);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002586 switch (prop->type)
2587 {
2588 case BT_PROPERTY_BDNAME:
2589 {
2590 bt_bdname_t *bd_name = (bt_bdname_t*)prop->val;
VenkatRaghavan VijayaRaghavan4540f592015-02-05 04:40:47 -08002591 strncpy((char *)bd_name->name, (char *)btif_get_default_local_name(),
VenkatRaghavan VijayaRaghavan1d8e6b82015-02-05 22:20:39 -08002592 sizeof(bd_name->name) - 1);
2593 bd_name->name[sizeof(bd_name->name) - 1] = 0;
The Android Open Source Project5738f832012-12-12 16:00:35 -08002594 prop->len = strlen((char *)bd_name->name);
2595 }
2596 break;
2597
2598 case BT_PROPERTY_ADAPTER_SCAN_MODE:
2599 {
2600 /* if the storage does not have it. Most likely app never set it. Default is NONE */
2601 bt_scan_mode_t *mode = (bt_scan_mode_t*)prop->val;
2602 *mode = BT_SCAN_MODE_NONE;
2603 prop->len = sizeof(bt_scan_mode_t);
2604 }
2605 break;
2606
2607 case BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT:
2608 {
2609 uint32_t *tmt = (uint32_t*)prop->val;
2610 *tmt = 120; /* default to 120s, if not found in NV */
2611 prop->len = sizeof(uint32_t);
2612 }
2613 break;
2614
2615 default:
2616 prop->len = 0;
2617 return BT_STATUS_FAIL;
2618 }
2619 return BT_STATUS_SUCCESS;
2620}
2621
2622/*******************************************************************************
2623**
2624** Function btif_dm_get_remote_services
2625**
2626** Description Start SDP to get remote services
2627**
2628** Returns bt_status_t
2629**
2630*******************************************************************************/
2631bt_status_t btif_dm_get_remote_services(bt_bdaddr_t *remote_addr)
2632{
2633 bdstr_t bdstr;
2634
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -07002635 BTIF_TRACE_EVENT("%s: remote_addr=%s", __FUNCTION__, bdaddr_to_string(remote_addr, bdstr, sizeof(bdstr)));
The Android Open Source Project5738f832012-12-12 16:00:35 -08002636
2637 BTA_DmDiscover(remote_addr->address, BTA_ALL_SERVICE_MASK,
2638 bte_dm_search_services_evt, TRUE);
2639
2640 return BT_STATUS_SUCCESS;
2641}
2642
2643/*******************************************************************************
2644**
2645** Function btif_dm_get_remote_service_record
2646**
2647** Description Start SDP to get remote service record
2648**
2649**
2650** Returns bt_status_t
2651*******************************************************************************/
2652bt_status_t btif_dm_get_remote_service_record(bt_bdaddr_t *remote_addr,
2653 bt_uuid_t *uuid)
2654{
2655 tSDP_UUID sdp_uuid;
2656 bdstr_t bdstr;
2657
Sharvil Nanavati8a6a89f2014-08-20 09:39:25 -07002658 BTIF_TRACE_EVENT("%s: remote_addr=%s", __FUNCTION__, bdaddr_to_string(remote_addr, bdstr, sizeof(bdstr)));
The Android Open Source Project5738f832012-12-12 16:00:35 -08002659
2660 sdp_uuid.len = MAX_UUID_SIZE;
2661 memcpy(sdp_uuid.uu.uuid128, uuid->uu, MAX_UUID_SIZE);
2662
2663 BTA_DmDiscoverUUID(remote_addr->address, &sdp_uuid,
2664 bte_dm_remote_service_record_evt, TRUE);
2665
2666 return BT_STATUS_SUCCESS;
2667}
2668
2669void btif_dm_execute_service_request(UINT16 event, char *p_param)
2670{
2671 BOOLEAN b_enable = FALSE;
2672 bt_status_t status;
2673 if (event == BTIF_DM_ENABLE_SERVICE)
2674 {
2675 b_enable = TRUE;
2676 }
2677 status = btif_in_execute_service_request(*((tBTA_SERVICE_ID*)p_param), b_enable);
2678 if (status == BT_STATUS_SUCCESS)
2679 {
2680 bt_property_t property;
2681 bt_uuid_t local_uuids[BT_MAX_NUM_UUIDS];
2682
2683 /* Now send the UUID_PROPERTY_CHANGED event to the upper layer */
2684 BTIF_STORAGE_FILL_PROPERTY(&property, BT_PROPERTY_UUIDS,
2685 sizeof(local_uuids), local_uuids);
2686 btif_storage_get_adapter_property(&property);
2687 HAL_CBACK(bt_hal_cbacks, adapter_properties_cb,
2688 BT_STATUS_SUCCESS, 1, &property);
2689 }
2690 return;
2691}
2692
Ganesh Ganapathi Battaa217ab92014-04-28 16:30:55 -07002693void btif_dm_proc_io_req(BD_ADDR bd_addr, tBTA_IO_CAP *p_io_cap, tBTA_OOB_DATA *p_oob_data,
2694 tBTA_AUTH_REQ *p_auth_req, BOOLEAN is_orig)
2695{
2696 UINT8 yes_no_bit = BTA_AUTH_SP_YES & *p_auth_req;
2697 /* if local initiated:
2698 ** 1. set DD + MITM
2699 ** if remote initiated:
2700 ** 1. Copy over the auth_req from peer's io_rsp
2701 ** 2. Set the MITM if peer has it set or if peer has DisplayYesNo (iPhone)
2702 ** as a fallback set MITM+GB if peer had MITM set
2703 */
2704 UNUSED (bd_addr);
2705 UNUSED (p_io_cap);
2706 UNUSED (p_oob_data);
2707
2708
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002709 BTIF_TRACE_DEBUG("+%s: p_auth_req=%d", __FUNCTION__, *p_auth_req);
Ganesh Ganapathi Battaa217ab92014-04-28 16:30:55 -07002710 if(pairing_cb.is_local_initiated)
2711 {
2712 /* if initing/responding to a dedicated bonding, use dedicate bonding bit */
2713 *p_auth_req = BTA_AUTH_DD_BOND | BTA_AUTH_SP_YES;
2714 }
2715 else if (!is_orig)
2716 {
2717 /* peer initiated paring. They probably know what they want.
2718 ** Copy the mitm from peer device.
2719 */
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002720 BTIF_TRACE_DEBUG("%s: setting p_auth_req to peer's: %d",
Ganesh Ganapathi Battaa217ab92014-04-28 16:30:55 -07002721 __FUNCTION__, pairing_cb.auth_req);
2722 *p_auth_req = (pairing_cb.auth_req & BTA_AUTH_BONDS);
2723
2724 /* copy over the MITM bit as well. In addition if the peer has DisplayYesNo, force MITM */
2725 if ((yes_no_bit) || (pairing_cb.io_cap & BTM_IO_CAP_IO) )
2726 *p_auth_req |= BTA_AUTH_SP_YES;
2727 }
2728 else if (yes_no_bit)
2729 {
2730 /* set the general bonding bit for stored device */
2731 *p_auth_req = BTA_AUTH_GEN_BOND | yes_no_bit;
2732 }
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002733 BTIF_TRACE_DEBUG("-%s: p_auth_req=%d", __FUNCTION__, *p_auth_req);
Ganesh Ganapathi Battaa217ab92014-04-28 16:30:55 -07002734}
2735
2736void btif_dm_proc_io_rsp(BD_ADDR bd_addr, tBTA_IO_CAP io_cap,
2737 tBTA_OOB_DATA oob_data, tBTA_AUTH_REQ auth_req)
2738{
2739 UNUSED (bd_addr);
2740 UNUSED (oob_data);
Andre Eisenbachb0daa5d2014-08-04 17:50:10 -07002741
Ganesh Ganapathi Battaa217ab92014-04-28 16:30:55 -07002742 if(auth_req & BTA_AUTH_BONDS)
2743 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002744 BTIF_TRACE_DEBUG("%s auth_req:%d", __FUNCTION__, auth_req);
Ganesh Ganapathi Battaa217ab92014-04-28 16:30:55 -07002745 pairing_cb.auth_req = auth_req;
2746 pairing_cb.io_cap = io_cap;
2747 }
2748}
2749
The Android Open Source Project5738f832012-12-12 16:00:35 -08002750#if (BTM_OOB_INCLUDED == TRUE)
2751void btif_dm_set_oob_for_io_req(tBTA_OOB_DATA *p_oob_data)
2752{
2753 if (oob_cb.sp_c[0] == 0 && oob_cb.sp_c[1] == 0 &&
2754 oob_cb.sp_c[2] == 0 && oob_cb.sp_c[3] == 0 )
2755 {
2756 *p_oob_data = FALSE;
2757 }
2758 else
2759 {
2760 *p_oob_data = TRUE;
2761 }
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002762 BTIF_TRACE_DEBUG("btif_dm_set_oob_for_io_req *p_oob_data=%d", *p_oob_data);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002763}
2764#endif /* BTM_OOB_INCLUDED */
2765
2766#ifdef BTIF_DM_OOB_TEST
2767void btif_dm_load_local_oob(void)
2768{
Nick Kralevichd70b7a82013-01-31 14:40:15 -08002769 char prop_oob[PROPERTY_VALUE_MAX];
The Android Open Source Project5738f832012-12-12 16:00:35 -08002770 property_get("service.brcm.bt.oob", prop_oob, "3");
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002771 BTIF_TRACE_DEBUG("btif_dm_load_local_oob prop_oob = %s",prop_oob);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002772 if (prop_oob[0] != '3')
2773 {
2774#if (BTM_OOB_INCLUDED == TRUE)
2775 if (oob_cb.sp_c[0] == 0 && oob_cb.sp_c[1] == 0 &&
2776 oob_cb.sp_c[2] == 0 && oob_cb.sp_c[3] == 0 )
2777 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002778 BTIF_TRACE_DEBUG("btif_dm_load_local_oob: read OOB, call BTA_DmLocalOob()");
The Android Open Source Project5738f832012-12-12 16:00:35 -08002779 BTA_DmLocalOob();
2780 }
2781#else
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002782 BTIF_TRACE_ERROR("BTM_OOB_INCLUDED is FALSE!!(btif_dm_load_local_oob)");
The Android Open Source Project5738f832012-12-12 16:00:35 -08002783#endif
2784 }
2785}
2786
2787void btif_dm_proc_loc_oob(BOOLEAN valid, BT_OCTET16 c, BT_OCTET16 r)
2788{
2789 FILE *fp;
2790 char *path_a = "/data/misc/bluedroid/LOCAL/a.key";
2791 char *path_b = "/data/misc/bluedroid/LOCAL/b.key";
2792 char *path = NULL;
Nick Kralevichd70b7a82013-01-31 14:40:15 -08002793 char prop_oob[PROPERTY_VALUE_MAX];
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002794 BTIF_TRACE_DEBUG("btif_dm_proc_loc_oob: valid=%d", valid);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002795 if (oob_cb.sp_c[0] == 0 && oob_cb.sp_c[1] == 0 &&
2796 oob_cb.sp_c[2] == 0 && oob_cb.sp_c[3] == 0 &&
2797 valid)
2798 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002799 BTIF_TRACE_DEBUG("save local OOB data in memory");
The Android Open Source Project5738f832012-12-12 16:00:35 -08002800 memcpy(oob_cb.sp_c, c, BT_OCTET16_LEN);
2801 memcpy(oob_cb.sp_r, r, BT_OCTET16_LEN);
2802 property_get("service.brcm.bt.oob", prop_oob, "3");
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002803 BTIF_TRACE_DEBUG("btif_dm_proc_loc_oob prop_oob = %s",prop_oob);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002804 if (prop_oob[0] == '1')
2805 path = path_a;
2806 else if (prop_oob[0] == '2')
2807 path = path_b;
2808 if (path)
2809 {
2810 fp = fopen(path, "wb+");
2811 if (fp == NULL)
2812 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002813 BTIF_TRACE_DEBUG("btif_dm_proc_loc_oob: failed to save local OOB data to %s", path);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002814 }
2815 else
2816 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002817 BTIF_TRACE_DEBUG("btif_dm_proc_loc_oob: save local OOB data into file %s",path);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002818 fwrite (c , 1 , BT_OCTET16_LEN , fp );
2819 fwrite (r , 1 , BT_OCTET16_LEN , fp );
2820 fclose(fp);
2821 }
2822 }
2823 }
2824}
2825BOOLEAN btif_dm_proc_rmt_oob(BD_ADDR bd_addr, BT_OCTET16 p_c, BT_OCTET16 p_r)
2826{
2827 char t[128];
2828 FILE *fp;
2829 char *path_a = "/data/misc/bluedroid/LOCAL/a.key";
2830 char *path_b = "/data/misc/bluedroid/LOCAL/b.key";
2831 char *path = NULL;
Nick Kralevichd70b7a82013-01-31 14:40:15 -08002832 char prop_oob[PROPERTY_VALUE_MAX];
The Android Open Source Project5738f832012-12-12 16:00:35 -08002833 BOOLEAN result = FALSE;
2834 bt_bdaddr_t bt_bd_addr;
2835 bdcpy(oob_cb.oob_bdaddr, bd_addr);
2836 property_get("service.brcm.bt.oob", prop_oob, "3");
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002837 BTIF_TRACE_DEBUG("btif_dm_proc_rmt_oob prop_oob = %s",prop_oob);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002838 if (prop_oob[0] == '1')
2839 path = path_b;
2840 else if (prop_oob[0] == '2')
2841 path = path_a;
2842 if (path)
2843 {
2844 fp = fopen(path, "rb");
2845 if (fp == NULL)
2846 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002847 BTIF_TRACE_DEBUG("btapp_dm_rmt_oob_reply: failed to read OOB keys from %s",path);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002848 return FALSE;
2849 }
2850 else
2851 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002852 BTIF_TRACE_DEBUG("btif_dm_proc_rmt_oob: read OOB data from %s",path);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002853 fread (p_c , 1 , BT_OCTET16_LEN , fp );
2854 fread (p_r , 1 , BT_OCTET16_LEN , fp );
2855 fclose(fp);
2856 }
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002857 BTIF_TRACE_DEBUG("----btif_dm_proc_rmt_oob: TRUE");
The Android Open Source Project5738f832012-12-12 16:00:35 -08002858 sprintf(t, "%02x:%02x:%02x:%02x:%02x:%02x",
2859 oob_cb.oob_bdaddr[0], oob_cb.oob_bdaddr[1], oob_cb.oob_bdaddr[2],
2860 oob_cb.oob_bdaddr[3], oob_cb.oob_bdaddr[4], oob_cb.oob_bdaddr[5]);
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002861 BTIF_TRACE_DEBUG("----btif_dm_proc_rmt_oob: peer_bdaddr = %s", t);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002862 sprintf(t, "%02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x",
2863 p_c[0], p_c[1], p_c[2], p_c[3], p_c[4], p_c[5], p_c[6], p_c[7],
2864 p_c[8], p_c[9], p_c[10], p_c[11], p_c[12], p_c[13], p_c[14], p_c[15]);
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002865 BTIF_TRACE_DEBUG("----btif_dm_proc_rmt_oob: c = %s",t);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002866 sprintf(t, "%02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x",
2867 p_r[0], p_r[1], p_r[2], p_r[3], p_r[4], p_r[5], p_r[6], p_r[7],
2868 p_r[8], p_r[9], p_r[10], p_r[11], p_r[12], p_r[13], p_r[14], p_r[15]);
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002869 BTIF_TRACE_DEBUG("----btif_dm_proc_rmt_oob: r = %s",t);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002870 bdcpy(bt_bd_addr.address, bd_addr);
2871 btif_transfer_context(btif_dm_generic_evt, BTIF_DM_CB_BOND_STATE_BONDING,
2872 (char *)&bt_bd_addr, sizeof(bt_bdaddr_t), NULL);
2873 result = TRUE;
2874 }
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002875 BTIF_TRACE_DEBUG("btif_dm_proc_rmt_oob result=%d",result);
The Android Open Source Project5738f832012-12-12 16:00:35 -08002876 return result;
2877}
2878#endif /* BTIF_DM_OOB_TEST */
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002879#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
2880
2881static void btif_dm_ble_key_notif_evt(tBTA_DM_SP_KEY_NOTIF *p_ssp_key_notif)
2882{
2883 bt_bdaddr_t bd_addr;
2884 bt_bdname_t bd_name;
2885 UINT32 cod;
Matthew Xie86f97ed2014-11-10 10:24:46 -08002886 int dev_type;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002887
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002888 BTIF_TRACE_DEBUG("%s", __FUNCTION__);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002889
2890 /* Remote name update */
Matthew Xie86f97ed2014-11-10 10:24:46 -08002891 if (!btif_get_device_type(p_ssp_key_notif->bd_addr, &dev_type))
2892 {
2893 dev_type = BT_DEVICE_TYPE_BLE;
2894 }
2895 btif_dm_update_ble_remote_properties(p_ssp_key_notif->bd_addr , p_ssp_key_notif->bd_name,
2896 (tBT_DEVICE_TYPE) dev_type);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002897 bdcpy(bd_addr.address, p_ssp_key_notif->bd_addr);
2898 memcpy(bd_name.name, p_ssp_key_notif->bd_name, BD_NAME_LEN);
2899
2900 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
2901 pairing_cb.is_ssp = FALSE;
2902 cod = COD_UNCLASSIFIED;
2903
2904 HAL_CBACK(bt_hal_cbacks, ssp_request_cb, &bd_addr, &bd_name,
2905 cod, BT_SSP_VARIANT_PASSKEY_NOTIFICATION,
2906 p_ssp_key_notif->passkey);
2907}
2908
2909/*******************************************************************************
2910**
2911** Function btif_dm_ble_auth_cmpl_evt
2912**
2913** Description Executes authentication complete event in btif context
2914**
2915** Returns void
2916**
2917*******************************************************************************/
2918static void btif_dm_ble_auth_cmpl_evt (tBTA_DM_AUTH_CMPL *p_auth_cmpl)
2919{
2920 /* Save link key, if not temporary */
2921 bt_bdaddr_t bd_addr;
2922 bt_status_t status = BT_STATUS_FAIL;
2923 bt_bond_state_t state = BT_BOND_STATE_NONE;
2924
2925 bdcpy(bd_addr.address, p_auth_cmpl->bd_addr);
2926 if ( (p_auth_cmpl->success == TRUE) && (p_auth_cmpl->key_present) )
2927 {
2928 /* store keys */
2929 }
2930 if (p_auth_cmpl->success)
2931 {
2932 status = BT_STATUS_SUCCESS;
2933 state = BT_BOND_STATE_BONDED;
2934
2935 btif_dm_save_ble_bonding_keys();
2936 BTA_GATTC_Refresh(bd_addr.address);
2937 btif_dm_get_remote_services(&bd_addr);
2938 }
2939 else
2940 {
2941 /*Map the HCI fail reason to bt status */
2942 switch (p_auth_cmpl->fail_reason)
2943 {
Priti Aghera156c52b2014-07-09 14:58:19 -07002944 case BTA_DM_AUTH_SMP_PAIR_AUTH_FAIL:
2945 case BTA_DM_AUTH_SMP_CONFIRM_VALUE_FAIL:
2946 btif_dm_remove_ble_bonding_keys();
2947 status = BT_STATUS_AUTH_FAILURE;
2948 break;
2949 case BTA_DM_AUTH_SMP_PAIR_NOT_SUPPORT:
2950 status = BT_STATUS_AUTH_REJECTED;
2951 break;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002952 default:
Andre Eisenbachca22ac42013-02-13 17:02:11 +09002953 btif_dm_remove_ble_bonding_keys();
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002954 status = BT_STATUS_FAIL;
2955 break;
2956 }
2957 }
2958 bond_state_changed(status, &bd_addr, state);
2959}
2960
2961
2962
2963void btif_dm_load_ble_local_keys(void)
2964{
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002965 memset(&ble_local_key_cb, 0, sizeof(btif_dm_local_key_cb_t));
2966
2967 if (btif_storage_get_ble_local_key(BTIF_DM_LE_LOCAL_KEY_ER,(char*)&ble_local_key_cb.er[0],
2968 BT_OCTET16_LEN)== BT_STATUS_SUCCESS)
2969 {
2970 ble_local_key_cb.is_er_rcvd = TRUE;
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002971 BTIF_TRACE_DEBUG("%s BLE ER key loaded",__FUNCTION__ );
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002972 }
2973
2974 if ((btif_storage_get_ble_local_key(BTIF_DM_LE_LOCAL_KEY_IR,(char*)&ble_local_key_cb.id_keys.ir[0],
2975 BT_OCTET16_LEN)== BT_STATUS_SUCCESS )&&
2976 (btif_storage_get_ble_local_key(BTIF_DM_LE_LOCAL_KEY_IRK, (char*)&ble_local_key_cb.id_keys.irk[0],
2977 BT_OCTET16_LEN)== BT_STATUS_SUCCESS)&&
2978 (btif_storage_get_ble_local_key(BTIF_DM_LE_LOCAL_KEY_DHK,(char*)&ble_local_key_cb.id_keys.dhk[0],
2979 BT_OCTET16_LEN)== BT_STATUS_SUCCESS))
2980 {
2981 ble_local_key_cb.is_id_keys_rcvd = TRUE;
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07002982 BTIF_TRACE_DEBUG("%s BLE ID keys loaded",__FUNCTION__ );
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08002983 }
2984
2985}
2986void btif_dm_get_ble_local_keys(tBTA_DM_BLE_LOCAL_KEY_MASK *p_key_mask, BT_OCTET16 er,
2987 tBTA_BLE_LOCAL_ID_KEYS *p_id_keys)
2988{
2989 if (ble_local_key_cb.is_er_rcvd )
2990 {
2991 memcpy(&er[0], &ble_local_key_cb.er[0], sizeof(BT_OCTET16));
2992 *p_key_mask |= BTA_BLE_LOCAL_KEY_TYPE_ER;
2993 }
2994
2995 if (ble_local_key_cb.is_id_keys_rcvd)
2996 {
2997 memcpy(&p_id_keys->ir[0], &ble_local_key_cb.id_keys.ir[0], sizeof(BT_OCTET16));
2998 memcpy(&p_id_keys->irk[0], &ble_local_key_cb.id_keys.irk[0], sizeof(BT_OCTET16));
2999 memcpy(&p_id_keys->dhk[0], &ble_local_key_cb.id_keys.dhk[0], sizeof(BT_OCTET16));
3000 *p_key_mask |= BTA_BLE_LOCAL_KEY_TYPE_ID;
3001 }
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07003002 BTIF_TRACE_DEBUG("%s *p_key_mask=0x%02x",__FUNCTION__, *p_key_mask);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003003}
3004
3005void btif_dm_save_ble_bonding_keys(void)
3006{
3007
3008 bt_bdaddr_t bd_addr;
3009
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07003010 BTIF_TRACE_DEBUG("%s",__FUNCTION__ );
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003011
3012 bdcpy(bd_addr.address, pairing_cb.bd_addr);
3013
3014 if (pairing_cb.ble.is_penc_key_rcvd)
3015 {
3016 btif_storage_add_ble_bonding_key(&bd_addr,
3017 (char *) &pairing_cb.ble.penc_key,
3018 BTIF_DM_LE_KEY_PENC,
3019 sizeof(btif_dm_ble_penc_keys_t));
3020 }
3021
3022 if (pairing_cb.ble.is_pid_key_rcvd)
3023 {
3024 btif_storage_add_ble_bonding_key(&bd_addr,
Andre Eisenbach5e808462014-10-21 12:37:53 -07003025 (char *) &pairing_cb.ble.pid_key,
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003026 BTIF_DM_LE_KEY_PID,
Andre Eisenbach5e808462014-10-21 12:37:53 -07003027 sizeof(btif_dm_ble_pid_keys_t));
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003028 }
3029
3030
3031 if (pairing_cb.ble.is_pcsrk_key_rcvd)
3032 {
3033 btif_storage_add_ble_bonding_key(&bd_addr,
3034 (char *) &pairing_cb.ble.pcsrk_key,
3035 BTIF_DM_LE_KEY_PCSRK,
3036 sizeof(btif_dm_ble_pcsrk_keys_t));
3037 }
3038
3039
3040 if (pairing_cb.ble.is_lenc_key_rcvd)
3041 {
3042 btif_storage_add_ble_bonding_key(&bd_addr,
3043 (char *) &pairing_cb.ble.lenc_key,
3044 BTIF_DM_LE_KEY_LENC,
3045 sizeof(btif_dm_ble_lenc_keys_t));
3046 }
3047
3048 if (pairing_cb.ble.is_lcsrk_key_rcvd)
3049 {
3050 btif_storage_add_ble_bonding_key(&bd_addr,
3051 (char *) &pairing_cb.ble.lcsrk_key,
3052 BTIF_DM_LE_KEY_LCSRK,
3053 sizeof(btif_dm_ble_lcsrk_keys_t));
3054 }
3055
Satya Calloji444a8da2015-03-06 10:38:22 -08003056 if (pairing_cb.ble.is_lidk_key_rcvd)
3057 {
3058 btif_storage_add_ble_bonding_key(&bd_addr,
3059 NULL,
3060 BTIF_DM_LE_KEY_LID,
3061 0);
3062 }
3063
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003064}
3065
3066
3067void btif_dm_remove_ble_bonding_keys(void)
3068{
3069 bt_bdaddr_t bd_addr;
3070
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07003071 BTIF_TRACE_DEBUG("%s",__FUNCTION__ );
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003072
3073 bdcpy(bd_addr.address, pairing_cb.bd_addr);
3074 btif_storage_remove_ble_bonding_keys(&bd_addr);
3075}
3076
3077
3078/*******************************************************************************
3079**
3080** Function btif_dm_ble_sec_req_evt
3081**
3082** Description Eprocess security request event in btif context
3083**
3084** Returns void
3085**
3086*******************************************************************************/
3087void btif_dm_ble_sec_req_evt(tBTA_DM_BLE_SEC_REQ *p_ble_req)
3088{
3089 bt_bdaddr_t bd_addr;
3090 bt_bdname_t bd_name;
3091 UINT32 cod;
Matthew Xie86f97ed2014-11-10 10:24:46 -08003092 int dev_type;
3093
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07003094 BTIF_TRACE_DEBUG("%s", __FUNCTION__);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003095
3096 if (pairing_cb.state == BT_BOND_STATE_BONDING)
3097 {
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07003098 BTIF_TRACE_DEBUG("%s Discard security request", __FUNCTION__);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003099 return;
3100 }
3101
3102 /* Remote name update */
Matthew Xie86f97ed2014-11-10 10:24:46 -08003103 if (!btif_get_device_type(p_ble_req->bd_addr, &dev_type))
3104 {
3105 dev_type = BT_DEVICE_TYPE_BLE;
3106 }
3107 btif_dm_update_ble_remote_properties(p_ble_req->bd_addr, p_ble_req->bd_name,
3108 (tBT_DEVICE_TYPE) dev_type);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003109
3110 bdcpy(bd_addr.address, p_ble_req->bd_addr);
3111 memcpy(bd_name.name, p_ble_req->bd_name, BD_NAME_LEN);
3112
3113 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
3114
Andre Eisenbach89363762015-01-26 13:49:36 -08003115 pairing_cb.bond_type = BOND_TYPE_PERSISTENT;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003116 pairing_cb.is_le_only = TRUE;
Satya Calloji7fb0da62015-01-29 20:40:17 -08003117 pairing_cb.is_le_nc = FALSE;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003118 pairing_cb.is_ssp = TRUE;
3119
3120 cod = COD_UNCLASSIFIED;
3121
3122 HAL_CBACK(bt_hal_cbacks, ssp_request_cb, &bd_addr, &bd_name, cod,
3123 BT_SSP_VARIANT_CONSENT, 0);
3124}
3125
3126
3127
3128/*******************************************************************************
3129**
3130** Function btif_dm_ble_passkey_req_evt
3131**
3132** Description Executes pin request event in btif context
3133**
3134** Returns void
3135**
3136*******************************************************************************/
3137static void btif_dm_ble_passkey_req_evt(tBTA_DM_PIN_REQ *p_pin_req)
3138{
3139 bt_bdaddr_t bd_addr;
3140 bt_bdname_t bd_name;
3141 UINT32 cod;
Matthew Xie86f97ed2014-11-10 10:24:46 -08003142 int dev_type;
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003143
3144 /* Remote name update */
Matthew Xie86f97ed2014-11-10 10:24:46 -08003145 if (!btif_get_device_type(p_pin_req->bd_addr, &dev_type))
3146 {
3147 dev_type = BT_DEVICE_TYPE_BLE;
3148 }
3149 btif_dm_update_ble_remote_properties(p_pin_req->bd_addr,p_pin_req->bd_name,
3150 (tBT_DEVICE_TYPE) dev_type);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003151
3152 bdcpy(bd_addr.address, p_pin_req->bd_addr);
3153 memcpy(bd_name.name, p_pin_req->bd_name, BD_NAME_LEN);
3154
3155 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
3156 pairing_cb.is_le_only = TRUE;
3157
3158 cod = COD_UNCLASSIFIED;
3159
3160 HAL_CBACK(bt_hal_cbacks, pin_request_cb,
3161 &bd_addr, &bd_name, cod);
3162}
Satya Calloji444a8da2015-03-06 10:38:22 -08003163static void btif_dm_ble_key_nc_req_evt(tBTA_DM_SP_KEY_NOTIF *p_notif_req)
3164{
3165 /* TODO implement key notification for numeric comparison */
3166 BTIF_TRACE_DEBUG("%s", __FUNCTION__);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003167
Satya Calloji444a8da2015-03-06 10:38:22 -08003168 /* Remote name update */
3169 btif_update_remote_properties(p_notif_req->bd_addr , p_notif_req->bd_name,
3170 NULL, BT_DEVICE_TYPE_BLE);
3171
3172 bt_bdaddr_t bd_addr;
3173 bdcpy(bd_addr.address, p_notif_req->bd_addr);
3174
3175 bt_bdname_t bd_name;
3176 memcpy(bd_name.name, p_notif_req->bd_name, BD_NAME_LEN);
3177
3178 bond_state_changed(BT_STATUS_SUCCESS, &bd_addr, BT_BOND_STATE_BONDING);
3179 pairing_cb.is_ssp = FALSE;
Satya Calloji7fb0da62015-01-29 20:40:17 -08003180 pairing_cb.is_le_only = TRUE;
3181 pairing_cb.is_le_nc = TRUE;
Satya Calloji444a8da2015-03-06 10:38:22 -08003182
3183 HAL_CBACK(bt_hal_cbacks, ssp_request_cb, &bd_addr, &bd_name,
3184 COD_UNCLASSIFIED, BT_SSP_VARIANT_PASSKEY_CONFIRMATION,
3185 p_notif_req->passkey);
3186}
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003187
3188void btif_dm_update_ble_remote_properties( BD_ADDR bd_addr, BD_NAME bd_name,
3189 tBT_DEVICE_TYPE dev_type)
3190{
3191 btif_update_remote_properties(bd_addr,bd_name,NULL,dev_type);
3192}
3193
3194static void btif_dm_ble_tx_test_cback(void *p)
3195{
3196 btif_transfer_context(btif_dm_generic_evt, BTIF_DM_CB_LE_TX_TEST,
3197 (char *)p, 1, NULL);
3198}
3199
3200static void btif_dm_ble_rx_test_cback(void *p)
3201{
3202 btif_transfer_context(btif_dm_generic_evt, BTIF_DM_CB_LE_RX_TEST,
3203 (char *)p, 1, NULL);
3204}
3205
3206static void btif_dm_ble_test_end_cback(void *p)
3207{
3208 btif_transfer_context(btif_dm_generic_evt, BTIF_DM_CB_LE_TEST_END,
3209 (char *)p, 3, NULL);
3210}
3211/*******************************************************************************
3212**
3213** Function btif_le_test_mode
3214**
3215** Description Sends a HCI BLE Test command to the Controller
3216**
3217** Returns BT_STATUS_SUCCESS on success
3218**
3219*******************************************************************************/
3220bt_status_t btif_le_test_mode(uint16_t opcode, uint8_t *buf, uint8_t len)
3221{
3222 switch (opcode) {
3223 case HCI_BLE_TRANSMITTER_TEST:
3224 if (len != 3) return BT_STATUS_PARM_INVALID;
3225 BTM_BleTransmitterTest(buf[0],buf[1],buf[2], btif_dm_ble_tx_test_cback);
3226 break;
3227 case HCI_BLE_RECEIVER_TEST:
3228 if (len != 1) return BT_STATUS_PARM_INVALID;
3229 BTM_BleReceiverTest(buf[0], btif_dm_ble_rx_test_cback);
3230 break;
3231 case HCI_BLE_TEST_END:
3232 BTM_BleTestEnd((tBTM_CMPL_CB*) btif_dm_ble_test_end_cback);
3233 break;
3234 default:
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07003235 BTIF_TRACE_ERROR("%s: Unknown LE Test Mode Command 0x%x", __FUNCTION__, opcode);
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003236 return BT_STATUS_UNSUPPORTED;
3237 }
3238 return BT_STATUS_SUCCESS;
3239}
Ganesh Ganapathi Battaead3cde2013-02-05 15:22:31 -08003240#endif
The Android Open Source Project5738f832012-12-12 16:00:35 -08003241
3242void btif_dm_on_disable()
3243{
3244 /* cancel any pending pairing requests */
3245 if (pairing_cb.state == BT_BOND_STATE_BONDING)
3246 {
3247 bt_bdaddr_t bd_addr;
3248
Sharvil Nanavatie8c3d752014-05-04 10:12:26 -07003249 BTIF_TRACE_DEBUG("%s: Cancel pending pairing request", __FUNCTION__);
The Android Open Source Project5738f832012-12-12 16:00:35 -08003250 bdcpy(bd_addr.address, pairing_cb.bd_addr);
3251 btif_dm_cancel_bond(&bd_addr);
3252 }
3253}
Matthew Xie1e5109b2012-11-09 18:26:26 -08003254
Satya Callojie5ba8842014-07-03 17:18:02 -07003255/*******************************************************************************
3256**
3257** Function btif_dm_read_energy_info
3258**
3259** Description Reads the energy info from controller
3260**
3261** Returns void
3262**
3263*******************************************************************************/
3264void btif_dm_read_energy_info()
3265{
Prerepa Viswanadham81b03192014-07-23 17:49:48 -07003266#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE))
Satya Callojie5ba8842014-07-03 17:18:02 -07003267 BTA_DmBleGetEnergyInfo(bta_energy_info_cb);
Prerepa Viswanadham81b03192014-07-23 17:49:48 -07003268#endif
Satya Callojie5ba8842014-07-03 17:18:02 -07003269}
3270
Matthew Xie1e5109b2012-11-09 18:26:26 -08003271static char* btif_get_default_local_name() {
3272 if (btif_default_local_name[0] == '\0')
3273 {
3274 int max_len = sizeof(btif_default_local_name) - 1;
3275 if (BTM_DEF_LOCAL_NAME[0] != '\0')
3276 {
3277 strncpy(btif_default_local_name, BTM_DEF_LOCAL_NAME, max_len);
3278 }
3279 else
3280 {
3281 char prop_model[PROPERTY_VALUE_MAX];
3282 property_get(PROPERTY_PRODUCT_MODEL, prop_model, "");
3283 strncpy(btif_default_local_name, prop_model, max_len);
3284 }
3285 btif_default_local_name[max_len] = '\0';
3286 }
3287 return btif_default_local_name;
3288}