OpenEdv-开源电子网

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

stm32初学被打击了。。。求大神指点

[复制链接]

14

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
113
金钱
113
注册时间
2013-4-21
在线时间
0 小时
发表于 2013-4-21 12:01:02 | 显示全部楼层 |阅读模式

void delay_init(u8 SYSCLK)
{
SysTick->CTRL&=0xfffffffb;//bit2清空,选择外部时钟  HCLK/8
fac_us=SYSCLK/8;    
fac_ms=(u16)fac_us*1000;
}
 这个SYSCLK现在到底是多少呢,如果是8M晶振外接,是8M还是9M啊,还有就是为什么要fac_us=SYSCLK/8;,这个和fac_us是8位有什么关系?


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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-4-21 13:28:10 | 显示全部楼层
SYSCLK=系统时钟/8=72/8=9Mhz
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-4-21 13:29:22 | 显示全部楼层
你告诉我,SYSTICK CLK=9M的时候, systick波形的每一个周期,是多少us?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

54

主题

1008

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2386
金钱
2386
注册时间
2012-11-22
在线时间
403 小时
发表于 2013-4-21 15:39:06 | 显示全部楼层
9M需要9个倍乘才能是1us
态度决定一切
回复 支持 反对

使用道具 举报

54

主题

1008

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2386
金钱
2386
注册时间
2012-11-22
在线时间
403 小时
发表于 2013-4-21 16:22:19 | 显示全部楼层
回复【3楼】正点原子:
---------------------------------
原子哥,如果选择内部时钟,那么就是8M的了吧?
态度决定一切
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-4-21 16:57:50 | 显示全部楼层
回复【5楼】冰封嗜魔:
---------------------------------
内部RC晶振,只有8M的.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

54

主题

1008

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2386
金钱
2386
注册时间
2012-11-22
在线时间
403 小时
发表于 2013-4-21 17:12:08 | 显示全部楼层
回复 支持 反对

使用道具 举报

14

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
113
金钱
113
注册时间
2013-4-21
在线时间
0 小时
 楼主| 发表于 2013-4-21 17:42:30 | 显示全部楼层
回复【3楼】正点原子:

你告诉我,SYSTICK CLK=9M的时候, systick波形的每一个周期,是多少us?

---------------------------------
我现在的想法:比如外部接9M晶振,如果Stm32_Clock_Init(9);倍频9倍之后,SYSCLK=81M,运行这个函数void delay_init(81),systick的时钟源81M的1/8,所以为10.125M,所以记一微秒就是10.125赋给fac_us,是这样吗,还有HCLK是不是SYSCLK的来源呢,他们什么关系,原子哥?
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-4-21 21:47:51 | 显示全部楼层
回复【8楼】gh1134537617:
---------------------------------
外部接的是8M晶振.这个你前提就错了.
8M,SYSCLK=72M,SYSTICKCLK=9M,1个周期是1/9us,那么加到9,不是1us么?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-7-21 02:09

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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