听说,电子工程师经常被“狗”咬!

电子技术

48人已加入

描述

  在研发初期,嵌入式工程师都需要在线仿真、调试产品,在这个过程中,有很多工程师在使用仿真器工具(以AK100Pro为例)过程中会遇到的一些异常:

  下载程序一半后进度条停止不前,直至提示下载失败;

  能够顺利进入仿真模式,不久就不能跟踪调试了,单片机自主跑起来了。

  出现上述现象的原因有很多,今天我们就仅从“看门狗”的角度来分析一下到底单片机发生了什么。

  看门狗简介

  在嵌入式系统中,单片机可能会受到外界电、磁等干扰,造成程序异常,从而使系统陷入瘫痪状态。为了防止此类后果发生,便出现了用于监控单片机运行状态的芯片--watch dog,中文译为“看门狗”。看门狗芯片输出端接单片机复位引脚,当在设定的时间间隔内没有收到单片机的脉冲信号(喂狗信号),看门狗内部定时器溢出,拉低复位引脚从而使得芯片复位。目前很多单片机已经内置了内部看门狗电路,原理与外部看门狗类似。

  通过下面几个我们在技术支持过程中遇到的问题,并总结了行之有效的解决办法。

  1. 内部看门狗

  客户采用STM32研发产品,需要为原有的代码增加看门狗程序,然而在用AK100Pro仿真调试时,发现程序在断点处停下来后一会儿,芯片居然自己全速跑起来了。

  单片机分为内核和外设,仿真调试过程中,在断点处停下来后,芯片内核是停止的,而外设则可以选择性的继续运行,如内部看门狗。内核停止,无法喂狗,导致看门狗将芯片复位。

  那么如何解决呢?有两种方法可以实现:一个是在用户程序中对相关寄存器进行初始化如下图所示。在调试时配置芯片的调试寄存器,让内核停止时,同时自动停止看门狗。在STM32F10x手册中,有对DBGMCU_CR寄存器,这个寄存器可以控制调试相关的外设行为。

  智能硬件

  另一个办法是在TKScope驱动设置中,设置【初始化宏】的参数,增加配置项,如下图所示。

  智能硬件

  注意,如果芯片本身没有类似的寄存器,那就只能在芯片初始化时,禁能看门狗了。

  2. 接有外部看门狗,且将看门狗控制端引出到编程接口

  前不久为客户添加Cypress公司的Cortex-M3芯片MB9F8268时,发现下载程序总是到一半,就突然通信不上了。

  智能硬件

  通过抓取数据包查看并分析后发现,复位引脚被周期性的拉低。原来客户板子上有一个外部看门狗芯片,由于编程过程过长,没有及时喂狗,导致芯片复位。

  找到了原因,问题就好解决了。在下载过程中,可以利用JTAG中的时钟线(TCK),将其接在看门狗芯片的控制端,这样在通信过程中就会为看门狗提供持续的脉冲信号,从而避免了看门狗定时器溢出,触发芯片复位了。

  3. 接有外部看门狗,但看门狗控制端未引出

  对于这种情况,由于无法控制外部看门狗,除非断开连接,否则仿真、编程工具也是无能为力的。

  总结

  最后,我们汇总了针对看门狗问题的解决办法,希望客户能够合理设计仿真、编程接口,以及合理设计应用程序,规避看门狗对编程、仿真的影响,别再被“狗”咬:

  用户程序在初始化时,禁能内部看门狗;

  配置【初始化宏】,使得AK100Pro去禁能看门狗;

  用户程序定时喂狗;

  断开外部看门狗;

  将调试时钟接在看门狗控制端,下载过程中可去喂狗。

   身处物联网洪流的你还在等什么!“关注物联网新机遇的你,怎能错过这个饕餮盛宴!!由华强聚丰旗下电子发烧友网举办的第三届“中国IoT大会”将 于12月2日在深圳隆重举行:全球化的 视野、更高价值的独家观点、更专业的技术分享、更前沿的脉动把握,汇聚全球物联网知名企业与精英的盛典,你不可错过!更多信息欢迎大家继续关注电子发烧友 网!”(点击图片查看详情)

 

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

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分