
1. 为什么 STM32WB BLE 应用需要 LSE ? 首先 LSE 可作为 STM32WB RF Wakeup 和 RTC 的时钟源。 STM32WB RF Wakeup 和 RTC 的时钟源可配置为 LSE,LSE 时钟相对比较稳定且准确,不需要校准,而且 LSE 可在所有的低功耗模式下保持工作。 STM32WB RF Wakeup 和 RTC 的时钟源也可配置为 HSE,由于 HSE 只能在RUN/LP RUN/SLEEP/LP SLEEP 模式保持,进入 STOP/STANDBY/STUTDOWN 模式后,HSE 会被关掉,这样系统就无法进入 STOP/STANDBY/STUTDOWN 模式,导致系统功耗会更高。另外 HSE 可能没那么稳定,可能需要校准,从而可能导致 STM32WB RF Wakeup 时钟不稳,也影响 BLE stack 运行,导致 BLE 工作不稳。 ![]() 2. 在需要 BLE 使能时,什么情况下可考虑不使用 LSE 在以下情况下,还需要使能 BLE 并进行开发,调试时可配置 STM32WB 使用 HSE 做RF Wakeup 和 RTC 的时钟源。 1. 设计时,遗漏 LSE,但是样机已做好 2. 生产了样机,忘记贴 LSE 了 3. 生产了样机,LSE 不匹配,暂时可去掉 3. 环境或应用使用某些 GPIO(PC13) 影响 LSE,导致 LSE 时钟异常或不稳 4. 不关心功耗,系统不需要进入低功耗 3. 如何配置 HSE 作为 RF Wakeup 和 RTC 的时钟源 已有介绍,基于 CubeMX v6.3.0 和 CubeWB v1.12.0,但是从 CubeMX v6.4.0 and CubeWB v1.13.1 后,CubeWB 有稍许更新,本 LAT 基于CubeMX v6.6.1 和 CubeWB v1.14.1 介绍。 3.1. 打开 BLE_p2pServer.ioc 用 CubeMX v6.6.1 打开 STM32Cube_FW_WB_V1.14.1\Projects\P-NUCLEOWB55.Nucleo\Applications\BLE\BLE_p2pServer\BLE_p2pServer.ioc,以此为例。 3.2. 失能 LSE 在 Pinout& Configuration => System Core => RCC=>Low Speed Clock (LSE)=>Disable,失能 LSE。 ![]() 3.3. 失能 LPM & 配置 RTC 预分频 在 Pinout& Configuration => Middleware => STM32_WPAN =>Configuration=>Generic parameters=>CFG_LPM_SUPPORT=>Disabled,失能低功耗 LPM,系统会保持在 RUN 模式 Application parameters=> CFG_RTC_ASYNCH_PRESCALER=>127 Application parameters=> CFG_RTC_SYNCH_PRESCALER =>7812 ![]() 其实,生成代码后在 Core\Inc\app_conf.h 中,如果使能了CFG_DEBUG_BLE_TRACE 或 CFG_DEBUG_APP_TRACE,会自动的失能CFG_LPM_SUPPORTED。 完整版请查看:附件 ![]() |
【NUCLEO-WBA65RI评测】围绕BleApplicationContext_t的端侧蓝牙开发逻辑
STM32入门系列-学习STM32要掌握的内容
【NUCLEO-WBA65RI评测】Android Studio手机端蓝牙开发
【NUCLEO-WBA65RI评测】6.手机蓝牙控制电机运动
【NUCLEO-WBA65RI评测】Android端蓝牙OTA升级
【NUCLEO-WBA65RI评测】USB HID设备测试
【NUCLEO-WBA65RI评测】5.OTA后不能Debug的原因和解决方案
新手必看!STM32单片机应该怎么学?
【NUCLEO-WBA65RI评测】使用BLE-Serial-comm进行BLE调试,蓝牙BLE动态运行
【NUCLEO-WBA65RI评测】评测小结