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

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

3天内不再提示

浅析STM32调试过程中的几个相关问题

茶话MCU 来源:cc 2019-01-21 13:50 次阅读

总的来讲,单片机调试是单片机开发工作必不可少的环节。不管你愿不愿意,调试过程中总会有各种不期而遇的问题出现在我们面前来磨砺我们。这里分享几点STM32调试过程中与开发工具及IDE有关的几个常见问题,以供参考。

1、做低功耗调试时连接不上目标板

默认情况下,当MCU进入低功耗模式后,内核时钟停止工作,调试连接将中断。不过,通过设置DBGMCU寄存器控制位,即使进入低功耗模式,还是可以进行一定程度的调试。

在保证DGBMCU控制位正确配置前提下,还需注意SWD调试脚没有被配置为【analog state】模拟输入状态。我们在具体应用时为了降低功耗可能会将芯片的包括SWD调试脚在内的GPIO配置为模拟功能,这样会到导致调试器连接不上情况。此时在连接前先做下复位,有时可能多做几次复位才连接得上。

当然,上面是指低功耗模式下连接不上目标板的情况。如果是一般性的连接不上,原因就更多了,比方硬件器件、连接线路、驱动程序、用户代码本身等,这些要结合具体情况来分析。关于低功耗模式的调试支持,请参考各个系列参考手册的相关描述。

2、打印输出失败

通常我们可以借助于串口助手做打印输出。如果使用STM32虚拟串口,注意PC端的虚拟串口驱动程序安装正常。相应软件包编号是STSW-STM32102。

再就是注意配置UART相关参数配置时,字长是包含了校验位的。比方8位字长,它是由 7个数据位,1个校验位组成。还有,VCP不支持字长在8位以下的传输。

另外,对于那些基于ARM CORTEX M3/M4/M7内核的STM32芯片,我们可以使用SWO方式做打印输出。

这里要注意的是:

a、不是所有MCU系列都支持SWO打印输出;目前仅基于ARM Cortex M3/M4/M7内核的芯片支持;

b、目前只支持SWD模式,不支持JTAG模式;

c、在调试环境里需做适当配置和代码补充,涉及到DBG_MCU_CR寄存器的控制位。

3、低功耗应用中功耗数据异常

这个原因很多,比方,测量方面的原因,不属于MCU的功耗也算进来了;有些外设及管脚没处理好,导致漏电流还在产生; 或者低功耗模式选择不对,或者进了低功耗模式马上又醒了而误测误判等等。

这里再提醒1点:

设置进入低功耗模式后,确认是否还在调试模式。即检查DBGMCU寄存器中与低功耗调试配置有关的寄存器控制位,确保关闭了低功耗调试状态。做低功耗数据测试时,最好不要还连接着调试器,给我们带来困扰。前不久就有人反映,用别的调试器连接着STM32目标板测得功耗与用STLINK调试器连接着测得功耗大不 一样,改用STLINK就合理了。

4、在Normal/System Reset模式下SWD连接不上目标板

此时我们可以尝试换个连接模式,比如Connect Under Reset,或者换个复位模式,比如Hardware Reset 。

如果说借助STLINK,即使使用Connect Under Reset或Hardware Reset方式还连接不上呢?我们可以查看下STLINK的NRST脚与目标板上的MCU的NRST脚是否相连了。如果是nucleo板的话,还需确认下跳线SB12是否为连接状态。

5、MCO脚无时钟信号输出

我们在STM32调试过程中,有时需要引出主时钟进行输出监视,即将主时钟通过MCO脚引出观察。

要想正确输出,MCO做正确配置是必须的了。当然用CubeMx配置的话一般不会有啥大问题 。不过有个地方要注意,那个GPIO的输出速率参数要合适配置,不同STM32系列的GPIO最大可输出速率在数据手册上都明确出来了。当MCO输出时钟频率较高以至于超过GPIO的输出能力时,这时需要考虑先做分频后再来做观察。

一般来讲,当MCO的输出频率在1Mhz以上时,如果观察到的波形带有很严重的噪声或者扁平的小幅度信号,甚至看不到输出的时候,我们可以考虑下是否那个OSPEED参数设置得太小了;如果说看到周期较长、幅度较大带有明显上下峰值过冲情形的波形,我们可以考虑下是否那个OSPEED参数设置得太大了。

6、没法对某些变量进行计算和监控或无法设置断点

这个原因较多,具体到调试环境,很可能跟你编译环境的优化等级配置有关。

我们在MCU调试过程中,往往会用到编译器的优化功能来提升芯片的性能和精简代码空间。不过,经过代码优化,往往可能给我们调试带来些影响,主要体现在下面几个方面:

a、 设置断点方面出现障碍,有些代码行没法做断点的设置;

b、 无法对某些变量进行观察;

c、 单步调试时出现代码运行“不连续”的情形,即执行到的地方和我看到的地方不一致;

因此,为了实现有效调试,我们在通过编译器做优化时要选择合适的优化等级。基本原则是不影响调试体验的前提下保障编译效率。一般来讲,在调试时建议将优化等级设置在较低水平。比方KEIL MDK 推荐调试时将优化等级设置在-O1, IAR 推荐调试时将优化等级设置在-None,GCC推荐调试是将优化等级设置在-Og.其实,编译器的优化等级设置越高,对代码的规范性要求以及我们对编译器的了解程度也越高。经常有人代码优化前程序运行得好好的,代码优化等级调高好程序功能变得面目全非了。

上面提到的几个问题及应对措施,都是些可能性的提示或提醒,仅供参考,毕竟调试过程中出现的一个故障现象往往可以映射出多种应用情形及具体原因。

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

    关注

    146

    文章

    17141

    浏览量

    351058
  • STM32
    +关注

    关注

    2270

    文章

    10897

    浏览量

    355813

原文标题:STM32调试过程中跟工具相关的几个问题

文章出处:【微信号:stmcu832,微信公众号:茶话MCU】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    为什么nulink会在调试过程中时不时的中断?

    为啥nulink 会在调试过程中时不时的中断?是不是要设置什么?
    发表于 01-17 06:52

    ADS1216芯片调试过程中数据采集一直不对

    有谁用过ADS1216这颗芯片啊,在调试过程中数据采集一直不对,不知道该如何配置它寄存器,具体怎么操作的,谁有demo或相关的例子程序啊?
    发表于 02-27 14:42

    AD芯片在调试过程中遇到的问题,应该怎么解决?

    AD芯片在调试过程中遇到的问题,应该怎么解决?一款TI/国半的超高速ADC调试经验分享
    发表于 04-09 06:41

    为什么你的示波器抓不到调试过程中的异常信号呢?

    如何让您在调试异常信号一览无余呢?为什么你的示波器抓不到调试过程中的异常信号呢?
    发表于 04-29 06:27

    STM32调试过程中常见的问题有哪些

    STM32调试过程中常见的问题及解决方法一、 在“Debug选项卡”下设置好仿真器的类型后,下载程序时却提示“No ULINK Device found.” 解决办法: Keil MDK默认
    发表于 08-06 06:12

    STM32F103RCT6项目调试过程中遇到了一些问题

    STM32F103RCT6项目调试过程中遇到了一些问题,现在总结记录一下,以留后用。程序经过调试没有问题,所有问题都可以说是硬件问题。出现的主要问题可以分为以下几类:电源问题、时钟问题、焊接问题。
    发表于 08-11 08:49

    记录一次STM32H743 CANFD调试过程中的一次BUG

    记录一次STM32H743 CANFD调试过程中的一次BUG
    发表于 08-13 06:30

    STM32的CAN总线调试过程中的一些小总结

    调试过程中的一些小总结
    发表于 08-19 06:06

    STM32调试过程中头哪些常见的问题

    STM32调试过程中头哪些常见的问题?怎样去解决这些问题呢?
    发表于 11-03 06:42

    电源设计调试过程中的异常现象分析

    调试过程中所看到的一些异常现象,以及后来的解决办法。其实很多工程师认为设计电源是非常重经验的一门技术,要见多识广。这种经
    发表于 10-09 10:49 1696次阅读

    变频器调试过程中的注意事项及其5个因素的介绍

    变频器的调试工作相对较复杂,一般设备使用厂家很难独立完成,基本上都会要求变频器生产厂家来协助其配合完成整个设备的调试工作。所以在变频器的调试过程中,不论是使用厂家还是生产厂家都要考虑和注意这些
    发表于 11-01 09:00 2次下载

    单片机调试过程中调试组件导致的问题

    单片机调试过程中,经常会遇到类似第3只眼的问题。何谓第3只眼呢?
    的头像 发表于 12-30 17:12 7395次阅读
    单片机<b class='flag-5'>调试过程中</b>的<b class='flag-5'>调试</b>组件导致的问题

    嵌入式开发过程中的一点调试经验

    嵌入式开发过程中的一点调试经验嵌入式开发最麻烦的在现场调试过程中或实际运营过程中出现问题很难定位。我在实际开发过程中一点经验分享给大家嵌入式
    发表于 11-02 18:06 15次下载
    嵌入式开发<b class='flag-5'>过程中</b>的一点<b class='flag-5'>调试</b>经验

    电磁流量计调试过程中存在的问题以及解决措施

    对流量计内部设置参数进行仔细检查,还需要调试显示数据情况和信号反馈情况,查看它们是否处于正常运行状态下。接下来就详细介绍电磁流量计调试过程中存在的问题以及解决措施。
    的头像 发表于 10-27 09:08 1468次阅读

    STMCU应用过程中与电源相关的案例分享

    我们在从事STM32单片机的应用开发及调试过程中,往往会碰到各类异常。其中有不少比例的问题跟电源有关。
    的头像 发表于 08-04 14:52 601次阅读
    STMCU应用<b class='flag-5'>过程中</b>与电源<b class='flag-5'>相关</b>的案例分享