查看原文
其他

如何解决IAR不能设置断点的问题

strongerHuang strongerHuang 2021-01-31


写在前面

有网友问:我在使用IAR在线调试过程中不能打断点,但在编辑的时候可以打断点,一点击调试按钮之后,所打的断点就失效了······


类似的问题:在先调试过程中,在反汇编的窗口中可以设置断点,在C编译区不能设置断点。


查看断点的方法:菜单view->breakpoints 就会在窗口显示所有断点信息。


通常出现这类现象是因为你要加断点的位置并没有程序(或不匹配程序),也就是你的C代码和你的实际代码对不上号了。遇到以上问题,解决的办法一般有下面几种。


常见解决办法

1.Rebuild All重新编译

A.Project -> Clean:把前面编译后的文件删除;

B.Project -> Rebuild All:再重新编译所有文件。

这种情况比较常见,有可能是在更改了部分文件。


2.查看配置是否正确

A.生产Debug信息

Project -> Options -> C/C++ Compiler -> Output:勾选上“Generate debug informat” 这个选项。


B.链接包含Debug信息

Project -> Options -> linker -> Output:勾选上“Include debug information in output ” 这个选项。


3.代码优化等级较高

在某些场合下,比如要求执行代码的速度,或者代码容量比较大而芯片容量又有限,就需要对代码进行优化,优化的等级分多种。

没有特别要求,代码就可以不用优化。代码高度优化存在弊端,特别是代码不规范的情况下。有一点就是本文说的,高度优化的代码,会影响在线调试,可能你某部分代码被优化导致你不能打断点。


这个时候就容易出现:在先调试过程中,在反汇编的窗口中可以设置断点,在C编译区不能设置断点。


Project -> Options -> C/C++ Compiler -> Optimizations选择优化的等级:


4.代码处于条件编译未选中状态

什么是条件编译呢?

就是#if #else #endif 这类带有#的预处理编译。

如果你的代码不再预编译里面,则不能打断点。


5.推测的问题

我们都知道软件一般都会存在bug,即使是强大的Windows、iOS、Android操作系统也经常修复或升级。


若怀疑是IAR软件自身的问题,建议升级到最新。我个人喜欢尝试新鲜的东西,之前看过我文章的人都知道,Keil、IAR新版我和大家分享过。若你IAR出现此类问题,上面几种方法都无效,建议更新IAR版本:


IAR for STM8介绍、下载、安装与注册


IAR for ARM介绍、下载、安装与注册


其他问题都排除了,还有可能是Windows系统高度优化的问题,这个建议重装系统。


最后

微信搜索“EmbeddDeveloper” 或者扫描下面二维码、关注,查看更多精彩内容!


    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存