一、在STM32中,有五个时钟源,为HSI、HSE、LSI、LSE、PLL。
①HSI是高速内部时钟,RC振荡器,频率为8MHz。
②HSE是高速外部时钟,可接石英/陶瓷谐振器,或许接外部时钟源,频率规模为4MHz~16MHz。
③LSI是低速内部时钟,RC振荡器,频率为40kHz。
④LSE是低速外部时钟,接频率为32.768kHz的石英晶体。
⑤PLL为锁相环倍频输出,其时钟输入源可挑选为HSI/2、HSE或许HSE/2。倍频可挑选为2~16倍,可是其输出频率最大不得超越72MHz。
二、在STM32上假如不运用外部晶振,OSC_IN和OSC_OUT的接法:假如运用内部RC振荡器而不运用外部晶振,请按照下面办法处理:
①关于100脚或144脚的产品,OSC_IN应接地,OSC_OUT应悬空。
②关于少于100脚的产品,有2种接法:第1种:OSC_IN和OSC_OUT别离通过10K电阻接地。此办法可进步EMC功能;第2种:别离重映射OSC_IN和OSC_OUT至PD0和PD1,再装备PD0和PD1为推挽输出并输出’0’。此办法能够减小功耗并(相对上面)节约2个外部电阻。
三、用HSE时钟,程序设置时钟参数流程:
01、将RCC寄存器从头设置为默许值 RCC_DeInit;
02、翻开外部高速时钟晶振HSE RCC_HSEConfig(RCC_HSE_ON);
03、等候外部高速时钟晶振作业 HSEStartUpStatus = RCC_WaitForHSEStartUp();
04、设置AHB时钟 RCC_HCLKConfig;
05、设置高速AHB时钟 RCC_PCLK2Config;
06、设置低速速AHB时钟 RCC_PCLK1Config;
07、设置PLL RCC_PLLConfig;
08、翻开PLL RCC_PLLCmd(ENABLE);
09、等候PLL作业 while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
10、设置体系时钟 RCC_SYSCLKConfig;
11、判别是否PLL是体系时钟 while(RCC_GetSYSCLKSource() != 0x08)
12、翻开要运用的外设时钟 RCC_APB2PeriphClockCmd()/RCC_APB1PeriphClockCmd()
四、下面是STM32软件固件库的程序中对RCC的装备函数(运用外部8MHz晶振)
void RCC_Configuration(void)
{
RCC_DeInit();
RCC_HSEConfig(RCC_HSE_ON); //RCC_HSE_ON——HSE晶振翻开(ON)
HSEStartUpStatus = RCC_WaitForHSEStartUp();
if(HSEStartUpStatus == SUCCESS) //SUCCESS:HSE晶振安稳且安排妥当
{
RCC_HCLKConfig(RCC_SYSCLK_Div1); //RCC_SYSCLK_Div1——AHB时钟= 体系时钟
RCC_PCLK2Config(RCC_HCLK_Div1); //RCC_HCLK_Div1——APB2时钟= HCLK
RCC_PCLK1Config(RCC_HCLK_Div2); //RCC_HCLK_Div2——APB1时钟= HCLK / 2
FLASH_SetLatency(FLASH_Latency_2); //FLASH_Latency_2 2延时周期
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); // 预取指缓存使能
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
// PLL的输入时钟= HSE时钟频率;RCC_PLLMul_9——PLL输入时钟x 9
RCC_PLLCmd(ENABLE);
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
{
}
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
//RCC_SYSCLKSource_PLLCLK——挑选PLL作为体系时钟
while(RCC_GetSYSCLKSource() != 0x08) //0x08:PLL作为体系时钟
{
}
}
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB |
RCC_APB2Periph_GPIOC , ENABLE);
//RCC_APB2Periph_GPIOA GPIOA时钟
//RCC_APB2Periph_GPIOB GPIOB时钟
//RCC_APB2Periph_GPIOC GPIOC时钟
//RCC_APB2Periph_GPIOD GPIOD时钟
}
五、时钟频率
STM32F103内部8M的内部震动,通过倍频后最高能够到达72M。现在TI的M3系列芯片最高频率能够到达80M。
在STM32固件库3.0中对时钟频率的挑选进行了大大的简化,原先的一大堆操作都在后台进行。体系给出的函数为SystemInit()。但在调用前还需要进行一些宏界说的设置,详细的设置在system_stm32f10x.c文件中。
文件最初就有一个这样的界说:
//#define SYSCLK_FREQ_HSE HSE_Value
//#define SYSCLK_FREQ_20MHz 20000000
//#define SYSCLK_FREQ_36MHz 36000000
//#define SYSCLK_FREQ_48MHz 48000000
//#define SYSCLK_FREQ_56MHz 56000000
#define SYSCLK_FREQ_72MHz 72000000
ST 官方引荐的外接晶振是 8M,所以库函数的设置都是假定你的硬件现已接了 8M 晶振来运算的.以上东西便是默许晶振 8M 的时分,引荐的 CPU 频率挑选.在这里挑选了:
#define SYSCLK_FREQ_72MHz 72000000
也便是103系列能跑到的最大值72M
然后这个 C文件持续往下看
#elif defined SYSCLK_FREQ_72MHz
const uint32_t SystemFrequency = SYSCLK_FREQ_72MHz;
const uint32_t SystemFrequency_SysClk = SYSCLK_FREQ_72MHz;
const uint32_t SystemFrequency_AHBClk = SYSCLK_FREQ_72MHz;
const uint32_t SystemFrequency_APB1Clk = (SYSCLK_FREQ_72MHz/2);
const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_72MHz;
这便是在界说了CPU跑72M的时分,各个体系的速度了.他们别离是:硬件频率,体系时钟,AHB总线频率,APB1总线频率,APB2总线频率.再往下看,看到这个了:
#elif defined SYSCLK_FREQ_72MHz
static void SetSysClockTo72(void);
这便是界说 72M 的时分,设置时钟的函数.这个函数被 SetSysClock ()函数调用,而
SetSysClock ()函数则是被 SystemInit()函数调用.最终 SystemInit()函数,便是被你调用的了
所以设置体系时钟的流程便是:
首要用户程序调用 SystemInit()函数,这是一个库函数,然后 SystemInit()函数里边,进行了一些寄存器必要的初始化后,就调用 SetSysClock()函数. SetSysClock()函数依据那个#define SYSCLK_FREQ_72MHz 72000000 的宏界说,知道了要调用SetSysClockTo72()这个函数,所以,就一堆费事而杂乱的设置~!@#$%^然后,CPU跑起来了,并且速度是 72M. 尽管说的有点负担,但我们只需要知道,用户要设置频率,程序中就做的就两个工作:
第一个: system_stm32f10x.c 中 #define SYSCLK_FREQ_72MHz 72000000
第二个:调用SystemInit()
- STM32单片机中文官网
- STM32单片机官方开发工具
- STM32单片机参阅规划