专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
keil重建工程后编译的结果跟之前不一样
2020-01-01 17:47
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
9573
35
35
编译器:mdk 5.17
如题,因为某些原因我重建了工程,文件还是之前的,但是编译后的hex比之前的小了几kb,最关键的是运行到某段代码竟然死机了。。。
工程的配置还是照之前的配的,重建了两次还是无果,有没有人遇到过这种情况?
ps:.o文件也是发现很多(几乎)多小跟之前的不一样了。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
35条回答
单飞
2020-01-05 23:50
security 发表于 2016-8-3 16:24
首先,祝贺一下
其次,不明觉厉
LZ 可否再详细说明一下,例如贴一些代码片段 ...
这个问题代码不重要,详情是这样的:
系统使用了os,但是os启动前有一段配置信息的代码,而该代码里定义了一个比较大局部变量。该段代码的堆栈分配在.s里(指向msp的堆栈段,与中断共用),该空间只分配的512字节。
那么问题来了,局部变量就接近400多字节,堆栈不溢出也是接近溢出的边缘。
以上都是知道原因后的分析。
其中,这个分析的过程可能是最痛苦的,一段本来没问题的(可能藏有隐患)代码,突然因为重建工程或者只改变文件的排列顺序,然后就变得不能用了。这是件很莫名其妙的事情,一
开始我是埋怨编译器的,然后想方设法恢复之前的样子。但结果不理想,恢复是恢复了,但是调整文件顺序的时候问题复现了,所以我觉得这个问题必须正视,且正面解决。先设法找到
程序崩溃的位置(1猜2屏蔽
),发现有个指针被篡改了,然后就开始仿真,一步一步的找篡改的位置。第一次找到一个调用printf的位置(比较奇怪当时没想通),然后屏蔽,却发
现还有。第二个位置是一个函数嵌套,此时此已经猜得八九不离十了,这个问题肯定是堆栈溢出!!!然后,屏蔽了那个大局部变量,bug就没了,此时皆大欢喜。
最后,整理了一下思路,显示把大局部变量改为静态的,然后把配置信息的代码放在了系统任务里,写了一个启动任务,这样系统启动前只有驱动初始化,msp段堆栈的压力就小了很多。
这样的好处也很明显,使用系统的堆栈段,调试比之前方便。
加载中...
查看其它35个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
这个问题代码不重要,详情是这样的:
系统使用了os,但是os启动前有一段配置信息的代码,而该代码里定义了一个比较大局部变量。该段代码的堆栈分配在.s里(指向msp的堆栈段,与中断共用),该空间只分配的512字节。
那么问题来了,局部变量就接近400多字节,堆栈不溢出也是接近溢出的边缘。
以上都是知道原因后的分析。
其中,这个分析的过程可能是最痛苦的,一段本来没问题的(可能藏有隐患)代码,突然因为重建工程或者只改变文件的排列顺序,然后就变得不能用了。这是件很莫名其妙的事情,一
开始我是埋怨编译器的,然后想方设法恢复之前的样子。但结果不理想,恢复是恢复了,但是调整文件顺序的时候问题复现了,所以我觉得这个问题必须正视,且正面解决。先设法找到
程序崩溃的位置(1猜2屏蔽 ),发现有个指针被篡改了,然后就开始仿真,一步一步的找篡改的位置。第一次找到一个调用printf的位置(比较奇怪当时没想通),然后屏蔽,却发
现还有。第二个位置是一个函数嵌套,此时此已经猜得八九不离十了,这个问题肯定是堆栈溢出!!!然后,屏蔽了那个大局部变量,bug就没了,此时皆大欢喜。
最后,整理了一下思路,显示把大局部变量改为静态的,然后把配置信息的代码放在了系统任务里,写了一个启动任务,这样系统启动前只有驱动初始化,msp段堆栈的压力就小了很多。
这样的好处也很明显,使用系统的堆栈段,调试比之前方便。
一周热门 更多>