使用CubeMX创建基于STM32WL的LoRa应用

描述

引言

本篇 LAT 介绍使用 CubeMX 创建基于 STM32WL 的 LoRa 应用。

STM32Cube_FW_WL_V1.0.0ProjectsNUCLEO-WL55JC 中的例程都是基于 STM32WL BGA73 的,CubeMX 无法直接创建基于 STM32WL QFN48 的例程。

同时介绍如何参考STM32Cube_FW_WL_V1.0.0ProjectsNUCLEOWL55JCApplicationsSubGHz_PhySubGHz_Phy_PingPong 创建一个 WLEx_PingPong 的例

子。

关于不同 MCU 间的移植可参考

UM1718 11.9 Switching to another MCU

UM1718 15 Tutorial 5: Exporting current project configuration to a compatible MCU

需要提前准备的环境:

IAR

 

1.配置 CubeMX

1.1 配置 CubeMX 并下载 CubeWL

 

可以使用 CubeMX 默认安装的仓库目录也可以自定义仓库目录,本例使用自定义的仓库目录C:UsersgongwSTM32CubeRepositoryCubeWL,如下Help=>Updater Settings=>Repository Forlder=>C:UsersgongwSTM32CubeRepositoryCubeWL=>OK

 

IAR

 

IAR

 

选择 Manage software installations 中的 Install or remove embedded software packages 下的

“INSTALL / REMOVE”

 

IAR

 

IAR

点Refresh 更新数据库

IAR

 

 

Fresh 结束后,点开 STM32WL 左侧的黑色三角,选中 STM32WL 下版本 1.0.0 的 STM32Cube

MCU Package for STM32WL Series,点 Install Now

 

IAR

 

点击 Close

 

 

1.2 CubeMX 新建项目

 

打开 STM32CubeMX,在 New Project 下有三中选择, 请根据需求选择 New Project 的方式!

IAR

 

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

 

IAR

 

IAR

 

IAR

 

选择 NUCLEO-WL55JC 对应的 STM32WL55JC

IAR

 

IAR

IAR

IAR

 

 

IAR

IAR

 

1.3 CubeMX 导入参考项目

 

IAR

 

IAR

IAR

IAR

 

IAR

IAR

 

此时再查看 File =>Import Project 选项,变为灰色,表示新项目已被配置,不能再 import 参考项目。

 

IAR

 

1.4 CubeMX 配置项目

 

1.4.1 CubeMX 配置 Project Manager

选择 Project Manager

1.4.1.1 配置 Project

选择右侧 Project 并配置如下:

IAR

注意:

通过 Browse 选择 Project 保存的目录

项目名称 WLEx_AT_Slave 创建在STM32Cube_FW_WL_V1.0.0ProjectsNUCLEO-

WL55JCApplicationsLoRaWAN 下,和LoRaWAN_End_Node 同级目录,即

C:UsersgongwSTM32CubeRepositoryCubeWLSTM32Cube_FW_WL_V1.0.0ProjectsNUCLEO-WL55JCApplicationsLoRaWANWLEx_PingPong,以 便于与 LoRaWAN_End_Node 进行比较

 

配置 Application Structure 为 Advanced 与 basic 有什么区别?

Application Structure 为 Advanced 时目录结构分类分级目录更清晰。

Application Structure 为 Basic 时,所有的*.h 都在 WLEx_PingPongInc 目录下,所有的*.c 在

WLEx_PingPongSrc 目录下。

 

一旦生成过一次代码后目录结构就无法更改了!!!

IAR

选择右侧 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”

IAR

IAR

注意:

Copy all used library Package (如复制 DriversSTM32WLxx_HAL_Driver 下的所有驱动)

WLEx_PingPong 复制到其他目录下,还能工作

 

Copy only the necessary library files(如仅复制 DriversSTM32WLxx_HAL_Driver 下使用到的驱动)WLEx_PingPong复制到其他目录下,还能工作

 

Add necessary library files as reference in the toolchain project configuration file(不生成 Drivers 和Middlewares 目录,仅参考DriversSTM32WLxx_HAL_Driver 下的所有驱动)

WLEx_PingPong 复制到其他目录下,不能工作

 

参考 UM1718 4.9 Project Manager view

IAR

IAR

IAR

 

3. 配置外设

2.1 使能外设

 

2.1.1 Middleware=>SUBGHZ_PHY 使能

IAR

2.1.2 Timers=>RTC 使能

Timers=>RTC=>勾选 Activate Clock Source

IAR

2.2 RTC

IAR

Clock Configuration => RTC Clock Mux=>LSE

在 Clock Configuration 中检查 RTC Clock Mux 是否配置为 LSE

IAR

Timer =>RTC=>Users Constants

IAR

IAR

IAR

Timer =>RTC=>Parameter Settings

IAR

Timer =>RTC=>NVIC Settings

IAR

Middleware => LORAWAN => Platform Settings => Timer Server => RTC

IAR

 

2.3 DebugLine

2.3.1 Middleware => SUBGHZ_PHY => SubGHz_Phy middleware => 

radio_board_if =>Actovate Debug Line

 

IAR

 

2.3.2. Platform Settings => VCOM => USART2

IAR

4.3.3. Clock Configuration => UART2 Clock Mux => SYSCLK

IAR

Platform Settings => VCOM => LPUART1

IAR

 

2.4 System Core => GPIO (RF SW CTRL / BUTTON / LED)

 

2.4.1 RF_CTRL

System Core => GPIO => PA8 (customizable)

IAR

IAR

IAR

Platform Settings => Radio => RF SW CTRL

IAR

 

2.4.2 LED

System Core => GPIO => PB2 (customizable)

IAR

Platform Settings => Board resources => LED

IAR

 

3 STM32WL Templates Patches for CubeMX

 

STM32WL Templates 在如下目录,如需要可自行定制自己的 Templates

IAR

针对不同的客户定制化的板子,硬件外设配置不一致,客户可根据需要定制化自己的外设配置。

从 NUCLEO-WL55JC(BGA73) 移植到STM32WLExCxUx(QFN48)定制化的板子上,射频开关(RF SW CTRL),按键(BUTTON), LED 的配置会不一样,可能导致编译错误,如想生成的代码不会产生编译错误,需要编辑一下 STM32WL的 template。

 

3.1 CubeMX template patches for stm32wl

请参考

IAR

 

3.2 CubeMX Updates from v6.1.1 to v6.2.0

IAR

IAR

IAR

 

 

4.验证

4.1 参考工程

IAR

4.2 编译并下载

 

用 IAR 打开STM32Cube_FW_WL_V1.0.0ProjectsNUCLEOWL55JCApplicationsLoRaWANWLEx_PingPongEWARMProject.eww

 

如果 IAR 之前已经打开了 WLEx_PingPong,在每次重新生成代码时都如有如下提示,选择“Yes to All”

IAR

按 F7 或选择 Project=>Make(F7)来编译工程,如果编译无错误,选择Project=>Download=>Download Active Application 下载WLEx_PingPong 应用

  审核编辑:汤梓红


打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分