stm32/rfcore: Allow BLE settings to be changed by a board.

Two of the defaults have also changed in this commit:

- MICROPY_HW_RFCORE_BLE_LSE_SOURCE changed from 1 to 0, which configures
  the LsSource to be LSE (needed due to errata 2.2.1).

- MICROPY_HW_RFCORE_BLE_VITERBI_MODE changed from 0 to 1, which enables
  Viterbi mode, following all the ST examples.

Signed-off-by: Damien George <damien@micropython.org>
This commit is contained in:
Damien George 2021-03-02 12:14:54 +11:00
parent cdaec0dcaf
commit 680ce45323
2 changed files with 39 additions and 19 deletions

View File

@ -262,6 +262,26 @@
#define MICROPY_HW_STM32WB_FLASH_SYNCRONISATION (1) #define MICROPY_HW_STM32WB_FLASH_SYNCRONISATION (1)
#endif #endif
// RF core BLE configuration (a board should define
// MICROPY_HW_RFCORE_BLE_NUM_GATT_ATTRIBUTES to override all values)
#ifndef MICROPY_HW_RFCORE_BLE_NUM_GATT_ATTRIBUTES
#define MICROPY_HW_RFCORE_BLE_NUM_GATT_ATTRIBUTES (0)
#define MICROPY_HW_RFCORE_BLE_NUM_GATT_SERVICES (0)
#define MICROPY_HW_RFCORE_BLE_ATT_VALUE_ARRAY_SIZE (0)
#define MICROPY_HW_RFCORE_BLE_NUM_LINK (1)
#define MICROPY_HW_RFCORE_BLE_DATA_LENGTH_EXTENSION (1)
#define MICROPY_HW_RFCORE_BLE_PREPARE_WRITE_LIST_SIZE (0)
#define MICROPY_HW_RFCORE_BLE_MBLOCK_COUNT (0x79)
#define MICROPY_HW_RFCORE_BLE_MAX_ATT_MTU (0)
#define MICROPY_HW_RFCORE_BLE_SLAVE_SCA (0)
#define MICROPY_HW_RFCORE_BLE_MASTER_SCA (0)
#define MICROPY_HW_RFCORE_BLE_LSE_SOURCE (0) // use LSE to clock the rfcore (see errata 2.2.1)
#define MICROPY_HW_RFCORE_BLE_MAX_CONN_EVENT_LENGTH (0xffffffff)
#define MICROPY_HW_RFCORE_BLE_HSE_STARTUP_TIME (0x148)
#define MICROPY_HW_RFCORE_BLE_VITERBI_MODE (1)
#define MICROPY_HW_RFCORE_BLE_LL_ONLY (1) // use LL only, we provide the rest of the BLE stack
#endif
#else #else
#error Unsupported MCU series #error Unsupported MCU series
#endif #endif

View File

@ -548,30 +548,30 @@ static const struct {
uint16_t AttMtu; uint16_t AttMtu;
uint16_t SlaveSca; uint16_t SlaveSca;
uint8_t MasterSca; uint8_t MasterSca;
uint8_t LsSource; // 0=LSE 1=internal RO uint8_t LsSource;
uint32_t MaxConnEventLength; uint32_t MaxConnEventLength;
uint16_t HsStartupTime; uint16_t HsStartupTime;
uint8_t ViterbiEnable; uint8_t ViterbiEnable;
uint8_t LlOnly; // 0=LL+Host, 1=LL only uint8_t LlOnly;
uint8_t HwVersion; uint8_t HwVersion;
} ble_init_params = { } ble_init_params = {
0, 0, // pBleBufferAddress
0, 0, // BleBufferSize
0, // NumAttrRecord MICROPY_HW_RFCORE_BLE_NUM_GATT_ATTRIBUTES,
0, // NumAttrServ MICROPY_HW_RFCORE_BLE_NUM_GATT_SERVICES,
0, // AttrValueArrSize MICROPY_HW_RFCORE_BLE_ATT_VALUE_ARRAY_SIZE,
1, // NumOfLinks MICROPY_HW_RFCORE_BLE_NUM_LINK,
1, // ExtendedPacketLengthEnable MICROPY_HW_RFCORE_BLE_DATA_LENGTH_EXTENSION,
0, // PrWriteListSize MICROPY_HW_RFCORE_BLE_PREPARE_WRITE_LIST_SIZE,
0x79, // MblockCount MICROPY_HW_RFCORE_BLE_MBLOCK_COUNT,
0, // AttMtu MICROPY_HW_RFCORE_BLE_MAX_ATT_MTU,
0, // SlaveSca MICROPY_HW_RFCORE_BLE_SLAVE_SCA,
0, // MasterSca MICROPY_HW_RFCORE_BLE_MASTER_SCA,
1, // LsSource MICROPY_HW_RFCORE_BLE_LSE_SOURCE,
0xffffffff, // MaxConnEventLength MICROPY_HW_RFCORE_BLE_MAX_CONN_EVENT_LENGTH,
0x148, // HsStartupTime MICROPY_HW_RFCORE_BLE_HSE_STARTUP_TIME,
0, // ViterbiEnable MICROPY_HW_RFCORE_BLE_VITERBI_MODE,
1, // LlOnly MICROPY_HW_RFCORE_BLE_LL_ONLY,
0, // HwVersion 0, // HwVersion
}; };