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

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

3天内不再提示

代码单步调试失联原因及解决方法

GReq_mcu168 来源:鱼鹰单片机 作者:鱼鹰单片机 2022-07-04 16:40 次阅读

不知道你是否有这样的体验:代码单步调试,调着调着,出现了下面的提示框:

很多时候,莫名其妙,一般情况,只能退出调试,再重新进入。

一般没啥影响,但有的时候,我们是为了抓 BUG 现场才进入的调试模式《BUG 终结者,现场抓获!|颠覆认知》,一旦因为失联导致不能继续调试,估计得骂娘了(BUG 容易复现还好,下次在来,但是很难复现的话,就麻烦大了)。

那会是什么导致失联了呢?

鱼鹰总结了以下几种可能:

1、调试器连线(PC 到调试器,调试器到芯片)不正常。

2、MDK 软件问题

3、MDK 工程兼容问题

4、看门狗复位(窗口、独立看门狗)

连线问题好解决,各种换即可,MDK 软件问题,只能说尽量找个稳定的版本了。另外就是 MDK 工程兼容的问题,比如这个项目开始不是你负责的,后来你入职了,用了另一个版本的 MDK,再次打开这个工程的时候,就可能出现问题,一般来说,这种情况下,不要嫌麻烦,直接新建工程即可(可以看这篇笔记《如何快速更换 MDK 工程?》)。

还有一种很容易忽略的可能是,项目代码开启了看门狗,单步调试时间太长,没有及时喂狗导致复位。

此时,我们又该如何解决呢?这就是本篇笔记的重点。

参考手册最后面,我们可以看到这个寄存器 DBGMCU_CR。

这里我们看看独立看门狗这个位的介绍:

可以看到,这个作用就是,当我们进入调试状态时,看门狗计数器停止工作。

F103 函数设置如下:

DBGMCU_Config(DBGMCU_IWDG_STOP, ENABLE);

什么意思?就是说,当我们在单步调试,程序停下来进行分析的时候,因为设置了该位,就可以让计数器不工作,这样一来,即使停止再久的时间,只要在调试模式下,都不会因为看门狗而复位,因为计数器已经不工作了,也就不能触发复位动作了。而一旦退出调试模式,看门狗继续正常工作。

这样也就不会导致前面说的失联问题,可以让你专心分析代码逻辑。

那如果说,原来的代码没有考虑这个点,没有配置这个位,咋办?

如果看门狗超时时间比较长(十几秒以上),你完全可以在进入调试模式后,从容打开寄存器窗口,手动设置该位,这样临时抱佛脚的行为也能起作用。

那如果只有几秒钟咋办?手动操作可能根本来不及,鱼鹰在此再支一招:

使用 MDK 中的 ini 文件,让其进入调试模式的同时,自动设置该位,相当方便。

那如果是毫秒级别的呢?自求多福吧,或许 ini 的方法可以解决,或许进入调试模式后,在程序运行的时候(别停!!!),先用 MDK 的命令窗口或寄存器窗口设置一下该位,再停止程序运行去分析问题。

总之,一定要先把这个位给设置了再慢慢调试分析,否则,可能调着调着,最终调了一个寂寞。

原文标题:代码调着调着就失联了???

文章出处:【微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

审核编辑:汤梓红


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

    关注

    7

    文章

    578

    浏览量

    33926
  • 代码
    +关注

    关注

    30

    文章

    4786

    浏览量

    68549
  • MDK
    MDK
    +关注

    关注

    4

    文章

    209

    浏览量

    32066

原文标题:代码调着调着就失联了???

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    服务器错误是怎么回事?常见错误原因解决方法汇总

    服务器错误是怎么回事?最常见的原因分有六个,分别是:硬件问题、软件问题、网络问题、资源耗尽、数据库、文件权限问题。可以根据以下具体错误原因进行辨别,并选择适合的解决方法。关于常见服务器原因
    的头像 发表于 08-12 10:11 1464次阅读

    ESP-IDF单步调试就报错怎么解决?

    /item.htm?_u=63g ... 1910969830),想做LVGL的开发,现在想做单步调试,完全找不到方向,不知道怎么进行,查了一些资料,现在OPENOCD已经正常了,但是一开始调试就弹出错误提示
    发表于 07-02 08:30

    请问ESP32-C3和ESP32-S2或WROOM系列是否支持单步调试

    ESP32-C3-DevKitM-1或者ESP32-S2、ESP32-WROOM-32D目前能够进行单步调试吗,官方文档中,C3芯片中英文版的Programming Guide说法上有些出入
    发表于 06-21 07:32

    接地网阻值偏大的原因解决方法

     地网接地电阻测试仪是保障电气设备安全运行的重要组成部分,但在实际使用中,我们可能会遇到接地网阻值偏大的情况。接下来,鸿蒙小小编介绍造成这种情况的原因,并提供一些解决方法。   1、接地体积不足
    发表于 06-17 09:19

    Tektronix示波器无法检测到探头的可能原因解决方法

    在使用 Tektronix 示波器进行测量时,有时可能会遇到无法检测到探头的情况。这可能是由多种因素引起的,下面将详细介绍可能的原因以及解决方法。 1. 探头连接问题 原因: 探头未正确连接到示波器
    的头像 发表于 05-08 11:09 741次阅读
    Tektronix示波器无法检测到探头的可能<b class='flag-5'>原因</b>及<b class='flag-5'>解决方法</b>

    STM32CUBEID单步调试总是会乱跳,中间跳过好几步直接进入while循环去,为什么?

    还需要怎么设置啊,这样不能单步调试太难了!
    发表于 03-28 06:25

    关于stm32f407的spi2调试稳定性问题求解

    成功通信了。请问这种情况是什么原因?十分感谢。 同样的现象是:当我单步调试并能跟spi设备成功通信后,我给板子断电后再上电,然后进行下一次单步调试,发现跟spi设备就又不能成功通信了。
    发表于 03-27 08:10

    使用单步调试发现单片机能够接收到连接请求信号,但是无法返回信号是怎么回事?

    使用单步调试发现单片机能够接收到连接请求信号,但是无法返回信号; 报错信息如下:Connection failed! No response, check the communication
    发表于 03-27 06:07

    MCSDK 5.2电机启动后经常导致串口原因有哪些?

    我用5.2的库生成的FOC程序对电机进行控制,上电后通过workbench 控制电机,正常启动电机后,串口会,电机还保持着前的状态转动
    发表于 03-15 06:37

    PCB产生串扰的原因解决方法

    PCB产生串扰的原因解决方法  PCB(印刷电路板)是电子产品中非常重要的组成部分,它连接着各种电子元件,并提供电气连接和机械支撑。在 PCB 设计和制造过程中,串扰是一个常见的问题,它可
    的头像 发表于 01-18 11:21 2032次阅读

    PCB焊盘脱落的原因解决方法

    PCB焊盘脱落的原因解决方法? PCB(印刷电路板)焊盘的脱落是一个常见的问题,它会导致电子设备无法正常工作。本文将详细介绍焊盘脱落的原因以及解决方法。 一、焊盘脱落的
    的头像 发表于 01-18 11:21 6794次阅读

    电流探头干扰的原因解决方法

    电流探头干扰的原因解决方法  电流探头干扰是指电流传感器(也称电流探头或电流传感器)在测量过程中,由于外界原因引起的测量值的误差或干扰。这些干扰可能来自电源线、电磁辐射、接地线、相邻传感器等。本文
    的头像 发表于 01-08 16:08 1336次阅读

    电阻屏触摸失灵的原因解决方法

    电阻屏触摸失灵是指在使用电阻屏时,手指或触摸笔无法正常识别触摸操作,导致无法进行正常的操作。这种情况可能是由于多种原因引起的,下面将介绍一些常见的原因解决方法。 屏幕表面脏污:电阻屏的工作原理
    的头像 发表于 12-28 17:34 7877次阅读

    WLAN显示不可上网的原因分析及解决方法

    WLAN显示不可上网的原因分析及解决方法  WLAN(无线局域网)是一种无线通信威廉希尔官方网站 ,可以使设备通过无线方式连接互联网。然而,有时我们可能会遇到WLAN显示不可上网的问题。 起初,要明确
    的头像 发表于 12-28 11:15 2611次阅读

    以太网阻塞的常见原因解决方法

    以太网阻塞的常见原因解决方法 以太网阻塞是指在以太网中数据流量增加超过网络设备处理能力的情况下,导致网络性能下降、延迟增加、丢包率上升等问题。下面将详细讨论以太网阻塞的常见原因解决方法
    的头像 发表于 12-27 13:58 1254次阅读