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

前言

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

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

串口打印故障

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

排查思路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

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

结语

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

相关推荐
憧憬一下13 小时前
PCIe_Host驱动分析_设备枚举
arm开发·嵌入式硬件·嵌入式·pcie·linux驱动开发
憧憬一下3 天前
PCIe_Host驱动分析_地址映射
arm开发·嵌入式硬件·嵌入式·linux驱动开发·pci/pcie
aspirestro三水哥7 天前
Linux: 通过/proc/pid/stack查看程序卡在内核的什么地方
linux·运维·服务器·嵌入式
@启智森8 天前
【C语言】浮点数的原理、整型如何转换成浮点数
c语言·开发语言·嵌入式·float·int·浮点数
@启智森8 天前
【Uboot】Uboot启动流程分析
linux·c++·嵌入式·uboot·启动·底层
不想写代码的我9 天前
基于ZYNQ-7000系列的FPGA学习笔记11——IP核之单端RAM读写
笔记·学习·fpga开发·嵌入式·zynq
7yewh9 天前
嵌入式 linux Git常用命令 抽补丁 打补丁
linux·arm开发·git·嵌入式硬件·ubuntu·嵌入式·嵌入式软件
Jason_zhao_MR10 天前
基于米尔全志T527开发板的OpenCV进行手势识别方案
人工智能·mcu·opencv·计算机视觉·嵌入式
昊虹AI笔记10 天前
Source Insight的使用经验汇总
嵌入式
7yewh10 天前
LeetCode 力扣 热题 100道(十九)最长连续序列(C++)
c语言·数据结构·c++·算法·leetcode·嵌入式