ESP32S3 开发说明
本章节包含以下部分,请按需阅读:
配置开发环境
1. 安装和配置
- 关于 ESP32S3 的环境搭建跟基本使用,请参考以下链接:
- 环境搭建完成后,即可连接 LoRa 模块,下载示例程序
硬件连接
参考下表进行连接
| Core2021-XF | ESP32S3 |
|---|---|
| CLK | 40 |
| MISO | 46 |
| MOSI | 45 |
| CS | 42 |
| IRQ | 38 |
| RESET | 39 |
| BUSY | 41 |
示例程序
- ESP32S3 示例程序位于 示例程序包 的
core2021-xf\examples\esp32s3目录中。 - 示例 01,02,03 都需要两个 Core2021-XF 模块,一个发送,一个接收。
| 示例程序 | 基础例程说明 | 依赖库 |
|---|---|---|
| 01_lr2021_tx | LR2021 发送 | RadioLib |
| 02_lr2021_rx | LR2021 接收 | RadioLib |
| 03_lr2021_pingpong | LR2021 PingPong | RadioLib |
| 04_lr2021_tx_cw | LR2021 以 CW 模式发送 | RadioLib |
| 05_lr2021_LoRaWAN | LoRaWAN | RadioLib |
运行 Arduino esp32 程序
- 进入到
core2021-xf\examples\esp32s3\arduino,选择需要测试的示例程序 - 选择开发板:

- 选择 ESP32S3 的端口,然后进行编译上传
- 上传完成后,打开串口监测器,就会输出相关的信息。
01_lr2021_tx
【程序说明】
- 基于 ESP32S3 + Core2021-XF 模块,使用 中断方式 实现 LoRa 数据包周期性发送
- 自定义 SPI 引脚(CLK/MOSI/MISO),适配 ESP32S3 硬件设计
- 采用非阻塞发送机制,不占用主循环 CPU 资源
- 每发送完成一包数据,自动延时 1 秒后继续发送下一包
- 支持字符串数据发送,自带数据包序号,方便调试
【代码分析】
SPI.begin(...):ESP32S3 硬件 SPI 引脚初始化,自定义 CLK/MOSI/MISOradio.irqDioNum = 11:配置 LR2021 模块中断映射引脚,必须在初始化前设置radio.XTAL = true:开启外部晶振,保证频率精度setFlag(void):中断回调函数,模块发送完成后自动触发,标记发送完成标志radio.setPacketSentAction(setFlag):绑定发送完成中断函数radio.startTransmit("内容"):启动 LoRa 异步发送,支持字符串 / 字节数组radio.finishTransmit():发送完成后收尾操作,关闭发射电路、复位模块状态loop()主逻辑:检测发送完成标志 → 打印状态 → 延时 → 发送下一包带序号的数据
【运行效果】
-
程序编译下载完成,打开串口监控可以看到打印发送完成的日志,如下图所示(搭配02_lr2021_rx):

02_lr2021_rx
【程序说明】
- 基于 ESP32S3 + Core2021-XF 模块,使用中断方式实现 LoRa 数据包无线接收
- 自定义硬件 SPI 引脚,适配 ESP32S3 专用硬件设计
- 采用非阻塞监听模式,模块自动等待数据,不占用 CPU 资源
- 接收成功后自动解析数据,并打印数据包内容、RSSI 信号强度、SNR 信噪比
- 必须与发送端配置相同频率、扩频因子、带宽、编码率才能正常通信
【代码分析】
SPI.begin(...):ESP32S3 硬件 SPI 初始化,自定义 CLK/MOSI/MISO 引脚radio.irqDioNum = 11:配置 LR2021 模块中断映射引脚,必须在初始化前设置radio.XTAL = true:开启外部晶振,保证频率精度,提升接收稳定性setFlag(void):中断回调函数,模块接收到完整数据包后自动触发radio.setPacketReceivedAction(setFlag):绑定接收完成中断服务函数radio.startReceive():启动 LoRa 连续接收模式,进入等待数据状态radio.readData(str):读取接收到的无线数据,支持字符串格式解析radio.getRSSI()/radio.getSNR():获取信号质量参数,用于调试与链路评估loop()主逻辑:检测接收完成标志 → 读取数据 → 解析打印 → 继续监听
【运行效果】
-
程序编译下载完成,打开串口监控可以看到实时接收日志,包含数据内容、RSSI、SNR 信息,如下图所示(搭配01_lr2021_tx):

03_lr2021_pingpong
【程序说明】
- 基于 ESP32S3 + Core2021-XF 模块,实现 LoRa 自动乒乓收发(一问一答)双向通信
- 自定义硬件 SPI 引脚,适配 ESP32S3 专用硬件设计
- 两块模块即可完成互发互收,无需手动控制
- 开启
INITIATING_NODE为发起端,另一块为接收端 - 自动切换发送 / 接收状态,非阻塞中断驱动
【代码分析】
SPI.begin(...):ESP32S3 硬件 SPI 初始化,自定义 CLK/MOSI/MISO 引脚radio.irqDioNum = 11:配置 LR2021 中断映射引脚,必须在初始化前设置radio.XTAL = true:开启外部晶振,保证通信频率精度setFlag(void):通用中断回调,发送完成或接收完成都会触发radio.setIrqAction(setFlag):绑定收发共用中断函数INITIATING_NODE宏定义:用于区分主动发起节点radio.startTransmit():启动数据包发送radio.startReceive():切换模块到监听接收状态radio.readData(str):读取接收到的 LoRa 数据包loop()主逻辑:发送完成 → 进入接收;接收完成 → 延时回复 → 再次发送
【运行效果】
- 两块模块分别烧录程序,一块打开
INITIATING_NODE宏定义 - 上电后自动互发互收,串口打印收发状态、数据、RSSI、SNR,如下图所示:

04_lr2021_tx_cw
【程序说明】
- 基于 ESP32S3 + Core2021-XF 模块,实现 LoRa 直接载波发射(CW/Direct Transmit)
- 自定义 SPI 引脚,适配 ESP32S3 硬件设计
- 输出固定频率的连续载波信号,无数据包格式,用于频段测试、信号检测、仪器校准
- 固定频率 868MHz,发射功率 22dBm
- 上电后持续发射,无额外逻辑操作
【代码分析】
SPI.begin(...):ESP32S3 硬件 SPI 初始化,自定义 CLK/MOSI/MISO 引脚radio.XTAL = true:开启外部晶振,保证载波频率精度OUT_HZ 868000000UL:定义直接发射频率(868MHz),可自行修改radio.setOutputPower(22):配置发射功率为 22dBmradio.transmitDirect(OUT_HZ):进入连续直接发射模式,输出固定频率载波loop():无业务逻辑,载波持续发射无需程序干预
【运行效果】
-
程序烧录后模块立即输出固定频率载波信号
-
串口打印初始化与发射启动状态,可使用频谱仪/接收模块检测到连续射频信号,如下图所示:

05_lr2021_LoRaWAN
【程序说明】
- 基于 ESP32S3 + Core2021-XF 模块,实现 LoRaWAN OTAA 入网 + 上下行通信
- 自定义 SPI 引脚,适配 ESP32S3 专用硬件设计
- 使用 NVS 闪存存储会话信息,掉电重启可快速恢复连接,无需重新入网
- 定时上传随机数据(默认 5 分钟),自动接收服务器下行指令
- 支持 HEX/ASCII 格式打印下行数据,便于调试与链路验证
【代码分析】
SPI.begin(...):ESP32S3 硬件 SPI 初始化,自定义 CLK/MOSI/MISO 引脚radio.irqDioNum = 11:配置 LR2021 中断映射,必须在初始化前设置radio.XTAL = true:开启外部晶振,保证 LoRaWAN 频点精度prefs.begin(...):初始化 ESP32 NVS 分区,用于保存 LoRaWAN 会话restoreLoRaWANState():从 NVS 恢复会话信息,实现快速重连node.beginOTAA()/node.activateOTAA():OTAA 入网相关函数saveLoRaWANState():成功入网后保存会话信息到 NVSnode.sendReceive():发送上行数据,并自动监听服务器下行printHex / printAscii:格式化打印接收数据
【运行效果】
-
烧录后自动完成 OTAA 接入,周期性上报数据并监听下行
-
串口实时打印入网状态、上下行消息、信号质量等信息,如下图所示:

运行 ESP-IDF 程序
01_lr2021_tx
【程序说明】
- 基于 ESP-IDF 原生框架 + ESP32S3 + Core2021-XF 模块,使用中断方式实现 LoRa 数据包周期性发送
- 内置专用硬件抽象层
EspHal.h,完美适配 ESP-IDF 环境 - 自定义 SPI 引脚配置,支持硬件 SPI2 总线
- 采用中断驱动非阻塞发送,每 1 秒自动发送一包带序号的测试数据
- 日志使用 ESP-IDF 原生
ESP_LOG输出,稳定可靠
【核心文件】
EspHal.h:ESP-IDF 硬件抽象层,提供 GPIO、SPI、延时、中断等底层实现(所有例程通用)main.cpp:LoRa 发送主程序
【代码分析】
EspHal* hal = new EspHal(...):ESP-IDF 硬件抽象层初始化radio.irqDioNum = 11:配置 LR2021 模块中断映射引脚radio.XTAL = true:开启外部晶振,保证频率精度setFlag(void):发送完成中断回调函数radio.setPacketSentAction(setFlag):绑定发送完成中断radio.startTransmit(...):启动异步 LoRa 发送radio.finishTransmit():发送完成后关闭射频电路,确保低功耗稳定
【运行效果】
- 编译烧录后,串口实时打印发送状态与数据包序号
- 可搭配02_lr2021_rx完成 ESP-IDF 环境 LoRa 单向无线通信

02_lr2021_rx
【程序说明】
- 基于 ESP-IDF 原生框架 + ESP32S3 + Core2021-XF 模块,使用中断方式实现 LoRa 数据包无线接收
- 依赖通用硬件抽象层
EspHal.h,完美适配 ESP-IDF 环境 - 自定义 SPI 引脚配置,支持硬件 SPI2 总线
- 中断驱动非阻塞监听,实时接收数据
- 接收后自动打印:长度、RSSI、SNR、HEX 格式、字符串格式
【核心文件】
EspHal.h:底层硬件抽象(所有例程通用)main.cpp:LoRa 接收主程序
【代码分析】
EspHal* hal:ESP-IDF 硬件抽象初始化(GPIO/SPI/中断)radio.irqDioNum = 11:配置 LR2021 中断映射radio.XTAL = true:开启外部晶振,保证接收频率精度setFlag(void):接收完成中断回调radio.setPacketReceivedAction(setFlag):绑定接收完成中断radio.startReceive():启动 LoRa 连续监听radio.readData():读取数据包并解析- 自动重新开启监听,实现不间断接收
【运行效果】
- 烧录后模块进入监听状态,收到数据实时打印
- 可与 01_lr2021_tx 配对完成完整无线通信

03_lr2021_pingpong
【程序说明】
- 基于 ESP-IDF 原生框架 + ESP32S3 + Core2021-XF 模块,实现 LoRa 自动乒乓双向收发(一问一答)
- 依赖通用硬件抽象层
EspHal.h,完美适配 ESP-IDF 环境 - 自定义 SPI 引脚配置,支持硬件 SPI2 总线
- 采用中断驱动非阻塞机制,自动切换发送/接收工作状态
- 支持通过宏定义区分主动发起节点与被动监听节点,上电自动互发互收
- 收到数据包后自动打印负载内容、RSSI 信号强度、SNR 信噪比,方便链路调试
【核心文件】
EspHal.h:底层硬件抽象(所有 ESP-IDF 例程通用)main.cpp:LoRa 乒乓双向收发应用程序
【代码分析】
EspHal* hal:ESP-IDF 硬件抽象层实例初始化,封装 SPI、GPIO、延时与中断radio.irqDioNum = 11:配置 LR2021 模块中断映射引脚radio.XTAL = true:启用外部晶振,保障 LoRa 频点精度setFlag(void):收发事件共用中断回调函数radio.setIrqAction(setFlag):绑定模块中断触发回调INITIATING_NODE:宏开关,定义设备为主动发包节点radio.startTransmit()/radio.startReceive():程序自动切换发送与监听模式radio.readData():解析接收数据包并打印文本、信号参数- 逻辑闭环:发完切接收、收完延时自动回复,持续循环乒乓通信
【运行效果】
- 两台 ESP32 烧录程序后自动建立双向 LoRa 链路,循环互发数据
- 串口终端实时打印初始化状态、收发结果、RSSI、SNR 信息

04_lr2021_tx_cw
【程序说明】
- 基于 ESP-IDF 原生框架 + ESP32S3 + Core2021-XF 模块,实现 LoRa 固定频率连续载波发射
- 依赖通用硬件抽象层
EspHal.h,完美适配 ESP-IDF 环境 - 自定义 SPI 引脚配置,支持硬件 SPI2 总线
- 输出纯净、无数据包的连续射频信号,适用于仪器校准、频段测试、信号强度检测
- 发射频率:868MHz,发射功率:22dBm,上电后持续发射不中断
【核心文件】
EspHal.h:底层硬件抽象(所有 ESP-IDF 例程通用)04_lr2021_direct_transmit.c:LoRa 载波发射主程序
【代码分析】
EspHal* hal:ESP-IDF 硬件抽象初始化(SPI、GPIO、延时、中断)radio.irqDioNum = 11:配置 LR2021 中断映射引脚radio.XTAL = true:开启外部晶振,保证载波频率精度OUT_HZ 868000000UL:定义连续发射频率(868MHz)radio.setOutputPower(22):设置发射功率为 22dBmradio.transmitDirect(OUT_HZ):进入直接载波发射模式,启动持续发射
【运行效果】
- 程序烧录后模块立即输出稳定的连续射频信号
- 可使用频谱仪或接收设备检测到稳定载波,用于频段测试与校准

05_lr2021_LoRaWAN
【程序说明】
- 基于 ESP-IDF 原生框架 + ESP32S3 + Core2021-XF 模块,实现 LoRaWAN OTAA 入网 + 周期性上报 + 下行接收
- 依赖通用硬件抽象层
EspHal.h,纯 ESP-IDF 环境独立运行 - 使用 NVS 闪存持久化保存会话信息,掉电重启可快速恢复,无需重复入网
- 自动上报随机测试数据,支持服务器下行数据解析与打印
- 完整日志输出:入网状态、信号质量、上下行数据、会话保存记录
【核心文件】
EspHal.h:底层硬件抽象(所有 ESP-IDF 例程通用)05_lr2021_lorawan_otaa.c:LoRaWAN OTAA 通信主程序
【代码分析】
EspHal* hal:ESP-IDF 硬件抽象初始化(SPI、GPIO、延时、中断)radio.irqDioNum = 11:配置 LR2021 中断映射引脚radio.XTAL = true:开启外部晶振,保证 LoRa 频点精度nvs_flash_init():启用 NVS 存储,用于保存 LoRaWAN 会话restoreLoRaWANState():从闪存恢复会话,支持快速重连node.beginOTAA()/node.activateOTAA():OTAA 入网关键函数node.sendReceive():发送上行数据并监听服务器下行printHex / printAscii:格式化打印下行数据
【运行效果】
- 程序运行后自动完成 OTAA 入网,周期性上报数据并接收服务器下行
- 串口终端实时打印入网状态、上传记录、信号质量、下行内容
