STM32入门基础篇(三)

(三)系统时钟

注:本文以STM32F407ZGT6为例编写。

1.各时钟频率大小

  • SYSCLK(系统时钟) 168MHz
  • AHB总线时钟(HCLK) 168MHz
  • APB1总线时钟(PCLK1) 42MHz
  • APB2总线时钟(PCLK2) 84MHz
  • PLL主时钟 168MHz

2.时钟配置函数

2.1.时钟使能配置函数

RCC_HSICmd
RCC_LSICmd
RCC_PLLCmd
RCC_PLLI2SCmd
RCC_PLLSAICmd
RCC_RTCCLKCmd
RCC_AHBxPeriphClockCmd
RCC_APBxPeriphClockCmd

2.2.时钟源和分频因子相关配置函数

RCC_HSEConfig 
RCC_LSEConfig 
RCC_PLLConfig 
RCC_PLLI2SConfig 
RCC_PLLSAIConfig 
RCC_MCO1Config
RCC_MCO2Config
RCC_SYSCLKConfig
RCC_HCLKConfig
RCC_PCLK1Config
RCC_PCLK2Config
RCC_RTCCLKConfig
RCC_I2SCLKConfig

2.3.外设复位函数

RCC_AHB1PeriphResetCmd
RCC_AHB2PeriphResetCmd
RCC_AHB3PeriphResetCmd
RCC_APB1PeriphResetCmd
RCC_APB2PeriphResetCmd

2.4.状态参数获取函数

RCC_GetSYSCLKSource
RCC_GetClocksFreq
RCC_GetFlagStatus
RCC_ClearFlag

2.5.RCC中断相关函数

RCC_ITConfig
RCC_ClearITPendingBit
RCC_GetITStatus

3.系统时钟设置步骤

//pllm:VCO 输入时钟 分频因子,范围0-63
//plln:VCO 输出时钟 倍频因子,范围192-432
//pllp:PLLCLK 时钟分频因子,范围2, 4, 6, or 8
//pllq:OTG FS,SDIO,RNG 时钟分频因子,范围4-15
void RCC_HSE_Config(u32 pllm,u32 plln,u32 pllp,u32 pllq)
{
	RCC_DeInit(); //将外设RCC寄存器重设为缺省值
	RCC_HSEConfig(RCC_HSE_ON);//设置外部高速晶振(HSE)
	if(RCC_WaitForHSEStartUp()==SUCCESS) //等待HSE起振,晶振起振是一个过程
	{
		RCC_HCLKConfig(RCC_SYSCLK_Div1);//设置AHB时钟(HCLK)
		RCC_PCLK2Config(RCC_HCLK_Div2);//设置低速APB2时钟(PCLK2)
		RCC_PCLK1Config(RCC_HCLK_Div4);//设置低速APB1时钟(PCLK1)
		RCC_PLLConfig(RCC_PLLSource_HSE,pllm,plln,pllp,pllq);//设置PLL时钟源及倍频系数
		RCC_PLLCmd(ENABLE); //使能或者失能PLL
		while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET);//检查指定的RCC标志位设置与否,PLL就绪
		RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//设置系统时钟(SYSCLK)
		while(RCC_GetSYSCLKSource()!=0x08);//返回用作系统时钟的时钟源,0x08:PLL作为系统时钟
	}
}
注:1.取值一般为pllm=8、plln=336、pllp=2、pllq=7;
2.该函数定义完后在main函数内调用,参照1设置参数即可;
3.可以不设置此函数,即可保持初始设置168MHz。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值