| # Bluetooth configuration options |
| |
| # Copyright (c) 2016 Intel Corporation |
| # Copyright (c) 2021 Nordic Semiconductor ASA |
| # SPDX-License-Identifier: Apache-2.0 |
| |
| menuconfig BT |
| bool "Bluetooth" |
| # Some BT threads use co-op priorities to implement critical sections, |
| # will need some refactoring to work on SMP systems. |
| depends on !SMP |
| select NET_BUF |
| help |
| This option enables Bluetooth support. |
| |
| if BT |
| |
| choice BT_STACK_SELECTION |
| prompt "Bluetooth Stack Selection" |
| default BT_HCI |
| help |
| Select the Bluetooth stack to compile. |
| |
| config BT_HCI |
| bool "HCI-based" |
| help |
| HCI-based stack with optional host & controller parts and an |
| HCI driver in between. |
| |
| config BT_CUSTOM |
| bool "Custom" |
| help |
| Select a custom, non-HCI based stack. If you're not sure what |
| this is, you probably want the HCI-based stack instead. |
| |
| endchoice |
| |
| # The Bluetooth subsystem requires the system workqueue to execute at |
| # a cooperative priority. |
| config SYSTEM_WORKQUEUE_PRIORITY |
| range -256 -1 |
| |
| if BT_HCI |
| |
| config BT_HCI_RAW |
| bool "RAW HCI access" |
| help |
| This option allows to access Bluetooth controller |
| from the application with the RAW HCI protocol. |
| |
| config BT_HCI_RAW_H4 |
| bool "RAW HCI H:4 transport" |
| help |
| This option enables HCI RAW access to work over an H:4 |
| transport, note that it still need to be selected at runtime. |
| |
| config BT_HCI_RAW_H4_ENABLE |
| bool "RAW HCI H:4 transport enable" |
| depends on BT_HCI_RAW_H4 |
| help |
| This option enables use of H:4 transport for HCI RAW access at |
| build time. |
| |
| config BT_HCI_RAW_RESERVE |
| int "Buffer headroom needed for HCI transport" |
| depends on BT_HCI_RAW |
| default 1 if BT_HCI_RAW_H4 |
| default 0 |
| help |
| This option is used by the HCI raw transport implementation to |
| declare how much headroom it needs for any HCI transport headers. |
| |
| config BT_HCI_RAW_CMD_EXT |
| bool "RAW HCI Command Extension" |
| help |
| This option enables HCI RAW command extension so the driver can |
| register it own command table extension. |
| |
| config BT_PERIPHERAL |
| bool "Peripheral Role support" |
| select BT_BROADCASTER |
| select BT_CONN |
| default y if BT_HCI_RAW |
| help |
| Select this for LE Peripheral role support. |
| |
| config BT_CENTRAL |
| bool "Central Role support" |
| select BT_OBSERVER |
| select BT_CONN |
| default y if BT_HCI_RAW |
| help |
| Select this for LE Central role support. |
| |
| config BT_BROADCASTER |
| bool "Broadcaster Role support" |
| default y if !BT_OBSERVER |
| help |
| Select this for LE Broadcaster role support. |
| |
| config BT_OBSERVER |
| bool "Observer Role support" |
| help |
| Select this for LE Observer role support. |
| |
| rsource "Kconfig.adv" |
| |
| config BT_CONN |
| bool |
| |
| config BT_MAX_CONN |
| int "Maximum number of simultaneous connections" |
| depends on BT_CONN |
| range 1 250 |
| default 2 if BT_MESH_GATT_CLIENT |
| default 1 |
| help |
| Maximum number of simultaneous Bluetooth connections |
| supported. |
| |
| config BT_CONN_TX |
| bool |
| default BT_CONN || BT_ISO_BROADCASTER |
| help |
| Hidden configuration that is true if ACL or broadcast ISO is enabled |
| |
| if BT_CONN |
| config BT_HCI_ACL_FLOW_CONTROL |
| bool "Controller to Host ACL flow control support" |
| # Enable if building a Host-only build |
| default y if !BT_CTLR && !BT_STM32_IPM && !BT_ESP32 && !BT_STM32WBA |
| # Enable if building a Controller-only build |
| default y if BT_HCI_RAW |
| select POLL |
| help |
| Enable support for throttling ACL buffers from the controller |
| to the host. This is particularly useful when the host and |
| controller are on separate cores since it ensures that we do |
| not run out of incoming ACL buffers. |
| |
| config BT_REMOTE_VERSION |
| bool "Allow fetching of remote version" |
| # Enable if building a Controller-only build |
| default y if BT_HCI_RAW |
| help |
| Enable this to get access to the remote version in the Controller and |
| in the Host through bt_conn_get_remote_info(). The fields in question |
| can then be found in the bt_conn_remote_info struct. |
| |
| config BT_PHY_UPDATE |
| bool "PHY Update" |
| default y |
| depends on !BT_CTLR || BT_CTLR_PHY_UPDATE_SUPPORT |
| help |
| Enable support for Bluetooth 5.0 PHY Update Procedure. |
| |
| config BT_DATA_LEN_UPDATE |
| bool "Data Length Update" |
| default y |
| depends on !BT_CTLR || BT_CTLR_DATA_LEN_UPDATE_SUPPORT |
| help |
| Enable support for Bluetooth v4.2 LE Data Length Update procedure. |
| |
| config BT_PER_ADV_SYNC_TRANSFER_RECEIVER |
| bool "Periodic Advertising Sync Transfer receiver" |
| depends on BT_PER_ADV_SYNC && (!BT_CTLR || BT_CTLR_SYNC_TRANSFER_RECEIVER_SUPPORT) |
| |
| config BT_PER_ADV_SYNC_TRANSFER_SENDER |
| bool "Periodic Advertising Sync Transfer sender" |
| depends on (BT_PER_ADV_SYNC || BT_PER_ADV) && (!BT_CTLR || BT_CTLR_SYNC_TRANSFER_SENDER_SUPPORT) |
| |
| config BT_SCA_UPDATE |
| bool "Sleep Clock Accuracy Update" |
| default y if BT_ISO_PERIPHERAL || BT_ISO_CENTRAL |
| depends on !BT_CTLR || BT_CTLR_SCA_UPDATE_SUPPORT |
| help |
| Enable support for Bluetooth 5.1 Sleep Clock Accuracy Update Procedure |
| |
| config BT_TRANSMIT_POWER_CONTROL |
| bool "LE Power Control" |
| depends on !BT_CTLR || BT_CTLR_LE_POWER_CONTROL_SUPPORT |
| help |
| Enable support for LE Power Control Request feature that is defined in the |
| Bluetooth Core specification, Version 5.4 | Vol 6, Part B, Section 4.6.31. |
| |
| endif # BT_CONN |
| |
| rsource "Kconfig.iso" |
| rsource "common/Kconfig" |
| rsource "host/Kconfig" |
| rsource "controller/Kconfig" |
| rsource "shell/Kconfig" |
| rsource "crypto/Kconfig" |
| rsource "lib/Kconfig" |
| rsource "Kconfig.logging" |
| |
| endif # BT_HCI |
| |
| config BT_COMPANY_ID |
| hex "Company Id" |
| default 0x05F1 |
| range 0x0000 0xFFFF |
| help |
| Set the Bluetooth Company Identifier for this device. The Linux |
| Foundation's Company Identifier (0x05F1) is the default value for |
| this option although silicon vendors and hardware manufacturers |
| can set their own. Note that the controller's Company Identifier is |
| controlled by BT_CTLR_COMPANY_ID. The full list of Bluetooth |
| Company Identifiers can be found here: |
| https://www.bluetooth.com/specifications/assigned-numbers/company-identifiers |
| |
| endif # BT |