OpenEdv-开源电子网

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

我用STM32F107测得单指令执行时间大约100多ns,根本不是1/72M,求指点

[复制链接]

2

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
57
金钱
57
注册时间
2018-10-10
在线时间
18 小时
发表于 2018-10-10 09:44:16 | 显示全部楼层 |阅读模式
1金钱
朋友们,我用STM32F107测得单指令执行时间大约100多ns,根本不是1/72M,我使用的库是3.5版本,已经定义了宏变量:#define SYSCLK_FREQ_72MHz  72000000,还有哪里需要设置吗?

最佳答案

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

楼主确认测量的是汇编的一个指令,而不是C语言中的一个语句? 另外一条汇编指令也不代表它运行就只有一个时钟周期啊。ARM的指令体系比较复杂,取指令、译码、执行都是需要耗费时间的,硬件上通过多条指令流水线或者指令地址预测的方式来进行译码,实际运行中的不确定性比较大,也有一定可能性得不到精准的运行时间测量。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

756

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4163
金钱
4163
注册时间
2017-10-24
在线时间
251 小时
发表于 2018-10-10 09:44:17 | 显示全部楼层
楼主确认测量的是汇编的一个指令,而不是C语言中的一个语句?

另外一条汇编指令也不代表它运行就只有一个时钟周期啊。ARM的指令体系比较复杂,取指令、译码、执行都是需要耗费时间的,硬件上通过多条指令流水线或者指令地址预测的方式来进行译码,实际运行中的不确定性比较大,也有一定可能性得不到精准的运行时间测量。
十六进制带我飞。
回复

使用道具 举报

24

主题

695

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1666
金钱
1666
注册时间
2016-4-29
在线时间
266 小时
发表于 2018-10-10 12:32:13 | 显示全部楼层
同问楼主的测量方法
回复

使用道具 举报

2

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
57
金钱
57
注册时间
2018-10-10
在线时间
18 小时
 楼主| 发表于 2018-10-10 13:49:18 | 显示全部楼层
DreamWaterPro 发表于 2018-10-10 11:10
楼主确认测量的是汇编的一个指令,而不是C语言中的一个语句?

另外一条汇编指令也不代表它运行就只有一 ...

我找了一下原因,现在感觉好像跟Keil的优化级别有关呢,同一个语句,0级和2级优化的时间差不少呢
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11555
金钱
11555
注册时间
2014-4-1
在线时间
1317 小时
发表于 2018-10-10 13:52:28 | 显示全部楼层
jubangyu 发表于 2018-10-10 13:49
我找了一下原因,现在感觉好像跟Keil的优化级别有关呢,同一个语句,0级和2级优化的时间差不少呢


看来,你测的确实是C语言的语句,不是汇编指令。

回复

使用道具 举报

2

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
57
金钱
57
注册时间
2018-10-10
在线时间
18 小时
 楼主| 发表于 2018-10-10 14:15:26 | 显示全部楼层
xuande 发表于 2018-10-10 13:52
看来,你测的确实是C语言的语句,不是汇编指令。

嗯,我测了一下整形++的操作,其实主要还是优化等级的原因
回复

使用道具 举报

2

主题

756

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4163
金钱
4163
注册时间
2017-10-24
在线时间
251 小时
发表于 2018-10-10 16:57:24 | 显示全部楼层
jubangyu 发表于 2018-10-10 13:49
我找了一下原因,现在感觉好像跟Keil的优化级别有关呢,同一个语句,0级和2级优化的时间差不少呢

优化等级这个。。。说明你的确是用的C语言。。。
要记住一条C语言的程序对应的汇编指令往往不止一条。。。。并且和程序上下文以及你所提到的编译器的优化等级有关系

如果需要精确测量每条指令执行的时间,还是要在汇编的层面上做的。
十六进制带我飞。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

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

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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