调试目标:验证 STM32L431 的 USART3 串口通信功能,能够通过电脑的串口助手收发数据。
硬件环境:
-
主控芯片:STM32L431RCT6
-
调试器:立创 DAPLink (CMSIS-DAP)
-
串口连接:USART3 (PC4-TX, PC5-RX)
软件环境:
-
STM32CubeMX
-
Keil MDK (V5)
-
串口助手软件
📝 调试过程回顾
| 步骤 | 操作 | 结果 |
|---|---|---|
| 1 | 在 CubeMX 中配置 USART1 (PA9, PA10),生成代码并测试 | ❌ 失败,无法收到数据 |
| 2 | 用 GPIO 点灯法测试 PA9 引脚硬件,确认引脚本身正常 | ✅ PC4 引脚有电压跳变,硬件正常 |
| 3 | 意识到实际使用的是 USART3 (PC4, PC5),重新配置 | --- |
| 4 | 在 CubeMX 中为 PC4、PC5 配置 USART3 模式,重新生成代码 | ✅ |
| 5 | 编写简单的发送测试代码 (HAL_UART_Transmit 发送 U) |
✅ 串口助手成功收到 U |
| 6 | 编写回环测试代码 (Receive → Transmit) | ✅ 能收到发送的数据 |
✅ 最终验证成功的代码
发送测试:
c
while (1)
{
uint8_t data = 'U';
HAL_UART_Transmit(&huart3, &data, 1, 100);
HAL_Delay(1000);
}
回环测试:
c
uint8_t rx_data;
while (1)
{
if (HAL_UART_Receive(&huart3, &rx_data, 1, 100) == HAL_OK)
{
HAL_UART_Transmit(&huart3, &rx_data, 1, 100);
}
}
🧠 核心问题与经验
-
引脚与外设不对应是主要障碍:手册上 24 号引脚是 PA9 (USART1_TX),但实际项目用的是 PC4/PC5 (USART3),两者混淆导致很长一段时间都在错误的链路上排查。
-
"点灯法"(GPIO 电平翻转 + 万用表测电压)是最直接的硬件验证手段:能快速确认引脚本身和链路是否正常,不依赖外设配置。
-
CubeMX 配置需要仔细核对:重新配置一次 USART3 后,链路才真正打通。前期的混淆耽误了不少时间。
-
DAPLink 的虚拟串口功能可靠:通过 RXD/TXD 交叉连接可以实现串口收发,适用于调试和数据上报。
-
调试节奏问题:前期在错误的引脚和外设上纠缠太久;换到正确的 USART3 后很快就调通了。
📌 后续建议
-
建立"引脚-外设"清单:建议在项目初期就明确记录所用外设和对应的物理引脚,避免后续混淆。
c
/* 串口引脚定义 */ // USART3_TX -> PC4 // USART3_RX -> PC5 -
用宏定义封装引脚:提高代码可读性,也方便后期修改。
-
保持"最小测试原则":调新外设时先跑最简单的验证代码,确认通路后再集成到复杂工程中。
-
善用调试工具:DAPLink 的虚拟串口、逻辑分析仪、万用表都是排查问题的好帮手。
🎉 总结
经过了反复的配置调整和排查,最终确认了使用的串口是 PC4 (USART3_TX) 和 PC5 (USART3_RX),并成功实现了 STM32L431 与 PC 之间的串口通信。验证了 USART3 的硬件链路和 HAL 库配置是正确的,为后续发送传感器数据(如霍尔传感器状态、DHT11 温湿度等)提供了可靠的基础。