STM32 寄存器配置笔记——系统时钟配置 HSE as PLL

本文详细介绍了如何在STM32F10xx平台上通过HSE高速外部时钟配置PLL,实现72MHz系统时钟的设置,包括复位RCC寄存器、启用HSE时钟、配置PLL等步骤,并提供了源码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、概述

       本文主要介绍使用HSE高速外部时钟通过PLL倍频输出72MHZ的时钟作为系统时钟。下图为时钟树。

        使用正点原子的开发板调试OSC_IN、OSC_OUT接的是8MHZ的晶振即为HSE时钟。

二、配置流程

        1)复位RCC相关的所有寄存器

            复位内容是参考正点原子例程,按照博主理解只要将HSE对应会影响到的RCC寄存器复位即可。本博客重点主要在时钟配置原理,此步骤可以不用特别关注。

 	RCC->APB1RSTR = 0x00000000;//
	RCC->APB2RSTR = 0x00000000; 
	  
  	RCC->AHBENR = 0x00000014;  //睡眠模式闪存和SRAM时钟使能,其他关闭
  	RCC->APB2ENR = 0x00000000; //外设时钟关闭		   
  	RCC->APB1ENR = 0x00000000;   
	RCC->CR |= 0x00000001;     //使能内部高速时钟HSION														 
	RCC->CFGR &= 0xF8FF0000;   //复位SW[1:0], HPRE[3:0], PPRE1[2:0], PPRE2[2:0], ADCPRE[1:0], MCO[2:0]
	RCC->CR &= 0xFEF6FFFF;     //复位HSEON, CSSON, PLLON
	RCC->CR &= 0xFFFBFFFF;     //复位HSEBYP
	RCC->CFGR &= 0xFF80FFFF;   //复位PLLSRC, PLLXTPRE, PLLMUL[3:0] and USBPRE
	RCC->CIR = 0x00000000;     //关闭所有中断

        2)使能HSE时钟

        使能HSE时钟等待就绪。

	RCC->CR |= 1 << 16;       // enable HSE clock
	while (!(RCC->CR >> 17)); // wait HSE rdy

      

        3)配置PLLXTPRE

             配置为0,使得HSE作为PLL输出时不分频,上面复位操作已经配置为0这里就不重新配。

        4)配置PLLMUL

       

RCC->CFGR |= PLL << 18;   // set PLLMUL 

        5)配置PLL时钟源为HSE

      

RCC->CFGR |= 1 << 16;     // PLLSRC HSE as PLL clock

        6)配置FLASH等待周期

         由于半导体制造工艺的限制,存放程序的FLASH存储器不可能达到这么高的工作频率,这样当CPU直接访问Flash存储器时必须插入等待周期以得到正确的结果。

         在<<STM32F10xxx存编程手册>>有如下规定:

        ACR寄存器内容:

        7)使能PLL

        使能PLL时钟,等待PLL时钟就绪。

	RCC->CR |= 1 << 24;       // PLLON PLL enable
    while(!(RCC->CR >> 25));  // wait PLL rdy

        8)PLL时钟作为系统时钟

        配置PLL时钟作为系统时钟等待配置完成。

        

RCC->CFGR |= 0x00000002;  // PLL as sysclk

do
{
    temp = RCC->CFGR>>2;
	temp &= 0x3;
} while (temp != 2);       // temp = 2 indicator PLL as sysclk suc

三、源码

        整个代码调用情况如下:

        

void Stm32_Clock_Init(u8 PLL)
{
	unsigned char temp=0;   
	MYRCC_DeInit();		      // reset and cfg vector tab
	RCC->CR |= 1 << 16;       // enable HSE clock
	while (!(RCC->CR >> 17)); // wait HSE rdy
    RCC->CFGR |= 0x00000400;  // APB1=DIV2;APB2=DIV1;AHB=DIV1;
	PLL -= 2;                 // 0 - PLL * 2   14/15 - PLL * 16
    RCC->CFGR |= PLL << 18;   // set PLLMUL 
	RCC->CFGR &= ~(1 << 17);  // PLLXTPRE set 0 HSE PLL DIV1
	RCC->CFGR |= 1 << 16;     // PLLSRC HSE as PLL clock
	FLASH->ACR |= 0x02;	      // LATENCY read Flash clock wait states
	RCC->CR |= 1 << 24;       // PLLON PLL enable
    while(!(RCC->CR >> 25));  // wait PLL rdy
	RCC->CFGR |= 0x00000002;  // PLL as sysclk

	do
	{
	    temp = RCC->CFGR>>2;
		temp &= 0x3;
	} while (temp != 2);       // temp = 2 indicator PLL as sysclk suc
}

        在时钟配置完成后,通过能够成功点亮LED来验证配置成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值