时钟图
//RCC_HSEConfig(RCC_HSE_OFF); // 封闭外部时钟
//RCC_HSEConfig(RCC_HSE_ON);//敞开外部时钟
//RCC_HSICmd(ENABLE);// 敞开内部时钟
//RCC_HS%&&&&&%md(DISABLE);// 敞开内部时钟
//双高档外设总线结构:高速APB(APB2)速度到达72MHz、低速APB(APB1)速度到达36MHz。
//答应用户优化外设的运用(18MHz的SPI、4.5Mbps的USART、72MHz的PWM定时器、18MHz触发I/O口)。
//RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_8); // 运用外部时钟源F,倍频输出等于 F*8/1
//RCC_PLLConfig(RCC_PLLSource_HSI_Div2, RCC_PLLMul_8); // 运用内部时钟源F,倍频输出等于 F*8/2
void RCC_Configuration(void)
{
RCC_DeInit();//将外设RCC存放器重设为缺省值(即默认值)
RCC_HSEConfig(RCC_HSE_ON);//翻开外部晶振
if(RCC_WaitForHSEStartUp() == SUCCESS) //判别起振是否成功
{
RCC_HCLKConfig(RCC_SYSCLK_Div1); //设置AHB时钟(HCLK)(这时设置为=体系时钟)
RCC_PCLK2Config(RCC_HCLK_Div1); //设置高速AHB时钟(HCLK2)(这时设置为=HCLK)
RCC_PCLK1Config(RCC_HCLK_Div2);//设置低速AHV时钟(HCLK1)(这时设置为=HCLK/2)
FLASH_SetLatency(FLASH_Latency_2);//设置FLASH存储器延时时钟周期数。(设置为延时2个时钟周期)
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);//使能预取指缓存
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);//PLL的时钟来历及倍频的倍数
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) //检测PLL是否安排妥当
{
}
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //设置PLL为体系时钟
while(RCC_GetSYSCLKSource() != 0x08) //检测体系的时钟源是否是PLL
{
}
}
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);//使能USART GPIOA时钟
}
声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/news/xinwen/258100.html