本文主要是介绍STM32手写超频到128M函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
今天学习了野火的STM32教程学会了如何设置STM32的时钟频率,步骤比较详细,也很容易理解,就是视频教程不能跳着看,只能一节节的看,不然会知识不连贯,造成有些知识不理解,连续着看还是没有什么难度的。
我把怎么设置系统时钟的步骤总结一下吧:
第一步:将RCC的所有寄存器都恢复成默认值
第二步:使能HSE
第三步:判断HSE启动是否成功
HSE启动成功的话:
{
1:使能预取缓冲区
2:预取缓冲区等待周期2
3:设置AHB的时钟 1分频 72M
4:APB1的时钟设置 2分频 36M
5:APB2的时钟设置 1分频 72M
6:锁相环时钟配置:来源HSE1分频,倍频因子9倍(也可以改成自己想要的倍数,超频就改这里)
7:使能锁相环
8:等待锁相环稳定
9:系统时钟选择锁相环时钟
10:等待系统时钟切换成功
}
HSE启动不成功:
{
写不成功的代码。
}
*******************************************************************************************************************
按照上面的步骤操作后,系统时钟就按照我们的标准来设置了。其实这个操作没有什么太大的必要性,因为系统会自动为我们配置好的,研究这个过程是为了更深一步的了解STM32的工作步骤。能叫自己的脑子里的思路更加清晰。
下面我就把源码发出来,自己研究吧!
RCC.c文件:
#include "RCC.h" // Device header/*HSE时钟设置函数(传入倍频因子)*/
void HSE_SetSysClk(uint32_t RCC_PLLMul_x)
{ErrorStatus HSEStatus; //定义一个HSE启动成功与否的标志位变量RCC_DeInit(); //RCC所有寄存器恢复成默认值RCC_HSEConfig(RCC_HSE_ON);//使能HSEHSEStatus = RCC_WaitForHSEStartUp();//HSE启动是否成功的返回值if(HSEStatus == SUCCESS){FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);//使能预取缓冲区 在《STM32F10xxx闪存编程》的3.1节 的FLASH_ACR 的 位4:PRFTBE 取值1 :启用预取缓冲区FLASH_SetLatency(FLASH_Latency_2); //预取缓冲区等待周期2RCC_HCLKConfig(RCC_SYSCLK_Div1); // AHB的时钟设置 1分频RCC_PCLK1Config(RCC_HCLK_Div2); // APB1的时钟设置 2分频RCC_PCLK2Config(RCC_HCLK_Div1); // APB2的时钟设置 1分频RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_x); //锁相环配置 时钟来源与倍频因子 16倍频 8*16=128MRCC_PLLCmd(ENABLE); //使能锁相环//等待锁相环稳定// RCC_GetFlagStatus(uint8_t RCC_FLAG); //RCC的标志位while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) != SET);//选择锁相环时钟RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //时钟源选择while( RCC_GetSYSCLKSource() != 0x08 ); //如果不等于0x08就是没有切换成功就while等待}else{/* 如果HSE启动失败,用户可以在这里添加处理错误的代码 */}}//配置PA8为时钟输出
void MCO_GPIO_Config(void)
{RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);GPIO_InitTypeDef GPIO_InitStruct;GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP;GPIO_InitStruct.GPIO_Pin = GPIO_Pin_8;GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &GPIO_InitStruct);
}
RCC.h文件:
#ifndef __RCC_H
#define __RCC_H#include "stm32f10x.h" // Device headervoid HSE_SetSysClk(uint32_t RCC_PLLMul_x);void MCO_GPIO_Config(void);#endif /*__RCC_H*/
main.c文件:
#include "stm32f10x.h" // Device header
#include "led.h"
#include "RCC.h" void Delay(uint32_t val)
{while(val){val--;}
}int main(void)
{LED_Init();//HSE_SetSysClk(RCC_PLLMul_16); //设置时钟频率为16倍频 8*16=128M 超频MCO_GPIO_Config();RCC_MCOConfig(RCC_MCO_PLLCLK_Div2);//MCO输出A8口输出锁相环时钟2分频,用示波器可以测量A8口的频率while(1){LED(ON);Delay(0xfffff);LED(OFF);Delay(0xfffff);}
}
由于我没有示波器,所以就只能用个led灯看看闪烁的速度来判断是不是超频了,所以还有个led的模块:
led.c文件:
#include "led.h" // Device headervoid LED_Init(void)
{RCC_APB2PeriphClockCmd(GPIO_CLK, ENABLE);GPIO_InitTypeDef GPIO_InitStruct;GPIO_InitStruct.GPIO_Mode = GPIO_Mode_Out_PP;GPIO_InitStruct.GPIO_Pin = GPIO_PIN;GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOx, &GPIO_InitStruct);}
led.h文件:
#ifndef __LED_H
#define __LED_H#include "stm32f10x.h" // Device header#define GPIOx GPIOB
#define GPIO_PIN GPIO_Pin_0
#define GPIO_CLK RCC_APB2Periph_GPIOB#define ON 1
#define OFF 0#define LED(x) if(x)\GPIO_ResetBits(GPIOx, GPIO_PIN);\else \GPIO_SetBits(GPIOx, GPIO_PIN);void LED_Init(void);#endif
这篇关于STM32手写超频到128M函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!