吐槽:我两个问题:TX与RX接反;GND没有共地
一、硬件连接与状态排查
-
TX/RX 交叉与共地
- 确保 ESP32 的 LoRa 模块
TX接 STM32 的 LoRa 模块RX,ESP32 的RX接 STM32 的TX,且两者GND 引脚必须共地(否则存在电势差,通信会完全中断)。 - 用万用表或逻辑分析仪检测引脚电平,确认数据是否真的从 ESP32 发出(例如 ESP32 的 TX 引脚在发送时应有高低电平跳变)。
- 确保 ESP32 的 LoRa 模块
-
电源与天线
- 检查 LoRa 模块供电是否稳定(通常需 3.3V 或 5V,电压波动会导致模块工作异常),可并联 100μF+0.1μF 电容滤波。
- 确认天线与 LoRa 模块频段匹配(如 433MHz/868MHz/915MHz),且天线未脱落、无物理损坏。
二、软件配置一致性验证
-
串口参数完全对齐
- 波特率、数据位、停止位、校验位必须两端一致。例如 ESP32 配置为
115200 8N1,STM32 也需严格相同。 - 检查代码中串口初始化逻辑:
- ESP32 端:确认
lora_uart_init和uart_config的波特率参数是否与 STM32 匹配。 - STM32 端:若使用 HAL 库,需确保
huart结构体的BaudRate、WordLength等参数与 ESP32 一致,且启用了接收中断(如HAL_UART_Receive_IT)或 DMA。
- ESP32 端:确认
- 波特率、数据位、停止位、校验位必须两端一致。例如 ESP32 配置为
-
LoRa 工作模式与参数匹配
- 地址与网络 ID :ESP32 配置的
LORA_HOST_ADD、LORA_HOST_NETID需与 STM32 端的 LoRa 模块完全相同(包括高位、低位的字节顺序)。 - 信道(CH) :
LORA_HOST_CH需两端一致,否则信号会因频段不匹配而丢失。 - 工作模式 :ESP32 初始化后处于传输模式(M0=0, M1=0),STM32 端的 LoRa 模块也需处于相同模式,否则收发逻辑会冲突。
- 地址与网络 ID :ESP32 配置的
三、数据帧与逻辑流程排查
-
数据帧格式验证
- 检查 ESP32 发送的帧(如
ff ff d ff fe aa a5 af 16 16 ff fd)是否符合 STM32 的解析逻辑:- 帧头、地址段、指令段需与 STM32 的接收协议匹配(例如 STM32 是否在等待特定帧头
0xFF 0xFF)。 - 若 STM32 需应答,需在代码中编写应答帧的构造与发送逻辑(如收到 ESP32 的查询帧后,返回包含自身信息的应答帧)。
- 帧头、地址段、指令段需与 STM32 的接收协议匹配(例如 STM32 是否在等待特定帧头
- 检查 ESP32 发送的帧(如
-
调试与日志输出
- 在 STM32 端添加串口打印,输出接收缓冲区的数据,确认是否收到了 ESP32 的发送帧(即使是乱码,也能验证物理层是否通)。
- 若 STM32 无任何数据接收,可将 ESP32 的 LoRa 模块 TX 直接连到 STM32 的串口助手 RX(跳过 LoRa 无线层),测试纯串口通信是否正常,以区分是 LoRa 模块问题还是串口逻辑问题。
四、环境与干扰排查
- 物理干扰:LoRa 信号易受金属遮挡、同频设备(如其他 LoRa 模块、WiFi 设备)干扰,可尝试缩短设备间距、移除障碍物后再测试。
- 模块固件与硬件故障 :
- 单独测试 LoRa 模块:将 ESP32 或 STM32 的 LoRa 模块连接到 PC 串口助手,发送 AT 指令(如
AT+VER?查询版本),确认模块本身是否正常。 - 若模块无响应,可能是硬件损坏或固件异常,需更换模块或升级固件。
- 单独测试 LoRa 模块:将 ESP32 或 STM32 的 LoRa 模块连接到 PC 串口助手,发送 AT 指令(如