基于STM32单片机的USB时钟配置设计

控制/MCU

1888人已加入

描述

1.首先要配置好系统的时钟如下:

RCC_DeInit();//将外设RCC寄存器重设为缺省值

/*EnableHSE*/

RCC_HSEConfig(RCC_HSE_ON);//设置外部高速晶振(HSE)

/*WaittillHSEisready*/

HSEStartUpStatus=RCC_WaitForHSEStartUp();//等待HSE起振,等待外部的时钟起振

if(HSEStartUpStatus==SUCCESS)

{

/*EnablePrefetchBuffer*/

FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);//使能或者失能预取指缓存

/*Flash2waitstate*/

FLASH_SetLatency(FLASH_Latency_2);//设置代码延时值

/*HCLK=SYSCLK*/

RCC_HCLKConfig(RCC_SYSCLK_Div1);//设置AHB时钟(HCLK)

/*PCLK2=HCLK*/

RCC_PCLK2Config(RCC_HCLK_Div1);//设置高速AHB时钟(PCLK2)toAPB2

/*PCLK1=HCLK/2*/

//STM32的时钟比较复杂

RCC_PCLK1Config(RCC_HCLK_Div2);//设置高速AHB时钟(PCLK1)toAPB1

/*ADCCLK=PCLK2/8*/

RCC_ADCCLKConfig(RCC_PCLK2_Div8);//设置ADC时钟(ADCCLK)

/*PLLCLK=8MHz*9=72MHz*/

//设置外部时钟源,且PLL等于外部时钟频率*9

RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);

//此时PLLCLK=72MHz,这个得知道他的值,因为USB的时钟USBCLK=PLLCLK/1或者PLLCLK/1.5,但得确保USBCLK=48MHz

//所以配置USBCLK的时候选择是1.5分频

RCC_PLLCmd(ENABLE);//最后才激活PLL,必须最后才激活!

/*WaittillPLLisready*/

while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET)

{

}

RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//配置SYSCLK

/*WaittillPLLisusedassystemclocksource*/

while(RCC_GetSYSCLKSource()!=0x08)

{

}

}

else

{

/*IfHSEfailstostart-up,theapplicationwillhavewrongclockconfiguration.

Usercanaddheresomecodetodealwiththiserror*/

/*Gotoinfiniteloop*/

while(1)

{

}

}

voidUSBclock_Config()

{

RCC_USBCLKConfig(RCC_USBCLKSource_PLLCLK_1Div5);//1.5分频

/*EnabletheUSBclock*/

RCC_APB1PeriphClockCmd(RCC_APB1Periph_USB,ENABLE);//此处是激活USB外设,USB属于APB1外设

}

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分