您的位置 首页 系统

STM32时钟设置

35的库中什么也不用做。已经在启动文件中设置好了时钟。大家都知道在使用单片机时,时钟速度决定于外部晶振或内部RC振荡电路的频率,是不

3.5的库中什么也不必做。现已在发动文件中设置好了时钟。

咱们都知道在运用单片机时,时钟速度决定于外部晶振或内部RC振动电路的频率,是不可以改动的。而ARM的呈现打破了这一传统的规律,可以经过软件随意改动时钟速度。这一呈现让咱们的规划愈加灵敏,可是也给咱们的规划增加了杂乱性。为了让用户可以更简略的运用这一功用,STM32的库函数现已为咱们规划的愈加简略便利。

在比较靠前的版别中,咱们需求向下面那样设置时钟:

ErrorStatus HSEStartUpStatus;

void RCC_Configuration(void)
{
RCC_DeInit(); // RCC system reset(for debug purpose)

RCC_HSEConfig(RCC_HSE_ON);// Enable HSE

HSEStartUpStatus = RCC_WaitForHSEStartUp();// Wait till HSE is ready

if (HSEStartUpStatus == SUCCESS)// 当HSE预备结束切振动安稳后
{
RCC_HCLKConfig(RCC_SYSCLK_Div1); // HCLK = SYSCLK
RCC_PCLK2Config(RCC_HCLK_Div1); // PCLK2 = HCLK
RCC_PCLK1Config(RCC_HCLK_Div2);// PCLK1 = HCLK/2
FLASH_SetLatency(FLASH_Latency_2);// Flash 2 wait state
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);// Enable Prefetch Buffer
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);// PLLCLK = 8MHz * 9 = 72 MHz
RCC_PLLCmd(ENABLE);// Enable PLL
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
{;// Wait till PLL is ready
}
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);// Select PLL as system clock source
while (RCC_GetSYSCLKSource() != 0x08)// Wait till PLL is used as system clock source
{
;
}
}
}

随之函数库的不断晋级,到3.0以上时,咱们就不必再这样编写时钟设置了,咱们只要做如下两部即可:

第一个: system_stm32f10x.c 中#define SYSCLK_FREQ_72MHz 72000000
第二个:调用SystemInit()

阐明:在stm32固件库3.0中对时钟频率的挑选进行了大大的简化,原先的一大堆操作都在后台进行。体系给出的函数为SystemInit()。但在调用前还需求进行一些宏界说的设置,详细的设置在system_stm32f10x.c文件中。

文件最初就有一个这样的界说:
//#define SYSCLK_FREQ_HSEHSE_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.

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qianrushi/xitong/256033.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部