常见的仿真器陷阱之看门狗篇

  • 格式:pdf
  • 大小:199.82 KB
  • 文档页数:3

下载文档原格式

  / 3
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

常见的仿真器陷阱之看门狗篇

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

这只“狗”叫作“看门狗(watch dog)”。

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

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

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

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

看门狗简介

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

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

1.内部看门狗

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

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

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

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

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

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

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

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

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

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

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

总结

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

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

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

●用户程序定时喂狗;

●断开外部看门狗;

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

产品链接:/product_details.php?id=4