mirror of
https://github.com/espressif/esp-idf.git
synced 2025-10-24 11:10:23 +00:00
825 lines
28 KiB
Plaintext
825 lines
28 KiB
Plaintext
|
|
menu "HCI Config"
|
|
choice BT_LE_HCI_INTERFACE
|
|
prompt "HCI mode"
|
|
default BT_LE_HCI_INTERFACE_USE_RAM
|
|
|
|
config BT_LE_HCI_INTERFACE_USE_RAM
|
|
bool "VHCI"
|
|
help
|
|
Use RAM as HCI interface
|
|
config BT_LE_HCI_INTERFACE_USE_UART
|
|
bool "UART(H4)"
|
|
help
|
|
Use UART as HCI interface
|
|
endchoice
|
|
|
|
choice BT_LE_UART_HCI_MODE_CHOICE
|
|
prompt "UART HCI mode"
|
|
depends on BT_LE_HCI_INTERFACE_USE_UART
|
|
default BT_LE_UART_HCI_NO_DMA_MODE
|
|
help
|
|
Specify UART HCI mode: DMA or No DMA
|
|
|
|
config BT_LE_UART_HCI_DMA_MODE
|
|
bool "UHCI(UART with DMA)(EXPERIMENTAL)"
|
|
help
|
|
UART HCI Mode with DMA functionality.
|
|
|
|
config BT_LE_UART_HCI_NO_DMA_MODE
|
|
bool "UART(NO DMA)"
|
|
help
|
|
UART HCI Mode without DMA functionality.
|
|
endchoice
|
|
|
|
config BT_LE_HCI_UART_PORT
|
|
int "HCI UART port"
|
|
depends on BT_LE_HCI_INTERFACE_USE_UART
|
|
default 1
|
|
help
|
|
Set the port number of HCI UART
|
|
|
|
config BT_LE_HCI_UART_FLOWCTRL
|
|
bool "HCI uart Hardware Flow ctrl"
|
|
depends on BT_LE_HCI_INTERFACE_USE_UART
|
|
default n
|
|
|
|
config BT_LE_HCI_UART_TX_PIN
|
|
int "HCI uart Tx gpio"
|
|
depends on BT_LE_HCI_INTERFACE_USE_UART
|
|
default 19
|
|
|
|
config BT_LE_HCI_UART_RX_PIN
|
|
int "HCI uart Rx gpio"
|
|
depends on BT_LE_HCI_INTERFACE_USE_UART
|
|
default 10
|
|
|
|
config BT_LE_HCI_UART_RTS_PIN
|
|
int "HCI uart RTS gpio"
|
|
depends on BT_LE_HCI_UART_FLOWCTRL
|
|
default 4
|
|
|
|
config BT_LE_HCI_UART_CTS_PIN
|
|
int "HCI uart CTS gpio"
|
|
depends on BT_LE_HCI_UART_FLOWCTRL
|
|
default 5
|
|
|
|
config BT_LE_HCI_UART_BAUD
|
|
int "HCI uart baudrate"
|
|
depends on BT_LE_HCI_INTERFACE_USE_UART
|
|
default 921600
|
|
help
|
|
HCI uart baud rate 115200 ~ 1000000
|
|
|
|
choice BT_LE_HCI_UART_PARITY
|
|
prompt "select uart parity"
|
|
depends on BT_LE_HCI_INTERFACE_USE_UART
|
|
default BT_LE_HCI_UART_UART_PARITY_DISABLE
|
|
|
|
config BT_LE_HCI_UART_UART_PARITY_DISABLE
|
|
bool "PARITY_DISABLE"
|
|
help
|
|
UART_PARITY_DISABLE
|
|
config BT_LE_HCI_UART_UART_PARITY_EVEN
|
|
bool "PARITY_EVEN"
|
|
help
|
|
UART_PARITY_EVEN
|
|
config BT_LE_HCI_UART_UART_PARITY_ODD
|
|
bool "PARITY_ODD"
|
|
help
|
|
UART_PARITY_ODD
|
|
endchoice
|
|
|
|
config BT_LE_HCI_UART_RX_BUFFER_SIZE
|
|
int "The size of rx ring buffer memory"
|
|
depends on BT_LE_UART_HCI_NO_DMA_MODE
|
|
default 512
|
|
help
|
|
The size of rx ring buffer memory
|
|
|
|
config BT_LE_HCI_UART_TX_BUFFER_SIZE
|
|
int "The size of tx ring buffer memory"
|
|
depends on BT_LE_UART_HCI_NO_DMA_MODE
|
|
default 256
|
|
help
|
|
The size of tx ring buffer memory
|
|
|
|
config BT_LE_HCI_TRANS_TASK_STACK_SIZE
|
|
int "HCI transport task stack size"
|
|
depends on !BT_LE_HCI_INTERFACE_USE_RAM
|
|
default 2048
|
|
help
|
|
This configures stack size of hci transport task
|
|
|
|
config BT_LE_HCI_TRANS_RX_MEM_NUM
|
|
int "The amount of rx memory received at the same time"
|
|
depends on BT_LE_UART_HCI_DMA_MODE
|
|
default 3
|
|
help
|
|
The amount of rx memory received at the same time
|
|
|
|
config BT_LE_HCI_LLDESCS_POOL_NUM
|
|
int "The amount of lldecs memory for driver dma mode"
|
|
depends on BT_LE_UART_HCI_DMA_MODE
|
|
default 20
|
|
help
|
|
The amount of lldecs memory for driver dma mode
|
|
endmenu
|
|
|
|
config BT_LE_CONTROLLER_NPL_OS_PORTING_SUPPORT
|
|
bool
|
|
default y
|
|
help
|
|
Enable NPL porting for controller.
|
|
|
|
|
|
menuconfig BT_LE_50_FEATURE_SUPPORT
|
|
bool "Enable BLE 5 feature"
|
|
depends on !BT_NIMBLE_ENABLED
|
|
default y
|
|
help
|
|
Enable BLE 5 feature
|
|
|
|
config BT_LE_LL_CFG_FEAT_LE_2M_PHY
|
|
bool "Enable 2M Phy"
|
|
depends on BT_LE_50_FEATURE_SUPPORT
|
|
default y
|
|
help
|
|
Enable 2M-PHY
|
|
|
|
config BT_LE_LL_CFG_FEAT_LE_CODED_PHY
|
|
bool "Enable coded Phy"
|
|
depends on BT_LE_50_FEATURE_SUPPORT
|
|
default y
|
|
help
|
|
Enable coded-PHY
|
|
|
|
config BT_LE_EXT_ADV
|
|
bool "Enable extended advertising"
|
|
depends on BT_LE_50_FEATURE_SUPPORT
|
|
default y
|
|
help
|
|
Enable this option to do extended advertising. Extended advertising
|
|
will be supported from BLE 5.0 onwards.
|
|
|
|
if BT_LE_EXT_ADV
|
|
config BT_LE_MAX_EXT_ADV_INSTANCES
|
|
int "Maximum number of extended advertising instances."
|
|
range 0 4
|
|
default 1
|
|
depends on BT_LE_EXT_ADV
|
|
help
|
|
Change this option to set maximum number of extended advertising
|
|
instances. Minimum there is always one instance of
|
|
advertising. Enter how many more advertising instances you
|
|
want.
|
|
Each extended advertising instance will take about 0.5k DRAM.
|
|
|
|
config BT_LE_EXT_ADV_MAX_SIZE
|
|
int "Maximum length of the advertising data."
|
|
range 0 1650
|
|
default 1650
|
|
depends on BT_LE_EXT_ADV
|
|
help
|
|
Defines the length of the extended adv data. The value should not
|
|
exceed 1650.
|
|
|
|
config BT_LE_ENABLE_PERIODIC_ADV
|
|
bool "Enable periodic advertisement."
|
|
default y
|
|
depends on BT_LE_EXT_ADV
|
|
help
|
|
Enable this option to start periodic advertisement.
|
|
|
|
config BT_LE_PERIODIC_ADV_SYNC_TRANSFER
|
|
bool "Enable Transfer Sync Events"
|
|
depends on BT_LE_ENABLE_PERIODIC_ADV
|
|
default y
|
|
help
|
|
This enables controller transfer periodic sync events to host
|
|
|
|
endif
|
|
|
|
config BT_LE_MAX_PERIODIC_SYNCS
|
|
int "Maximum number of periodic advertising syncs"
|
|
depends on BT_LE_50_FEATURE_SUPPORT && !BT_NIMBLE_ENABLED
|
|
|
|
range 0 8
|
|
default 1 if BT_LE_ENABLE_PERIODIC_ADV
|
|
default 0
|
|
help
|
|
Set this option to set the upper limit for number of periodic sync
|
|
connections. This should be less than maximum connections allowed by
|
|
controller.
|
|
|
|
config BT_LE_MAX_PERIODIC_ADVERTISER_LIST
|
|
int "Maximum number of periodic advertiser list"
|
|
depends on BT_LE_50_FEATURE_SUPPORT && !BT_NIMBLE_ENABLED
|
|
range 1 5
|
|
default 5
|
|
help
|
|
Set this option to set the upper limit for number of periodic advertiser list.
|
|
|
|
config BT_LE_POWER_CONTROL_ENABLED
|
|
bool "Enable controller support for BLE Power Control"
|
|
depends on BT_LE_50_FEATURE_SUPPORT && !BT_NIMBLE_ENABLED && IDF_TARGET_ESP32C6
|
|
default n
|
|
help
|
|
Set this option to enable the Power Control feature on controller
|
|
|
|
config BT_LE_CTE_FEATURE_ENABLED
|
|
bool "Enable Bluetooth LE Direction Finding (AoA/AoD)"
|
|
depends on BT_LE_50_FEATURE_SUPPORT && SOC_BLE_CTE_SUPPORTED
|
|
default n
|
|
help
|
|
Enable this option to activate Bluetooth LE Direction Finding (AoA/AoD) feature.
|
|
Note:
|
|
This feature allows devices to determine the direction of a Bluetooth CTE signal,
|
|
enabling Angle of Arrival (AoA) and Angle of Departure (AoD) functionality.
|
|
|
|
menu "Memory Settings"
|
|
depends on !BT_NIMBLE_ENABLED
|
|
|
|
config BT_LE_MSYS_1_BLOCK_COUNT
|
|
int "MSYS_1 Block Count"
|
|
default 12
|
|
help
|
|
MSYS is a system level mbuf registry. For prepare write & prepare
|
|
responses MBUFs are allocated out of msys_1 pool. For NIMBLE_MESH
|
|
enabled cases, this block count is increased by 8 than user defined
|
|
count.
|
|
|
|
config BT_LE_MSYS_1_BLOCK_SIZE
|
|
int "MSYS_1 Block Size"
|
|
default 256
|
|
help
|
|
Dynamic memory size of block 1
|
|
|
|
config BT_LE_MSYS_2_BLOCK_COUNT
|
|
int "MSYS_2 Block Count"
|
|
default 24
|
|
help
|
|
Dynamic memory count
|
|
|
|
config BT_LE_MSYS_2_BLOCK_SIZE
|
|
int "MSYS_2 Block Size"
|
|
default 320
|
|
help
|
|
Dynamic memory size of block 2
|
|
|
|
config BT_LE_MSYS_BUF_FROM_HEAP
|
|
bool "Get Msys Mbuf from heap"
|
|
default y
|
|
depends on BT_LE_MSYS_INIT_IN_CONTROLLER
|
|
help
|
|
This option sets the source of the shared msys mbuf memory between
|
|
the Host and the Controller. Allocate the memory from the heap if
|
|
this option is sets, from the mempool otherwise.
|
|
|
|
config BT_LE_ACL_BUF_COUNT
|
|
int "ACL Buffer count"
|
|
default 10
|
|
help
|
|
The number of ACL data buffers.
|
|
|
|
config BT_LE_ACL_BUF_SIZE
|
|
int "ACL Buffer size"
|
|
default 517
|
|
help
|
|
This is the maximum size of the data portion of HCI ACL data packets.
|
|
It does not include the HCI data header (of 4 bytes)
|
|
|
|
config BT_LE_HCI_EVT_BUF_SIZE
|
|
int "HCI Event Buffer size"
|
|
default 257 if BT_LE_EXT_ADV
|
|
default 70
|
|
help
|
|
This is the size of each HCI event buffer in bytes. In case of
|
|
extended advertising, packets can be fragmented. 257 bytes is the
|
|
maximum size of a packet.
|
|
|
|
config BT_LE_HCI_EVT_HI_BUF_COUNT
|
|
int "High Priority HCI Event Buffer count"
|
|
default 30
|
|
help
|
|
This is the high priority HCI events' buffer size. High-priority
|
|
event buffers are for everything except advertising reports. If there
|
|
are no free high-priority event buffers then host will try to allocate a
|
|
low-priority buffer instead
|
|
|
|
config BT_LE_HCI_EVT_LO_BUF_COUNT
|
|
int "Low Priority HCI Event Buffer count"
|
|
default 8
|
|
help
|
|
This is the low priority HCI events' buffer size. Low-priority event
|
|
buffers are only used for advertising reports. If there are no free
|
|
low-priority event buffers, then an incoming advertising report will
|
|
get dropped
|
|
endmenu
|
|
|
|
config BT_LE_CONTROLLER_TASK_STACK_SIZE
|
|
int "Controller task stack size"
|
|
default 5120 if BLE_MESH
|
|
default 4096
|
|
help
|
|
This configures stack size of NimBLE controller task
|
|
|
|
menu "Controller debug features"
|
|
menuconfig BT_LE_CONTROLLER_LOG_ENABLED
|
|
bool "Controller log enable"
|
|
default n
|
|
help
|
|
Enable controller log
|
|
|
|
config BT_LE_CONTROLLER_LOG_CTRL_ENABLED
|
|
bool "enable controller log module"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default y
|
|
help
|
|
Enable controller log module
|
|
|
|
config BT_LE_CONTROLLER_LOG_HCI_ENABLED
|
|
bool "enable HCI log module"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default y
|
|
help
|
|
Enable hci log module
|
|
|
|
config BT_LE_CONTROLLER_LOG_DUMP_ONLY
|
|
bool "Controller log dump mode only"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default y
|
|
help
|
|
Only operate in dump mode
|
|
|
|
config BT_LE_CONTROLLER_LOG_SPI_OUT_ENABLED
|
|
bool "Output ble controller logs to SPI bus (Experimental)"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
depends on !BT_LE_CONTROLLER_LOG_DUMP_ONLY
|
|
select BT_BLE_LOG_SPI_OUT_ENABLED
|
|
default n
|
|
help
|
|
Output ble controller logs to SPI bus
|
|
|
|
config BT_LE_CONTROLLER_LOG_STORAGE_ENABLE
|
|
bool "Store ble controller logs to flash(Experimental)"
|
|
depends on !BT_LE_CONTROLLER_LOG_DUMP_ONLY
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default n
|
|
help
|
|
Store ble controller logs to flash memory.
|
|
|
|
config BT_LE_CONTROLLER_LOG_PARTITION_SIZE
|
|
int "size of ble controller log partition(Multiples of 4K)"
|
|
depends on BT_LE_CONTROLLER_LOG_STORAGE_ENABLE
|
|
default 65536
|
|
help
|
|
The size of ble controller log partition shall be a multiples of 4K.
|
|
The name of log partition shall be "bt_ctrl_log".
|
|
The partition type shall be ESP_PARTITION_TYPE_DATA.
|
|
The partition sub_type shall be ESP_PARTITION_SUBTYPE_ANY.
|
|
|
|
config BT_LE_LOG_CTRL_BUF1_SIZE
|
|
int "size of the first BLE controller LOG buffer"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default 4096
|
|
help
|
|
Configure the size of the first BLE controller LOG buffer.
|
|
|
|
config BT_LE_LOG_CTRL_BUF2_SIZE
|
|
int "size of the second BLE controller LOG buffer"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default 1024
|
|
help
|
|
Configure the size of the second BLE controller LOG buffer.
|
|
|
|
config BT_LE_LOG_HCI_BUF_SIZE
|
|
int "size of the BLE HCI LOG buffer"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default 4096
|
|
help
|
|
Configure the size of the BLE HCI LOG buffer.
|
|
|
|
config BT_LE_CONTROLLER_LOG_WRAP_PANIC_HANDLER_ENABLE
|
|
bool "Enable wrap panic handler"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default n
|
|
help
|
|
Wrap esp_panic_handler to get controller logs when PC pointer exception crashes.
|
|
|
|
config BT_LE_CONTROLLER_LOG_TASK_WDT_USER_HANDLER_ENABLE
|
|
bool "Enable esp_task_wdt_isr_user_handler implementation"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
default n
|
|
help
|
|
Implement esp_task_wdt_isr_user_handler to get controller logs when task wdt issue is triggered.
|
|
|
|
config BT_LE_CONTROLLER_LOG_OUTPUT_LEVEL
|
|
int "The output level of controller log"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
range 0 5
|
|
default 1
|
|
help
|
|
The output level of controller log.
|
|
|
|
config BT_LE_CONTROLLER_LOG_MOD_OUTPUT_SWITCH
|
|
hex "The switch of module log output"
|
|
depends on BT_LE_CONTROLLER_LOG_ENABLED
|
|
range 0 0xFFFFFFFF
|
|
default 0xFFFFFFFF
|
|
help
|
|
The switch of module log output, this is an unsigned 32-bit hexadecimal value.
|
|
|
|
config BT_LE_ERROR_SIM_ENABLED
|
|
bool "Enable controller features for internal testing"
|
|
default n
|
|
|
|
config BT_LE_ASSERT_WHEN_ABNORMAL_DISCONN_ENABLED
|
|
bool "When ACL disconnects abnormally, assertion processing is performed(Experimental)"
|
|
default n
|
|
|
|
config BT_LE_DEBUG_REMAIN_SCENE_ENABLED
|
|
bool "Remain scene with GDB to capture relevant status info(Experimental)"
|
|
default n
|
|
help
|
|
Retain scene with GDB to capture info, requires disabling WDT (CONFIG_ESP_INT_WDT, CONFIG_ESP_TASK_WDT_EN).
|
|
|
|
config BT_LE_PTR_CHECK_ENABLED
|
|
bool "Enable boundary check for internal memory"
|
|
default n
|
|
endmenu
|
|
|
|
config BT_LE_LL_RESOLV_LIST_SIZE
|
|
int "BLE LL Resolving list size"
|
|
range 1 5
|
|
default 4
|
|
help
|
|
Configure the size of resolving list used in link layer.
|
|
|
|
menuconfig BT_LE_SECURITY_ENABLE
|
|
bool "Enable BLE SM feature"
|
|
depends on !BT_NIMBLE_ENABLED
|
|
default y
|
|
help
|
|
Enable BLE sm feature
|
|
|
|
config BT_LE_SM_LEGACY
|
|
bool "Security manager legacy pairing"
|
|
depends on BT_LE_SECURITY_ENABLE
|
|
default y
|
|
help
|
|
Enable security manager legacy pairing
|
|
|
|
config BT_LE_SM_SC
|
|
bool "Security manager secure connections (4.2)"
|
|
depends on BT_LE_SECURITY_ENABLE
|
|
default y
|
|
help
|
|
Enable security manager secure connections
|
|
|
|
config BT_LE_SM_SC_DEBUG_KEYS
|
|
bool "Use predefined public-private key pair"
|
|
default n
|
|
depends on BT_LE_SECURITY_ENABLE && BT_LE_SM_SC
|
|
help
|
|
If this option is enabled, SM uses predefined DH key pair as described
|
|
in Core Specification, Vol. 3, Part H, 2.3.5.6.1. This allows to
|
|
decrypt air traffic easily and thus should only be used for debugging.
|
|
|
|
config BT_LE_LL_CFG_FEAT_LE_ENCRYPTION
|
|
bool "Enable LE encryption"
|
|
depends on BT_LE_SECURITY_ENABLE
|
|
default y
|
|
help
|
|
Enable encryption connection
|
|
|
|
config BT_LE_CRYPTO_STACK_MBEDTLS
|
|
bool "Override TinyCrypt with mbedTLS for crypto computations"
|
|
default y
|
|
depends on !BT_NIMBLE_ENABLED
|
|
select MBEDTLS_CMAC_C
|
|
help
|
|
Enable this option to choose mbedTLS instead of TinyCrypt for crypto
|
|
computations.
|
|
|
|
config BT_LE_WHITELIST_SIZE
|
|
int "BLE white list size"
|
|
range 1 31
|
|
default 12
|
|
depends on !BT_NIMBLE_ENABLED
|
|
|
|
help
|
|
BLE list size
|
|
|
|
config BT_LE_LL_DUP_SCAN_LIST_COUNT
|
|
int "BLE duplicate scan list count"
|
|
range 5 100
|
|
default 20
|
|
help
|
|
config the max count of duplicate scan list
|
|
|
|
config BT_LE_LL_SCA
|
|
int "BLE Sleep clock accuracy"
|
|
range 0 500
|
|
default 60
|
|
help
|
|
Sleep clock accuracy of our device (in ppm)
|
|
|
|
config BT_LE_MAX_CONNECTIONS
|
|
int "Maximum number of concurrent connections"
|
|
depends on !BT_NIMBLE_ENABLED
|
|
range 1 70
|
|
default 3
|
|
help
|
|
Defines maximum number of concurrent BLE connections. For ESP32, user
|
|
is expected to configure BTDM_CTRL_BLE_MAX_CONN from controller menu
|
|
along with this option. Similarly for ESP32-C3 or ESP32-S3, user is expected to
|
|
configure BT_CTRL_BLE_MAX_ACT from controller menu.
|
|
Each connection will take about 1k DRAM.
|
|
|
|
choice BT_LE_COEX_PHY_CODED_TX_RX_TLIM
|
|
prompt "Coexistence: limit on MAX Tx/Rx time for coded-PHY connection"
|
|
default BT_LE_COEX_PHY_CODED_TX_RX_TLIM_DIS
|
|
depends on ESP_COEX_SW_COEXIST_ENABLE
|
|
help
|
|
When using PHY-Coded in BLE connection, limitation on max tx/rx time can be applied to
|
|
better avoid dramatic performance deterioration of Wi-Fi.
|
|
|
|
config BT_LE_COEX_PHY_CODED_TX_RX_TLIM_EN
|
|
bool "Force Enable"
|
|
help
|
|
Always enable the limitation on max tx/rx time for Coded-PHY connection
|
|
|
|
config BT_LE_COEX_PHY_CODED_TX_RX_TLIM_DIS
|
|
bool "Force Disable"
|
|
help
|
|
Disable the limitation on max tx/rx time for Coded-PHY connection
|
|
endchoice
|
|
|
|
config BT_LE_COEX_PHY_CODED_TX_RX_TLIM_EFF
|
|
int
|
|
default 0 if !ESP_COEX_SW_COEXIST_ENABLE
|
|
default 1 if BT_LE_COEX_PHY_CODED_TX_RX_TLIM_EN
|
|
default 0 if BT_LE_COEX_PHY_CODED_TX_RX_TLIM_DIS
|
|
|
|
config BT_LE_SLEEP_ENABLE
|
|
bool "Enable BLE sleep"
|
|
default n
|
|
help
|
|
Enable BLE sleep
|
|
|
|
choice BT_LE_LP_CLK_SRC
|
|
prompt "BLE low power clock source"
|
|
default BT_LE_LP_CLK_SRC_MAIN_XTAL
|
|
config BT_LE_LP_CLK_SRC_MAIN_XTAL
|
|
bool "Use main XTAL as RTC clock source"
|
|
help
|
|
User main XTAL as RTC clock source.
|
|
This option is recommended if external 32.768k XTAL is not available.
|
|
Using the external 32.768 kHz XTAL will have lower current consumption
|
|
in light sleep compared to using the main XTAL.
|
|
|
|
config BT_LE_LP_CLK_SRC_DEFAULT
|
|
bool "Use system RTC slow clock source"
|
|
help
|
|
Use the same slow clock source as system RTC
|
|
Using any clock source other than external 32.768 kHz XTAL supports only
|
|
legacy ADV and SCAN due to low clock accuracy.
|
|
|
|
endchoice
|
|
|
|
config BT_LE_USE_ESP_TIMER
|
|
bool "Enable Esp Timer for Callout"
|
|
depends on !BT_NIMBLE_ENABLED
|
|
default y
|
|
help
|
|
Set this option to use Esp Timer which has higher priority timer
|
|
instead of FreeRTOS timer
|
|
config BT_CTRL_BLE_ADV_REPORT_FLOW_CTRL_SUPP
|
|
bool "BLE adv report flow control supported"
|
|
default y
|
|
help
|
|
The function is mainly used to enable flow control for advertising reports. When it is enabled,
|
|
advertising reports will be discarded by the controller if the number of unprocessed advertising
|
|
reports exceeds the size of BLE adv report flow control.
|
|
|
|
config BT_CTRL_BLE_ADV_REPORT_FLOW_CTRL_NUM
|
|
int "BLE adv report flow control number"
|
|
depends on BT_CTRL_BLE_ADV_REPORT_FLOW_CTRL_SUPP
|
|
range 50 1000
|
|
default 100
|
|
help
|
|
The number of unprocessed advertising report that bluetooth host can save.If you set
|
|
`BT_CTRL_BLE_ADV_REPORT_FLOW_CTRL_NUM` to a small value, this may cause adv packets lost.
|
|
If you set `BT_CTRL_BLE_ADV_REPORT_FLOW_CTRL_NUM` to a large value, bluetooth host may cache a
|
|
lot of adv packets and this may cause system memory run out. For example, if you set
|
|
it to 50, the maximum memory consumed by host is 35 * 50 bytes. Please set
|
|
`BT_CTRL_BLE_ADV_REPORT_FLOW_CTRL_NUM` according to your system free memory and handle adv
|
|
packets as fast as possible, otherwise it will cause adv packets lost.
|
|
|
|
config BT_CTRL_BLE_ADV_REPORT_DISCARD_THRSHOLD
|
|
int "BLE adv lost event threshold value"
|
|
depends on BT_CTRL_BLE_ADV_REPORT_FLOW_CTRL_SUPP
|
|
range 1 1000
|
|
default 20
|
|
help
|
|
When adv report flow control is enabled, The ADV lost event will be generated when the number
|
|
of ADV packets lost in the controller reaches this threshold. It is better to set a larger value.
|
|
If you set `BT_CTRL_BLE_ADV_REPORT_DISCARD_THRSHOLD` to a small value or printf every adv lost event, it
|
|
may cause adv packets lost more.
|
|
|
|
config BT_LE_SCAN_DUPL
|
|
bool "BLE Scan Duplicate Options"
|
|
default y
|
|
help
|
|
This select enables parameters setting of BLE scan duplicate.
|
|
|
|
choice BT_LE_SCAN_DUPL_TYPE
|
|
prompt "Scan Duplicate Type"
|
|
default BT_LE_SCAN_DUPL_TYPE_DEVICE
|
|
depends on BT_LE_SCAN_DUPL
|
|
help
|
|
Scan duplicate have three ways. one is "Scan Duplicate By Device Address", This way is to use
|
|
advertiser address filtering. The adv packet of the same address is only allowed to be reported once.
|
|
Another way is "Scan Duplicate By Device Address And Advertising Data". This way is to use advertising
|
|
data and device address filtering. All different adv packets with the same address are allowed to be
|
|
reported. The last way is "Scan Duplicate By Advertising Data". This way is to use advertising data
|
|
filtering. All same advertising data only allow to be reported once even though they are from
|
|
different devices.
|
|
|
|
config BT_LE_SCAN_DUPL_TYPE_DEVICE
|
|
bool "Scan Duplicate By Device Address"
|
|
help
|
|
This way is to use advertiser address filtering. The adv packet of the same address is only
|
|
allowed to be reported once
|
|
|
|
config BT_LE_SCAN_DUPL_TYPE_DATA
|
|
bool "Scan Duplicate By Advertising Data"
|
|
help
|
|
This way is to use advertising data filtering. All same advertising data only allow to be reported
|
|
once even though they are from different devices.
|
|
|
|
config BT_LE_SCAN_DUPL_TYPE_DATA_DEVICE
|
|
bool "Scan Duplicate By Device Address And Advertising Data"
|
|
help
|
|
This way is to use advertising data and device address filtering. All different adv packets with
|
|
the same address are allowed to be reported.
|
|
endchoice
|
|
|
|
config BT_LE_SCAN_DUPL_TYPE
|
|
int
|
|
depends on BT_LE_SCAN_DUPL
|
|
default 0 if BT_LE_SCAN_DUPL_TYPE_DEVICE
|
|
default 1 if BT_LE_SCAN_DUPL_TYPE_DATA
|
|
default 2 if BT_LE_SCAN_DUPL_TYPE_DATA_DEVICE
|
|
default 0
|
|
|
|
config BT_LE_SCAN_DUPL_CACHE_REFRESH_PERIOD
|
|
int "Duplicate scan list refresh period (seconds)"
|
|
depends on BT_LE_SCAN_DUPL
|
|
range 0 1000
|
|
default 0
|
|
help
|
|
If the period value is non-zero, the controller will periodically clear the device information
|
|
stored in the scan duuplicate filter. If it is 0, the scan duuplicate filter will not be cleared
|
|
until the scanning is disabled. Duplicate advertisements for this period should not be sent to the
|
|
Host in advertising report events.
|
|
There are two scenarios where the ADV packet will be repeatedly reported:
|
|
1. The duplicate scan cache is full, the controller will delete the oldest device information and
|
|
add new device information.
|
|
2. When the refresh period is up, the controller will clear all device information and start filtering
|
|
again.
|
|
|
|
config BT_LE_MSYS_INIT_IN_CONTROLLER
|
|
bool "Msys Mbuf Init in Controller"
|
|
default y
|
|
|
|
config BT_LE_TX_CCA_ENABLED
|
|
bool "Enable TX CCA feature"
|
|
default n
|
|
help
|
|
Enable CCA feature to cancel sending the packet if the signal power is stronger than CCA threshold.
|
|
|
|
config BT_LE_CCA_RSSI_THRESH
|
|
int "CCA RSSI threshold value"
|
|
depends on BT_LE_TX_CCA_ENABLED
|
|
range 20 100
|
|
default 20
|
|
help
|
|
Power threshold of CCA in unit of -1 dBm.
|
|
|
|
choice BT_LE_DFT_TX_POWER_LEVEL_DBM
|
|
prompt "BLE default Tx power level(dBm)"
|
|
default BT_LE_DFT_TX_POWER_LEVEL_P9
|
|
help
|
|
Specify default Tx power level(dBm).
|
|
config BT_LE_DFT_TX_POWER_LEVEL_N15
|
|
bool "-15dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_N12
|
|
bool "-12dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_N9
|
|
bool "-9dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_N6
|
|
bool "-6dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_N3
|
|
bool "-3dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_N0
|
|
bool "0dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_P3
|
|
bool "+3dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_P6
|
|
bool "+6dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_P9
|
|
bool "+9dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_P12
|
|
bool "+12dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_P15
|
|
bool "+15dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_P18
|
|
bool "+18dBm"
|
|
config BT_LE_DFT_TX_POWER_LEVEL_P20
|
|
bool "+20dBm"
|
|
endchoice
|
|
|
|
config BT_LE_DFT_TX_POWER_LEVEL_DBM_EFF
|
|
int
|
|
default -15 if BT_LE_DFT_TX_POWER_LEVEL_N15
|
|
default -12 if BT_LE_DFT_TX_POWER_LEVEL_N12
|
|
default -9 if BT_LE_DFT_TX_POWER_LEVEL_N9
|
|
default -6 if BT_LE_DFT_TX_POWER_LEVEL_N6
|
|
default -3 if BT_LE_DFT_TX_POWER_LEVEL_N3
|
|
default 0 if BT_LE_DFT_TX_POWER_LEVEL_N0
|
|
default 3 if BT_LE_DFT_TX_POWER_LEVEL_P3
|
|
default 6 if BT_LE_DFT_TX_POWER_LEVEL_P6
|
|
default 9 if BT_LE_DFT_TX_POWER_LEVEL_P9
|
|
default 12 if BT_LE_DFT_TX_POWER_LEVEL_P12
|
|
default 15 if BT_LE_DFT_TX_POWER_LEVEL_P15
|
|
default 18 if BT_LE_DFT_TX_POWER_LEVEL_P18
|
|
default 20 if BT_LE_DFT_TX_POWER_LEVEL_P20
|
|
default 0
|
|
|
|
config BT_LE_CTRL_CHECK_CONNECT_IND_ACCESS_ADDRESS
|
|
bool "Enable enhanced Access Address check in CONNECT_IND"
|
|
default n
|
|
help
|
|
Enabling this option will add stricter verification of the Access Address in the CONNECT_IND PDU.
|
|
This improves security by ensuring that only connection requests with valid Access Addresses are accepted.
|
|
If disabled, only basic checks are applied, improving compatibility.
|
|
|
|
config BT_CTRL_RUN_IN_FLASH_ONLY
|
|
bool "Reduce BLE IRAM usage (READ DOCS FIRST) (EXPERIMENTAL)"
|
|
default n
|
|
help
|
|
Move most IRAM into flash. This will increase the usage of flash and reduce ble performance.
|
|
Because the code is moved to the flash, the execution speed of the code is reduced.
|
|
To have a small impact on performance, you need to enable flash suspend (SPI_FLASH_AUTO_SUSPEND).
|
|
|
|
menu "BLE disconnects when Instant Passed (0x28) occurs"
|
|
config BT_LE_CTRL_LLCP_CONN_UPDATE
|
|
bool "BLE ACL connection update procedure"
|
|
default n
|
|
help
|
|
If this option is enabled, Controller will terminate the connection
|
|
when Instant Passed (0x28) error occurs during connection update procedure.
|
|
|
|
config BT_LE_CTRL_LLCP_CHAN_MAP_UPDATE
|
|
bool "BLE ACL channel map update procedure"
|
|
default n
|
|
help
|
|
If this option is enabled, Controller will terminate the connection
|
|
when Instant Passed (0x28) error occurs in channel map update procedure.
|
|
|
|
config BT_LE_CTRL_LLCP_PHY_UPDATE
|
|
bool "BLE ACL PHY update procedure"
|
|
default n
|
|
help
|
|
If this option is enabled, Controller will terminate the connection
|
|
when Instant Passed (0x28) error occurs in PHY update procedure.
|
|
endmenu
|
|
|
|
config BT_CTRL_SCAN_BACKOFF_UPPERLIMITMAX
|
|
int "The value of upperlimitmax during scan backoff procedure"
|
|
range 1 256
|
|
default 32
|
|
help
|
|
The value of upperlimitmax needs to be a power of 2.
|
|
|
|
config BT_LE_CTRL_CHAN_ASS_EN
|
|
bool "Enable channel assessment(Experimental)"
|
|
default n
|
|
help
|
|
If this option is enabled, The Controller will records the communication quality
|
|
for each channel and then start a timer to check and update the channel map every 4 seconds.
|
|
|
|
config BT_LE_CTRL_ADV_DATA_LENGTH_ZERO_AUX
|
|
bool "Enable aux packet when ext adv data length is zero(Experimental)"
|
|
default y
|
|
help
|
|
When this option is enabled, auxiliary packets will be present in the events of
|
|
'Non-Connectable and Non-Scannable' regardless of whether the advertising length is 0.
|
|
If this option is not enabled, auxiliary packets will only be present when the advertising length is not 0.
|
|
|
|
config BT_LE_RXBUF_OPT_ENABLED
|
|
bool "Enable rxbuf optimization feature"
|
|
default y
|