STM32F103时钟配置流程

知识点:

  1. 系统复位后,HSI振荡器被选为系统时钟。当时钟源被直接或通过PLL间接作为系统时钟时,它将不能被停止。
  2. STM32F103的三个可以作为系统时钟的时钟源,分别是HSI、HSE、PLL。而PLL的时钟源是HSI/2(内部RC振荡器二分频)、HSE。
  3. 如果使用HSI,系统时钟我们能达到的最大频率是64MHz,如果使用HSE,系统时钟最大频率是72MHz。
  4. APB时钟有低速PCLK1和高速PCLK2;PCLK1是从HCLK二分频得到的,最大36MHZ,根据上一条知识点如果是使用HSI,则最快是32MHz。
  5. PLL的设定需要在使能之前,一旦PLL使能后参数不可更改。
  6. 附录是一些缩写的英文全称,也有一些补充的知识点。

步骤:

第一步 初始化时钟

不管现在SYSCLK的时钟源是哪个,我们先重置系统时钟源。
RCC_DeInit();

第二步 打开对应的时钟输入

若使用内部高速时钟HSI
RCC_HSICmd(ENABLE);
若使用外部高速时钟HSE
RCC_HSEConfig(RCC_HSE_ON);

第三步 等待时钟晶振工作

HSI
While(RCC_GetFlagStatus(RCC_FLAG_HSIRDY)==RESET);
HSE
While(RCC_GetFlagStatus(RCC_FLAG_HSERDY)==RESET);

第四步 设置AHB时钟HCLK

RCC_HCLKConfig(RCC_SYSCLK_Div1);
分频系数自己设定,一般都是RCC_SYSCLK_Div1即不分频。

第五步 设置低速APB1时钟

RCC_PCLK1Config(RCC_HCLK_Div2);

第六步 设置高速APB2时钟

RCC_PCLK2Config(RCC_HCLK_Div1);

第七步 设置Flash预缓冲周期

FLASH_SetLatency(FLASH_Latency_2);//设置等待周期
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); // 使能flash预缓冲
Flash的操作也没有总线时钟快,所以需要总线在操作flash时稍作等待。
推荐根据HCLK设置:

  1. 0-24MHz时,取FLASH_Latency_0;
  2. 24-48MHz,取FLASH_Latency_1;
  3. 48-72MHz时,取FLASH_Latency_2。

第八步 设置PLL (如果不使用PLL,请略过此步骤)

HSI
RCC_PLLConfig(RCC_PLLSource_HSI_Div2, RCC_PLLMul_16 );
HSE
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9 );

第九步 打开PLL (如果不使用PLL,请略过此步骤)

RCC_PLLCmd(ENABLE);

第十步 等待PLL工作 (如果不使用PLL,请略过此步骤)

while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)== RESET);

第十一步 设置系统时钟

HSI
RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);
HSE
RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);
PLL
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

第十二步 判断是否是设置的时钟

HSI
while(RCC_GetSYSCLKSource()!= 0x00);
HSE
while(RCC_GetSYSCLKSource()!= 0x04);
PLL
while(RCC_GetSYSCLKSource()!= 0x08);

例程:外部晶振为8M的72M系统时钟配置

void SysclkInit(void)
{
	RCC_DeInit();
	RCC_HSEConfig(ENABLE);
    while(RCC_GetFlagStatus(RCC_FLAG_HSERDY)==RESET);
    RCC_HCLKConfig(RCC_SYSCLK_Div1);
    RCC_PCLK1Config(RCC_HCLK_Div2);
    RCC_PCLK2Config(RCC_HCLK_Div1);
    FLASH_SetLatency(FLASH_Latency_2);
    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9 );
    RCC_PLLCmd(ENABLE);
    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)== RESET);
    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
    while(RCC_GetSYSCLKSource()!= 0x08);
}
  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STM32F103R6是一款基于ARM Cortex-M3内核的微控制器,它具有丰富的外设和功能。在配置STM32F103R6的时钟时,需要设置系统时钟和外设时钟。 1. 系统时钟配置: - 首先,需要选择系统时钟源。可以选择内部时钟源(HSI)或外部时钟源(HSE)。 - 如果选择内部时钟源,可以使用默认的内部高速时钟(HSI)作为系统时钟源。可以通过设置RCC_CFGR寄存器来配置HSI的分频系数。 - 如果选择外部时钟源,需要将外部时钟源连接到MCU的引脚上,并通过设置RCC_CFGR寄存器来配置外部时钟源的分频系数。 - 然后,需要选择系统时钟的分频系数。可以通过设置RCC_CFGR寄存器来配置分频系数,以得到所需的系统时钟频率。 2. 外设时钟配置: - 对于每个外设,都有一个时钟使能寄存器(RCC_APBxENR或RCC_AHBxENR),用于控制外设时钟的使能和禁用。 - 通过设置相应的时钟使能位,可以使能或禁用特定的外设时钟。 下面是一个示例代码,演示了如何配置STM32F103R6的时钟: ```c #include "stm32f10x.h" void SystemClock_Config(void) { // 选择系统时钟源为外部时钟源(HSE) RCC->CFGR |= RCC_CFGR_SW_HSE; // 配置外部时钟源的分频系数 RCC->CFGR |= RCC_CFGR_HPRE_DIV1; // AHB时钟不分频 RCC->CFGR |= RCC_CFGR_PPRE1_DIV2; // APB1时钟分频系数为2 RCC->CFGR |= RCC_CFGR_PPRE2_DIV1; // APB2时钟不分频 // 使能外部时钟源(HSE) RCC->CR |= RCC_CR_HSEON; while(!(RCC->CR & RCC_CR_HSERDY)); // 使能外设时钟 RCC->APB1ENR |= RCC_APB1ENR_TIM2EN; // 使能TIM2时钟 RCC->APB2ENR |= RCC_APB2ENR_IOPAEN; // 使能GPIOA时钟 } int main(void) { // 配置系统时钟 SystemClock_Config(); // 其他代码... return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值