0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

嵌入式开发中调试器的技巧与窍门

工程师兵营 来源:互联网 作者:佚名 2018-07-17 08:59 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

从只有几千字节存储空间的简单 8 位控制器,到现在先进的 32 位控制器,虽然微控制器经历了诸多演变,但是许多开发人员仍在使用老旧的工具,拖慢了开发周期。

设计人员若要适应当今快速发展且复杂多变的开发环境,则需要确保拥有合适的工具才能应对。他们需要嵌入式工具,以便监视芯片并查看其软件是否按照预期方式运行;他们还需要可指出错误或优化代码规模的工具,以降低其 BOM 成本。

现在有许多工具可以帮助他们降低整体开发成本,加快调试过程,从而缩短上市时间。本文将介绍一些这样的工具,然后说明如何通过它们获得最大收益。

利用专业调试器节省时间和金钱

开发人员编写的软件程序第一次试运行就正常工作非常少见。因此软件开发需要调试,所以对于软件开发人员来说,最重要的工具就是调试器。利用调试器,开发人员可以将应用程序加载到目标微控制器上,逐步检查代码,查看存储器和其他寄存器,并操纵硬件。

问题是,许多专业开发人员通常使用的调试器是其低成本开发板所附带的。这些调试器方便、便宜,而且在演示时表现完美。但是,在开发专业软件时,可能会出现以下限制:

  • 断点有限

  • 时钟速率降低

  • 缺乏跟踪功能

  • 功能极少

换言之,有时真是一分钱一分货:附送的简化工具集可能不是快速有效地开发和调试软件的最佳方式。

专业级调试器具有许多功能,可提高工程师的生产力,例如无限制的断点。许多调试器只能使用微控制器的内部比较器来设置断点,而在大多数情况下只有两个可用。在有数万行代码的复杂程序中,只有两个可用的断点可能会导致开发人员把时间浪费断点切换上,也可能会导致开发人员错过软件中的关键点,从而错过潜伏的漏洞。这样一来,可能会导致编码时间更长,反而增加了开发成本并影响了上市时间。

专业级调试器提供的算法不仅可以使用硬件断点,还可以使用软件和闪存断点,为开发人员提供了更多的灵活性,而且用来评估代码的断点数量几无限制。

当然专业级调试器不便宜。它们的价格可以轻松标到几百到几千美元。但它们为开发人员带来了不可计算的投资回报,并能使用多年,无需升级或更换。选择调试器时,开发人员应该问自己几个问题:

  • 调试器的断点数是否无限制?

  • 这是一款可以与几乎所有工具链和微控制器配合使用的第三方调试器吗?

  • 五年后这个调试器还能使用吗?

  • 这个调试器有很好的生态系统吗?

  • 调试器的能力可以扩展吗?

因为符合上述标准而变得非常受欢迎的一款第三方调试器是 Segger J-Link。根据开发人员的需求,Segger J-Link 可提供不同的版本。其中包括 J-Link Base Unit、J-Link Plus、J-Link Ultra Plus 和 J-Link Trace(图 1)。

Segger J-Link 调试器型号比较图片

图 1:Segger J-Link 调试器型号比较。(来源:Segger)

使用调试器跟踪和分支检测来揪出潜藏的错误

高级调试器(通常也是最昂贵的)配备 ETM 跟踪连接器,可以获得大量跟踪数据,这是使用 JTAG 或 SWD 的标准跟踪无法实现的。

使用高级跟踪功能,开发人员可以将调试器与商业工具链(如适用于 ARMKeil MDK-PRO)连用,来监视系统中的每一行代码在测试期间是否得到执行。如下例所示,针对 ARM 的 Keil MDK-PRO 与跟踪调试器一并运行,检测到了那些代码行在测试期间得到执行(图 2)。这种跟踪对于需要 100% 测试覆盖的安全关键型系统非常有用。在未测试代码之处,可能会潜藏错误并在以后导致问题。

在调试模式下运行的用于 ARM 的 Keil MDK-PRO 图片

图 2:在调试模式下运行并对软件执行分支分析的用于 ARM 的 Keil MDK-PRO。左侧的绿色块表示在测试期间得到执行的代码行。(图片来源:Keil)

如果开发人员不想购买成熟的跟踪工具,则可以使用 SWD 进行跟踪。在这种情况下,开发人员可以选择使用如 Segger 的 SystemView 或 Percepio 的 Tracelyzer 之类软件工具将跟踪信息流传输到在 PC 上执行的应用程序。这些跟踪系统通常在 RTOS 中工作,并且需要几行代码来设置跟踪任务、捕获数据并将其发送到调试器,然后再发送到 PC 上。

显示软件跟踪的输出示例(图 3)。开发人员可以使用这些工具来检测诸如优先级转换、死锁、线程饥饿以及许多在复杂系统中可能遇到的其他问题。每个任务都有一条生命线,显示其何时就绪、何时执行、何时完成,以及在此期间可能发生的任何事件,例如发出和接收信号

专业开发人员需要这样的细节,同样地,也要求他们使用的调试工具能够检索这类信息。

Percepio 的 Tracealyzer 图片

图 3:使用如 Percepio 的 Tracealyzer 之类工具检查软件操作,并查看执行时间和时间长短。(图片来源:Digi-Key

最大限度利用调试器的技巧与窍门

调试工具有很多功能,但有时可能受限于为应用选择的微控制器。开发人员需要了解其调试器的功能,并要将其与微控制器正确配对。现今的许多调试器都可与 ARM® Cortex®-M 微控制器配合使用,开发人员在调试这些系统时应考虑以下几个因素:

  • 避免通过 UART 进行 printf。而应使用 ITM 端口来获得更好的性能

  • 不要逐条查看代码,使用高级断点来提高调试效率

  • 选择一个通过服务器控制的调试器,以便为多个应用提供调试数据,即自定义分析仪、跟踪、调试环境等等。

  • 调整调试器使用的默认时钟速率,因该速率通常比最大值慢得多

  • 在开发周期的早期阶段设置跟踪,以建立比较基准

  • 使 SWO 能够从系统获取更多信息

  • 在硬件、软件和闪存断点之间进行选择性选择,以最小化实时性能影响

使用这些技巧可以帮助开发人员从调试器及其调试会话中获取更多信息。

使用商业编译器降低成本

GCC 是一款极受欢迎且大获成功的编译器。它与商业工具相比有一个优点就是免费!免费并不意味着编译器的质量和输出将产生与商业工具同等的可执行代码。事实上,在许多情况下,将 GCC 与商业编译器(如用于 ARM 的 Keil MDK-PRO 或 IAR Embedded Workbench)进行比较,得出的结果是,GCC 使用的代码规模更大,占用的 RAM 空间更多。Renesas 甚至在他们的 Synergy 平台规格书中显示了这一点(图 4)。

在图中,Renesas 使用 EEMBC CoreMark® 对其编译器进行了基准测试,显示了 IAR 编译的代码比 GCC 编译的代码更快。

基准测试还显示,使用商业级编译器可以显著减少代码规模。乍一看,开发人员可能会认为购买诸如用于 ARM 的 Keil MDK-PRO 之类工具不值得投资,而应该使用 GCC。但是,当开发人员使用包含 128 KB 代码空间的微控制器(如 NXP MK20DX128)并发现使用 GCC 应用程序需要 132 KB 时,会发生什么?

若发生这种情况,开发团队就被迫要寻找一个具有足够内存但却更为昂贵的引脚兼容器件,如 NXP MKD20DX256。如果该公司只能生产适量的产品,那么每年花在 MCU 上的成本可能会超过最初投资于商业编译器上的成本。

使用商业编译器也有其他优势,有助于降低成本,例如:

  • 代码分析功能,如分支检测

  • 软件复杂性测量

  • 高效生成代码

  • 卓越的调试工具和功能

  • 技术支持

  • 集成到驱动程序库和框架

结论

开发人员当然可以使用免费或便宜的开发工具。然而问题在于,这些低成本工具在大多数情况下并非是适合这种工作的最佳工具。它们往往缺乏每个开发人员所需的高级功能,不能节省时间和金钱,而且常常会导致项目延迟并增加成本。

购买好的专业调试器和工具链是一项投资,可以在未来几年节省大量时间和金钱,并大幅提高开发团队的工作效率和绩效。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ARM
    ARM
    +关注

    关注

    135

    文章

    9499

    浏览量

    388754
  • 嵌入式
    +关注

    关注

    5186

    文章

    20151

    浏览量

    328896
  • 调试器
    +关注

    关注

    1

    文章

    325

    浏览量

    24926
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    一个面向单片机、事件驱动的嵌入式开发平台介绍

    EventOS,是一个面向单片机、事件驱动的嵌入式开发平台。它主要有两大技术特色:一是事件驱动,二是超轻量。EventOS以及其母项目EventOS,目标是开发一个企业级的嵌入式开发平台,以事件总线
    发表于 12-05 06:26

    分享一个嵌入式开发学习路线

    法,这些语法在嵌入式开发至关重要。 2. 技能进阶期(2-3个月) 从51单片机过渡到主流的ARM Cortex-M系列(嵌入式就业核心平台),学会使用STM32单片机,掌握嵌入式开发
    发表于 12-04 11:01

    嵌入式开发的关键点介绍

    嵌入式开发在现代科技扮演着非常重要的角色。随着物联网的发展,嵌入式系统的需求也越来越大。嵌入式开发不仅需要开发人员具备深入的硬件知识和编程
    发表于 11-13 08:12

    恩智浦如何攻克两大嵌入式开发难题

    在我们的身边,嵌入式系统无处不在。而随着技术的进步和应用的拓展,今天的嵌入式开发也面临着诸多新课题、新挑战。
    的头像 发表于 10-27 09:28 1188次阅读

    嵌入式开发就业还有前景吗?

    。在智能家居领域,嵌入式开发的主要工作是开发各种智能化设备和系统,如智能照明、智能安防、智能家电等。嵌入式开发人员需要掌握相关的硬件和软件技术,如处理、传感
    发表于 07-16 10:47

    RIGOL MSO5000系列混合信号示波器如何加速嵌入式开发

    MSO5000系列混合信号示波器凭借其高性能参数、多功能集成和智能化分析能力,为嵌入式开发提供了全面的解决方案,大幅提升了调试效率。本文将从技术特性、应用场景及实战技巧三个方面,深入探讨MSO5000如何加速嵌入式开发。  
    的头像 发表于 06-24 12:08 390次阅读
    RIGOL MSO5000系列混合信号示波器如何加速<b class='flag-5'>嵌入式开发</b>

    嵌入式开发入门指南:从零开始学习嵌入式

    特定功能的计算机系统,广泛应用于智能家居、工业控制、医疗设备、车载系统等领域。 2. 学习嵌入式开发的前置知识熟悉C语言编程掌握基本的数据结构与算法了解数字电路与微控制原理熟悉Linux操作系统
    发表于 05-15 09:29

    嵌入式开发:高门槛的系统性工程与 996 的行业困局

    嵌入式开发的门槛,往往被培训机构和表象所掩盖。许多人误以为 “用 C 语言写个跑在 ARM 上的程序” 就是嵌入式,实则连皮毛都未触及。真正的嵌入式开发是硬件与软件深度融合的系统性工程,需跨越三重壁垒
    的头像 发表于 04-09 11:06 679次阅读
    <b class='flag-5'>嵌入式开发</b>:高门槛的系统性工程与 996 的行业困局

    BlackBerry QNX推出通用嵌入式开发平台

    BlackBerry有限公司(纽交所代码:BB;多伦多证券交易所代码:BB)旗下部门QNX今日宣布推出QNX 通用嵌入式开发平台(General Embedded Development
    的头像 发表于 03-11 16:04 943次阅读

    如何成为嵌入式开发工程师?

    如何成为嵌入式开发工程师? 成为嵌入式开发工程师通常需要掌握一系列技能和知识,并且在实践不断积累经验。以下是一些基本步骤和建议: 1. 基础教育:- 获取电子工程、计算机科学或相关领域的学位
    发表于 02-19 10:39

    嵌入式开发新纪元:AI大模型助力乐鑫芯片高效编程

    芯片开发的有效途径。看看它们如何为乐鑫ESP32系列芯片开发赋能,实现从代码生成到调试优化全流程的效率飞跃!嵌入式开发者的得力AI助手Cursor与Trae:代码生
    的头像 发表于 02-17 18:06 2282次阅读
    <b class='flag-5'>嵌入式开发</b>新纪元:AI大模型助力乐鑫芯片高效编程

    盘点工程师常用的嵌入式开发工具

    嵌入式开发涉及硬件与软件的紧密结合,开发工具的选择对效率和质量至关重要。以下是嵌入式开发中常用的工具分类及代表性工具,涵盖开发全流程: 1. 集成
    的头像 发表于 02-07 10:06 3744次阅读

    嵌入式开发必备-RK3562演示Linux常用系统查询命令(上)触觉智能出品

    实用干货!嵌入式开发学习必备-RK3562演示Linux常用系统查询命令(上)关注触觉智能持续为大家带来更多嵌入式开发内容
    的头像 发表于 12-31 10:51 117次阅读
    <b class='flag-5'>嵌入式开发</b>必备-RK3562演示Linux常用系统查询命令(上)触觉智能出品

    嵌入式工程师常用的开发工具有哪些?

    。此外,ARM 公司的编译也备受青睐,针对 ARM 架构的微控制进行了深度优化,能够生成高效的代码。 三、调试工具 调试嵌入式开发过程中
    发表于 12-20 15:29

    如何使用 RISC-V 进行嵌入式开发

    RISC-V是一种开源的指令集架构(ISA),它允许任何人设计、制造和销售基于RISC-V的处理,这为嵌入式开发提供了极大的灵活性和创新空间。以下是使用RISC-V进行嵌入式开发的基本步骤: 一
    的头像 发表于 12-11 17:32 2752次阅读