OpenEdv-开源电子网

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

stm32延时函数问题

[复制链接]

2

主题

4

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2016-8-1
在线时间
2 小时
发表于 2016-8-1 10:14:35 | 显示全部楼层 |阅读模式
1金钱
大家好,我用的是原子哥的stm32F103开发板,现在把外部的8M晶振换成了13.56M,想要产生一个延时,是9.44us,精确值是128/13.56. 我用原子哥的定时器历程里的delay函数改,弄了好几天也没弄成,求大神指导迷津。感激不尽。

最佳答案

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

Systick时钟源可以选择HCLK和HCLK/8.。。。库函数delay.c中有一行: SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8); //选择外部时钟 HCLK/8 很容易看到这里选择的是HCLK/8, 你改为 SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK); 即可,也就是选择HCLK为systick时钟,配置没有问题的话,我们的程序里面HCLK就等于SYSCLK。。。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

351

主题

1472

帖子

12

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
8077
金钱
8077
注册时间
2015-10-15
在线时间
2915 小时
发表于 2016-8-1 10:14:36 | 显示全部楼层
Systick时钟源可以选择HCLK和HCLK/8.。。。库函数delay.c中有一行:
SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8);        //选择外部时钟  HCLK/8
很容易看到这里选择的是HCLK/8,
你改为
SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK);
即可,也就是选择HCLK为systick时钟,配置没有问题的话,我们的程序里面HCLK就等于SYSCLK。。。       
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11544
金钱
11544
注册时间
2014-4-1
在线时间
1315 小时
发表于 2016-8-1 10:20:28 | 显示全部楼层

晶体频率改了,系统时钟怎么变的?定时器的时钟是多少?
这个时钟会影响所有外设,包括定时器。


回复

使用道具 举报

5

主题

103

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
235
金钱
235
注册时间
2014-11-26
在线时间
25 小时
发表于 2016-8-1 10:37:26 | 显示全部楼层
你这个程序,时钟分配的时候,就不要倍频了,系统时钟就选13.56M,然后选择一个定时器,这个定时器的时钟源也不要分频,这样设置定时器的arr寄存器为127,这样就能实现你的延时,还有就是原子哥的时钟源是有倍频的,这个需要你改一下
回复

使用道具 举报

2

主题

4

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2016-8-1
在线时间
2 小时
 楼主| 发表于 2016-8-1 10:38:43 | 显示全部楼层
1376115749 发表于 2016-8-1 10:37
你这个程序,时钟分配的时候,就不要倍频了,系统时钟就选13.56M,然后选择一个定时器,这个定时器的时钟源 ...

具体怎么改能说一下吗 方便留个qq吗 谢谢啦
回复

使用道具 举报

5

主题

103

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
235
金钱
235
注册时间
2014-11-26
在线时间
25 小时
发表于 2016-8-1 10:58:02 | 显示全部楼层
ccml 发表于 2016-8-1 10:38
具体怎么改能说一下吗 方便留个qq吗 谢谢啦

你要具体改啊,好的,你加一下我的账号那个137那个
回复

使用道具 举报

2

主题

4

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2016-8-1
在线时间
2 小时
 楼主| 发表于 2016-8-3 18:06:22 | 显示全部楼层
openedvadmin 发表于 2016-8-1 14:37
Systick时钟源可以选择HCLK和HCLK/8.。。。库函数delay.c中有一行:
SysTick_CLKSourceConfig(SysTick_CLK ...

        SysTick->CTRL&=0xffffffb; 跟这个是一个意思吗?
回复

使用道具 举报

351

主题

1472

帖子

12

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
8077
金钱
8077
注册时间
2015-10-15
在线时间
2915 小时
发表于 2016-8-3 18:24:04 | 显示全部楼层
ccml 发表于 2016-8-3 10:06
SysTick->CTRL&=0xffffffb; 跟这个是一个意思吗?

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

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-8 15:52

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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