阅读更多

1顶
0踩

操作系统

原创新闻 加速Cortex-M MCU调试的五个技巧

2016-05-16 16:39 by 副主编 mengyidan1988 评论(0) 有6491人浏览
引用

原文链接:Debugging the Cortex-M MCU
作者:Jacob Beningo
译者:刘帝伟 审校:刘翔宇
责编:周建丁(zhoujd@csdn.net)

调试嵌入式软件是我最不喜欢的行为,不幸地是,它却是必要的。值得庆幸地是,技术和工具链创新的进步衍生出大量的新技术,从而大大地加快了调试过程。下面让我们来看看其中一些方法,从传统的断点调试出发到更先进的仪器跟踪技术。

技巧1# - 传统的断点调试
每个开发人员都熟悉传统的调试技术,设置断点、执行代码,然后单步调试代码进行监视,同时监视寄存器和变量值。断点调试是我看到的使用最多的技术。然而,结果却不甚乐观,因为断点调试的效率较低,通常会产生次优的结果。

既然如此,为什么大家还如此频繁地使用断点调试呢?主要原因似乎是断点调试便于使用,易于理解,并且开发人员都乐观地认为,对于工作而言,断点是正确的工具。这种乐观需要校验。断点有可能破坏系统的实时性能,同时会将开发者吸进一个黑洞,使其无休止地去单步执行代码,盲目地寻找问题的一种解决方法。

技巧2#- IDE值图
如今,几乎所有的现代调试器和IDE都允许开发者监视存储在内存中的变量值。开发人员可以选择内存位置以及值刷新率,然后启动调试会话。一些IDE自身就有能力监视内置到IDE的值,而另外一些IDE则需要依靠外部软件。

值监测非常有用,如果将监测到的数据与图形化表示关联到一起,其带来的价值则更大。对实时的数据绘制值图对于发现意想不到的变化和验证特定波形的生成极其有用。例如,一个三相无刷直流电机(BLDC motor)。开发人员如果想要监测每个电机支架的电流和电压,则需要驱动电机所形成的非常具体的波形。绘制每个电机支架电流和电压能够让开发人员实时看到发生的事情。

技巧3#-从printf到SWO
在高端的ARM Cortex-M系列配件中,如M3/M4,它为开发人员提供了额外的调试能力,即串行线查看器(Serial Wire Viewer,SWV)。SWV还包括除串行线输出(SWO)以外的标准串行线调试。SWO可以用来做很酷的东西,如程序检索计数器,事件计数器,及数据追踪等。开发者还可以对它们进行自定义,设置自己想要在SWO中传送的信息。

许多开发者为了从他们的嵌入式系统中获取调试信息通常会设置printf。实际上则并不是在单片机中使用串口引脚,而是开发人员可以使用SWO通过调试器重新路由printf信息。以这种方式使用调试器可以保存专用串行接口的需要,同时消除了开发UART和USB设备的时间,效率更高。现在通过SWO和调试硬件将最初被应用程序所使用的开销卸去,缩减了那些有可能被应用程序代码使用的宝贵的时钟周期。

技巧4#-RTOS跟踪
试图透过表像看清一个实时操作系统中(RTOS)的本质可以说是相当具有挑战性。开发者并不想扰乱实时系统的性能,但仍然需要一些方法来了解系统的行为。这也是Blinky LED经常使用的把戏,但最近开发者的工具箱中增加了更多惊人的跟踪工具。例如免费的商用RTOS工具,如TraceX、SystemView和tracealyzer等等。

当RTOS闲置,或是有任务进入和退出时,跟踪工具允许开发者进行追踪分析。开发人员可以监控系统的异常,响应时间,执行时间,以及正确开发一个嵌入式系统所需的许多其他关键细节。RTOS跟踪工具最酷的功能是它们能够展示系统内部发生了什么。实时地或是在日志文件中进行审查和时序图监视,能够让开发者确定一个置信水平,用以估量系统是否能够按预期正常运行,或者帮助他们发现一些小问题,否则将花费大量的时间去寻找。

技巧5 #- 使用指令追踪技术(ETM / ETB / ETM)
有时开发人员面临的调试问题,只是在处理器中所能想象到的最低层面的问题。跟踪技术的存在,可以监视处理器执行的单个指令。在测试和验证软件时这种低水平跟踪对于监测分支覆盖非常有用。用于指令跟踪的调试工具不同于那些开发人员使用的串行线查看,而且成本略高。

结束语
调试工具和技术在过去几年里迅速发展,特别是高端微控制器。一般来讲,工程师都是视觉型生物,工具供应商正在寻找方法以刺激视觉的方式来揭示一个实时系统究竟发生什么。配置调试工具可能需要做一些前期工作,但是在设计上多花一点时间可以换来更少的调试时间,确实是一笔非常值得的时间投资。开发人员至少应该熟悉不同的调试工具和可用的功能,以便在出现问题,系统需要调试时,他们可以选择合适的工具完成任务。你有用过其它可以帮助工程师更快、更有效率地调试他们系统的技术么?
引用

Jacob Beningo是Beningo Engineering(一个嵌入式软件咨询公司)的首席顾问。Jacob在开发、查核和批判驱动、为那些对固件有鲁棒性和可扩展性要求的公司设计框架以及编写应用程序代码方面经验丰富。他通过研讨会、网络会议和博客积极提升对升嵌入式软件开发的整体理解。如有您有任何问题,也可随时联系他:jacob@beningo.com,网站www.beningo.com,在这里可以订阅他每月的嵌入式字节快讯。
1
0
评论 共 0 条 请登录后发表评论

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • Cortex-M3

    Cortex-M3(转) 首先,在学习Cortex-M3时,我们必须要知道必要的缩略语。整理如下:AMBA:先进单片机总线架构 ADK:AMBA设计套件 AHB:先进高性能总线 AHB-AP:AHB访问端口 APB:先进外设总线 ARM ARM:ARM架构...

  • ARM Cortex-M3权威指南-概览和基础

    Thumb-2是16位Thumb指令集的一个超集,在Thumb-2中, 16位指令首次与32位指令并存,结果在Thumb状态下可以做的事情一下子丰富了许多,同样工作需要的指令周期数也明显下降。内部的数据路径是32位的,寄存器是32位的...

  • Cortex-M3学习笔记(一)

    Cortex-M3学习笔记(一) 首先,在学习Cortex-M3时,我们必须要知道必要的缩略语。整理如下:AMBA:先进单片机总线架构 ADK:AMBA设计套件 AHB:先进高性能总线 AHB-AP:AHB访问端口 APB:先进外设总线 ...

  • 从Cortex-M3权威指南中整理的Cortex-M3学习笔记

    首先,在学习Cortex-M3时,我们必须要知道必要的缩略语。整理如下:AMBA:先进单片机总线架构 ADK:AMBA设计套件 AHB:先进高性能总线 AHB-AP:AHB访问端口 APB:先进外设总线 ARM ARM:ARM架构参考手册

  • Cortex-M3学习笔记--1--基础知识

    首先,在学习Cortex-M3时,我们必须要知道必要的缩略语。整理如下:AMBA:先进单片机总线架构 ADK:AMBA设计套件 AHB:先进高性能总线 AHB-AP:AHB访问端口 APB:先进外设总线 ARM ARM:ARM架构参考手册

  • Cortex-M3(转)

    原来一直在Cortex-A8上做相关算法的开发和移植,最近要在Cortex-M3上实现一小功能,所以要了解一下Cortex-M3 架构,在网上看到这篇blog不错,特转载一下。 ... 首先,在学习Cortex-M3时,我们必须要知道必要的缩略语。...

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

    每当需求一下来,我代码很快就可以写完,但是,调试需要花很多时间。这里需要明确的是, 调试的目的不仅仅是调通整个功能需求 。调通功能是最基本的要求,还需要进行优化、完善逻辑、完善异常处理。所以,需要非常长...

  • 破解市场迷思:MIPS-最适用于设计MCU的处理器

    (在下面这个网站可看到很多mips相关的文章:http://www.embedstudy.com/category-22) 转一篇不错的介绍mips芯片的文章。当然这里面说arm没有影子寄存器是不对的。 wait指令的介绍也不错:M4K内核还通过使用内部...

  • 你选的低功耗MCU是不是真省电?看后请自测

    对于电池供电的互连设备而言,能耗是至关重要的,降低能耗可以最大程度地延长电池的更换时间,甚至让设备在没有环境能量源的情况下运行。...此类方法不仅必须要考虑存储容量、MCU性能和功耗的因素,还必须考虑到无...

  • 关于Mips--基本认识

    破解市场迷思:MIPS-最适用于设计MCU的处理器 Time:2011-04-07 14:26:14 Author: Source:MIPS科技公司 关键字:MIPS科技公司,破解市场迷思,MIPS,设计MCU的处理器 1 引言 MIPS科技公司以开发与授

  • 嵌入式学习笔记-2022.2.22

    ---Cortex-M(微控制器/单片机)/Cortex-A(应用级,手机、平板)/Cortex-R(实时的、工业航天…)… ARMv8-------Cortex-A30、ARM Cortex-A50、ARM Cortex-A70 ARMv9 ############################################# 内核...

  • STM32经典概述(干货 )

    首先,在学习Cortex-M3时,我们必须要知道必要的缩略语。 在网上看的,觉得挺好的,分享过来了 整理如下: AMBA:先进单片机总线架构 ADK:AMBA设计套件, AHB:先进高性能总线 AHB-AP:AHB访问端口APB:先进外设...

  • stm32概述

    这篇是在网上看见的,讲的比较好 ... 如果需要转载的请注明出处!...首先,在学习Cortex-M3时,我们必须要知道必要的缩略语。整理如下:AMBA:先进单片机总线架构 ADK:AMBA设计套件 AHB:先进高性能总线 AHB-AP:AHB

  • 汽车电子ECU bootloader开发要点详解

    引言 1. bootloader的功能 2. 如何建立可靠的总线通信? 3. 解析编程文件(S19/HEX/BIN) 4. NVM驱动程序开发 ... 开发bootloader需要掌握的知识和调试方法技巧 d.量产时bootloader和应用程序的下载...

  • Buildroot笔记

    CSDN仅用于增加百度收录权重,排版未优化,日常不维护。... ... 整理Buildroot笔记,包含配置选项注释、目录结构分析、常用命令、构建示例、 使用技巧。 1.Buildroot基本介绍 Buildroot是Linu...

  • C语言程序设计之(一)手机通讯录管理系统

    C语言程序设计之(一)手机通讯录管理系统

  • 清华大学2023级物理学专业本科培养方案

    清华大学2023级物理学专业本科培养方案

  • docbook5-style-xsl-extensions-1.78.1-4.el7.x64-86.rpm.tar.gz

    1、文件内容:docbook5-style-xsl-extensions-1.78.1-4.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/docbook5-style-xsl-extensions-1.78.1-4.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装

  • Python网络爬虫开发指南.docx

    网络爬虫简介, 介绍了网络爬虫, 并讲解了爬取网站的方法。 数据抓取,展示了如何从网 页中抽取数据。 下载缓存, 学习了如何通过缓存结果避免重复下载的问题。 并发下载, 通过并行下载加速数据抓 取。 动态内容, 展示了如何从动态网 站中抽取数据。 表单交互, 展示了如何与 表单进行交互, 从而访问你需要的数据。 验证码处理, 阐述了如何访问被验证码图像保护的数据。 Scrapy, 学习了如何使用流行的高级框架 Scrapy。

Global site tag (gtag.js) - Google Analytics