共1条
1/1 1 跳转至页
分享变量被异常读写的bug解决
同事在编写程序时,定义了一个静态的局部结构体变量。在运行的时候,他发现这个局部变量的值会异常改变,而且改变的值呈现随机、杂乱无章的特征。他开始对静态局部变量的定义与实现存疑,于是,更新为全局变量,但故障依旧。把我招呼过去后,我在Review他的代码后,首先明确static定义的局部变量不会被系统回收。再明确了当前通过watch窗口观察到的数据变化是真实有效的,即结构体变量的数据确实被修改了。所以,我定位其原因为“数据溢出,污染到了观察的结构体”。可是,反查代码未看到有紧随变量的操作。哪里有“污染变量”的动作呢?调试一度陷入僵局。再进行一轮检查时,看到其有DMA操作,再经询问,DMA开启了MEM2MEM测试。关闭此DMA操作,故障清除。再查其代码,其将DMA的目的地址取自栈上的变量,从而导致全局变量的部分内存被错误改写。话说,系统没有crash也是挺强的。分享出来,大家在操作DMA的MEM2MEM功能时,一定要确定好内存的地址。
关键词: 变量 异常
共1条
1/1 1 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| OK1126B-S开发板下函数构建及步进电机驱动控制被打赏¥25元 | |
| 【S32K3XX】LPI2C 参数配置说明被打赏¥20元 | |
| OK1126B-S开发板的脚本编程及应用设计被打赏¥27元 | |
| 5v升压8.4v两节锂电池充电芯片,针对同步和异步的IC测试被打赏¥35元 | |
| 【S32K3XX】S32DS LPI2C 配置失败问题解决被打赏¥22元 | |
| 【S32K3XX】FLASH 的 DID 保护机制被打赏¥19元 | |
| OK1126B-S开发板串口通信及其使用被打赏¥18元 | |
| 【S32K3XX】多核 CORE ID 获取被打赏¥18元 | |
| OK1126B-S开发板的GPIO资源及其使用被打赏¥20元 | |
| 【分享开发笔记,赚取电动螺丝刀】三分钟快速上手驱动屏幕(Arduino IDE环境)被打赏¥23元 | |
我要赚赏金
