[APM32F4] 分享变量被异常读写的bug解决

[复制链接]
213|5
天鹅绒之夜 发表于 2025-9-22 13:28 | 显示全部楼层 |阅读模式
同事在编写程序时,定义了一个静态的局部结构体变量。在运行的时候,他发现这个局部变量的值会异常改变,而且改变的值呈现随机、杂乱无章的特征。
他开始对静态局部变量的定义与实现存疑,于是,更新为全局变量,但故障依旧。
把我招呼过去后,我在Review他的代码后,首先明确static定义的局部变量不会被系统回收。再明确了当前通过watch窗口观察到的数据变化是真实有效的,即结构体变量的数据确实被修改了。所以,我定位其原因为“数据溢出,污染到了观察的结构体”。可是,反查代码未看到有紧随变量的操作。哪里有“污染变量”的动作呢?调试一度陷入僵局。
再进行一轮检查时,看到其有DMA操作,再经询问,DMA开启了MEM2MEM测试。关闭此DMA操作,故障清除。
再查其代码,其将DMA的目的地址取自栈上的变量,从而导致全局变量的部分内存被错误改写。话说,系统没有crash也是挺强的。
分享出来,大家在操作DMA的MEM2MEM功能时,一定要确定好内存的地址。

jobszheng 发表于 2025-9-23 15:01 | 显示全部楼层
内存越界,被污染很正常,也很常见。
白天写bug,晚上找bug呗
天体书记 发表于 2025-10-5 11:45 | 显示全部楼层
DMA的工作也MCU不相关,DMA要是出错,排查起来难度就比较大了
 楼主| 天鹅绒之夜 发表于 2025-10-13 20:41 | 显示全部楼层
jobszheng 发表于 2025-9-23 15:01
内存越界,被污染很正常,也很常见。
白天写bug,晚上找bug呗

唉,说多了都是泪啊
黎明热忱 发表于 2025-10-14 19:04 | 显示全部楼层
DMA的源地址也是增长的。也会出现hardfault错误
幻影书记 发表于 2025-10-14 19:24 | 显示全部楼层
其实,MCU进入hardfault大概率还是地址溢出导致的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

2

主题

32

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部