OpenEdv-开源电子网

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

今天调试发现奇怪问题,整数跑乱了。

[复制链接]

29

主题

338

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1181
金钱
1181
注册时间
2018-4-13
在线时间
170 小时
发表于 2018-10-19 09:59:20 | 显示全部楼层 |阅读模式
很简单的程序,int iStep控制程序步调,只有1和2、3三种状态,通过一整晚的运行没有问题,可是今早重新下载运行发现出现两次停运的情况,用ST-Link调试发现停止时iStep变成了一个不该有的值:0x080043C0。
昨天也出现这个问题。昨天iStep也出现乱值,但程序还在运行,只是由于iStep是不该有的值,没有按要求执行了,今天程序停留在main()开头了不运行了。
刚刚打完这几个字,发现精英版的LED等又不闪了......从串口助手看程序应该在运行,可能是iStep又跑没了。


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

29

主题

338

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1181
金钱
1181
注册时间
2018-4-13
在线时间
170 小时
 楼主| 发表于 2018-10-19 10:00:53 | 显示全部楼层
通过ST-Link查看,iStep为0x080043C0,和刚刚一样。
回复 支持 反对

使用道具 举报

1

主题

882

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3071
金钱
3071
注册时间
2018-2-7
在线时间
285 小时
发表于 2018-10-19 10:12:19 | 显示全部楼层
检查一下是不是整数的值超范围了,程序没控制住。
回复 支持 反对

使用道具 举报

8

主题

206

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1010
金钱
1010
注册时间
2016-4-6
在线时间
234 小时
发表于 2018-10-19 11:11:24 | 显示全部楼层
该不会是局部变量定义的时候没有初始化吧?
回复 支持 反对

使用道具 举报

0

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
90
金钱
90
注册时间
2018-10-12
在线时间
30 小时
发表于 2018-10-19 12:32:14 来自手机 | 显示全部楼层
既然是int,怎么可能有这么大呢?
回复 支持 反对

使用道具 举报

0

主题

28

帖子

0

精华

高级会员

Rank: 4

积分
762
金钱
762
注册时间
2018-7-25
在线时间
276 小时
发表于 2018-10-19 16:08:15 | 显示全部楼层
看芯片有没有SWO,有的话将iStep定义为全局变量,然后通过SWO的Data log功能,记录每次变量值被改写的值和PC指针,这样有可能知道是哪条代码导致的了。
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-20 22:58

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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