2016-09-26 21:37:39 +08:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* Copyright (C) 1999-2012 Broadcom Corporation
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at:
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* This file contains functions for BLE address management.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "bt_types.h"
|
|
|
|
#include "hcimsgs.h"
|
|
|
|
#include "btu.h"
|
|
|
|
#include "btm_int.h"
|
|
|
|
#include "gap_api.h"
|
|
|
|
#include "controller.h"
|
|
|
|
|
|
|
|
#if (defined BLE_INCLUDED && BLE_INCLUDED == TRUE)
|
|
|
|
#include "btm_ble_int.h"
|
|
|
|
#include "smp_api.h"
|
|
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_gen_resolve_paddr_cmpl
|
|
|
|
**
|
|
|
|
** Description This is callback functioin when resolvable private address
|
|
|
|
** generation is complete.
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
static void btm_gen_resolve_paddr_cmpl(tSMP_ENC *p)
|
|
|
|
{
|
|
|
|
tBTM_LE_RANDOM_CB *p_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
BTM_TRACE_EVENT ("btm_gen_resolve_paddr_cmpl");
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p) {
|
2016-09-26 21:37:39 +08:00
|
|
|
/* set hash to be LSB of rpAddress */
|
|
|
|
p_cb->private_addr[5] = p->param_buf[0];
|
|
|
|
p_cb->private_addr[4] = p->param_buf[1];
|
|
|
|
p_cb->private_addr[3] = p->param_buf[2];
|
|
|
|
/* set it to controller */
|
|
|
|
btsnd_hcic_ble_set_random_addr(p_cb->private_addr);
|
|
|
|
|
|
|
|
p_cb->own_addr_type = BLE_ADDR_RANDOM;
|
2017-07-19 14:50:40 +08:00
|
|
|
if (p_cb->set_local_privacy_cback){
|
|
|
|
(*p_cb->set_local_privacy_cback)(BTM_SET_PRIVACY_SUCCESS);
|
|
|
|
p_cb->set_local_privacy_cback = NULL;
|
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
/* start a periodical timer to refresh random addr */
|
|
|
|
btu_stop_timer_oneshot(&p_cb->raddr_timer_ent);
|
|
|
|
#if (BTM_BLE_CONFORMANCE_TESTING == TRUE)
|
|
|
|
btu_start_timer_oneshot(&p_cb->raddr_timer_ent, BTU_TTYPE_BLE_RANDOM_ADDR,
|
2016-11-25 02:10:15 +08:00
|
|
|
btm_cb.ble_ctr_cb.rpa_tout);
|
2016-09-26 21:37:39 +08:00
|
|
|
#else
|
|
|
|
btu_start_timer_oneshot(&p_cb->raddr_timer_ent, BTU_TTYPE_BLE_RANDOM_ADDR,
|
2016-11-25 02:10:15 +08:00
|
|
|
BTM_BLE_PRIVATE_ADDR_INT);
|
2016-09-26 21:37:39 +08:00
|
|
|
#endif
|
2016-11-25 02:10:15 +08:00
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
/* random address set failure */
|
|
|
|
BTM_TRACE_DEBUG("set random address failed");
|
2017-07-19 14:50:40 +08:00
|
|
|
if (p_cb->set_local_privacy_cback){
|
|
|
|
(*p_cb->set_local_privacy_cback)(BTM_SET_PRIVACY_FAIL);
|
|
|
|
p_cb->set_local_privacy_cback = NULL;
|
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_gen_resolve_paddr_low
|
|
|
|
**
|
|
|
|
** Description This function is called when random address has generate the
|
|
|
|
** random number base for low 3 byte bd address.
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
void btm_gen_resolve_paddr_low(tBTM_RAND_ENC *p)
|
|
|
|
{
|
|
|
|
#if (BLE_INCLUDED == TRUE && SMP_INCLUDED == TRUE)
|
|
|
|
tBTM_LE_RANDOM_CB *p_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
tSMP_ENC output;
|
|
|
|
|
|
|
|
BTM_TRACE_EVENT ("btm_gen_resolve_paddr_low");
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p) {
|
2016-09-26 21:37:39 +08:00
|
|
|
p->param_buf[2] &= (~BLE_RESOLVE_ADDR_MASK);
|
|
|
|
p->param_buf[2] |= BLE_RESOLVE_ADDR_MSB;
|
|
|
|
|
|
|
|
p_cb->private_addr[2] = p->param_buf[0];
|
|
|
|
p_cb->private_addr[1] = p->param_buf[1];
|
|
|
|
p_cb->private_addr[0] = p->param_buf[2];
|
|
|
|
|
|
|
|
/* encrypt with ur IRK */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (!SMP_Encrypt(btm_cb.devcb.id_keys.irk, BT_OCTET16_LEN, p->param_buf, 3, &output)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
btm_gen_resolve_paddr_cmpl(NULL);
|
2016-11-25 02:10:15 +08:00
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
btm_gen_resolve_paddr_cmpl(&output);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_gen_resolvable_private_addr
|
|
|
|
**
|
|
|
|
** Description This function generate a resolvable private address.
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
void btm_gen_resolvable_private_addr (void *p_cmd_cplt_cback)
|
|
|
|
{
|
|
|
|
BTM_TRACE_EVENT ("btm_gen_resolvable_private_addr");
|
|
|
|
/* generate 3B rand as BD LSB, SRK with it, get BD MSB */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (!btsnd_hcic_ble_rand((void *)p_cmd_cplt_cback)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
btm_gen_resolve_paddr_cmpl(NULL);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
}
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_gen_non_resolve_paddr_cmpl
|
|
|
|
**
|
|
|
|
** Description This is the callback function when non-resolvable private
|
|
|
|
** function is generated and write to controller.
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
static void btm_gen_non_resolve_paddr_cmpl(tBTM_RAND_ENC *p)
|
|
|
|
{
|
|
|
|
tBTM_LE_RANDOM_CB *p_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
tBTM_BLE_ADDR_CBACK *p_cback = p_cb->p_generate_cback;
|
|
|
|
void *p_data = p_cb->p;
|
|
|
|
UINT8 *pp;
|
|
|
|
BD_ADDR static_random;
|
|
|
|
|
|
|
|
BTM_TRACE_EVENT ("btm_gen_non_resolve_paddr_cmpl");
|
|
|
|
|
|
|
|
p_cb->p_generate_cback = NULL;
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p) {
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
pp = p->param_buf;
|
|
|
|
STREAM_TO_BDADDR(static_random, pp);
|
|
|
|
/* mask off the 2 MSB */
|
|
|
|
static_random[0] &= BLE_STATIC_PRIVATE_MSB_MASK;
|
|
|
|
|
|
|
|
/* report complete */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_cback) {
|
2016-09-26 21:37:39 +08:00
|
|
|
(* p_cback)(static_random, p_data);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
BTM_TRACE_DEBUG("btm_gen_non_resolvable_private_addr failed");
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_cback) {
|
2016-09-26 21:37:39 +08:00
|
|
|
(* p_cback)(NULL, p_data);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_gen_non_resolvable_private_addr
|
|
|
|
**
|
|
|
|
** Description This function generate a non-resolvable private address.
|
|
|
|
**
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
void btm_gen_non_resolvable_private_addr (tBTM_BLE_ADDR_CBACK *p_cback, void *p)
|
|
|
|
{
|
|
|
|
tBTM_LE_RANDOM_CB *p_mgnt_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
|
|
|
|
BTM_TRACE_EVENT ("btm_gen_non_resolvable_private_addr");
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_mgnt_cb->p_generate_cback != NULL) {
|
2016-09-26 21:37:39 +08:00
|
|
|
return;
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
p_mgnt_cb->p_generate_cback = p_cback;
|
|
|
|
p_mgnt_cb->p = p;
|
2016-11-25 02:10:15 +08:00
|
|
|
if (!btsnd_hcic_ble_rand((void *)btm_gen_non_resolve_paddr_cmpl)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
btm_gen_non_resolve_paddr_cmpl(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
** Utility functions for Random address resolving
|
|
|
|
*******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_resolve_address_cmpl
|
|
|
|
**
|
|
|
|
** Description This function sends the random address resolving complete
|
|
|
|
** callback.
|
|
|
|
**
|
|
|
|
** Returns None.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
2017-04-17 22:53:43 -04:00
|
|
|
#if SMP_INCLUDED == TRUE
|
2016-09-26 21:37:39 +08:00
|
|
|
static void btm_ble_resolve_address_cmpl(void)
|
|
|
|
{
|
|
|
|
tBTM_LE_RANDOM_CB *p_mgnt_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
tBTM_SEC_DEV_REC *p_dev_rec = NULL;
|
|
|
|
|
|
|
|
BTM_TRACE_EVENT ("btm_ble_resolve_address_cmpl p_mgnt_cb->index = %d", p_mgnt_cb->index);
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_mgnt_cb->index < BTM_SEC_MAX_DEVICE_RECORDS) {
|
2016-09-26 21:37:39 +08:00
|
|
|
p_dev_rec = &btm_cb.sec_dev_rec[p_mgnt_cb->index];
|
|
|
|
}
|
|
|
|
|
|
|
|
p_mgnt_cb->busy = FALSE;
|
|
|
|
|
|
|
|
(* p_mgnt_cb->p_resolve_cback)(p_dev_rec, p_mgnt_cb->p);
|
|
|
|
}
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_proc_resolve_x
|
|
|
|
**
|
|
|
|
** Description This function compares the X with random address 3 MSO bytes
|
|
|
|
** to find a match, if not match, continue for next record.
|
|
|
|
**
|
|
|
|
** Returns None.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
static BOOLEAN btm_ble_proc_resolve_x(tSMP_ENC *p)
|
|
|
|
{
|
|
|
|
tBTM_LE_RANDOM_CB *p_mgnt_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
UINT8 comp[3];
|
|
|
|
BTM_TRACE_EVENT ("btm_ble_proc_resolve_x");
|
|
|
|
/* compare the hash with 3 LSB of bd address */
|
|
|
|
comp[0] = p_mgnt_cb->random_bda[5];
|
|
|
|
comp[1] = p_mgnt_cb->random_bda[4];
|
|
|
|
comp[2] = p_mgnt_cb->random_bda[3];
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p) {
|
|
|
|
if (!memcmp(p->param_buf, &comp[0], 3)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
/* match is found */
|
|
|
|
BTM_TRACE_EVENT ("match is found");
|
|
|
|
btm_ble_resolve_address_cmpl();
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
2017-04-17 22:53:43 -04:00
|
|
|
|
2016-09-26 21:37:39 +08:00
|
|
|
return FALSE;
|
|
|
|
}
|
2017-04-17 22:53:43 -04:00
|
|
|
#endif ///SMP_INCLUDED == TRUE
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_init_pseudo_addr
|
|
|
|
**
|
|
|
|
** Description This function is used to initialize pseudo address.
|
|
|
|
** If pseudo address is not available, use dummy address
|
|
|
|
**
|
|
|
|
** Returns TRUE is updated; FALSE otherwise.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
BOOLEAN btm_ble_init_pseudo_addr (tBTM_SEC_DEV_REC *p_dev_rec, BD_ADDR new_pseudo_addr)
|
|
|
|
{
|
2017-04-17 22:53:43 -04:00
|
|
|
#if (SMP_INCLUDED == TRUE)
|
2016-09-26 21:37:39 +08:00
|
|
|
BD_ADDR dummy_bda = {0};
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (memcmp(p_dev_rec->ble.pseudo_addr, dummy_bda, BD_ADDR_LEN) == 0) {
|
2016-09-26 21:37:39 +08:00
|
|
|
memcpy(p_dev_rec->ble.pseudo_addr, new_pseudo_addr, BD_ADDR_LEN);
|
|
|
|
return TRUE;
|
|
|
|
}
|
2017-04-17 22:53:43 -04:00
|
|
|
#endif ///SMP_INCLUDED == TRUE
|
2016-09-26 21:37:39 +08:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_addr_resolvable
|
|
|
|
**
|
|
|
|
** Description This function checks if a RPA is resolvable by the device key.
|
|
|
|
**
|
|
|
|
** Returns TRUE is resolvable; FALSE otherwise.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
BOOLEAN btm_ble_addr_resolvable (BD_ADDR rpa, tBTM_SEC_DEV_REC *p_dev_rec)
|
|
|
|
{
|
|
|
|
BOOLEAN rt = FALSE;
|
2017-04-17 22:53:43 -04:00
|
|
|
#if (SMP_INCLUDED == TRUE)
|
2016-11-25 02:10:15 +08:00
|
|
|
if (!BTM_BLE_IS_RESOLVE_BDA(rpa)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
return rt;
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
UINT8 rand[3];
|
|
|
|
tSMP_ENC output;
|
|
|
|
if ((p_dev_rec->device_type & BT_DEVICE_TYPE_BLE) &&
|
2016-11-25 02:10:15 +08:00
|
|
|
(p_dev_rec->ble.key_type & BTM_LE_KEY_PID)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
BTM_TRACE_DEBUG("%s try to resolve", __func__);
|
|
|
|
/* use the 3 MSB of bd address as prand */
|
|
|
|
rand[0] = rpa[2];
|
|
|
|
rand[1] = rpa[1];
|
|
|
|
rand[2] = rpa[0];
|
|
|
|
|
|
|
|
/* generate X = E irk(R0, R1, R2) and R is random address 3 LSO */
|
|
|
|
SMP_Encrypt(p_dev_rec->ble.keys.irk, BT_OCTET16_LEN,
|
|
|
|
&rand[0], 3, &output);
|
|
|
|
|
|
|
|
rand[0] = rpa[5];
|
|
|
|
rand[1] = rpa[4];
|
|
|
|
rand[2] = rpa[3];
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (!memcmp(output.param_buf, &rand[0], 3)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
btm_ble_init_pseudo_addr (p_dev_rec, rpa);
|
|
|
|
rt = TRUE;
|
|
|
|
}
|
|
|
|
}
|
2017-04-17 22:53:43 -04:00
|
|
|
#endif ///SMP_INCLUDED == TRUE
|
2016-09-26 21:37:39 +08:00
|
|
|
return rt;
|
|
|
|
}
|
|
|
|
|
2017-04-17 22:53:43 -04:00
|
|
|
#if (BLE_INCLUDED == TRUE && SMP_INCLUDED == TRUE)
|
2016-09-26 21:37:39 +08:00
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_match_random_bda
|
|
|
|
**
|
|
|
|
** Description This function match the random address to the appointed device
|
|
|
|
** record, starting from calculating IRK. If record index exceed
|
|
|
|
** the maximum record number, matching failed and send callback.
|
|
|
|
**
|
|
|
|
** Returns None.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
static BOOLEAN btm_ble_match_random_bda(UINT16 rec_index)
|
|
|
|
{
|
|
|
|
/* use the 3 MSB of bd address as prand */
|
|
|
|
|
|
|
|
tBTM_LE_RANDOM_CB *p_mgnt_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
UINT8 rand[3];
|
|
|
|
rand[0] = p_mgnt_cb->random_bda[2];
|
|
|
|
rand[1] = p_mgnt_cb->random_bda[1];
|
|
|
|
rand[2] = p_mgnt_cb->random_bda[0];
|
|
|
|
|
|
|
|
BTM_TRACE_EVENT("%s rec_index = %d", __func__, rec_index);
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (rec_index < BTM_SEC_MAX_DEVICE_RECORDS) {
|
2016-09-26 21:37:39 +08:00
|
|
|
tSMP_ENC output;
|
|
|
|
tBTM_SEC_DEV_REC *p_dev_rec;
|
|
|
|
p_dev_rec = &btm_cb.sec_dev_rec[rec_index];
|
|
|
|
|
|
|
|
BTM_TRACE_DEBUG("sec_flags = %02x device_type = %d", p_dev_rec->sec_flags,
|
|
|
|
p_dev_rec->device_type);
|
|
|
|
|
|
|
|
if ((p_dev_rec->device_type & BT_DEVICE_TYPE_BLE) &&
|
2016-11-25 02:10:15 +08:00
|
|
|
(p_dev_rec->ble.key_type & BTM_LE_KEY_PID)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
/* generate X = E irk(R0, R1, R2) and R is random address 3 LSO */
|
|
|
|
SMP_Encrypt(p_dev_rec->ble.keys.irk, BT_OCTET16_LEN,
|
|
|
|
&rand[0], 3, &output);
|
|
|
|
return btm_ble_proc_resolve_x(&output);
|
2016-11-25 02:10:15 +08:00
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
// not completed
|
|
|
|
return FALSE;
|
|
|
|
}
|
2016-11-25 02:10:15 +08:00
|
|
|
} else { /* no match found */
|
2016-09-26 21:37:39 +08:00
|
|
|
btm_ble_resolve_address_cmpl();
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
2017-04-17 22:53:43 -04:00
|
|
|
#endif ///BLE_INCLUDED == TRUE && SMP_INCLUDED == TRUE
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_resolve_random_addr
|
|
|
|
**
|
|
|
|
** Description This function is called to resolve a random address.
|
|
|
|
**
|
|
|
|
** Returns pointer to the security record of the device whom a random
|
|
|
|
** address is matched to.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
2016-11-25 02:10:15 +08:00
|
|
|
void btm_ble_resolve_random_addr(BD_ADDR random_bda, tBTM_BLE_RESOLVE_CBACK *p_cback, void *p)
|
2016-09-26 21:37:39 +08:00
|
|
|
{
|
2017-04-17 22:53:43 -04:00
|
|
|
#if (SMP_INCLUDED == TRUE)
|
2016-09-26 21:37:39 +08:00
|
|
|
tBTM_LE_RANDOM_CB *p_mgnt_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
|
|
|
|
|
|
|
|
BTM_TRACE_EVENT ("btm_ble_resolve_random_addr");
|
2016-11-25 02:10:15 +08:00
|
|
|
if ( !p_mgnt_cb->busy) {
|
2016-09-26 21:37:39 +08:00
|
|
|
p_mgnt_cb->p = p;
|
|
|
|
p_mgnt_cb->busy = TRUE;
|
|
|
|
p_mgnt_cb->index = 0;
|
|
|
|
p_mgnt_cb->p_resolve_cback = p_cback;
|
|
|
|
memcpy(p_mgnt_cb->random_bda, random_bda, BD_ADDR_LEN);
|
|
|
|
/* start to resolve random address */
|
|
|
|
/* check for next security record */
|
2016-11-25 02:10:15 +08:00
|
|
|
while (TRUE) {
|
|
|
|
if (btm_ble_match_random_bda(p_mgnt_cb->index)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
/* atch found or went through the list */
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
p_mgnt_cb->index ++;
|
|
|
|
}
|
2016-11-25 02:10:15 +08:00
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
(*p_cback)(NULL, p);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
#endif
|
|
|
|
|
2017-04-17 22:53:43 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-09-26 21:37:39 +08:00
|
|
|
/*******************************************************************************
|
|
|
|
** address mapping between pseudo address and real connection address
|
|
|
|
*******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_find_dev_by_identity_addr
|
|
|
|
**
|
|
|
|
** Description find the security record whose LE static address is matching
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
2016-11-25 02:10:15 +08:00
|
|
|
tBTM_SEC_DEV_REC *btm_find_dev_by_identity_addr(BD_ADDR bd_addr, UINT8 addr_type)
|
2016-09-26 21:37:39 +08:00
|
|
|
{
|
|
|
|
#if BLE_PRIVACY_SPT == TRUE
|
|
|
|
UINT8 i;
|
|
|
|
tBTM_SEC_DEV_REC *p_dev_rec = &btm_cb.sec_dev_rec[0];
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
for (i = 0; i < BTM_SEC_MAX_DEVICE_RECORDS; i ++, p_dev_rec ++) {
|
2016-09-26 21:37:39 +08:00
|
|
|
if ((p_dev_rec->sec_flags & BTM_SEC_IN_USE) &&
|
2016-11-25 02:10:15 +08:00
|
|
|
memcmp(p_dev_rec->ble.static_addr, bd_addr, BD_ADDR_LEN) == 0) {
|
2016-09-26 21:37:39 +08:00
|
|
|
if ((p_dev_rec->ble.static_addr_type & (~BLE_ADDR_TYPE_ID_BIT)) !=
|
2016-11-25 02:10:15 +08:00
|
|
|
(addr_type & (~BLE_ADDR_TYPE_ID_BIT))) {
|
2016-09-26 21:37:39 +08:00
|
|
|
BTM_TRACE_WARNING("%s find pseudo->random match with diff addr type: %d vs %d",
|
2016-11-25 02:10:15 +08:00
|
|
|
__func__, p_dev_rec->ble.static_addr_type, addr_type);
|
2016-09-26 21:37:39 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* found the match */
|
|
|
|
return p_dev_rec;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_identity_addr_to_random_pseudo
|
|
|
|
**
|
|
|
|
** Description This function map a static BD address to a pseudo random address
|
|
|
|
** in security database.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
BOOLEAN btm_identity_addr_to_random_pseudo(BD_ADDR bd_addr, UINT8 *p_addr_type, BOOLEAN refresh)
|
|
|
|
{
|
|
|
|
#if BLE_PRIVACY_SPT == TRUE
|
|
|
|
tBTM_SEC_DEV_REC *p_dev_rec = btm_find_dev_by_identity_addr(bd_addr, *p_addr_type);
|
|
|
|
|
|
|
|
BTM_TRACE_EVENT ("%s", __func__);
|
|
|
|
/* evt reported on static address, map static address to random pseudo */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_dev_rec != NULL) {
|
2016-09-26 21:37:39 +08:00
|
|
|
/* if RPA offloading is supported, or 4.2 controller, do RPA refresh */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (refresh && controller_get_interface()->get_ble_resolving_list_max_size() != 0) {
|
2016-09-26 21:37:39 +08:00
|
|
|
btm_ble_read_resolving_list_entry(p_dev_rec);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
/* assign the original address to be the current report address */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (!btm_ble_init_pseudo_addr (p_dev_rec, bd_addr)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
memcpy(bd_addr, p_dev_rec->ble.pseudo_addr, BD_ADDR_LEN);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
*p_addr_type = p_dev_rec->ble.ble_addr_type;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_random_pseudo_to_identity_addr
|
|
|
|
**
|
|
|
|
** Description This function map a random pseudo address to a public address
|
|
|
|
** random_pseudo is input and output parameter
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
BOOLEAN btm_random_pseudo_to_identity_addr(BD_ADDR random_pseudo, UINT8 *p_static_addr_type)
|
|
|
|
{
|
|
|
|
#if BLE_PRIVACY_SPT == TRUE
|
|
|
|
tBTM_SEC_DEV_REC *p_dev_rec = btm_find_dev (random_pseudo);
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_dev_rec != NULL) {
|
|
|
|
if (p_dev_rec->ble.in_controller_list & BTM_RESOLVING_LIST_BIT) {
|
2016-09-26 21:37:39 +08:00
|
|
|
* p_static_addr_type = p_dev_rec->ble.static_addr_type;
|
|
|
|
memcpy(random_pseudo, p_dev_rec->ble.static_addr, BD_ADDR_LEN);
|
2017-06-14 09:01:29 -04:00
|
|
|
if (controller_get_interface()->supports_ble_privacy() && p_dev_rec->ble.ble_addr_type != BLE_ADDR_PUBLIC) {
|
2016-09-26 21:37:39 +08:00
|
|
|
*p_static_addr_type |= BLE_ADDR_TYPE_ID_BIT;
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_refresh_peer_resolvable_private_addr
|
|
|
|
**
|
|
|
|
** Description This function refresh the currently used resolvable remote private address into security
|
|
|
|
** database and set active connection address.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
void btm_ble_refresh_peer_resolvable_private_addr(BD_ADDR pseudo_bda, BD_ADDR rpa,
|
2016-11-25 02:10:15 +08:00
|
|
|
UINT8 rra_type)
|
2016-09-26 21:37:39 +08:00
|
|
|
{
|
|
|
|
#if BLE_PRIVACY_SPT == TRUE
|
|
|
|
UINT8 rra_dummy = FALSE;
|
|
|
|
BD_ADDR dummy_bda = {0};
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (memcmp(dummy_bda, rpa, BD_ADDR_LEN) == 0) {
|
2016-09-26 21:37:39 +08:00
|
|
|
rra_dummy = TRUE;
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
|
|
|
|
/* update security record here, in adv event or connection complete process */
|
|
|
|
tBTM_SEC_DEV_REC *p_sec_rec = btm_find_dev(pseudo_bda);
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_sec_rec != NULL) {
|
2016-09-26 21:37:39 +08:00
|
|
|
memcpy(p_sec_rec->ble.cur_rand_addr, rpa, BD_ADDR_LEN);
|
|
|
|
|
|
|
|
/* unknown, if dummy address, set to static */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (rra_type == BTM_BLE_ADDR_PSEUDO) {
|
|
|
|
p_sec_rec->ble.active_addr_type = rra_dummy ? BTM_BLE_ADDR_STATIC : BTM_BLE_ADDR_RRA;
|
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
p_sec_rec->ble.active_addr_type = rra_type;
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
BTM_TRACE_ERROR("No matching known device in record");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
BTM_TRACE_DEBUG("%s: active_addr_type: %d ",
|
|
|
|
__func__, p_sec_rec->ble.active_addr_type);
|
|
|
|
|
|
|
|
/* connection refresh remote address */
|
|
|
|
tACL_CONN *p_acl = btm_bda_to_acl(p_sec_rec->bd_addr, BT_TRANSPORT_LE);
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_acl == NULL) {
|
2016-09-26 21:37:39 +08:00
|
|
|
p_acl = btm_bda_to_acl(p_sec_rec->ble.pseudo_addr, BT_TRANSPORT_LE);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
2016-09-26 21:37:39 +08:00
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p_acl != NULL) {
|
|
|
|
if (rra_type == BTM_BLE_ADDR_PSEUDO) {
|
2016-09-26 21:37:39 +08:00
|
|
|
/* use static address, resolvable_private_addr is empty */
|
2016-11-25 02:10:15 +08:00
|
|
|
if (rra_dummy) {
|
2016-09-26 21:37:39 +08:00
|
|
|
p_acl->active_remote_addr_type = p_sec_rec->ble.static_addr_type;
|
|
|
|
memcpy(p_acl->active_remote_addr, p_sec_rec->ble.static_addr, BD_ADDR_LEN);
|
2016-11-25 02:10:15 +08:00
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
p_acl->active_remote_addr_type = BLE_ADDR_RANDOM;
|
|
|
|
memcpy(p_acl->active_remote_addr, rpa, BD_ADDR_LEN);
|
|
|
|
}
|
2016-11-25 02:10:15 +08:00
|
|
|
} else {
|
|
|
|
p_acl->active_remote_addr_type = rra_type;
|
|
|
|
memcpy(p_acl->active_remote_addr, rpa, BD_ADDR_LEN);
|
2016-09-26 21:37:39 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
BTM_TRACE_DEBUG("p_acl->active_remote_addr_type: %d ", p_acl->active_remote_addr_type);
|
|
|
|
BTM_TRACE_DEBUG("%s conn_addr: %02x:%02x:%02x:%02x:%02x:%02x",
|
2016-11-25 02:10:15 +08:00
|
|
|
__func__, p_acl->active_remote_addr[0], p_acl->active_remote_addr[1],
|
|
|
|
p_acl->active_remote_addr[2], p_acl->active_remote_addr[3],
|
|
|
|
p_acl->active_remote_addr[4], p_acl->active_remote_addr[5]);
|
2016-09-26 21:37:39 +08:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Function btm_ble_refresh_local_resolvable_private_addr
|
|
|
|
**
|
|
|
|
** Description This function refresh the currently used resolvable private address for the
|
|
|
|
** active link to the remote device
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
void btm_ble_refresh_local_resolvable_private_addr(BD_ADDR pseudo_addr,
|
2016-11-25 02:10:15 +08:00
|
|
|
BD_ADDR local_rpa)
|
2016-09-26 21:37:39 +08:00
|
|
|
{
|
|
|
|
#if BLE_PRIVACY_SPT == TRUE
|
|
|
|
tACL_CONN *p = btm_bda_to_acl(pseudo_addr, BT_TRANSPORT_LE);
|
|
|
|
BD_ADDR dummy_bda = {0};
|
|
|
|
|
2016-11-25 02:10:15 +08:00
|
|
|
if (p != NULL) {
|
|
|
|
if (btm_cb.ble_ctr_cb.privacy_mode != BTM_PRIVACY_NONE) {
|
2016-09-26 21:37:39 +08:00
|
|
|
p->conn_addr_type = BLE_ADDR_RANDOM;
|
2016-11-25 02:10:15 +08:00
|
|
|
if (memcmp(local_rpa, dummy_bda, BD_ADDR_LEN)) {
|
2016-09-26 21:37:39 +08:00
|
|
|
memcpy(p->conn_addr, local_rpa, BD_ADDR_LEN);
|
2016-11-25 02:10:15 +08:00
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
memcpy(p->conn_addr, btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, BD_ADDR_LEN);
|
2016-11-25 02:10:15 +08:00
|
|
|
}
|
|
|
|
} else {
|
2016-09-26 21:37:39 +08:00
|
|
|
p->conn_addr_type = BLE_ADDR_PUBLIC;
|
2016-11-25 02:10:15 +08:00
|
|
|
memcpy(p->conn_addr, &controller_get_interface()->get_address()->address, BD_ADDR_LEN);
|
2016-09-26 21:37:39 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|