Skip to content

HCI UART bridge to Nordic SoftDevice with custom LE Audio time sync command

Notifications You must be signed in to change notification settings

bluekitchen/hci_uart_iso_timesync

Repository files navigation

nRF5340 Bluetooth Controller with Support for LE ISO Timesync

This fork of the Zephyr HCI UART example adds a custom HCI Command to allow for timesync between the Bluetooth Host and the Bluetooth Controller. When the HCI LE Read ISO Clock command is received, the Controller toggles a GPIO and returns its current Bluetooth LE ISO Clock in the Command Complete Event.

It has been tested on the nRF5340 Audio DK, but it should work with any nRF5340 dev kit.

Requirements

  • nRF Connect SDK v2.8 or newer

HCI LE Read ISO Clock Command

  • OGF: 0x3f, OCF: 0x200
  • Parameters: Flags (1 Octet) unused
  • Response: HCI Command Complete Event with status and 4 bytes timestamp in microseconds

nRF58233 Development Kit

The first Virtual UART (UART1, ...) is Zephyr UART 0 The second Virtual UART (UART2, ...) is Zephyr UART 1

Pinout

Signal direction as seen from the nRF52833.

PIN Arduino MCU Direction
TX D0 P0.05 out
RX D1 P0.06 in
RTS D7 P0.07 out
CTS D8 P0.08 in
Time Sync D10 P1.01 out

HCI over UART 0 connected to first Virtual UART in J-Link Probe

Release build:

west build --pristine -b nrf52833dk/nrf52833

Debug build:

west build --pristine -b nrf52833dk/nrf52833 -- -DOVERLAY_CONFIG=debug.conf

To use UART 0 via Arduino headers, the virtual UART of the J-Link probe needs to be disabled, e.g. with the JLink Configuration Tool.

nRF5340 Development Kit

The first Virtual UART (UART1, ...) is Zephyr UART 1 The second Virtual UART (UART2, ...) is Zephyr UART 0

Pinout

Signal direction as seen from the nRF5340.

PIN Arduino MCU Direction
TX D0 P1.00 out
RX D1 P1.01 in
RTS D7 P1.11 out
CTS D8 P1.10 in
Time Sync D10 P1.06 out

HCI over USB CDC

west build --pristine -b nrf5340dk/nrf5340/cpuapp -- -DEXTRA_DTC_OVERLAY_FILE=usb.overlay -DOVERLAY_CONFIG=overlay-usb.conf

HCI over UART 0 connected to second Virtual UART in J-Link Probe

west build --pristine -b nrf5340dk/nrf5340/cpuapp
  • HCI over second Virtual port / UART 0
  • Boot banner on Arduino Header UART (P1.01) / UART 1

HCI over UART 1 connected to first Virtual UART in J-Link Probe as well as Arduino Headers

west build --pristine -b nrf5340dk/nrf5340/cpuapp -- -DEXTRA_DTC_OVERLAY_FILE=uart1.overlay
  • No Boot Banner on Arduino Header UART

nRF5340 Audio DK

The first UART (UART1, P1.04, P1.05) is only available via test points (TP60, TP61, ...) The second UART (UART2, P1.08, P1.09) is connected to the Arduino headers.

Pinout

Signal direction as seen from the nRF5340.

PIN Arduino MCU Direction
TX D0 P1.09 out
RX D1 P1.08 in
RTS D7 P1.11 out
CTS D8 P1.10 in
Time Sync D10 P1.01 out

HCI over USB CDC

west build --pristine -b nrf5340_audio_dk/nrf5340/cpuapp -- -DEXTRA_DTC_OVERLAY_FILE=usb.overlay -DOVERLAY_CONFIG=overlay-usb.conf

HCI over UART 0 connected to Virtual UART in J-Link Probe

west build --pristine -b nrf5340_audio_dk/nrf5340/cpuapp

HCI over UART 1 connected to Virtual UART in J-Link Probe as well as Arduino Headers

Release build:

west build --pristine -b nrf5340_audio_dk/nrf5340/cpuapp -- -DEXTRA_DTC_OVERLAY_FILE=uart1.overlay

Debug build:

west build --pristine -b nrf5340_audio_dk/nrf5340/cpuapp -- -DEXTRA_DTC_OVERLAY_FILE=uart1.overlay -DOVERLAY_CONFIG=debug.conf

To use UART 1 via Arduino headers, the virtual UART of the J-Link probe needs to be disabled, e.g. with the JLink Configuration Tool.

nRF54L15

HCI over UART 0 connected to second Virtual UART in J-Link Probe

Release build:

west build -d nrf54l15-iso --pristine -b nrf54l15dk/nrf54l15/cpuapp

Debug build:

west build -d nrf54l15-iso --pristine -b nrf54l15dk/nrf54l15/cpuapp -- -DOVERLAY_CONFIG=debug.conf

To use UART 0 via Arduino headers, the virtual UART of the J-Link probe needs to be disabled, e.g. with the JLink Configuration Tool.

Pinout

Signal direction as seen from the nRF54L15.

PIN MCU Direction
TX P0.00 out
RX P0.01 in
RTS P0.02 out
CTS P0.03 in
Time Sync P1.11 out

Maintainer Notes

  • nRF5340 use Controller configuration in sybuild/ipc_radio/prj.conf, while others, e.g. nRF54L15, use configuration from prj.conf. Please update both at the same time.
  • We can detect nRF5340 SoC in CMake with if(CONFIG_SOC STREQUAL "nrf5340") after find_package zephyr.

About

HCI UART bridge to Nordic SoftDevice with custom LE Audio time sync command

Resources

Stars

Watchers

Forks

Releases

No releases published