OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3157|回复: 10

全局结构体莫名被纂改,跪求如何快速定位野指针位置

[复制链接]

6

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
79
金钱
79
注册时间
2018-11-26
在线时间
21 小时
发表于 2019-8-15 11:33:49 | 显示全部楼层 |阅读模式
10金钱
本人使用的是STM32F107VC+LWIP+DP83848,用一个全局结构体来保存设备的参数,参数是保存到STM32片内Flash的最后一页,主要的参数就是设备的IP地址、MAC地址、子网掩码等等。
程序一开始是运行得很好的,但是有的设备运行了一段时间(可能是1周、可能是1个月、可能永远不会出现)以后,就会发现结构体的参数乱了,并且还把错误的参数写入到了Flash里面
简直让人奔溃啊,我们的设备是用在工业上的,安装的地方很高,每次参数乱了,就会导致网络ping不通,需要重新把设备拆下来,连接串口才能重新配置网络参数,这很很致命。关键是,
这个问题很难复现,有的设备根本不会出现这个问题,有的设备一周就能出现了,而一旦出现,就是很大的缺陷,不知道如何调试才好。因此求助各位广大网友,应该如何去定位这种问题
发生的原因,提供一些调试的思路。感谢!

最佳答案

查看完整内容[请看2#楼]

很可能是内存溢出导致的,可以给参数设置一个备份区域,程序隔断时间检测一下设备参数和备份区域的参数是否一致。若参数不一致报警或者自动重写参数。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

882

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3071
金钱
3071
注册时间
2018-2-7
在线时间
285 小时
发表于 2019-8-15 11:33:50 | 显示全部楼层
很可能是内存溢出导致的,可以给参数设置一个备份区域,程序隔断时间检测一下设备参数和备份区域的参数是否一致。若参数不一致报警或者自动重写参数。
回复

使用道具 举报

2

主题

35

帖子

0

精华

高级会员

Rank: 4

积分
533
金钱
533
注册时间
2014-5-17
在线时间
81 小时
发表于 2019-8-15 17:57:22 | 显示全部楼层
1. 楼上说的,看看有没有缓冲区溢出情况,即接受数据最大长度不受控,给你一个假数据帧,你当真了,结果里面的数据量超长;
2.建议看看MAP文件,看看被不该被改,但被改变的结构体的前后有什么变量(可以看看前后多少个变量,扩大范围),这些变量会不会被指针访问,这些访问的指针有没有越界的可能。
回复

使用道具 举报

10

主题

277

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2075
金钱
2075
注册时间
2016-8-15
在线时间
413 小时
发表于 2019-8-15 13:40:29 | 显示全部楼层
在什么情况下,程序会把设备参数存入到flash中?
我的简书:https://www.jianshu.com/u/3e9efbf4a8c2
回复

使用道具 举报

8

主题

293

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1001
金钱
1001
注册时间
2018-8-16
在线时间
327 小时
发表于 2019-8-15 13:40:58 | 显示全部楼层
没有捷径,只能检查所有使用了指针或数组的地方,看看是否未分配空间或未初始化赋值就使用了。
回复

使用道具 举报

0

主题

2

帖子

0

精华

新手入门

积分
9
金钱
9
注册时间
2019-8-12
在线时间
1 小时
发表于 2019-8-15 13:42:58 | 显示全部楼层
可以将这些参数保存在多个存储空间,每次读的时候对比下
回复

使用道具 举报

11

主题

1044

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3722
金钱
3722
注册时间
2011-5-23
在线时间
2013 小时
发表于 2019-8-15 14:04:42 | 显示全部楼层
JTAG下写断点
RT-Thread RTOS 音频,WIFI,蓝牙
回复

使用道具 举报

3

主题

51

帖子

0

精华

高级会员

Rank: 4

积分
530
金钱
530
注册时间
2017-7-25
在线时间
188 小时
发表于 2019-8-15 15:42:03 | 显示全部楼层
flash不是要有特定操作才能修改么
加个日志记录出问题时参考
回复

使用道具 举报

6

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
79
金钱
79
注册时间
2018-11-26
在线时间
21 小时
 楼主| 发表于 2019-8-16 21:39:33 | 显示全部楼层
HXYDJ 发表于 2019-8-15 16:29
很可能是内存溢出导致的,可以给参数设置一个备份区域,程序隔断时间检测一下设备参数和备份区域的参数是否 ...

非常感谢答复,根据你提供的思路,我直接在程序中主循环中加了一个判断,用于对比全局结构体和Flash中的参数,当全局结构体和Flash直接读出来的参数不一致的时候,应该就是发生了内存溢出的情况了,就把Flash中的参数更新到全局结构体上,来保证全局变量的稳定。
----------------------------------------------------------------------------------------------目前临时就这样做了,因为这个问题很难复现,说明也是不经常发生,只要能够判断它发生了及时矫正就行。
----------------------------------------------------------------------------------------------
最终想要彻底解决,估计最简单的调试方法是用JTAG的写中断,就是写到了这个结构体所在的内存的时候,就产生中断,然后看看是哪里导致的,到时候拿一个JTAG直接煲机,看看行不行。
回复

使用道具 举报

3

主题

347

帖子

3

精华

金牌会员

Rank: 6Rank: 6

积分
2082
金钱
2082
注册时间
2014-12-19
在线时间
711 小时
发表于 2019-8-17 07:08:21 来自手机 | 显示全部楼层
全局变量定义3份,flash备份定义3份,只有2个及以上备份数据相同才执行,否则就可能是RAM出错,要发警告或执行其他补救措施。
回复

使用道具 举报

3

主题

1907

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4106
金钱
4106
注册时间
2018-8-14
在线时间
696 小时
发表于 2019-8-17 11:06:23 | 显示全部楼层
这类Bug要靠ErrorLog来抓, 如果说平时有养成在各个奇异处加Assert就很容易加ErrorLog
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-8 15:52

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表