OpenEdv-开源电子网

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

关于浮点指令执行时间的问题

[复制链接]

9

主题

44

帖子

0

精华

初级会员

Rank: 2

积分
100
金钱
100
注册时间
2016-6-5
在线时间
27 小时
发表于 2017-3-19 10:07:55 | 显示全部楼层 |阅读模式
3金钱
本帖最后由 Tekmarine 于 2017-3-19 10:12 编辑

根据手册,貌似大多数浮点指令都是单周期的 093631h3ppbz3ywypw3cpy.jpg 在实际调试中单步执行时也是如此,但是一次执行很多条时貌似就不对了。
102631le84pivzk17ppv8k.png 102642sops416yo75axa7x.png 这个是本人写的FFT的一部分,截图是连续执行两个断点之间的指令,从states来看,两个断点之间的连续执行用了30个周期,但是单步调试时却只用了20个周期,这是怎么回事?另外调试这部分时已经先停掉了所有的中断响应,应该算是全静态操作吧。。。。难道和流水线有关?

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

使用道具 举报

11

主题

1044

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3722
金钱
3722
注册时间
2011-5-23
在线时间
2013 小时
发表于 2017-3-19 11:17:01 | 显示全部楼层
凡是带加速的CPU这样看都是不太准确的。
要准确的话,得靠计算NN次,然后用总时间去除。
比如流水线,分支预测,cache命中等,以及仿真本身的影响(虽然JTAG影响比较小)。
RT-Thread RTOS 音频,WIFI,蓝牙
回复

使用道具 举报

9

主题

44

帖子

0

精华

初级会员

Rank: 2

积分
100
金钱
100
注册时间
2016-6-5
在线时间
27 小时
 楼主| 发表于 2017-3-19 11:46:03 | 显示全部楼层
本帖最后由 Tekmarine 于 2017-3-19 11:47 编辑
aozima 发表于 2017-3-19 11:17
凡是带加速的CPU这样看都是不太准确的。
要准确的话,得靠计算NN次,然后用总时间去除。
比如流水线,分 ...

我猜是流水线的问题,因为这部分代码里面没有分支,都是顺序执行,所以反复执行下来,用的都是30个周期,但是还是不清楚具体是怎么回事,为什么比单步执行的时间长一些?有什么资料解释这个吗?
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-18 21:42

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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