OpenEdv-开源电子网

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

请教:延时函数用软件仿真和实测值差异较大

[复制链接]

1

主题

6

帖子

0

精华

新手上路

积分
30
金钱
30
注册时间
2011-9-3
在线时间
0 小时
发表于 2011-9-3 12:20:25 | 显示全部楼层 |阅读模式

 就是一个简单的延时函数:

void Delay_us(unsigned int t)
{
    unsigned int i;
    volatile unsigned int n;

    for(i = 0; i < t; i++)
   {
      for(n = 0; n < 14; n++);
   }
}

void main(void)
{
    .....
    LED_ON; 
    Delay_us(1000);
    LED_OFF;
    ....
}

将工程选项中的Debug选择 use simulator,用软件仿真Delay_us函数,观察其运行时间(调试窗口左边的Internal中的sec可以看到已运行的时间),其结果为1027uS(Delay_us(1000),但我用示波器观察,波形的宽度却为1750uS,相差很大,请问可能是什么原因?以下原因已排查:
1、示波器没有问题,使用也没有问题(这型号示波器我用了快8年了)
2、LED_ON LED_OFF执行时间很短,就一条指令

我的单片机型号是:STM32F103R8,工程选项中选的也是这个型号,工程选项中的晶振为8M,实际也为8M,main函数之前的初始化代码已经系统内核频率设定为72MHZ,Debug中唯一的设置项:limit speed to real time也试过了,没有作用。

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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2011-9-3 14:22:09 | 显示全部楼层
回复【楼主位】lwtlwt:
---------------------------------
那个时间你不能和示波器比
只能在仿真环境下看的!!!
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

6

帖子

0

精华

新手上路

积分
30
金钱
30
注册时间
2011-9-3
在线时间
0 小时
 楼主| 发表于 2011-9-3 15:11:08 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
谢谢!
请问应该在哪看一段代码实际运行时间是多长呢(不用示波器和逻辑分析仪的方法)?以前用的是AVR,在AVRSTUDIO下可以看到精确的运行时间。另外,我现在用的硬件仿真器是JTAG V7,用硬件仿真也看不了函数运行时间是多长,是不是我看错了地方?我现在观察的是调试窗口左边的Internal --> sec,Analysis windows看到的时间也是一样的。
回复 支持 反对

使用道具 举报

1

主题

6

帖子

0

精华

新手上路

积分
30
金钱
30
注册时间
2011-9-3
在线时间
0 小时
 楼主| 发表于 2011-9-3 15:15:21 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
用软件仿真的方式有没有办法看一段代码执行的时间呢?理论上,编译后生成的代码指令已确定,函数的运行时间是可以确定的,而且M3的内核是不爱cache、乱序指令影响的,执行时间应该是确定的。实在不行,我只能用手工去一条条看指令,然后根据指令周期计算了,这样太麻烦了,几乎所有的开发工具带的软件仿真都提供指令运行时间参考,MDK应该也有这项基本功能吧?
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2011-9-3 15:36:08 | 显示全部楼层
回复【4楼】lwtlwt:
---------------------------------
可以看的
在软件仿真的时候,MDK的最右下脚.
有个  t1:0.00000xxxx sec的,就是仿真的执行时间.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

6

帖子

0

精华

新手上路

积分
30
金钱
30
注册时间
2011-9-3
在线时间
0 小时
 楼主| 发表于 2011-9-3 23:16:38 | 显示全部楼层
回复【5楼】正点原子:
---------------------------------
右下脚显示的时间就是我上面所说的Internal---Sec。
这个时间与实测值相差很大
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2011-9-3 23:23:24 | 显示全部楼层
回复【6楼】lwtlwt:
---------------------------------
差距总是有的,呵呵.软件仿真肯定不可能完全替代真实情况的.这点你要明确.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

6

帖子

0

精华

新手上路

积分
30
金钱
30
注册时间
2011-9-3
在线时间
0 小时
 楼主| 发表于 2011-9-3 23:44:05 | 显示全部楼层
回复【7楼】正点原子:
---------------------------------
唉,这个差距不是一点半点啊.....这应该是MDK的又一不足,也可以没设置好吧,不过我全找过了,没有地方可设了。
有时间试试IAR,有结果了再告诉大家。谢谢了!
回复 支持 反对

使用道具 举报

1

主题

6

帖子

0

精华

新手上路

积分
30
金钱
30
注册时间
2011-9-3
在线时间
0 小时
 楼主| 发表于 2011-9-3 23:46:29 | 显示全部楼层
回复【7楼】正点原子:
---------------------------------
软件仿真是不能代替硬件,但对于一个不涉及到硬件操作的函数指令执行时间,这在多数编译器都是可以精确无误地仿真
回复 支持 反对

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
21
金钱
21
注册时间
2014-12-20
在线时间
0 小时
发表于 2014-12-20 15:40:27 | 显示全部楼层
这个问题是不是由于IO口翻转的延时或者是测试仪器的问题导致的时间不同?
回复 支持 反对

使用道具 举报

0

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
119
金钱
119
注册时间
2016-4-29
在线时间
22 小时
发表于 2017-4-14 13:20:21 | 显示全部楼层
这位问题没有人关注了吗?
回复 支持 反对

使用道具 举报

0

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
119
金钱
119
注册时间
2016-4-29
在线时间
22 小时
发表于 2017-4-14 13:21:29 | 显示全部楼层
我尝试了一下1s的延时,仿真里出来是7s多延时,而且改里面的晶振频率对这个时间没有影响
回复 支持 反对

使用道具 举报

0

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
119
金钱
119
注册时间
2016-4-29
在线时间
22 小时
发表于 2017-4-14 13:49:48 | 显示全部楼层
我选择了use simulator后,时间是对的。但我用st-link进行硬件仿真,为什么时间就不对呢?
回复 支持 反对

使用道具 举报

0

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
119
金钱
119
注册时间
2016-4-29
在线时间
22 小时
发表于 2017-4-14 13:53:55 | 显示全部楼层
哈哈,还是在论坛里找到答案了,验证可以用。
http://www.openedv.com/forum.php?mod=viewthread&tid=77771
方法在上面链接的5楼(5#)
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-8-22 05:32

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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