花那么多美刀买嵌入式开发工具,到底值不值?

2018-06-04 13:42:04编辑:冀凯 关键字:调试器

作者:Digi-Key's North American Editors

 

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

 

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

 

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

 

用专业调试器节,省钱省时间

 

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

 

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

 

  • 断点有限

  • 时钟速率降低

  • 缺乏跟踪功能

  • 功能极少

 

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

 

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

 

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

 

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

 

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

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

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

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

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

 

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

 

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

 

消除隐患,揪出潜藏的错误

 

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

 

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

 

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

 

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

 

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

 

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

 

图 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 编译的代码更快。

 

图 4:Renesas Synergy平台 CoreMark 结果。Coremark值越大,性能越好。(来源:Renesas SSP 1.0.0 规格书)

 

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

 

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

 

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

 

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

  • 软件复杂性测量

  • 高效生成代码

  • 卓越的调试工具和功能

  • 技术支持

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

 

买或不买?好好算算这笔账

 

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

 

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


关键字:调试器

来源: EEWORLD 引用地址:http://www.eeworld.com.cn/qrs/article_2018060448923.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:基于mbedTLS实现的嵌入式固件知识产权保护方案
下一篇:编程器及适配器命名规则

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

嵌入式系统分析工具

能否及时高效地构建嵌入式系统,取决于软件开发人员在工作台上是否有合适工具来帮助完成开发工作。虽然预算通常受到限制,但有些工具是每位嵌入式软件工程师都必需的,这些工具可以帮助他们大幅减少构建、调试和验证其设计所需的时间。选择调试器开发人员的工作台上必备的第一种最重要工具是调试器。调试器的作用就如同包含应用代码的主机开发机与将要运行应用代码的目标嵌入式处理器之间的桥梁。调试器提供几种关键功能:提取已编译和链接的应用,并将其加载到目标存储器中。向目标处理器告知调试器已连接,并配置所有板载硬件调试模块和功能。负责设置软件和硬件断点。在调试过程中可用于读取寄存器和片上存储器。接收实时应用程序跟踪信息以用于调试应用程序。在很多实例中,开发人员
发表于 2018-05-30 17:31:41
嵌入式系统分析工具

基于USB接口并以SOPC方式实现的M8051嵌入式调试器设计

    引言    在嵌入式系统开发过程中,上位机通过调试器完成对目标机软件的开发、下载、调试。早期的调试器与上位机之间通过串口或并口通信,存在速度慢、通用性差等缺陷。相比之下,USB接口优势明显,具备速度快、易插拔、支持多个调试器同时工作等优势。但目前的USB接口调试器一般采用USB芯片和可编程器件结合的实现方式,成本和复杂度较高。    M8051是Mentor公司的嵌入式8051处理器,凭借良好的性能和功耗控制,占据了大量的SoC(System on a Chip)市场。该处理器集成了OCI(On-Chip Instrumentation,片上调试单元
发表于 2018-02-16 21:55:04
基于USB接口并以SOPC方式实现的M8051嵌入式调试器设计

Microchip新一代在线调试器问世,拥有无与伦比的速度

电子网消息,Microchip (美国微芯)日前发布MPLAB® ICD 4——Microchip的PIC®单片机和dsPIC®数字信号控制器系列产品的在线编程和调试开发工具。MPLAB ICD 4囊括了MPLAB ICD 3调试器的所有功能,在此基础上采用更快的处理器提高了速度并增大了RAM容量。MPLAB ICD 4速度之所以能够显著提高是因为采用了一片运行在300 MHz的32位MCU。处理速度更快,还增加了2 MB的高速缓存,使得该产品速度是前一代产品的两倍。圆形MPLAB ICD 4封装在一个耐用的黑色外壳中,顶部采用拉丝铝,醒目的LED灯带用于指示调试状态。该工具具有以下特性:•1.2V至5.5 V更宽的目标电压范围
发表于 2017-08-15 20:37:38
Microchip新一代在线调试器问世,拥有无与伦比的速度

单片机裸机下写一个自己的shell调试器

该文章是针对于串口通讯过程中快速定义命令而写的,算是我自己的一个通用化的平台,专门用来进行串口调试用,莫要取笑    要处理串口数据首先是要对单片机的串口中断进行处理,我的方法是正确的命令必须要在命令的结尾处同时带有回车和换行,处理过程如下//串口接收缓冲区u8 serial_Buffer[SERIAL_MAX_LENGTH] = {0};//串口接收数据长度u16 serial_Buffer_Length = 0;static void SerialRecv(u8 ch){    if((serial_Buffer_Length&0x8000) == 0x8000)//已经接收
发表于 2017-01-13 10:00:39

Microchip最新推出两款PIC 32 Curiosity开发板

全球领先的整合单片机、混合信号、模拟器件和闪存专利解决方案的供应商——Microchip Technology Inc.(美国微芯科技公司)日前发布了两款适用于32位应用的全新低成本快速原型开发板:PIC32MX和PIC32MZ Curiosity开发板。它们均集成有编程器调试器,并且能与Microchip MPLAB® X集成开发环境(IDE)充分融合。   新款开发板专为开发32位应用而设计,拥有种类丰富的外设以及用户界面和扩展选项,包括支持超过180款MikroElectronika Click™板的两个mikroBUS™ Click接口插头。两款
发表于 2016-11-08 16:58:08
Microchip最新推出两款PIC 32 Curiosity开发板

小广播

何立民专栏

单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2018 EEWORLD.com.cn, Inc. All rights reserved
ע39ַ ͼag콢 lolͶעʲô agֳ Űע ggٷ ɳַ ɳ Ű 7777 վٷվ GNSǮ Ԫƴ Ѷ1.5ֲ mgϷˮʱ ȫƶ Ѷ չ˾ Ȥζ ag Ǯ bbinհײ˴ȫ bbinϷͲʽ gnsվ 940 ճ淶 羺 ƱϷԪ ע mgЩ