OpenEdv-开源电子网

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

请问如何使用Systick测量程序执行的时间?

[复制链接]

4

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2015-5-12
在线时间
2 小时
发表于 2015-6-5 03:43:56 | 显示全部楼层 |阅读模式
5金钱
void delay_init(u8 SYSCLK)
{
// SysTick->CTRL&=0xfffffffb;//bit2清空,选择外部时钟  HCLK/8
SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8); //bit2清空,选择外部时钟  HCLK/8
fac_us=SYSCLK/8;    
fac_ms=(u16)fac_us*1000;
SysTick->VAL=0x00;
SysTick->CTRL=0x00;
}
这是初始化

void tic(void)                            //程序开始计时
{

SysTick->VAL=0X00;            //当前数值寄存器清零
SysTick->LOAD=0XFFFFFF;     //计数器赋初值
SysTick->CTRL |= (1<<0);     //开启计数器
}

float toc(void)                            //结束计时
{
float ElaspTime;
uint32_t ClkNum;
SysTick->CTRL &= ~(1<<0); //关闭计数器
ClkNum=SysTick->VAL; //读取计数器的值
ElaspTime=(float)(0xffffff-ClkNum)/SystemCoreClock/8); //计算时间
return ElaspTime;
}
我发现只要一读取SysTick->VAL的值必为0,时间肯定没有那么久。。。。无解啊
那么直接返回(float)(SysTick->LOAD-SysTick->VAL)/SystemCoreClock/8)也还是0
Systick不能直接读吗?如果想要测量代码执行时间(做采样间隔),应该怎么做?

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

使用道具 举报

15

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
141
金钱
141
注册时间
2015-5-14
在线时间
6 小时
发表于 2015-6-5 08:57:31 | 显示全部楼层
抛砖引玉,在SysTick中断全局变量自增,在调试模式,设置断点,然后查全局变量,其实我也不知道对不对
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-6-5 23:49:59 | 显示全部楼层
可以printf打印出来。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

4

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2015-5-12
在线时间
2 小时
 楼主| 发表于 2015-6-7 17:36:19 | 显示全部楼层
回复【3楼】正点原子:
---------------------------------
我是要把时间作为一个函数的参数作为陀螺仪姿态解算的时间间隔啊。
那么也就是说systick里面的数据读不出来吗??
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-6-8 00:21:32 | 显示全部楼层
回复【4楼】yummychop:
---------------------------------
当然可以读出来
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

4

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2015-5-12
在线时间
2 小时
 楼主| 发表于 2015-6-8 11:00:54 | 显示全部楼层
回复【5楼】正点原子:
---------------------------------
我每次一做ClkNum=SysTick->VAL;
ClkNum都是0,SysTick我不用来做延时,用来计时,我看网上的例子很多很多都是用来做延时的。。。
请问你们有把SysTick用来做计时的例子吗??
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-6-8 23:18:50 | 显示全部楼层
回复【6楼】yummychop:
---------------------------------
我们也是用来做延时的。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

0

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2016-2-19
在线时间
19 小时
发表于 2016-2-19 18:36:44 | 显示全部楼层
同问,楼主解决了?
我也想通过读取VAL时下的值来计时,
不过想想通过ClkNum=SysTick->VAL;得到的真的是bit[23:0]上面的数值?不是得到它的首地址0xE000E018? 这里有点不大懂……
话说不读取VAL时下的值 通过判断countflag是1或0,可以计算值耶,只要在LOAD装入合适的初始值就可以了?这是我的思考也不知怎样
回复

使用道具 举报

1

主题

27

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
399
金钱
399
注册时间
2015-10-5
在线时间
41 小时
发表于 2018-5-18 14:25:27 | 显示全部楼层
我也想知道
天是棺材盖,地是棺材底,无论闯哪里,总在棺材里
回复

使用道具 举报

0

主题

2

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2020-5-27
在线时间
13 小时
发表于 2020-6-4 14:08:49 | 显示全部楼层
想问下这个问问题解决了吗
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 00:58

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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