嵌入式 | 串口调试可能遇到的问题记录及解决方案

前言

在嵌入式开发的过程中,通过串口连接方式对开发板进行调试是不可或缺的一环。然而,使用串口调试时可能也会遇到这样那样的问题。笔者近日参加了一场培训,其中就罗列了一些常见问题及解决方案,笔者觉得很有参考意义。特此记录并整理,为日后的工作积累经验。

注:下述的排查思路及解决方案是按先后顺序逐层深入的。

串口打印故障

上位机串口助手不显示任何打印信息

排查思路1:检查上位机及对应连接

有可能是对设备的物理连接出现错误。检查以下三点:

  • 串口工具是否已与上位机连接
  • 串口助手相关配置信息是否有误
  • TX、RX信号线连接是否正确

排查思路2:检查串口调试工具与上位机的连接是否正常

具体检查方法:将USB转TTL串口工具的TX和RX短接

排查思路3:测试串口输出是否正常

具体检查方法:测量CPU的串口TX是否有输出

排查思路4:检查启动介质和启动段位信息是否有误

正确的参数应为:

  • 启动介质:001:QSPI
  • 启动段位:00:Default(RECOVER0)

排查思路5:查看CPU有没有正常的读取操作

具体检查方法:查看QSPI的时钟信号

QSPI读固件前的时钟频率波形应为1.57M左右;读取后,根据配置频率不同,会在3.7MHz到37.5MHz间浮动。

若QSPI CLK无输出,说明CPU没有正常工作。

排查思路678针对CPU没有正常工作的情况:

排查思路6:检查系统时钟信号

检查系统时钟的信号波形,正常频率为50MHZ。

排查思路7:检查CPU复位信号信号

具体检查方法:

  • 检查信号CPU_PRO_N是否处于拉低状态

排查思路8:检查上电时序是否有误

不同板子的上电时序不同,详情参考对应的手册。

若前面测得CPU有正常工作,则按下面的步骤继续找原因

排查思路9:检查接口的IO0和IO1信号

  • IO0为CPU发出的读取指令
  • IO1为FLASH发出的反馈信号

若没有收到反馈信号,排查以下原因:

  • flash引脚位置是否有误
  • flash硬件是否有故障

排查思路10:检查FLASH读指令信号质量

典型例子如:03H信号

前述是针对没有任何打印信息的情况,而接下来则是串口助手输出了打印信息,但却是异常信息。

串口打印信息异常

输出卡在pwr on qspi set

解决方案:通过更换固件,降低QSPI的速率

输出卡在peu0 clk _status1 0x0,target clk_status 0x3f

解决方案:通过测量PCle时钟,查看时钟波形

输出卡在entry bl2 form bl1

解决方案:是由于内存不稳定导致的,可测量相关电源,检查内存线路和配置参数是否合理

输出卡在Bad S3 recover status

解决方案:查开发板手册,检查GPIO状态

输出信息显示Training fail

解决方案:检查内存线路和配置参数是否合理

结语

文中只是列出了串口调试遇到的问题中的常见情况,仅仅是为排查故障提供了一些基本思路,在实际的开发调试中,所面对的情况肯定远比上述提到的要复杂。然而,学会基于已有理论知识和经验解决未知问题也是一种很重要的能力,与读者共勉!

相关推荐
lularible1 小时前
从沙子到车辙(4.5):时间同步与PTP
开源·嵌入式·汽车电子
求知喻4 小时前
KEIL5进行MSPM0开发
嵌入式
lularible4 小时前
从沙子到车辙(4.3):板级通信——CAN / CAN-FD
开源·嵌入式·汽车电子
程序员打怪兽5 小时前
嵌入式C语言
嵌入式
凉、介6 小时前
深入理解 ARMv8-A|异常/中断处理
笔记·学习·嵌入式·arm
济6177 小时前
ROS开发专栏---基于 NAV2 实现仿真环境自主导航实验--适配Ubuntu 22.04
嵌入式硬件·嵌入式·ros2·机器人方向
济6177 小时前
ROS开发专栏---基于开源导航插件 wp_map_tools 多航点巡航导航实验--适配Ubuntu 22.04
ubuntu·嵌入式·ros2·机器人开发·机器人方向
加成BUFF1 天前
机器人专业2025年12月5日《嵌入式系统STM32》期末考试范围+试卷
stm32·嵌入式·期末复习
不脱发的程序猿1 天前
如何让Skill同时跑在Cursor、Codex和Claude Code里?
单片机·嵌入式硬件·嵌入式
底层开发智库1 天前
C1-Ultra FVP调试并运行Linux kernel全程记录,硬核演示如何解决启动问题
linux·arm开发·内核·嵌入式·arm