mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
Merge branch 'bugfix/fix_can_not_find_mac_addr_error_mr' into 'master'
fix can not find mac addr error Closes BT-2032 See merge request espressif/esp-idf!16143
This commit is contained in:
commit
fe289ec670
@ -2065,14 +2065,41 @@ static void btu_ble_phy_update_complete_evt(UINT8 *p)
|
||||
btm_ble_update_phy_evt(&update_phy);
|
||||
}
|
||||
|
||||
#if BLE_PRIVACY_SPT == TRUE
|
||||
/*******************************************************************************
|
||||
**
|
||||
** Function btm_ble_resolve_random_addr_adv_ext
|
||||
**
|
||||
** Description resolve random address complete callback.
|
||||
**
|
||||
** Returns void
|
||||
**
|
||||
*******************************************************************************/
|
||||
static void btm_ble_resolve_random_addr_adv_ext(void *p_rec, void *p)
|
||||
{
|
||||
tBTM_SEC_DEV_REC *match_rec = (tBTM_SEC_DEV_REC *) p_rec;
|
||||
BD_ADDR bda;
|
||||
UINT8 *pp = (UINT8 *)p+4; //jump to the location of bd addr
|
||||
if (match_rec) {
|
||||
// Assign the original address to be the current report address
|
||||
memcpy(bda, match_rec->ble.pseudo_addr, BD_ADDR_LEN);
|
||||
BDADDR_TO_STREAM(pp,bda);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
static void btu_ble_ext_adv_report_evt(UINT8 *p, UINT16 evt_len)
|
||||
{
|
||||
tBTM_BLE_EXT_ADV_REPORT ext_adv_report = {0};
|
||||
UINT8 num_reports = {0};
|
||||
UINT8 *pp = p;
|
||||
//UINT8 legacy_event_type = 0;
|
||||
UINT16 evt_type = 0;
|
||||
uint8_t addr_type;
|
||||
BD_ADDR bda;
|
||||
#if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
|
||||
BOOLEAN match = FALSE;
|
||||
#endif
|
||||
|
||||
if (!p) {
|
||||
HCI_TRACE_ERROR("%s, Invalid params.", __func__);
|
||||
@ -2106,12 +2133,17 @@ static void btu_ble_ext_adv_report_evt(UINT8 *p, UINT16 evt_len)
|
||||
|
||||
STREAM_TO_UINT8(addr_type, p);
|
||||
STREAM_TO_BDADDR(bda, p);
|
||||
// if it is an anonymous adv, skip address resolution
|
||||
if(addr_type != 0xFF) {
|
||||
#if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
|
||||
btm_identity_addr_to_random_pseudo(bda, &addr_type, FALSE);
|
||||
#endif
|
||||
if(addr_type != 0xFF) {
|
||||
match = btm_identity_addr_to_random_pseudo(bda, &addr_type, FALSE);
|
||||
if (!match && BTM_BLE_IS_RESOLVE_BDA(bda)) {
|
||||
btm_ble_resolve_random_addr(bda, btm_ble_resolve_random_addr_adv_ext, pp);
|
||||
//the BDADDR may be updated, so read it again
|
||||
p = p - sizeof(bda);
|
||||
STREAM_TO_BDADDR(bda, p);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
ext_adv_report.addr_type = addr_type;
|
||||
memcpy(ext_adv_report.addr, bda, 6);
|
||||
STREAM_TO_UINT8(ext_adv_report.primary_phy, p);
|
||||
|
Loading…
Reference in New Issue
Block a user