
引言 本篇 LAT 介绍使用 CubeMX 创建基于 STM32WL 的 LoRa 应用。 STM32Cube_FW_WL_V1.0.0\Projects\NUCLEO-WL55JC 中的例程都是基于 STM32WL BGA73 的,CubeMX 无法直接创建基于 STM32WL QFN48 的例程。 同时介绍如何参考STM32Cube_FW_WL_V1.0.0\Projects\NUCLEOWL55JC\Applications\SubGHz_Phy\SubGHz_Phy_PingPong 创建一个 WLEx_PingPong 的例 子。 ! Q; n0 e6 d5 v q 关于不同 MCU 间的移植可参考 UM1718 11.9 Switching to another MCU UM1718 15 Tutorial 5: Exporting current project configuration to a compatible MCU 需要提前准备的环境: ![]() : ]8 {! E/ Q W/ b# r& i: W4 g- J 1.配置 CubeMX 1.1 配置 CubeMX 并下载 CubeWL 可以使用 CubeMX 默认安装的仓库目录也可以自定义仓库目录,本例使用自定义的仓库目录C:\Users\gongw\STM32Cube\Repository\CubeWL,如下Help=>Updater Settings=>Repository Forlder=>C:\Users\gongw\STM32Cube\Repository\CubeWL=>OK ![]() ![]() 选择 Manage software installations 中的 Install or remove embedded software packages 下的 “INSTALL / REMOVE” ![]() ) J2 S. K; E: F/ w4 Q: J) m9 Y ![]() 点Refresh 更新数据库 ![]() 3 v9 i- R! L7 m# n3 L" t Fresh 结束后,点开 STM32WL 左侧的黑色三角,选中 STM32WL 下版本 1.0.0 的 STM32Cube MCU Package for STM32WL Series,点 Install Now ![]() . q! p8 ^1 a+ [4 Z5 @ 点击 Close 1.2 CubeMX 新建项目 - Q K3 F: E _) ~. b. E打开 STM32CubeMX,在 New Project 下有三中选择, 请根据需求选择 New Project 的方式! ![]() ; j _) B% b+ E& \8 E 1.2.1 Start My project from MCU 第 1 种可使用于所有的 WL 产品,只能生成和配置的用户自定义(User Defined)的LoRaWAN/SigFox/SUBGHZ 应用,不能生成 CubeWL 中 AT_Slave/EndNode/PingPong demo 1.2.2 Start My project from BOARD 第 2 种适用于 NUCLEO-WL55JC1 和 NUCLEO-WL55JC1 两种 Demo 板,只能生成和配置的用户自定义(User Defined)的LoRaWAN/SigFox/SUBGHZ 应用,不能生成 CubeWL 中AT_Slave/EndNode/PingPong demo 1.2.3 Start My project from EXAMPLES 第 3 种适用于生成 CubeWL 中 NUCLEO-WL55JC1 和 NUCLEO-WL55JC1 的 Examples,可生成和配置 CubeWL 中AT_Slave/EndNode/PingPong demo ![]() ![]() 5 Y( c* m# w( X( W; |6 I$ }, A ![]() 选择 NUCLEO-WL55JC 对应的 STM32WL55JC ![]() ![]() ![]() ![]() ![]() 1.3 CubeMX 导入参考项目 ![]() 2 H/ ]+ r& f- X ![]() ![]() ![]() 4 r1 f ]4 b2 b9 j. D ![]() ![]() 此时再查看 File =>Import Project 选项,变为灰色,表示新项目已被配置,不能再 import 参考项目。 ![]() 1.4 CubeMX 配置项目 5 r, H( x: C h! E* \% A6 P5 P- z1.4.1 CubeMX 配置 Project Manager 选择 Project Manager 1.4.1.1 配置 Project 选择右侧 Project 并配置如下: ![]() 注意: 通过 Browse 选择 Project 保存的目录 ⚫ 项目名称 WLEx_AT_Slave 创建在STM32Cube_FW_WL_V1.0.0\Projects\NUCLEO- WL55JC\Applications\LoRaWAN 下,和LoRaWAN_End_Node 同级目录,即 C:\Users\gongw\STM32Cube\Repository\CubeWL\STM32Cube_FW_WL_V1.0.0\Projects\NUCLEO-WL55JC\Applications\LoRaWAN\WLEx_PingPong,以 便于与 LoRaWAN_End_Node 进行比较 ⚫ 配置 Application Structure 为 Advanced 与 basic 有什么区别? Application Structure 为 Advanced 时目录结构分类分级目录更清晰。 Application Structure 为 Basic 时,所有的*.h 都在 WLEx_PingPong\Inc 目录下,所有的*.c 在 WLEx_PingPong\Src 目录下。 一旦生成过一次代码后目录结构就无法更改了!!! ![]() 选择右侧 Code Generator 并配置如下,选择”Add necessary library files as reference in the toolchain project configuration file “,这样将不生成 Drivers 和 Middlewares 目录。 选择 Generated files 下的“Generate peripheral initialization as a pair of ‘.c/.h’ per peripheral” ![]() ![]() 注意: ⚫ Copy all used library Package (如复制 Drivers\STM32WLxx_HAL_Driver 下的所有驱动) WLEx_PingPong 复制到其他目录下,还能工作 ⚫ Copy only the necessary library files(如仅复制 Drivers\STM32WLxx_HAL_Driver 下使用到的驱动)WLEx_PingPong复制到其他目录下,还能工作 ⚫ Add necessary library files as reference in the toolchain project configuration file(不生成 Drivers 和Middlewares 目录,仅参考Drivers\STM32WLxx_HAL_Driver 下的所有驱动) WLEx_PingPong 复制到其他目录下,不能工作 * J1 V8 N% |/ E3 @) |参考 UM1718 4.9 Project Manager view ![]() ![]() ![]() . r2 D: B7 s2 \" ` 3. 配置外设 2.1 使能外设 2.1.1 Middleware=>SUBGHZ_PHY 使能 ![]() 2.1.2 Timers=>RTC 使能 Timers=>RTC=>勾选 Activate Clock Source ![]() 2.2 RTC ![]() Clock Configuration => RTC Clock Mux=>LSE 在 Clock Configuration 中检查 RTC Clock Mux 是否配置为 LSE ![]() Timer =>RTC=>Users Constants ![]() ![]() ![]() Timer =>RTC=>Parameter Settings ![]() Timer =>RTC=>NVIC Settings ![]() Middleware => LORAWAN => Platform Settings => Timer Server => RTC ![]() 2.3 DebugLine 2.3.1Middleware => SUBGHZ_PHY => SubGHz_Phy middleware => radio_board_if =>Actovate Debug Line ![]() - @2 k# }& |- S: X" L 2.3.2. Platform Settings => VCOM => USART2 ![]() 4.3.3. Clock Configuration => UART2 Clock Mux => SYSCLK ![]() Platform Settings => VCOM => LPUART1 ![]() & l9 @5 q: x1 m: J7 O 2.4 System Core => GPIO (RF SW CTRL / BUTTON / LED) ( L" b( T1 p) U) I2.4.1 RF_CTRL System Core => GPIO => PA8 (customizable) ![]() ![]() ![]() Platform Settings => Radio => RF SW CTRL ![]() 2.4.2 LED g' l. g# \3 s# a' q4 {' F0 | System Core => GPIO => PB2 (customizable) ![]() Platform Settings => Board resources => LED ![]() 3 STM32WL Templates Patches for CubeMX7 x' U. E, [' Q& O6 } 4 r+ _0 z' Q0 mSTM32WL Templates 在如下目录,如需要可自行定制自己的 Templates ![]() 针对不同的客户定制化的板子,硬件外设配置不一致,客户可根据需要定制化自己的外设配置。 从 NUCLEO-WL55JC(BGA73) 移植到STM32WLExCxUx(QFN48)定制化的板子上,射频开关(RF SW CTRL),按键(BUTTON), LED 的配置会不一样,可能导致编译错误,如想生成的代码不会产生编译错误,需要编辑一下 STM32WL的 template。 3.1 CubeMX template patches for stm32wl 请参考 ![]() 9 q5 ^1 g; m, a5 E9 n$ O% }& W 3.2 CubeMX Updates from v6.1.1 to v6.2.0 ![]() ![]() ![]() ' J4 [1 f& y% T1 J' z - h$ @6 d1 `0 b6 q/ R9 K3 I 4.验证 4.1 参考工程0 |# Z5 R- B& t2 o ![]() 4.2 编译并下载 用 IAR 打开STM32Cube_FW_WL_V1.0.0\Projects\NUCLEOWL55JC\Applications\LoRaWAN\WLEx_PingPong\EWARM\Project.eww 如果 IAR 之前已经打开了 WLEx_PingPong,在每次重新生成代码时都如有如下提示,选择“Yes to All” ![]() 按 F7 或选择 Project=>Make(F7)来编译工程,如果编译无错误,选择Project=>Download=>Download Active Application 下载WLEx_PingPong 应用 |
【2025·STM32峰会】GUI解决方案实训分享1-对LVGL咖啡机例程的牛刀小试以及问题排查
OpenBLT移植到STM32F405开发板
为什么要先开启STM32外设时钟?
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【经验分享】STM32实例-RTC实时时钟实验④-获取RTC时间函数与中断服务函数
STM32 以太网 MAC Loopback 的实现
刘氓兔的64位入门挑战【1】——MP257芯片下单和硬件准备
刘氓兔的64位入门挑战【0】——MP257选型
STM32功能安全设计包,助力产品功能安全认证
基于STM32启动过程startup_xxxx.s文件经验分享