Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Resolve advertising reports and connection complete #13630

Merged

Conversation

paul-szczepanek-arm
Copy link
Member

Summary of changes

Add host resolution of RPAs for advertising and connecting.

Impact of changes

Migration actions required

Documentation

none


Pull request type

[] Patch update (Bug fix / Target update / Docs update / Test update / Refactor)
[x] Feature update (New feature / Functionality change / New API)
[] Major update (Breaking change E.g. Return code change / API behaviour change)

Test results

[] No Tests required for this change (E.g docs only update)
[x] Covered by existing mbed-os tests (Greentea or Unittest)
[] Tests / results supplied as part of this PR

Reviewers

@pan-


@ciarmcom
Copy link
Member

@paul-szczepanek-arm, thank you for your changes.
@pan- @ARMmbed/mbed-os-maintainers please review.

Copy link
Member

@pan- pan- left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @paul-szczepanek-arm I left a few comments for improvements.

connectivity/FEATURE_BLE/source/generic/GapImpl.h Outdated Show resolved Hide resolved
connectivity/FEATURE_BLE/source/generic/GapImpl.h Outdated Show resolved Hide resolved
connectivity/FEATURE_BLE/source/generic/GapImpl.h Outdated Show resolved Hide resolved
connectivity/FEATURE_BLE/source/generic/GapImpl.h Outdated Show resolved Hide resolved
private:
/** Last in First Out list*/
template<typename T>
class EventList {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Side note: we would really benefit from a true list available to all Mbed OS.

event.setLocalResolvablePrivateAddress(_address_registry.get_resolvable_private_address());

event.setPeerAddress(*identity_address);
event.setPeerAddressType((peer_address_type_t&)identity_address_type);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

peer_address_type_t and target_peer_address_type_t are not exact match.
peer_address_type_t has values that represents public identity address and random static identity address.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thanks, replaced with translation

#if BLE_ROLE_PERIPHERAL
if (!identity_address) {
if (_peripheral_privacy_configuration.resolution_strategy ==
peripheral_privacy_configuration_t::REJECT_NON_RESOLVED_ADDRESS) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

According to the documentation we are supposed to disconnect if a bond is not present in the security db.
I'm not certain of what we should do if there's no bond though.

connectivity/FEATURE_BLE/source/generic/GapImpl.cpp Outdated Show resolved Hide resolved
if (pending_event && pending_event->event) {
allocation_successful = _reports_pending_address_resolution.push(pending_event);
}
if (allocation_successful) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please cleanup memory if allocation_successful is false.

@@ -56,6 +56,7 @@ struct AdvertisingReportEvent {
* @param advertisingData Advertising payload.
*/
AdvertisingReportEvent(
ble_error_t status,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change the semantic of AdvertisingReportEvent. I don't think we need to report allocation failures to the user in the AdvertisingReportEvent as advertising reports are not reliable. The cordio stack will silent drop events if it doesn't have memory capacity, same for the controller.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

dropped

@paul-szczepanek-arm
Copy link
Member Author

Now I can copy events I'll make events part of the entries so that should deal with all the memory comments

@mergify
Copy link

mergify bot commented Sep 21, 2020

This PR cannot be merged due to conflicts. Please rebase to resolve them.

Copy link
Member

@pan- pan- left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks Paul, I merge this into the feature branch.
Next stop, next PR.

@pan- pan- merged commit 3e2db59 into ARMmbed:feature-ble-host-privacy Sep 22, 2020
@pan- pan- mentioned this pull request Oct 5, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

4 participants