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

前言

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

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

串口打印故障

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

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

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

结语

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

相关推荐
憧憬一下9 小时前
FreeRTOS定时器
嵌入式·freertos·定时器
网易独家音乐人Mike Zhou10 小时前
【Linux应用】Linux系统日志上报服务,以及thttpd的配置、发送函数
linux·运维·服务器·mcu·物联网·嵌入式·iot
程序员打怪兽11 小时前
线程间数据传递机制详解(共享全局内存 + 互斥锁同步)
linux·嵌入式
憧憬一下1 天前
FreeRTOS任务通知
嵌入式·freertos·任务通知
星羽空间1 天前
项目课题——智能花盆系统设计
物联网·毕业设计·嵌入式·课程设计·嵌入式开发
我命由我123452 天前
STM32 开发 - 中断案例(中断概述、STM32 的中断、NVIC 嵌套向量中断控制器、外部中断配置寄存器组、EXTI 外部中断控制器、实例实操)
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·嵌入式
SY师弟2 天前
台湾TEMI协会竞赛——2、足球机器人组装教学
c语言·单片机·嵌入式硬件·机器人·嵌入式·台湾temi协会
凉、介2 天前
Linux 下 pcie 初始化设备枚举流程代码分析
linux·运维·服务器·学习·嵌入式·c·pcie
SY师弟3 天前
台湾TEMI协会竞赛——1、龙舟机器人组装教学
c语言·单片机·嵌入式硬件·机器人·嵌入式·台湾temi协会
不脱发的程序猿4 天前
常见的CAN总线协议面试题
嵌入式·can·汽车电子