OpenEdv-开源电子网

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

STM32F103,运行没问题,调试时乱跳并且不对

[复制链接]

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
发表于 2017-11-24 11:30:02 | 显示全部楼层 |阅读模式
10金钱
单片机:STM32F103C8T6;
测试功能:通过检测按钮状态, 点亮或熄灭指示灯
故障现象: 写好代码后,下载程序,运行时一切正常;
但是当我用JLINK调试时,运行顺序不对,并且会进入一些本不应该进入的行中,但是通过外部的指示灯表明其实没有运行此行
所以怀疑是disassembly window中有问题(我对汇编不太懂);
通过分析disassembly window中,发现代码和汇编对应在有些地方对应的不对;
本人将代码行和disassembly window中代码拿出来;
这个问题已经查了一个星期了,就几行代码,已经让我开始怀疑人生了,跪求各位大神(也希望偶像原子大人显神通)

最佳答案

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

可能和编译器的优化有关吧
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

349

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1046
金钱
1046
注册时间
2017-5-19
在线时间
335 小时
发表于 2017-11-24 11:30:03 | 显示全部楼层
可能和编译器的优化有关吧
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 11:49:26 | 显示全部楼层
图片:

disassembly window

disassembly window

代码

代码
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 11:50:58 | 显示全部楼层
代码 图片旁边的是调试时候的顺序,第4本不应该进去的
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 11:51:33 | 显示全部楼层
这个问题,在网上找了好长时间都没有出现,原子大人快来吧
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 11:54:54 | 显示全部楼层
任何人只要能够提供正确的信息的,并且我测试后能够解决的,立马红包 66 块钱!
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 11:55:17 | 显示全部楼层
红包66
回复

使用道具 举报

5

主题

13

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2017-11-21
在线时间
17 小时
发表于 2017-11-24 12:52:07 | 显示全部楼层
能不能使用串口1下载程序?或者使用ST-LINK V2下载器下载程序?你这个问题我昨天刚解决完,给一些提示,就是新的芯片里面,boot脚全拨0,用ST下载的程序会乱跳或者不走,只是运行完初始化就不动了,最惨的是下载了之后ST竟然就不能用了。怎么下载都下载不进去,后来只能用串口1,boot0接1,boot接0, 接上去使用串口1 全片擦除,擦除的时候需要复位一下。擦除完再把两个boot拨回0.。。。。。。。恩,就可以重新烧录运行。。。。当然要保证代码是正确的,再还有一个,就是ST官方也说了,使用库里面的时钟的频率不对,也会导致芯片不运行,只能运行初始化或者跑飞什么的,这个问题我也怀疑了很久,因为从网上买过最小系统板烧录是没问题的代码,但是偏偏就是那么莫名其妙,我从网上复制了一段使用内部时钟的代码放到初始化里,问题竟然解决了,不知道能不能帮到你
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 13:07:22 | 显示全部楼层
我这个运行完全没有问题, 就是监控调试的时候,代码跳的位置不对,有些地方如判断条件不应该进的,却进去了,但是根据外面的指示灯来看的话,却实际没有运行。我怀疑是DISASSEMBLY WINDOW中的问题
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 13:09:00 | 显示全部楼层
监控调试时候,虽然单步跳会乱跳,但是程序在外边看的逻辑却没有问题(因为我外边接了按钮和指示灯)
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 13:12:26 | 显示全部楼层
感觉只是DISASSEMBLY window中代码 和 汇编对应的一种假象,我也用STM32F103和STM32F407开发了2年的项目了(公司就是做这个开发的),第一次遇到这么奇葩的情况(运行没问题,JLINK监控虽然有问题,但是实际上外部的指示灯都是按照正常亮的,并不是按照程序调试的情况,所以很怀疑disassembly window的代码对应一块的问题)
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 13:13:10 | 显示全部楼层
望大神或者原子给与支持
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 14:53:42 | 显示全部楼层
我也是这么想的,查了一些资料,但是具体如何可以解决这个问题不知道
回复

使用道具 举报

10

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
173
金钱
173
注册时间
2017-8-4
在线时间
45 小时
发表于 2017-11-24 15:56:38 | 显示全部楼层
程序里面有没有加看门狗?调试的时候把看门狗注释掉
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 18:00:47 | 显示全部楼层
没有看门狗
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 18:20:48 | 显示全部楼层
下面这个代码是我缩减了,只剩下关键地方的代码,里面有说明,注释和不注释的功能都是点亮灯,如果用注释的调试流程就对,用注释的调试流程不对;但是从外边看的现象都是正确的,就是说实际运行并不像监控中看到的那样

新建位图图像 (3).jpg
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 18:25:29 | 显示全部楼层
下边是源代码,

BUG_CODE.rar

7.64 MB, 下载次数: 181

回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 18:27:06 | 显示全部楼层
我出红包166,如果有大神能够解决这个BUG的,虽然不多,只是表达谢意。
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 18:27:26 | 显示全部楼层
第一次发帖,望大神出现
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-24 19:23:57 | 显示全部楼层
貌似找到原因了, 还在测试中。。。。。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-11-25 00:00:49 | 显示全部楼层
张宇 发表于 2017-11-24 19:23
貌似找到原因了, 还在测试中。。。。。

哪里的问题?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-25 09:43:03 | 显示全部楼层
可能跟这个有关系, 我先再测试一下,如果确实是这个问题,红包66就是你的了
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-25 09:44:42 | 显示全部楼层
就是编译器优化的问题,但是感觉这个还是很诡异,说不清楚。我把编译器优化调整到0后,暂时没问题了,不确定到底是不是编译器优化的问题。最好有一个大神能够用程序直接看看才好。
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-25 09:45:10 | 显示全部楼层
如果测试没问题,红包是那个最佳答案的那个的
回复

使用道具 举报

4

主题

349

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1046
金钱
1046
注册时间
2017-5-19
在线时间
335 小时
发表于 2017-11-25 21:11:50 | 显示全部楼层
大家互相帮忙,提钱太俗,都是被软件硬件虐了无数次的
回复

使用道具 举报

1

主题

9

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2017-6-17
在线时间
6 小时
发表于 2017-11-26 10:58:58 来自手机 | 显示全部楼层
优化度为0,编译器不会优化你的代码,完全按照你的代码来执行;优化度非0,编译器会根据你的代码适当优化一下,在保证你的功能的前提下改变你代码的扏行顺序,优化度越高,这差异就越大
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-26 13:23:19 | 显示全部楼层
wxjhby 发表于 2017-11-25 21:11
大家互相帮忙,提钱太俗,都是被软件硬件虐了无数次的

说出去的话泼出去的谁,之前跟你说的是66,你把微信号给我,我发给你,否则我就不仁义了
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-27 14:24:08 | 显示全部楼层
wxjhby 发表于 2017-11-25 21:11
大家互相帮忙,提钱太俗,都是被软件硬件虐了无数次的

大哥,你的微信号是多少?
回复

使用道具 举报

0

主题

10

帖子

0

精华

高级会员

Rank: 4

积分
597
金钱
597
注册时间
2017-8-29
在线时间
46 小时
发表于 2017-11-28 09:03:56 | 显示全部楼层
我也遇到过这个问题,确实是编译器优化的原因,当时也是非常疑惑,很长时间没有解决,最后我甚至放弃MDK,用IAR调试发现优化级别太高同样会出现这个问题。之后又回到MDK把编译器优化级别调低后问题就再也没有出现过了。
回复

使用道具 举报

4

主题

32

帖子

0

精华

新手上路

积分
33
金钱
33
注册时间
2017-11-24
在线时间
10 小时
 楼主| 发表于 2017-11-30 17:36:47 | 显示全部楼层
luò 发表于 2017-11-28 09:03
我也遇到过这个问题,确实是编译器优化的原因,当时也是非常疑惑,很长时间没有解决,最后我甚至放弃MDK, ...

听了你这个经验, 我更加确定是这个问题了,同时也感谢所有提供帮助的大神
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 17:45

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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