首先说明,因为STM32芯片的型号不同,所以对于不同芯片有不同频率的限制,比如某些时钟频率不能大于多少,这是根据手册来设置的!但改变频率的寄存器都一样,只是我们设置频率大小要受芯片的限制!下面我用的芯片型号是STM32F103VBT6!它就限制了内部晶振的倍频不能大于64MHz(但其实我实验出来是52MHz)!
本文是利用内部晶振(HSI)来倍频,与外部晶振倍频区分开!
第一步:打开system_STM32f10x.c,找到函数void SystemInit (void){},把原有的都注释掉,将下面的代码复制进去:
/* 开启HSI 即内部晶振时钟 */
RCC->CR |= (uint32_t)0x00000001;
/*选择HSI为PLL的时钟源HSI必须2分频给PLL*/
RCC->CFGR |= (uint32_t)RCC_CFGR_PLLSRC_HSI_Div2;
/*PLLCLK=8/2*13=52MHz 设置倍频得到时钟源PLL的频率*/
RCC->CFGR |= (uint32_t)RCC_CFGR_PLLMULL13;
/* PLL不分频输出 */
RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;
/* 使能 PLL时钟 */
RCC->CR |= RCC_CR_PLLON;
/* 等待PLL时钟就绪*/
while((RCC->CR & RCC_CR_PLLRDY) == 0)
{
}
/* 选择PLL为系统时钟的时钟源 */
RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;
/* 等到PLL成为系统时钟的时钟源*/
while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)0x08)
{
}
这段代码其实就是是HSI倍频成为PLL的时钟源,又使PLL成为系统时钟的时钟源,这样就相当于HSI倍频后给系统时钟了!
最后我用一个库函数RCC_GetClocksFreq() 它是用来获取各个时钟的频率的!他要先初始化,就在开始前利用RCC_ClocksTypeDef 来使他初始化,我们代码是RCC_ClocksTypeDef RCC_Clocks,这样RCC_Clocks.SYSCLK_Frequency就是系统时钟的频率了!我们串口输出就可以了!
主函数代码:
int main (void)
{
RCC_ClocksTypeDef RCC_Clocks; //初始化
SystemInit(); //调用刚才改过的函数
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
Usart_Init(115200); //串口为了看数据而已
RCC_GetClocksFreq(&RCC_Clocks); //获取各个时钟频率
while(1)
{
printf("SYSCLK_Frequency %d rn",RCC_Clocks.SYSCLK_Frequency);
//printf("SYSCLK_Frequency %d rn",RCC_Clocks.SYSCLK_Frequency);
}
}
串口显示:(我的实验利用内部晶振最高只能倍频到52MHz)
上一篇:STM32F103 系统各部分时钟设置
下一篇:stm32时钟选择与配置HSL HSE PLL
推荐阅读最新更新时间:2024-10-31 10:03
设计资源 培训 开发板 精华推荐
- 【创意PCB】立方灯
- SOT-23 10MHz 轨到轨运算放大器节省电路板空间和功耗
- 使用 Diodes Incorporated 的 AP1538 的参考设计
- DC1250A-BA,用于 LTM9001-BA CMOS 输出的演示板,16 位,160Msps,DC-300MHz LPF,8dB 增益
- LD2980ABM50TR SOT23-5L 与低 ESR 抑制输出电容器兼容的超低压降稳压器的典型应用
- 适用于数字温度传感器的单线控制器参考设计
- 使用 NXP Semiconductors 的 TDA8580 的参考设计
- #第五届立创电子设计大赛#数控直流电子负载
- 用于基本连接的 LT6656BCDC-2.5、2.5V 电压基准的典型应用
- EVAL-ADM3050EEBZ,用于评估 ADM3050E 5.7kV rms、信号隔离、基本 CAN FD 收发器的评估板