STM32WLE5之LoRa# 系列2:易智联LM401 评估板PingPong例程移植
前言
记录基于STM32CubeMX构建STM32WLE5模块的PingPong收发例程的过程。硬件平台为易智联蓝色的LM401 LoraWan评估板,对应的MCU型号为STM32WLE5CBU6。PingPong例程具有完整的数据收发过程,并且配置了ST的基本任务调度、软定时、队列和日志输出,是我们开发Lora私有协议的基础工程。
一、开发环境
STM32CubeIDE 是 ST 公司基于 Eclipse/CDT 框架和 GUN GCC 工具链制作的免费 IDE,并集成了STM32CubeMX。 可以实现 STM32 系列芯片的外围设备配置、代码生成、代码编辑、代码编译、在线调试,并且支持数百个 Eclipse 现有插件。
1、STM32CubeMX与STM32CubeIDE软件安装
官网下载stm32cubemx、stm32cubeide stm32cubemx:https://www.st.com/en/development-tools/stm32cubemx.html stm32cubeide:https://www.st.com/en/development-tools/stm32cubeide.html 基本上一路确定即可。 虽然STM32CubeIDE集成了STM32CubeMX,不如单独的灵活STM32CubeMX。单独安装STM32CubeMX一方面方便导入应用例程,另一方面方便生成MDK、IAR的工程。
2、下载STM32WL固件库
运行STM32CubeMX,HELP–>Manage embedded software packages如下图所示 data:image/s3,"s3://crabby-images/05167/0516737d73eb09968c4bf905ccaa1ba56bc52bae" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/cb9f5/cb9f5b6f189e51d932ac82e1bca443fd1c7b4b18" alt="在这里插入图片描述" 等待下载安装完成,默认的安装位置为C:\Users\用户\STM32Cube\Repository\STM32Cube_FW_WL_V1.1.0
二、硬件平台
LM401-LoraWAN 评估板板载基于STM32WLE5CB的LM401模块。提供了基本的硬件电路,并提供了板载USB转COM以及LDO。USB连接电脑既可以实现供电、打印输出、输入操作。 data:image/s3,"s3://crabby-images/3d8f7/3d8f79346af37425c0f6c2cac4fe0b21f0feb9bc" alt="在这里插入图片描述" PingPong例程中Log输出端口为板载的USB转串口PA2、PA3,软件配置成UART2 波特率115200-8-N-1。
三、 PingPong例程的简介
1、PingPong例程位置
\STM32Cube\Repository\STM32Cube_FW_WL_V1.1.0\Projects\NUCLEO-WL55JC\Applications\SubGHz_Phy\SubGHz_Phy_PingPong 目录如下: data:image/s3,"s3://crabby-images/6d2e0/6d2e0308227203f3f0d80d455bb602bc8ac94ab8" alt="在这里插入图片描述"
2、PingPong例程功能
PingPong例程是两个评估板之间的一个简单收发例程。默认情况下,评估板作为主设备发送一个“Ping”消息然后等待回复。第一个收到“Ping”消息的评估板将自己设置成从设备,并回复“Pong”消息。当主设备收到“Pong”消息之后继续发送“Ping”消息。这样就建立了一个持续的PingPong收发对。 这个例程能够使我们快速的了解STM32WLE5的收发过程,方便LoRa私有协议的开发。
3、附加功能
在移植PingPong例程过程中,STM32CubeMX配置时我们增加一路ADC的采集,以便后续做采集上报例程。
四、 PingPong例程的移植
1、创建STM32CubeMX工程;
a、打开STM32CubeMX工具; b、新建工程Start My Project From MCU; data:image/s3,"s3://crabby-images/a7b07/a7b07953d86b75fb97bcc45c84c2f0bad68a5dc3" alt="在这里插入图片描述" c、选择STM32WL系列,选择STM32WLE5CB双击 data:image/s3,"s3://crabby-images/6c783/6c7838f1a58b3b78fb8016f10104d91338580216" alt="在这里插入图片描述" d、File菜单–>Import Project导入PingPong例程并点击OK,用户名为自己实际目录 C:\Users\用户\STM32Cube\Repository\STM32Cube_FW_WL_V1.1.0\Projects\NUCLEO-WL55JC\Applications\SubGHz_Phy\SubGHz_Phy_PingPong\SubGHz_Phy_PingPong.ioc data:image/s3,"s3://crabby-images/9c498/9c498708455051c16a084ec7737e7eb4706d70e2" alt="在这里插入图片描述" 中间会有些错误,是因为原例程平台STM32WL55JC为BGA封装,有些引脚STM32WLE5CB没有。 e、配置时钟输入,HSE 32MHz晶体振荡器,LSE 32.768K晶体振荡器 data:image/s3,"s3://crabby-images/5f90d/5f90d057ee311a934673b2dfc2bd6291115e47e9" alt="在这里插入图片描述" f、RTC开启Alarm A,软件定时使用 data:image/s3,"s3://crabby-images/1e9aa/1e9aa1f46534f5896b221751ee53a8bbba47631a" alt="在这里插入图片描述" g、启RTC中断 data:image/s3,"s3://crabby-images/39057/390572a09bad324d59c664ab21298c55dd603326" alt="在这里插入图片描述" h、配置ADC data:image/s3,"s3://crabby-images/fab07/fab07d6d15dd6e19fb8945064ec4c421f1d08a50" alt="在这里插入图片描述" i、SUBGHZ_PHY按如下配置 data:image/s3,"s3://crabby-images/20304/203040db8849193cdcb1aff3d65178f698b7499d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b10c0/b10c0aec36a5e7bee07812341d84875c43e26a3f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/33c08/33c0840d67bf7f2297947e9a1a3412926b1c927a" alt="在这里插入图片描述"
k、时钟配置 RTC配置32.768Khz,HSE 32Mhz,MCU时钟48Mhz使用内部MSI RC时钟 data:image/s3,"s3://crabby-images/bf42a/bf42a5fc6193c085996e4b0237527262dba7b97c" alt="在这里插入图片描述"
2、生产STM32CubeIDE工程;
a、Project Manager配置 data:image/s3,"s3://crabby-images/eab52/eab5237f8193998d0b0d6efc82e0c8bd85ab5dfb" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/81ad6/81ad6e000a675dbd063ec82abafd2590425cca75" alt="在这里插入图片描述" b、执行GENERATE CODE生成工程
五、工程编译
1、工程配置
将BSP文件夹放入\PingPong_csdn\STM32CubeIDE\Drivers目录, 打开\PingPong_csdn\STM32CubeIDE目录,双击.project打开工程。 右击工程名称,选择Properties,将BSP目录加载到Inclue paths data:image/s3,"s3://crabby-images/bd0af/bd0af4e6930d8e3d765a3bd73707556df3248c6e" alt="在这里插入图片描述" 修改platform.h,将原来的
#if defined(USE_BSP_DRIVER)
#include "stm32wlxx_LM401.h"
#include "stm32wlxx_LM401_radio.h"
#endif
data:image/s3,"s3://crabby-images/e4102/e4102f46096fc855b9a186e59021883091d55d9f" alt="在这里插入图片描述"
2、工程编译
执行Build All。 data:image/s3,"s3://crabby-images/d1458/d1458a23b6f8ec16510d66f8df27802df6f491a6" alt="在这里插入图片描述" 编译成功,生成二进制代码 data:image/s3,"s3://crabby-images/6e64e/6e64ecdc184a6c4840720288c9c09a094c441a76" alt="在这里插入图片描述"
六、小结
至此PingPong例程的CubeMX工程和CubeIDE工程移植完成,打开app_subghz_phy.c如下所示,只有一个基本框架。后续需要完善没有定义的射频功能函数和PingPong例程的应用程序。
static RadioEvents_t RadioEvents;
static void OnTxDone(void);
static void OnRxDone(uint8_t *payload, uint16_t size, int16_t rssi, int8_t LoraSnr_FskCfo);
static void OnTxTimeout(void);
static void OnRxTimeout(void);
static void OnRxError(void);
void SubghzApp_Init(void)
{
RadioEvents.TxDone = OnTxDone;
RadioEvents.RxDone = OnRxDone;
RadioEvents.TxTimeout = OnTxTimeout;
RadioEvents.RxTimeout = OnRxTimeout;
RadioEvents.RxError = OnRxError;
Radio.Init(&RadioEvents);
}
static void OnTxDone(void)
{
}
static void OnRxDone(uint8_t *payload, uint16_t size, int16_t rssi, int8_t LoraSnr_FskCfo)
{
}
static void OnTxTimeout(void)
{
}
static void OnRxTimeout(void)
{
}
static void OnRxError(void)
{
}
|