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

[v2.2] Bluetooth: controller: split: Regression slave latency during connection update #24183

Closed
cvinayak opened this issue Apr 8, 2020 · 1 comment · Fixed by #23965
Closed
Assignees
Labels
area: Bluetooth bug The issue is a bug, or the PR is fixing a bug priority: low Low impact/importance bug Regression Something, which was working, does not anymore
Milestone

Comments

@cvinayak
Copy link
Contributor

cvinayak commented Apr 8, 2020

Describe the bug
Slave latency should not be applied between the ack of a
Connection Update Indication PDU and until the instant.
When caching was introduced in split controller, implementation missed this
consideration which caused connection events to be skipped, being in slave latency.

To Reproduce
You will need logic analyser to observe the GPIO toggles of BLE controller radio events.

Steps to reproduce the behavior in peripheral, building:

  1. mkdir build; cd build
  2. cmake -GNinja -DBOARD=nrf52_pca10040 -DCONFIG_BT_CTLR_DEBUG_PINS=y ../samples/bluetooth/peripheral
  3. ninja

Building of central (test shell) for testing:

  1. mkdir build; cd build
  2. cmake -GNinja -DBOARD=nrf52_pca10040 ../tests/bluetooth/shell
  3. ninja

Steps:

  1. bt init
  2. bt scan on
  3. Use the discovered Bluetooth address of the peripheral
  4. bt connect <address>
  5. wait until auto connection update completes
  6. bt conn-update 6 6 9 64
  7. bt conn-update 28 28 0 64

Observe in the logic trace that connection events before the switch to 50 ms interval does not show cancelled slave latency during the time between the connection update procedure intiation to the connection update instant.

Expected behavior
Slave latency should not be applied between the ack of a
Connection Update Indication PDU and until the instant.

Impact
BT Specification violation.

Screenshots or console output
If applicable, add a screenshot (drag-and-drop an image), or console logs
(cut-and-paste text and put a code fence (```) before and after, to help
explain the issue.

None.

Environment (please complete the following information):

  • OS: (e.g. Linux, MacOS, Windows): Linux
  • Toolchain (e.g Zephyr SDK, ...): Zephyr SDK
  • Commit SHA or Version used: 79942b4

Additional context
Add any other context about the problem here.

This is fixed in bc35771 for the split controller and b7e35ae for legacy controller.
Backport 2.2 PR: #23965

@cvinayak cvinayak added bug The issue is a bug, or the PR is fixing a bug area: Bluetooth Regression Something, which was working, does not anymore labels Apr 8, 2020
@cvinayak cvinayak self-assigned this Apr 8, 2020
@carlescufi carlescufi added this to the v2.2.1 milestone Apr 8, 2020
@carlescufi carlescufi changed the title Bluetooth: controller: split: Regression slave latency during connection update [v2.2] Bluetooth: controller: split: Regression slave latency during connection update Apr 8, 2020
@carlescufi carlescufi added the priority: low Low impact/importance bug label Apr 8, 2020
@wopu-ot
Copy link
Collaborator

wopu-ot commented Jun 3, 2020

Fix has been merged, no reason to keep the issue open.

@wopu-ot wopu-ot closed this as completed Jun 3, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area: Bluetooth bug The issue is a bug, or the PR is fixing a bug priority: low Low impact/importance bug Regression Something, which was working, does not anymore
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants