分享嵌入式软件调试方法和几个工具

strongerHuang 2022-11-09 08:20
关注+星标公众,不错过精彩内容
作者 | 杂烩君
转自 | 嵌入式大杂烩

我们常常说,软件三分写七分调。实际开发中,确实也是这样子的。我工作这几年了,对这体会也越来越深。每当需求一下来,我代码很快就可以写完,但是,调试需要花很多时间。

这里需要明确的是, 调试的目的不仅仅是调通整个功能需求 。调通功能是最基本的要求,还需要进行优化、完善逻辑、完善异常处理。所以,需要非常长的时间。

记得毕业的时候参与的第一个项目,那个项目的硬件架构相对一般产品来说会复杂一些:


我负责的部分就是D芯片的软件。D芯片所做的事情就是跟产品功能比较相近的,当时通过A发数据,经过B、C之后,再到D,产品功能表现得不正常。我当时的 第一反应 就是我负责得D芯片的逻辑可能出问题了。

A、B、C都是比较有经验的工程师负责的,而且负责C的还是个组长级别的,大家也觉得应该是我负责的D芯片的代码出的问题,因为我是个刚毕业的新人,觉得问题出在我这里的概率比较大。

他们也没有去查是不是他们的问题,每天就是来看看我是否有找到问题。花了几天的时间,我最后才定位出来,是C芯片给我发的数据出问题了~

因为当时缺乏调试经验,所以没能很快就定位出问题所在。要是现在的话,这种问题很快就能查出来的。因为现在积累了一些经验:

调试经验

平时开发调试时,可能会有这么两种情况:

  • 独立开发,自己调试

  • 协作开发,联合调试

1、独立开发

一些小的项目,如果整个项目是我们自己开发的话,调试起来也比较方便,因为是我们自己开发的,所以会比较熟悉一些。

我的习惯是:分模块来进行开发,每开发完一个模块就先想办法测一下这个模块,没问题了再集成到工程里。模块初步开发、测试时,代码可以随意一些,调好了之后,再重新梳理、整理代码,集成到工程里。

自测的方式:有一些代码直接对应着功能,直接测试看功能正不正常;有一些代码可以通过log打印来看是否正常;有一些可能需要在线调试看看是否符合预期;有一些需要数据输入的,可以自己模拟一些数据等。

2、协同开发

协同开发时,可能就比较麻烦一些。特别的,有时候甚至需要跨部门对接调试。

我的习惯是:先开发并自测自己的模块;然后模拟对方,简单地自测通信。

自测自己模块的方式如上面独立开发一样。我们模拟对方进行测试时,需要考虑是不是需要花比较多的时间,如果需要花太多的时间的花就算了,等到联调再一起调。

花时间较少的,可以自测通信的情况可能有如下三种:

  • 线程/进程间通信。这应该比较容易,模拟对方线程/进程进行收发测试。可以写一些测试命令,比如发某个命令,触发某条消息发送。
  • 板间通信,如串口通信。可以用串口助手模拟对方进行测试,自己对照协议模拟一些协议数据进行收发测试。
  • socket通信,如TCP通信。你负责客户端,就模拟服务端;你负责服务端,就模拟客户端。

当然,协作开发也可以不自测通信,看个人习惯。

我模拟自测通信是为了对我自己的模块的通信有一定的把控,联调时出问题时,就可以比较快地指出对方的问题。当然,这不是为了推锅,而是为了能更好地分析、解决联调问题。

比如,我最近的项目中,设备与手机APP对接。配网功能、设备于APP局域网内通信功能。我负责设备端,设备端作为服务器;对方作为客户端。

在与对方联调前,我已经写了一个客户端运行于PC或设备上,模拟对方的手机APP,对我的模块做了基本的自测,也测出了我的模块的一些问题。

然后在与对方正式联调时,出现的大多问题都在对方那边,所以这时候我就可以帮助对方分析问题,提高了联调效率。

上面分享了一些我的经验及思路,下面看看一些具体的调试方法与调试工具:

调试方法

1、LOG

我在实际工作中,log打印调试解决了我大多数的问题,一般的问题,通过分析log都可以定位出问题所在。但是,打log也是有很多讲究的,需要我们打印出有助于我们调试的信息。

比如:

  • log的格式

带时间戳、函数名、行号等有助于分析问题的信息。比如:

[func:100]

当然,实际中可能不只包含如上信息,根据需要添加。

  • 在一些判断分支要加上log

这样可以清楚地知道程序跑到分支判断时的执行流程。

  • 在一些大的操作的开始处,加上显眼的log

可以清楚地知道某个操作开始的地方。

  • 业务逻辑模块,可以加上特定的标签

比如统一的log的格式中加上特定标签,比如BUSINESS。如:

[BUSINESS][func:100]

因为业务逻辑一般是整个项目地最上层,其它模块都是为它服务的。

我们看log的时候,通过编辑器搜索关键字 BUSINESS 就可以只列出业务逻辑相关的log,我们只要看这些log,就可以大致知道程序的运行流程。

当然,其它模块也可以根据需要加上标签。

  • 控制log打印频率

与数据打交道的模块可能需要打印一些数据来分析源数据是否正常。可以稍微的控制打印频率,尽可能在不影响数据分析的情况下打印尽可能少的log。

否则,一些log的文件动不动就几百MB,分析起来也很头疼。特别的,log需要保存在flash上时,为了防止log爆满flash,常常需要限制log文件的大小并做log滚动覆盖,这时候无效log太多了可能就会覆盖掉有效的log。

往期关于log调试相关的文章:

C语言、嵌入式中几个非常实用的宏技巧

bug解决不了?使用日志法

分享一个极简的log模块!

嵌入式软件打log的一些心得!

2、在线调试

在线调试,可以看到程序运行的更多细节。基本的应该都会吧。

GDB往期相关推文:

例说GDB调试

手把手教你使用VSCode + gdb + gdbserver调试ARM程序

GDB调试器的简单使用(图文)

关于keil的调试相关的内容,推荐看一下我同事鱼鹰写的文章(公众号:鱼鹰谈单片机),他对这方面研究得比较深。

3、其它调试工具

我们公众号之前也分享了很多有用的调试相关的工具:

(1)VirtLCD

这是一个实用的LCD模拟器,手头上暂时没有LCD或者开发初期,需要频繁下载程序,验证效果的时候,可以使用VirtLCD来提高我们的开发、调试效率。

VirtLCD的介绍及简单使用:

实用 | 手头上无LCD却又急着开发UI?LCD模拟器了解一下~

(2)Wireshark

Wireshark 是一个网络封包分析软件。比如我们在调试socket通信的时候,可以使用Wireshark 监控看看我们有没有发送数据出去,或者有没有收到对方发送的数据。

wireshark的介绍及简单使用:

wireshark抓包工具的使用及分析

(3)VSPD

Virtual Serial Port Driver(VSPD)是一个虚拟串口软件。虚拟串口软件是一种模拟物理串行接口的软件,它完全复制了硬件 COM 接口的功能,并且将被操作系统和串行应用程序识别为真实端口。

在编写串口上位机时,需要进行调试。一种方式是与下位机进行通信进行测试;另一种方式是借助虚拟串口软件来进行测试。

VSPD的介绍及简单使用:

工具 | 虚拟串口软件的使用分享

(4)LVGL GUI Guider

GUI Guider是恩智浦为LVGL开发了一个上位机GUI设计工具,可以通过拖放控件的方式设计LVGL GUI页面,加速GUI的设计。

相关文章:

实用工具 | LVGL GUI-Guider的使用分享

基于vs2019的lvgl模拟器使用

lvgl最新版本在STM32上的移植使用

(5)Jlink+JScope

J-Scope 是  SEGGER 推出的波形显示软件,傻瓜式,简单易上手。需要搭配 Jlink仿真器 (V9或V10)使用。

J-Scope的介绍及简单使用:

J-Scope的介绍及简单使用

(6)SEGGER_RTT

RTT全称是Real Time Transmit(实时传输),是SEGGER 公司推出的,是搭配 Jlink仿真器 (V9或V10)使用的一种调试手段。

SEGGER_RTT的介绍及简单使用:

SEGGER_RTT的介绍及简单使用

(7)CmBacktrace

CmBacktrace (Cortex Microcontroller Backtrace)是一款针对 ARM Cortex-M 系列 MCU 的错误代码自动追踪、定位,错误原因自动分析的开源库。

CmBacktrace 的介绍及简单使用:

CmBacktrace 的介绍及简单使用

(8)VOFA+

VOFA+(伏特加)插件驱动的高自由度上位机。其是一款通用的数据调试工具,它让图形化调试变得像串口调试一样简单。通过打印字符串,或者发送十六进制数字的方式,就能完成数据的可视化操作。

官网:

https://www.vofa.plus/

VOFA+的介绍及简单使用:

VOFA+的介绍及简单使用

(9)QEMU

QEMU是一款知名的而且开源的模拟器(官网:https://www.qemu.org/),它能在 X86 PC 上运行能够模拟 Arm、MIPS、RISC-V 等各种 CPU 和开发板,以及 网卡、声卡、键盘、sdcard、emmc、usb等各种外设。

QEMU我还未使用过,之前转载的一篇文章:

Linux利器:QEMU!用它模拟开发板能替代真开发板?

(10)Valgrind

Valgrind是一套Linux下,开放源代码(GPL V2)的仿真调试工具的集合。

Valgrind的介绍及简单使用:

工具 | Valgrind仿真调试工具的使用

(11)Bus hound

Bus hound是一款为了在pc电脑上进行总线数据包监控以及操控的开发工具。用来捕捉来自设备的协议包和输入输出操作,它是功能强大的总线协议分析器。

之前有与USB上位机联调,通过这个工具可以监控上位机发出的数据是否正确。关于Bus hound的文章我们公众号还没有分享过,先占个坑,之后有机会再分享。

最后,为大家送上合集:嵌入式工具

声明:本文素材来源网络,版权归原作者所有。如涉及作品版权问题,请与我联系删除。


------------ END ------------



●专栏《嵌入式工具

●专栏《嵌入式开发》

●专栏《Keil教程》

●嵌入式专栏精选教程


关注公众号回复“加群”按规则加入技术交流群,回复“1024”查看更多内容。




点击“阅读原文”查看更多分享。

strongerHuang 作者黄工,高级嵌入式软件工程师,分享嵌入式软硬件、物联网、单片机、开发工具、电子等内容。
评论
  • 最近几年,新能源汽车愈发受到消费者的青睐,其销量也是一路走高。据中汽协公布的数据显示,2024年10月,新能源汽车产销分别完成146.3万辆和143万辆,同比分别增长48%和49.6%。而结合各家新能源车企所公布的销量数据来看,比亚迪再度夺得了销冠宝座,其10月新能源汽车销量达到了502657辆,同比增长66.53%。众所周知,比亚迪是新能源汽车领域的重要参与者,其一举一动向来为外界所关注。日前,比亚迪汽车旗下品牌方程豹汽车推出了新车方程豹豹8,该款车型一上市就迅速吸引了消费者的目光,成为SUV
    刘旷 2024-12-02 09:32 98浏览
  • 概述 说明(三)探讨的是比较器一般带有滞回(Hysteresis)功能,为了解决输入信号转换速率不够的问题。前文还提到,即便使能滞回(Hysteresis)功能,还是无法解决SiPM读出测试系统需要解决的问题。本文在说明(三)的基础上,继续探讨为SiPM读出测试系统寻求合适的模拟脉冲检出方案。前四代SiPM使用的高速比较器指标缺陷 由于前端模拟信号属于典型的指数脉冲,所以下降沿转换速率(Slew Rate)过慢,导致比较器检出出现不必要的问题。尽管比较器可以使能滞回(Hysteresis)模块功
    coyoo 2024-12-03 12:20 70浏览
  •         温度传感器的精度受哪些因素影响,要先看所用的温度传感器输出哪种信号,不同信号输出的温度传感器影响精度的因素也不同。        现在常用的温度传感器输出信号有以下几种:电阻信号、电流信号、电压信号、数字信号等。以输出电阻信号的温度传感器为例,还细分为正温度系数温度传感器和负温度系数温度传感器,常用的铂电阻PT100/1000温度传感器就是正温度系数,就是说随着温度的升高,输出的电阻值会增大。对于输出
    锦正茂科技 2024-12-03 11:50 66浏览
  • RDDI-DAP错误通常与调试接口相关,特别是在使用CMSIS-DAP协议进行嵌入式系统开发时。以下是一些可能的原因和解决方法: 1. 硬件连接问题:     检查调试器(如ST-Link)与目标板之间的连接是否牢固。     确保所有必要的引脚都已正确连接,没有松动或短路。 2. 电源问题:     确保目标板和调试器都有足够的电源供应。     检查电源电压是否符合目标板的规格要求。 3. 固件问题: &n
    丙丁先生 2024-12-01 17:37 83浏览
  • 当前,智能汽车产业迎来重大变局,随着人工智能、5G、大数据等新一代信息技术的迅猛发展,智能网联汽车正呈现强劲发展势头。11月26日,在2024紫光展锐全球合作伙伴大会汽车电子生态论坛上,紫光展锐与上汽海外出行联合发布搭载紫光展锐A7870的上汽海外MG量产车型,并发布A7710系列UWB数字钥匙解决方案平台,可应用于数字钥匙、活体检测、脚踢雷达、自动泊车等多种智能汽车场景。 联合发布量产车型,推动汽车智能化出海紫光展锐与上汽海外出行达成战略合作,联合发布搭载紫光展锐A7870的量产车型
    紫光展锐 2024-12-03 11:38 65浏览
  • 11-29学习笔记11-29学习笔记习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-02 23:58 51浏览
  • 作为优秀工程师的你,已身经百战、阅板无数!请先醒醒,新的项目来了,这是一个既要、又要、还要的产品需求,ARM核心板中一个处理器怎么能实现这么丰富的外围接口?踌躇之际,你偶阅此文。于是,“潘多拉”的魔盒打开了!没错,USB资源就是你打开新世界得钥匙,它能做哪些扩展呢?1.1  USB扩网口通用ARM处理器大多带两路网口,如果项目中有多路网路接口的需求,一般会选择在主板外部加交换机/路由器。当然,出于成本考虑,也可以将Switch芯片集成到ARM核心板或底板上,如KSZ9897、
    万象奥科 2024-12-03 10:24 37浏览
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2024-12-02 10:40 102浏览
  • 戴上XR眼镜去“追龙”是种什么体验?2024年11月30日,由上海自然博物馆(上海科技馆分馆)与三湘印象联合出品、三湘印象旗下观印象艺术发展有限公司(下简称“观印象”)承制的《又见恐龙》XR嘉年华在上海自然博物馆重磅开幕。该体验项目将于12月1日正式对公众开放,持续至2025年3月30日。双向奔赴,恐龙IP撞上元宇宙不久前,上海市经济和信息化委员会等部门联合印发了《上海市超高清视听产业发展行动方案》,特别提到“支持博物馆、主题乐园等场所推动超高清视听技术应用,丰富线下文旅消费体验”。作为上海自然
    电子与消费 2024-11-30 22:03 86浏览
  • 《高速PCB设计经验规则应用实践》+PCB绘制学习与验证读书首先看目录,我感兴趣的是这一节;作者在书中列举了一条经典规则,然后进行详细分析,通过公式推导图表列举说明了传统的这一规则是受到电容加工特点影响的,在使用了MLCC陶瓷电容后这一条规则已经不再实用了。图书还列举了高速PCB设计需要的专业工具和仿真软件,当然由于篇幅所限,只是介绍了一点点设计步骤;我最感兴趣的部分还是元件布局的经验规则,在这里列举如下:在这里,演示一下,我根据书本知识进行电机驱动的布局:这也算知行合一吧。对于布局书中有一句:
    wuyu2009 2024-11-30 20:30 106浏览
  • 遇到部分串口工具不支持1500000波特率,这时候就需要进行修改,本文以触觉智能RK3562开发板修改系统波特率为115200为例,介绍瑞芯微方案主板Linux修改系统串口波特率教程。温馨提示:瑞芯微方案主板/开发板串口波特率只支持115200或1500000。修改Loader打印波特率查看对应芯片的MINIALL.ini确定要修改的bin文件#查看对应芯片的MINIALL.ini cat rkbin/RKBOOT/RK3562MINIALL.ini修改uart baudrate参数修改以下目
    Industio_触觉智能 2024-12-03 11:28 41浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦