You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@mynewt.apache.org by an...@apache.org on 2022/04/18 17:19:44 UTC
[mynewt-nimble] branch master updated: nimble/ll: Fix AUX_CONNECT_RSP verification
This is an automated email from the ASF dual-hosted git repository.
andk pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/mynewt-nimble.git
The following commit(s) were added to refs/heads/master by this push:
new 1fb4475b nimble/ll: Fix AUX_CONNECT_RSP verification
1fb4475b is described below
commit 1fb4475bea9bd8159cece77eeb28be57c9a7c6bb
Author: Andrzej Kaczmarek <an...@codecoup.pl>
AuthorDate: Sat Apr 16 11:46:37 2022 +0200
nimble/ll: Fix AUX_CONNECT_RSP verification
This handles properly the case where AdvA is an identity address in
advertising, but an RPA is used in AUX_CONNECT_RSP.
---
nimble/controller/src/ble_ll_scan_aux.c | 17 ++++++++---------
1 file changed, 8 insertions(+), 9 deletions(-)
diff --git a/nimble/controller/src/ble_ll_scan_aux.c b/nimble/controller/src/ble_ll_scan_aux.c
index ce2ac072..e3b94822 100644
--- a/nimble/controller/src/ble_ll_scan_aux.c
+++ b/nimble/controller/src/ble_ll_scan_aux.c
@@ -1517,23 +1517,22 @@ ble_ll_scan_aux_check_connect_rsp(uint8_t *rxbuf,
targeta_type = !!(pdu_hdr & BLE_ADV_PDU_HDR_RXADD_RAND);
#if MYNEWT_VAL(BLE_LL_CFG_FEAT_LL_PRIVACY)
- /* If AdvA was initially resolved, we need to check if current AdvA also
- * resolved with the same IRK since it may have changes due to RPA timeout.
- * Otherwise it shall be the same as in AUX_CONNECT_REQ.
+ /* If we have IRK for peer and AdvA is an RPA, we need to check if current
+ * RPA resolves using that IRK. This is to verify AdvA in case RPS changed
+ * due to timeout or AdvA in advertising was an identity address but is an
+ * RPA in AUX_CONNECT_RSP.
+ * Otherwise, it shall be the same as in AUX_CONNECT_REQ.
*/
- if (addrd->adva_resolved) {
- if (!adva_type) {
- return -1;
- }
-
- BLE_LL_ASSERT(addrd->rpa_index >= 0);
+ if ((addrd->rpa_index >= 0) && ble_ll_is_rpa(adva, adva_type)) {
rl = &g_ble_ll_resolv_list[addrd->rpa_index];
if (!ble_ll_resolv_rpa(adva, rl->rl_peer_irk)) {
return -1;
}
+ addrd->adva_resolved = 1;
addrd->adva = adva;
+ addrd->adva_type = adva_type;
} else if ((adva_type !=
!!(pdu_data->hdr_byte & BLE_ADV_PDU_HDR_RXADD_MASK)) ||
(memcmp(adva, pdu_data->adva, 6) != 0)) {