Files
BoilerControlUnit_Firmware/config/sl_bluetooth_config.h
GClarkson 9d06f983af Imported more library files
Not compiling currently
2025-04-12 23:37:19 +01:00

176 lines
8.1 KiB
C

/***************************************************************************//**
* @file
* @brief Bluetooth Stack configuration
*******************************************************************************
* # License
* <b>Copyright 2023 Silicon Laboratories Inc. www.silabs.com</b>
*******************************************************************************
*
* SPDX-License-Identifier: Zlib
*
* The licensor of this software is Silicon Laboratories Inc.
*
* This software is provided 'as-is', without any express or implied warranty.
* In no event will the authors be held liable for any damages arising from the
* use of this software.
*
* Permission is granted to anyone to use this software for any purpose,
* including commercial applications, and to alter it and redistribute it
* freely, subject to the following restrictions:
*
* 1. The origin of this software must not be misrepresented; you must not
* claim that you wrote the original software. If you use this software in a
* product, an acknowledgment in the product documentation would be
* appreciated but is not required.
* 2. Altered source versions must be plainly marked as such, and must not be
* misrepresented as being the original software.
* 3. This notice may not be removed or altered from any source distribution.
*
******************************************************************************/
#ifndef SL_BLUETOOTH_CONFIG_H
#define SL_BLUETOOTH_CONFIG_H
#if defined(SL_COMPONENT_CATALOG_PRESENT)
#include "sl_component_catalog.h"
#endif
// <<< Use Configuration Wizard in Context Menu >>>
// <h> Bluetooth Stack Configuration
#ifdef SL_CATALOG_BLUETOOTH_FEATURE_CONNECTION_PRESENT
#include "sl_bluetooth_connection_config.h"
#else
#define SL_BT_CONFIG_MAX_CONNECTIONS (0)
#endif
// Max number of connections reserved by user application and components
#define SL_BT_CONFIG_MAX_CONNECTIONS_SUM (SL_BT_CONFIG_MAX_CONNECTIONS + SL_BT_COMPONENT_CONNECTIONS)
#ifdef SL_CATALOG_BLUETOOTH_FEATURE_ADVERTISER_PRESENT
#include "sl_bluetooth_advertiser_config.h"
#else
#define SL_BT_CONFIG_USER_ADVERTISERS (0)
#endif
#define SL_BT_CONFIG_MAX_ADVERTISERS (SL_BT_CONFIG_USER_ADVERTISERS + SL_BT_COMPONENT_ADVERTISERS)
// <o SL_BT_CONFIG_MAX_SOFTWARE_TIMERS> Max number of software timers <0-16>
// <i> Default: 4
// <i> Define the number of software timers the application needs. Each timer needs resources from the stack to be implemented. Increasing amount of soft timers may cause degraded performance in some use cases.
#define SL_BT_CONFIG_MAX_SOFTWARE_TIMERS (4)
// <o SL_BT_CONFIG_BUFFER_SIZE> Buffer memory size for Bluetooth stack
// <i> Default: 3150
// <i> Define buffer memory size for running Bluetooth stack and buffering data over Bluetooth connections,
// <i> advertising and scanning. The default value is an estimation for achieving adequate throughput
// <i> and supporting multiple simultaneous connections. Consider increasing this value for
// <i> higher data throughput over connections, advertising or scanning long advertisement data.
#define SL_BT_CONFIG_BUFFER_SIZE (3150)
// <e SL_BT_CONFIG_SET_CUSTOM_ADDRESS_FROM_NVM3> Enable using a custom Bluetooth address stored in NVM3
// <i> Enable or disable using a custom Bluetooth address stored the Bluetooth space of NVM3. When enabled,
// <i> the Bluetooth stack sets the address as the Bluetooth identity address of the device if a valid address
// <i> is found in NVM3.
// <i> Default: 1
#define SL_BT_CONFIG_SET_CUSTOM_ADDRESS_FROM_NVM3 (1)
// </e>
// <e SL_BT_CONFIG_SET_CTUNE_FROM_NVM3> Enable setting the HFXO CTUNE with a value stored in the Bluetooth space of NVM3.
// <i> Enable or disable setting the HFXO CTUNE with a value stored in the Bluetooth space of NVM3. When enabled, the
// <i> Bluetooth stack sets the HFXO CTUNE at Bluetooth starting phase if a CTUNE value is found in NVM3. This
// <i> operation will override the CTUNE that is set to with the value stored in the MFG_CTUNE token or the
// <i> configuration value in the Clock Manager.
// <i> Setting the HFXO CTUNE with this method is deprecated. Currently the functionality is provided for keeping
// <i> backwards compatibility with legacy SDKs, and the support will be discontinued in future SDK releases.
// <i> The recommended method is to store CTUNE value in the MFG_CTUNE token.
// <i> Default: 0
#define SL_BT_CONFIG_SET_CTUNE_FROM_NVM3 (0)
// </e>
// </h> End Bluetooth Stack Configuration
// <h> TX Power Levels
// <o SL_BT_CONFIG_MIN_TX_POWER> Minimum radiated TX power level in 0.1dBm unit
// <i> Default: -30 (-3 dBm)
// <i> Configure the minimum radiated TX power level for Bluetooth connections and DTM testing.
// <i> This configuration is used for power control on Bluetooth connections
// <i> if the LE Power Control feature is enabled.
// <i> When this configuration is passed into stack initialization, the stack
// <i> will select the closest value that the device supports.
// <i> API sl_bt_system_get_tx_power_setting() can be used to query the selected value.
#define SL_BT_CONFIG_MIN_TX_POWER (-30)
// <o SL_BT_CONFIG_MAX_TX_POWER> Maximum radiated TX power level in 0.1dBm unit
// <i> Default: 80 (8 dBm)
// <i> Configure the maximum radiated TX power level for Bluetooth connections,
// <i> advertising, scanning and DTM testing.
// <i> When this configuration is passed into stack initialization, the stack
// <i> will select the closest value that the device supports.
// <i> API sl_bt_system_get_tx_power_setting() can be used to query the selected value.
#define SL_BT_CONFIG_MAX_TX_POWER (80)
// </h> End TX Power Levels
// <h> RF Path
// <o SL_BT_CONFIG_RF_PATH_GAIN_TX> RF TX path gain in 0.1dBm unit
// <i> Default: 0
// <i> The Bluetooth stack takes TX RF path gain into account when adjusting transmitter
// <i> output power. Power radiated from the antenna then matches the application request.
// <i> A negative value indicates some power loss in the path. For example,
// <i> with radiated TX power set to +10 dBm and this configuration to -10
// <i> (i.e., 1 dBm loss), the transmitter output power will be set to +11 dBm.
#define SL_BT_CONFIG_RF_PATH_GAIN_TX (0)
// <o SL_BT_CONFIG_RF_PATH_GAIN_RX> RF RX path gain in 0.1dBm unit
// <i> Default: 0
// <i> RX RF path gain is used to compensate the RSSI reports from the Bluetooth Stack.
#define SL_BT_CONFIG_RF_PATH_GAIN_RX (0)
// </h> End RF Path
// <<< end of configuration section >>>
/**
* By default, Bluetooth requires accurate LF clock for EM2. If the component
* catalog presents, an inaccurate LF clock for EM2 can be used if the Bluetooth
* connection, periodic advertising and periodic advertising synchronization
* features are known to not present.
*/
#define BT_EM2_LFCLK_REQ_FLAG 0
#if defined(SL_COMPONENT_CATALOG_PRESENT)
#if !defined(SL_CATALOG_BLUETOOTH_FEATURE_CONNECTION_PRESENT) \
&& !defined(SL_CATALOG_BLUETOOTH_FEATURE_PERIODIC_ADV_PRESENT) \
&& !defined(SL_CATALOG_BLUETOOTH_FEATURE_SYNC_PRESENT)
#undef BT_EM2_LFCLK_REQ_FLAG
#define BT_EM2_LFCLK_REQ_FLAG SL_BT_CONFIG_FLAG_INACCURATE_LFCLK_EM2
#endif
#endif // SL_COMPONENT_CATALOG_PRESENT
#ifdef SL_CATALOG_KERNEL_PRESENT
#define SL_BT_CONFIG_FLAGS (SL_BT_CONFIG_FLAG_RTOS | BT_EM2_LFCLK_REQ_FLAG)
#else
#define SL_BT_CONFIG_FLAGS (BT_EM2_LFCLK_REQ_FLAG)
#endif // SL_CATALOG_KERNEL_PRESENT
#include "sl_bt_stack_config.h"
#define SL_BT_CONFIG_DEFAULT \
{ \
.config_flags = SL_BT_CONFIG_FLAGS, \
.bluetooth.max_buffer_memory = SL_BT_CONFIG_BUFFER_SIZE, \
.scheduler_callback = NULL, \
.stack_schedule_callback = NULL, \
.gattdb = &gattdb, \
.max_timers = SL_BT_CONFIG_MAX_SOFTWARE_TIMERS, \
.rf.tx_gain = SL_BT_CONFIG_RF_PATH_GAIN_TX, \
.rf.rx_gain = SL_BT_CONFIG_RF_PATH_GAIN_RX, \
.rf.tx_min_power = SL_BT_CONFIG_MIN_TX_POWER, \
.rf.tx_max_power = SL_BT_CONFIG_MAX_TX_POWER, \
}
#endif // SL_BLUETOOTH_CONFIG_H