OpenEdv-开源电子网

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

系统时钟初始化函数

[复制链接]

12

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
185
金钱
185
注册时间
2015-7-29
在线时间
33 小时
发表于 2015-8-3 15:57:52 | 显示全部楼层 |阅读模式
5金钱
//系统时钟初始化函数
//pll:选择的倍频数,从2开始,最大值为16  
void Stm32_Clock_Init(u8 PLL)
{
unsigned char temp=0;   
MYRCC_DeInit();  //复位并配置向量表
  RCC->CR|=0x00010000;  //外部高速时钟使能HSEON 
while(!(RCC->CR>>17));//等待外部时钟就绪
RCC->CFGR=0X00000400; //APB1=DIV2;APB2=DIV1;AHB=DIV1
PLL-=2;//抵消2个单位
RCC->CFGR|=PLL<<18;   //设置PLL值 2~16
RCC->CFGR|=1<<16;  //PLLSRC ON  
FLASH->ACR|=0x32;  //FLASH 2个延时周期

RCC->CR|=0x01000000;  //PLLON  
while(!(RCC->CR>>25));//等待PLL锁定
RCC->CFGR|=0x00000002;//PLL作为系统时钟  
while(temp!=0x02)     //等待PLL作为系统时钟设置成功
{   
temp=RCC->CFGR>>2;
temp&=0x03;
}    
}  
大家好,这是一段系统时钟设置的代码,原子提供的。前面都明白啥意思,就这一段是什么意思  while(temp!=0x02)     //等待PLL作为系统时钟设置成功
{   
temp=RCC->CFGR>>2;
temp&=0x03;
}    
一直看不明白,望各位大虾指导!!!

最佳答案

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

每一个时钟源使能,都要等待稳定。。同时PLL选择作为系统时钟源,也要等待设置成功。。。 这算比较好理解了。。。。 设置好,然后就等待响应的标志位置位,标志设置成功。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

230

主题

1950

帖子

10

精华

论坛元老

Rank: 8Rank: 8

积分
4562
金钱
4562
注册时间
2010-12-14
在线时间
32 小时
发表于 2015-8-3 15:57:53 | 显示全部楼层
每一个时钟源使能,都要等待稳定。。同时PLL选择作为系统时钟源,也要等待设置成功。。。 这算比较好理解了。。。。

设置好,然后就等待响应的标志位置位,标志设置成功。
我是开源电子网?网站管理员,对网站有任何问题,请与我联系!QQ:389063473Email:389063473@qq.com
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-8-3 15:57:53 | 显示全部楼层
楼主,请看《STM32参考手册》CFGR寄存器的描述。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-19 00:43

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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