Skip to content

Commit 417a9e8

Browse files
rugeGerritsenfabiobaltieri
authored andcommitted
Bluetooth: Controller: Add device tree dependency to selection
This commit makes the device tree configuration decide which link layer is compiled in. We do this to avoid hard-to-understand linker errors referencing device tree nodes. The following configuration creates a difficult to parse linker error: * BT_LL_CHOICE contains multiple entries, BT_LL_SW_SPLIT is selected. * Each BT_LL_CHOICE has its own unique device tree node with its own "compatible". * Only one of the link layer device tree nodes has status "okay", but not the one corresponding to BT_LL_SW_SPLIT. The linker error indicates that code using the HCI driver fails to link with the controller. This because the HCI driver device tree node references the link layer selected in devicetree which is not compiled in. By adding a dependendency to the device tree node, this can no longer happen. Instead, if BT_LL_SW_SPLIT is now selected in a configuration file, a Kconfig warning will be issued: ``` warning: The choice symbol BT_LL_SW_SPLIT (defined at subsys/bluetooth/controller/Kconfig:129) was selected (set =y), but BT_LL_SOFTDEVICE (defined at /home/ruge/ncs/nrf/subsys/bluetooth/controller/Kconfig:11) ended up as the choice selection. ``` This should be easier to understand than: ``` ...(hci_core.c.obj):(.data.bt_dev+0x16c): undefined reference to `__device_dts_ord_132' ``` After this commit we should consider getting rid of link layer selection from Kconfig completely as the link layer is in practice selected through device tree. Unit tests have been updated to satisfy the dts dependency. Signed-off-by: Rubin Gerritsen <[email protected]>
1 parent 2668476 commit 417a9e8

File tree

28 files changed

+82
-0
lines changed

28 files changed

+82
-0
lines changed

subsys/bluetooth/controller/Kconfig

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -138,6 +138,7 @@ choice BT_LL_CHOICE
138138

139139
config BT_LL_SW_SPLIT
140140
bool "Software-based BLE Link Layer"
141+
depends on DT_HAS_ZEPHYR_BT_HCI_LL_SW_SPLIT_ENABLED
141142
help
142143
Use Zephyr software BLE Link Layer ULL LLL split implementation.
143144

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
# Copyright (c) 2024 Nordic Semiconductor ASA
2+
# SPDX-License-Identifier: Apache-2.0
3+
4+
# The link layer requires a corresponding device tree node to be enabled
5+
# The corresponding Kconfig entry is not generated for unit tests,
6+
# so we add it here.
7+
config DT_HAS_ZEPHYR_BT_HCI_LL_SW_SPLIT_ENABLED
8+
bool
9+
default y

tests/bluetooth/controller/ctrl_api/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,5 +25,7 @@ config ENTROPY_NRF_FORCE_ALT
2525
config ENTROPY_NRF5_RNG
2626
default n
2727

28+
source "tests/bluetooth/controller/common/Kconfig"
29+
2830
# Include Zephyr's Kconfig
2931
source "Kconfig"

tests/bluetooth/controller/ctrl_chmu/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,5 +25,7 @@ config ENTROPY_NRF_FORCE_ALT
2525
config ENTROPY_NRF5_RNG
2626
default n
2727

28+
source "tests/bluetooth/controller/common/Kconfig"
29+
2830
# Include Zephyr's Kconfig
2931
source "Kconfig"

tests/bluetooth/controller/ctrl_cis_create/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,5 +25,7 @@ config ENTROPY_NRF_FORCE_ALT
2525
config ENTROPY_NRF5_RNG
2626
default n
2727

28+
source "tests/bluetooth/controller/common/Kconfig"
29+
2830
# Include Zephyr's Kconfig
2931
source "Kconfig"

tests/bluetooth/controller/ctrl_cis_terminate/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,5 +25,7 @@ config ENTROPY_NRF_FORCE_ALT
2525
config ENTROPY_NRF5_RNG
2626
default n
2727

28+
source "tests/bluetooth/controller/common/Kconfig"
29+
2830
# Include Zephyr's Kconfig
2931
source "Kconfig"

tests/bluetooth/controller/ctrl_collision/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,5 +25,7 @@ config ENTROPY_NRF_FORCE_ALT
2525
config ENTROPY_NRF5_RNG
2626
default n
2727

28+
source "tests/bluetooth/controller/common/Kconfig"
29+
2830
# Include Zephyr's Kconfig
2931
source "Kconfig"

tests/bluetooth/controller/ctrl_conn_update/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,5 +25,7 @@ config ENTROPY_NRF_FORCE_ALT
2525
config ENTROPY_NRF5_RNG
2626
default n
2727

28+
source "tests/bluetooth/controller/common/Kconfig"
29+
2830
# Include Zephyr's Kconfig
2931
source "Kconfig"

tests/bluetooth/controller/ctrl_cte_req/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -43,5 +43,7 @@ config ENTROPY_NRF_FORCE_ALT
4343
config ENTROPY_NRF5_RNG
4444
default n
4545

46+
source "tests/bluetooth/controller/common/Kconfig"
47+
4648
# Include Zephyr's Kconfig
4749
source "Kconfig"

tests/bluetooth/controller/ctrl_data_length_update/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,5 +25,7 @@ config ENTROPY_NRF_FORCE_ALT
2525
config ENTROPY_NRF5_RNG
2626
default n
2727

28+
source "tests/bluetooth/controller/common/Kconfig"
29+
2830
# Include Zephyr's Kconfig
2931
source "Kconfig"

0 commit comments

Comments
 (0)