找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3091|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

STM32的嵌套中斷系統(tǒng)NVIC和RCC詳細(xì)整理

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:140725 發(fā)表于 2016-11-15 12:44 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
完整的word文檔下載:
STM32的嵌套中斷系統(tǒng)NVIC詳細(xì)整理.doc (1.5 MB, 下載次數(shù): 12)

STM32的時(shí)鐘系統(tǒng)RCC詳細(xì)整理.doc (417.5 KB, 下載次數(shù): 10)


STM32的嵌套中斷系統(tǒng)NVIC和RCC詳細(xì)整理 用的是stm32f103的最新3.5的庫。
一、綜述:
1、STM32 (Cortex-M3) 中的優(yōu)先級(jí)概念
    STM32(Cortex-M3)中有兩個(gè)優(yōu)先級(jí)的概念:搶占式優(yōu)先級(jí)和響應(yīng)優(yōu)先級(jí),也把響應(yīng)優(yōu)先級(jí)稱作“亞優(yōu)先級(jí)”或“副優(yōu)先級(jí)”,每個(gè)中斷源都需要被指定這兩種優(yōu)先級(jí)。
1. 何為占先式優(yōu)先級(jí)(pre-emption priority)
   高占先式優(yōu)先級(jí)的中斷事件會(huì)打斷當(dāng)前的主程序/中斷程序運(yùn)行—搶斷式優(yōu)先響應(yīng),俗稱中斷嵌套。
2. 何為副優(yōu)先級(jí)(subpriority)
   在占先式優(yōu)先級(jí)相同的情況下,高副優(yōu)先級(jí)的中斷優(yōu)先被響應(yīng);
   在占先式優(yōu)先級(jí)相同的情況下,如果有低副優(yōu)先級(jí)中斷正在執(zhí)行,高副優(yōu)先級(jí)的中斷要等待已被響應(yīng)的低副優(yōu)先級(jí)中斷執(zhí)行結(jié)束后才能得到響應(yīng)—非搶斷式響應(yīng)(不能嵌套)。
3. 判斷中斷是否會(huì)被響應(yīng)的依據(jù)
   首先是占先式優(yōu)先級(jí),其次是副優(yōu)先級(jí);
   占先式優(yōu)先級(jí)決定是否會(huì)有中斷嵌套;
   Reset、NMI、Hard Fault 優(yōu)先級(jí)為負(fù)(高于普通中斷優(yōu)先級(jí))且不可調(diào)整。
4. 優(yōu)先級(jí)沖突的處理
   具有高搶占式優(yōu)先級(jí)的中斷可以在具有低搶占式優(yōu)先級(jí)的中斷處理過程中被響應(yīng),即中斷的嵌套,或者說高搶占式優(yōu)先級(jí)的中斷可以嵌套低搶占式優(yōu)先級(jí)的中斷。
   當(dāng)兩個(gè)中斷源的搶占式優(yōu)先級(jí)相同時(shí),這兩個(gè)中斷將沒有嵌套關(guān)系,當(dāng)一個(gè)中斷到來后,如果正在處理另一個(gè)中斷,這個(gè)后到來的中斷就要等到前一個(gè)中斷處理完之后才能被處理。如果這兩個(gè)中斷同時(shí)到達(dá),則中斷控制器根據(jù)他們的響應(yīng)優(yōu)先級(jí)高低來決定先處理哪一個(gè);如果他們的搶占式優(yōu)先級(jí)和響應(yīng)優(yōu)先級(jí)都相等,則根據(jù)他們在中斷表中的排位順序決定先處理哪一個(gè)。
5.Cortex-M3中對(duì)中斷優(yōu)先級(jí)的定義
   既然每個(gè)中斷源都需要被指定這兩種優(yōu)先級(jí),就需要有相應(yīng)的寄存器位記錄每個(gè)中斷的優(yōu)先級(jí);在Cortex-M3中定義了8個(gè)比特位用于設(shè)置中斷源的優(yōu)先級(jí),這8個(gè)比特位可以有8種分配方式,如下:
所有8位用于指定響應(yīng)優(yōu)先級(jí)
最高1位用于指定搶占式優(yōu)先級(jí),最低7位用于指定響應(yīng)優(yōu)先級(jí)
最高2位用于指定搶占式優(yōu)先級(jí),最低6位用于指定響應(yīng)優(yōu)先級(jí)
最高3位用于指定搶占式優(yōu)先級(jí),最低5位用于指定響應(yīng)優(yōu)先級(jí)
最高4位用于指定搶占式優(yōu)先級(jí),最低4位用于指定響應(yīng)優(yōu)先級(jí)
最高5位用于指定搶占式優(yōu)先級(jí),最低3位用于指定響應(yīng)優(yōu)先級(jí)
最高6位用于指定搶占式優(yōu)先級(jí),最低2位用于指定響應(yīng)優(yōu)先級(jí)
最高7位用于指定搶占式優(yōu)先級(jí),最低1位用于指定響應(yīng)優(yōu)先級(jí)
這就是優(yōu)先級(jí)分組的概念。
6.stm32中對(duì)中斷優(yōu)先級(jí)的定義
   Cortex-M3允許具有較少中斷源時(shí)使用較少的寄存器位指定中斷源的優(yōu)先級(jí),因此STM32把指定中斷優(yōu)先級(jí)的寄存器位減少到4位,這4個(gè)寄存器位的分組方式如下:
第0組:所有4位用于指定響應(yīng)優(yōu)先級(jí)
第1組:最高1位用于指定搶占式優(yōu)先級(jí),最低3位用于指定響應(yīng)優(yōu)先級(jí)
第2組:最高2位用于指定搶占式優(yōu)先級(jí),最低2位用于指定響應(yīng)優(yōu)先級(jí)
第3組:最高3位用于指定搶占式優(yōu)先級(jí),最低1位用于指定響應(yīng)優(yōu)先級(jí)
第4組:所有4位用于指定搶占式優(yōu)先級(jí)
file:///C:/DOCUME~1/LU/LOCALS~1/Temp/msohtml1/03/clip_image001.jpg
   AIRC(Application Interrupt and Reset Register)寄存器中有用于指定優(yōu)先級(jí)的 4bits。這4個(gè)bits用于分配preemption優(yōu)先級(jí)和sub優(yōu)先級(jí),在STM32的固件庫中定義如下:
/*Preemption Priority Group */
#define NVIC_PriorityGroup_0        ((u32)0x700) /* 0 bits for pre-emption priority
                                                    4 bits for subpriority */
#define NVIC_PriorityGroup_1        ((u32)0x600) /* 1 bits for pre-emption priority
                                                    3 bits for subpriority */
#define NVIC_PriorityGroup_2        ((u32)0x500) /* 2 bits for pre-emption priority
                                                    2 bits for subpriority */
#define NVIC_PriorityGroup_3        ((u32)0x400) /* 3 bits for pre-emption priority
                                                    1 bits for subpriority */
#define NVIC_PriorityGroup_4        ((u32)0x300) /* 4 bits for pre-emption priority
                                                    0 bits for subpriority */
    可以通過調(diào)用STM32的固件庫中的函數(shù)NVIC_PriorityGroupConfig()選擇使用哪種優(yōu)先級(jí)分組方式,這個(gè)函數(shù)的參數(shù)有下列5種:
NVIC_PriorityGroup_0=> 選擇第0組
NVIC_PriorityGroup_1 => 選擇第1組
NVIC_PriorityGroup_2 => 選擇第2組
NVIC_PriorityGroup_3 => 選擇第3組
NVIC_PriorityGroup_4 => 選擇第4組
   接下來就是指定中斷源的優(yōu)先級(jí),下面以一個(gè)簡單的例子說明如何指定中斷源的搶占式優(yōu)先級(jí)和響應(yīng)優(yōu)先級(jí):
// 選擇使用優(yōu)先級(jí)分組第1組
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
//定義NVIC的結(jié)構(gòu)體變量
NVIC_InitTypeDef  NVIC_InitStructure;
// 使能EXTI0中斷
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQ;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
//指定搶占式優(yōu)先級(jí)別1
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; // 指定響應(yīng)優(yōu)先級(jí)別0
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
// 使能EXTI9_5中斷
NVIC_InitStructure.NVIC_IRQChannel = EXTI9_5_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; //指定搶占式優(yōu)先級(jí)別0
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;// 指定響應(yīng)優(yōu)先級(jí)別1
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
-------------------------------------------------------------------------------
   要注意的幾點(diǎn)是:
   1. 如果指定的搶占式優(yōu)先級(jí)別或響應(yīng)優(yōu)先級(jí)別超出了選定的優(yōu)先級(jí)分組所限定的范圍,將可能得到意想不到的結(jié)果;
   2. 搶占式優(yōu)先級(jí)別相同的中斷源之間沒有嵌套關(guān)系;
   3. 如果某個(gè)中斷源被指定為某個(gè)搶占式優(yōu)先級(jí)別,又沒有其它中斷源處于同一個(gè)搶占式優(yōu)先級(jí)別,則可以為這個(gè)中斷源指定任意有效的響應(yīng)優(yōu)先級(jí)別。
2、開關(guān)總中斷
   在STM32/Cortex-M3中是通過改變CPU的當(dāng)前優(yōu)先級(jí)來允許或禁止中斷。
PRIMASK位:只允許NMI和hardfault異常,其他中斷/異常都被屏蔽(當(dāng)前CPU優(yōu)先級(jí)=0)。
FAULTMASK位:只允許NMI,其他所有中斷/異常都被屏蔽(當(dāng)前CPU優(yōu)先級(jí)=-1)。
   在STM32固件庫中(stm32f10x_nvic.c和stm32f10x_nvic.h) 定義了四個(gè)函數(shù)操作PRIMASK位和FAULTMASK位,改變CPU的當(dāng)前優(yōu)先級(jí),從而達(dá)到控制所有中斷的目的。
下面兩個(gè)函數(shù)等效于關(guān)閉總中斷:
voidNVIC_SETPRIMASK(void);
voidNVIC_SETFAULTMASK(void);
下面兩個(gè)函數(shù)等效于開放總中斷:
voidNVIC_RESETPRIMASK(void);
voidNVIC_RESETFAULTMASK(void);
上面兩組函數(shù)要成對(duì)使用,但不能交叉使用。
例如:
第一種方法:
NVIC_SETPRIMASK();  //關(guān)閉總中斷 ,只允許NMI和hard fault異常
NVIC_RESETPRIMASK();//開放總中斷
第二種方法:
NVIC_SETFAULTMASK();  //關(guān)閉總中斷 ,只允許NMI
NVIC_RESETFAULTMASK();//開放總中斷
常常使用:
NVIC_SETPRIMASK();     //Disable Interrupts
NVIC_RESETPRIMASK();  // Enable Interrupts
可以用:
#define CLI()  __set_PRIMASK(1)  //關(guān)閉總中斷
#define SEI()  __set_PRIMASK(0)  //打開總中斷
來實(shí)現(xiàn)開關(guān)總中斷的功能。
二、寄存器介紹:
1、 core_cm3.h中定義了:

…………………………
…………………………
…………………………
五、實(shí)例詳解
void NVIC_config()//配置中斷
{
NVIC_InitTypeDef NVIC_InitStructure;
//NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);//選擇中斷分組1
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//選擇串口1中斷
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority= 0;//搶占式中斷優(yōu)先級(jí)設(shè)置為0
NVIC_InitStructure.NVIC_IRQChannelSubPriority= 3;//響應(yīng)式中斷優(yōu)先級(jí)設(shè)置為3
NVIC_InitStructure.NVIC_IRQChannelCmd =ENABLE;//使能中斷
NVIC_Init(&NVIC_InitStructure);
}



STM32的時(shí)鐘系統(tǒng)
本文檔由“~風(fēng)中的葉~”整理;QQ:654705188
一、綜述:
1、時(shí)鐘源
在 STM32 中,一共有 5 個(gè)時(shí)鐘源,分別是 HSI 、 HSE 、 LSI 、 LSE 、 PLL 。
①HSI 是高速內(nèi)部時(shí)鐘, RC 振蕩器,頻率為 8MHz ;
②HSE 是高速外部時(shí)鐘,可接石英 / 陶瓷諧振器,或者接外部時(shí)鐘源,頻率范圍是 4MHz –16MHz ;
③LSI 是低速內(nèi)部時(shí)鐘, RC 振蕩器,頻率為 40KHz ;
④LSE 是低速外部時(shí)鐘,接頻率為 32.768KHz的石英晶體;
⑤PLL 為鎖相環(huán)倍頻輸出,嚴(yán)格的來說并不算一個(gè)獨(dú)立的時(shí)鐘源, PLL 的輸入可以接 HSI/2 、 HSE 或者 HSE/2 。PLL倍頻可選擇為 2– 16 倍,但是其輸出頻率最大不得超過 72MHz 。
其中, 40kHz 的 LSI 供獨(dú)立看門狗 IWDG 使用,另外它還可以被選擇為實(shí)時(shí)時(shí)鐘 RTC 的時(shí)鐘源。另外,實(shí)時(shí)時(shí)鐘 RTC 的時(shí)鐘源還可以選擇 LSE ,或者是 HSE 的 128 分頻。
STM32 中有一個(gè)全速功能的 USB 模塊,其串行接口引擎需要一個(gè)頻率為 48MHz 的時(shí)鐘源。該時(shí)鐘源只能從 PLL 端獲取,可以選擇為 1.5 分頻或者 1分頻,也就是,當(dāng)需使用到 USB 模塊時(shí), PLL 必須使能,并且時(shí)鐘配置為 48MHz 或 72MHz 。
另外 STM32 還可以選擇一個(gè)時(shí)鐘信號(hào)輸出到 MCO 腳 (PA.8) 上,可以選擇為 PLL 輸出的 2分頻、 HSI 、 HSE 或者系統(tǒng)時(shí)鐘。
系統(tǒng)時(shí)鐘 SYSCLK ,它是提供 STM32 中絕大部分部件工作的時(shí)鐘源。系統(tǒng)時(shí)鐘可以選擇為 PLL 輸出、 HSI 、 HSE 。系系統(tǒng)時(shí)鐘最大頻率為 72MHz ,它通過 AHB 分頻器分頻后送給各個(gè)模塊使用, AHB 分頻器可以選擇 1 、 2 、 4 、 8 、 16 、 64 、 128 、 256 、 512 分頻,AHB分頻器輸出的時(shí)鐘送給 5大模塊使用:
       ①送給 AHB 總線、內(nèi)核、內(nèi)存和 DMA 使用的 HCLK 時(shí)鐘;
       ②通過 8分頻后送給 Cortex 的系統(tǒng)定時(shí)器時(shí)鐘STCLK;
       ③直接送給 Cortex 的空閑運(yùn)行時(shí)鐘 FCLK ;
       ④送給 APB1 分頻器。 APB1 分頻器可以選擇 1 、 2 、 4 、 8 、 16 分頻,其輸出一路供 APB1 外設(shè)使用( PCLK1 ,最大頻率 36MHz ),另一路送給定時(shí)器 (Timer)2 、3 、4 倍頻器使用。該倍頻器根據(jù)PCLK1的分頻值自動(dòng)選擇 1或者 2倍頻,時(shí)鐘輸出供定時(shí)器 2、 3、 4使用。
       ⑤送給 APB2 分頻器。 APB2 分頻器可以選擇 1 、 2 、 4 、 8 、 16 分頻,其輸出一路供 APB2 外設(shè)使用( PCLK2 ,最大頻率 72MHz ),另外一路送給定時(shí)器 (Timer)1 倍頻使用。該倍頻器根據(jù)PCLK2的分頻值自動(dòng)選擇1 或2 倍頻,時(shí)鐘輸出供定時(shí)器 1使用。另外 APB2 分頻器還有一路輸出供 ADC 分頻器使用,分頻后送給 ADC 模塊使用。 ADC 分頻器可選擇為 2 、 4 、 6 、 8 分頻。
需要注意的是定時(shí)器的倍頻器,當(dāng) APB 的分頻為 1 時(shí),它的倍頻值為 1 ,否則它的倍頻值就為 2 。
file:///C:/DOCUME~1/LU/LOCALS~1/Temp/msohtml1/01/clip_image002.jpg
2、APB1APB2連接的模塊
①連接在 APB1( 低速外設(shè) )上的設(shè)備有:電源接口、備份接口、 CAN 、 USB 、 I2C1 、 I2C2 、 UART2 、 UART3 、 SPI2 、窗口看門狗、 Timer2 、 Timer3 、 Timer4 。注意 USB模塊雖然需要一個(gè)單獨(dú)的48MHz的時(shí)鐘信號(hào),但是它應(yīng)該不是供USB模塊工作的時(shí)鐘,而只是提供給串行接口引擎(SIE)使用的時(shí)鐘。USB模塊的工作時(shí)鐘應(yīng)該是由APB1提供的。
②連接在 APB2 (高速外設(shè))上的設(shè)備有: UART1 、 SPI1 、 Timer1 、 ADC1 、 ADC2 、 GPIOx(PA~PE) 、第二功能IO 口。

file:///C:/DOCUME~1/LU/LOCALS~1/Temp/msohtml1/01/clip_image004.jpg
二、寄存器介紹:
typedefstruct
{
  __IO uint32_t CR;
  __IO uint32_t CFGR;
  __IO uint32_t CIR;
  __IO uint32_t APB2RSTR;
  __IO uint32_t APB1RSTR;
  __IO uint32_t AHBENR;
  __IO uint32_t APB2ENR;
  __IO uint32_t APB1ENR;
  __IO uint32_t BDCR;
  __IO uint32_t CSR;
#ifdefSTM32F10X_CL  
  __IO uint32_t AHBRSTR;
  __IO uint32_t CFGR2;
#endif /*STM32F10X_CL */
#if defined(STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined(STM32F10X_HD_VL)   
  uint32_t RESERVED0;
  __IO uint32_t CFGR2;
#endif /*STM32F10X_LD_VL || STM32F10X_MD_VL || STM32F10X_HD_VL */
}RCC_TypeDef;
1、時(shí)鐘控制寄存器(RCC_CR):(復(fù)位值為0x0000 xx83,內(nèi)部低速時(shí)鐘使能和就緒,內(nèi)部時(shí)鐘校準(zhǔn))
主要功能:內(nèi)外部高速時(shí)鐘的使能和就緒標(biāo)志(含內(nèi)部高速時(shí)鐘校準(zhǔn)調(diào)整),外部高速時(shí)鐘旁路,時(shí)鐘安全系統(tǒng)CSS使能,PLL使能和PLL就緒標(biāo)志。
2、時(shí)鐘配置寄存器(RCC_CFGR):(復(fù)位值為0x0000 0000)
主要功能:系統(tǒng)時(shí)鐘源切換及狀態(tài),AHB、APB1、APB2、ADC、USB預(yù)分頻,PLL輸入時(shí)鐘源選擇及HSE輸入PLL分頻選擇,PLL倍頻系數(shù),MCO(PA8)引腳微控制器時(shí)鐘輸出。
3、時(shí)鐘中斷寄存器 (RCC_CIR):(復(fù)位值: 0x0000 0000)
主要功能:LSI、LSE、HIS、HSE、PLL就緒中斷標(biāo)志,HSE時(shí)鐘失效導(dǎo)致時(shí)鐘安全系統(tǒng)中斷標(biāo)志,LSI、LSE、HIS、HSE、PLL就緒中斷使能,清除LSI、LSE、HIS、HSE、PLL就緒中斷,清除時(shí)鐘安全系統(tǒng)中斷。
4、APB2外設(shè)復(fù)位寄存器 (RCC_APB2RSTR):(復(fù)位值: 0x0000 0000)
主要功能:AFIO、IOPA、IOPB、IOPC、IOPD、IOPE、IOPF、IOPG、ADC1、ADC2、TIM1、SPI1、TIM8、USART1、ADC3復(fù)位。
5、APB1外設(shè)復(fù)位寄存器 (RCC_APB1RSTR) :(復(fù)位值: 0x0000 0000)
主要功能:TIM2、TIM3、TIM4、TIM5、TIM6、TIM7、WWDG、SPI2、SPI3、USART2、USART3、USART4、USART5、I2C1、I2C2、USB、CAN、BKP、PWR、DAC復(fù)位。
6、AHB外設(shè)時(shí)鐘使能寄存器 (RCC_AHBENR) :(復(fù)位值: 0x0000 0014睡眠模式時(shí)SRAM、閃存接口電路時(shí)鐘開啟)
主要功能:DMA1、DMA2、SRAM、FLITF、CRC、FSMC、SDIO時(shí)鐘使能。
7、APB2外設(shè)時(shí)鐘使能寄存器(RCC_APB2ENR) :(復(fù)位值: 0x0000 0000)
主要功能:AFIO、IOPA、IOPB、IOPC、IOPD、IOPE、IOPF、IOPG、ADC1、ADC2、TIM1、SPI1、TIM8、USART1、ADC3時(shí)鐘使能。
8、APB1外設(shè)時(shí)鐘使能寄存器(RCC_APB1ENR) :(復(fù)位值: 0x0000 0000)
主要功能:TIM2、TIM3、TIM4、TIM5、TIM6、TIM7、WWDG、SPI2、SPI3、USART2、USART3、USART4、USART5、I2C1、I2C2、USB、CAN、BKP、PWR、DAC時(shí)鐘使能。
9、備份域控制寄存器 (RCC_BDCR) :(復(fù)位值: 0x0000 0000)
主要功能:外部低速振蕩器使能和就緒標(biāo)志及旁路、RTC時(shí)鐘源選擇和時(shí)鐘使能、備份域軟件復(fù)位。
10、控制/狀態(tài)寄存器 (RCC_CSR) :(復(fù)位值: 0x0C00 0000 NRST引腳復(fù)位標(biāo)志、上電/掉電復(fù)位標(biāo)志)
主要功能:內(nèi)部低速振蕩器就緒、清除復(fù)位標(biāo)志、NRST引腳復(fù)位標(biāo)志、上電/掉電復(fù)位標(biāo)志、軟件復(fù)位標(biāo)志、獨(dú)立看門狗復(fù)位標(biāo)志、窗口看門狗復(fù)位標(biāo)志、低功耗復(fù)位標(biāo)志。
三、初始化設(shè)置
采用8MHz 外部HSE 時(shí)鐘,在 MDK 編譯平臺(tái)中,程序的時(shí)鐘設(shè)置參數(shù)流程如下:
   將 RCC 寄存器重新設(shè)置為默認(rèn)值:RCC_DeInit();
   打開外部高速時(shí)鐘晶振 HSE :     RCC_HSEConfig(RCC_HSE_ON);
   等待外部高速時(shí)鐘晶振工作:       HSEStartUpStatus= RCC_WaitForHSEStartUp();
   設(shè)置 AHB 時(shí)鐘 (HCLK):          RCC_HCLKConfig(RCC_SYSCLK_Div1);
       設(shè)置APB 2時(shí)鐘 (APB2)    RCC_PCLK2Config(RCC_HCLK_Div1);
       設(shè)置APB1 時(shí)鐘 (APB1)    RCC_PCLK1Config(RCC_HCLK_Div2);
       設(shè)置 PLL :       RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);
   打開 PLL :                                  RCC_PLLCmd(ENABLE);
   等待 PLL 工作:    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)== RESET);
設(shè)置系統(tǒng)時(shí)鐘:    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
判斷 PLL 是否是系統(tǒng)時(shí)鐘:        while(RCC_GetSYSCLKSource()!= 0x08);
1、使用庫函數(shù)進(jìn)行時(shí)鐘系統(tǒng)初始化配置
voidRCC_config()//如果外部晶振為8MPLLCLK=SYSCLK=72M,HCLK=72M,//P2CLK=72M,P1CLK=36MADCCLK=36M,USBCLK=48MTIMCLK=72M
{
       ErrorStatus HSEStartUpStatus; // 定義錯(cuò)誤狀態(tài)變量
       RCC_DeInit();//RCC寄存器重新設(shè)置為默認(rèn)值
       RCC_HSEConfig(RCC_HSE_ON); //打開外部高速時(shí)鐘晶振
       HSEStartUpStatus =RCC_WaitForHSEStartUp();// 等待外部高速時(shí)鐘晶振工作
       if(HSEStartUpStatus == SUCCESS)
       {
       RCC_HCLKConfig(RCC_SYSCLK_Div1);//設(shè)置AHB不分頻,HCLK=SYSCLK
       RCC_PCLK2Config(RCC_HCLK_Div1);//設(shè)置APB2不分頻,P2CLK=HCLK
       RCC_PCLK1Config(RCC_HCLK_Div2); //設(shè)置APB1 2分頻,P1CLK=HCLK/2
       FLASH_SetLatency(FLASH_Latency_2);//設(shè)置FLASH代碼延時(shí)
       FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);//使能預(yù)取指緩存
       RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);//設(shè)置PLL時(shí)鐘源,
//外部時(shí)鐘不分頻,為HSE的9倍頻8MHz * 9 =72MHz
       RCC_PLLCmd(ENABLE);//使能PLL
       while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)== RESET);//等待PLL準(zhǔn)備就緒
       RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//設(shè)置PLL為系統(tǒng)時(shí)鐘源
       while(RCC_GetSYSCLKSource() != 0x08);//判斷PLL是否是系統(tǒng)時(shí)鐘
       }
            /*RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB| RCC_APB2Periph_GPIOD, ENABLE);// 打開PB 和PD 用于點(diǎn)亮LED 燈*/
}
2、使用寄存器進(jìn)行RCC時(shí)鐘初始化配置
voidRCC_init(u8 PLL)//輸入PLL的倍頻值2—16倍頻
//HCLK=PLLCLK=SYSCLK=P2CLK=P1CLK*2=ADCCLK*2=TIMCLK=USBCLK*2/3
{
       unsigned char temp=0;   
       //RCC_DeInit();              //將RCC寄存器重新設(shè)置為默認(rèn)值
       RCC->CR|=0x00010000;  //外部高速時(shí)鐘使能HSEON
       while(!(RCC->CR>>17));//等待外部時(shí)鐘就緒
       RCC->CFGR=0X00000400;//APB1=DIV2;APB2=DIV1;AHB=DIV1;
       PLL-=2;//抵消2個(gè)單位
       RCC->CFGR|=PLL<<18;   //設(shè)置PLL倍頻值 2~16
       RCC->CFGR|=1<<16;     //PLL時(shí)鐘源選擇
       FLASH->ACR|=0x32;    //FLASH 2個(gè)延時(shí)周期
       RCC->CR|=0x01000000;  //PLLON
       while(!(RCC->CR>>25));//等待PLL鎖定
       RCC->CFGR|=0x00000002;//PLL作為系統(tǒng)時(shí)鐘        
       while(temp!=0x02)     //等待PLL作為系統(tǒng)時(shí)鐘設(shè)置成功
       {  
              temp=RCC->CFGR>>2;
              temp&=0x03;
       }   
}
四、相關(guān)庫函數(shù)解析
1、庫中所涉及到的結(jié)構(gòu)體
typedef struct
{
  uint32_t SYSCLK_Frequency;  /*!< returns SYSCLK clock frequencyexpressed in Hz */
  uint32_t HCLK_Frequency;    /*!< returns HCLK clock frequencyexpressed in Hz */
  uint32_t PCLK1_Frequency;   /*!< returns PCLK1 clock frequencyexpressed in Hz */
  uint32_t PCLK2_Frequency;   /*!< returns PCLK2 clock frequencyexpressed in Hz */
  uint32_t ADCCLK_Frequency; /*!< returnsADCCLK clock frequency expressed in Hz */
}RCC_ClocksTypeDef;
2、庫函數(shù)解析
void RCC_DeInit(void);//將外設(shè)RCC寄存器設(shè)為缺省值;(除RCC_BDCR和RCC_CSR)
voidRCC_HSEConfig(uint32_t RCC_HSE);//設(shè)置外部高速晶振(HSE);
//輸入:RCC_HSE_OFF,RCC_HSE_ON,RCC_HSE_Bypass(HSE旁路)
ErrorStatusRCC_WaitForHSEStartUp(void);//等待HSE起振;
//返回值:SUCCESS,HSE晶振穩(wěn)定且就緒;ERROR,HSE晶振未就緒
voidRCC_AdjustHSICalibrationValue(uint8_t HSICalibrationValue);//調(diào)整內(nèi)部高速晶振(HSI)校準(zhǔn)值
//輸入:校準(zhǔn)補(bǔ)償值(該參數(shù)取值必須在0到0x1F之間)
voidRCC_HSICmd(FunctionalState NewState);//使能或者失能內(nèi)部高速晶振(HSI)
//輸入:ENABLE或者DISABLE(如果HSI被用于系統(tǒng)時(shí)鐘,或者FLASH編寫操作進(jìn)行中,那么它不能被停振)
void RCC_PLLConfig(uint32_tRCC_PLLSource, uint32_t RCC_PLLMul);//設(shè)置PLL時(shí)鐘源及倍頻系數(shù)
//輸入:RCC_PLLSource_HSI_Div2,RCC_PLLSource_HSE_Div1,RCC_PLLSource_HSE_Div2
//輸入:RCC_PLLMul_2到RCC_PLLMul_16
voidRCC_PLLCmd(FunctionalState NewState);// 使能或者失能PLL
//輸入:ENABLE或者DISABLE
#if defined(STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined (STM32F10X_HD_VL) ||defined (STM32F10X_CL)
void RCC_PREDIV1Config(uint32_tRCC_PREDIV1_Source, uint32_t RCC_PREDIV1_Div);//
#endif
#ifdef  STM32F10X_CL
void RCC_PREDIV2Config(uint32_t RCC_PREDIV2_Div);//
void RCC_PLL2Config(uint32_t RCC_PLL2Mul);//
void RCC_PLL2Cmd(FunctionalState NewState);//
void RCC_PLL3Config(uint32_t RCC_PLL3Mul);//
void RCC_PLL3Cmd(FunctionalState NewState);//
#endif /* STM32F10X_CL*/
voidRCC_SYSCLKConfig(uint32_t RCC_SYSCLKSource);//設(shè)置系統(tǒng)時(shí)鐘(SYSCLK)源
// RCC_SYSCLKSource_HSI,RCC_SYSCLKSource_HSE,RCC_SYSCLKSource_PLLCLK
uint8_tRCC_GetSYSCLKSource(void);// 返回用作系統(tǒng)時(shí)鐘的時(shí)鐘源
//返回值:0x00 HSI作為系統(tǒng)時(shí)鐘,0x04 HSE作為系統(tǒng)時(shí)鐘,0x08 PLL作為系統(tǒng)時(shí)鐘
voidRCC_HCLKConfig(uint32_t RCC_SYSCLK);//設(shè)置AHB時(shí)鐘(HCLK)
//輸入:RCC_SYSCLK_Div1,RCC_SYSCLK_Div2,RCC_SYSCLK_Div4,RCC_SYSCLK_Div8,RCC_SYSCLK_Div16,
//RCC_SYSCLK_Div32,RCC_SYSCLK_Div64,RCC_SYSCLK_Div128,RCC_SYSCLK_Div256,RCC_SYSCLK_Div512
voidRCC_PCLK1Config(uint32_t RCC_HCLK);// 設(shè)置低速AHB時(shí)鐘(PCLK1)
//輸入: RCC_HCLK_Div1, RCC_HCLK_Div2, RCC_HCLK_Div4, RCC_HCLK_Div8, RCC_HCLK_Div16
voidRCC_PCLK2Config(uint32_t RCC_HCLK);//設(shè)置高速AHB時(shí)鐘(PCLK2)
//輸入:RCC_HCLK_Div1, RCC_HCLK_Div2, RCC_HCLK_Div4, RCC_HCLK_Div8, RCC_HCLK_Div16
voidRCC_ITConfig(uint8_t RCC_IT, FunctionalState NewState);// 使能或者失能指定的RCC中斷
//輸入:RCC_IT_LSIRDY  LSI就緒中斷->ENABLE或者DISABLE
//RCC_IT_LSERDY  LSE就緒中斷,RCC_IT_HSIRDY  HSI就緒中斷
//RCC_IT_HSERDY  HSE就緒中斷,RCC_IT_PLLRDY  PLL就緒中斷
#ifndef STM32F10X_CL
void RCC_USBCLKConfig(uint32_tRCC_USBCLKSource);// 設(shè)置USB時(shí)鐘(USBCLK)
//輸入:RCC_USBCLKSource_PLLCLK_1Div5,USB時(shí)鐘 = PLL時(shí)鐘除以1.5
RCC_USBCLKSource_PLLCLK_Div1,USB時(shí)鐘 = PLL時(shí)鐘
#else
void RCC_OTGFSCLKConfig(uint32_tRCC_OTGFSCLKSource);//
#endif /* STM32F10X_CL*/
voidRCC_ADCCLKConfig(uint32_t RCC_PCLK2);// 設(shè)置ADC時(shí)鐘(ADCCLK)
//RCC_PCLK2_Div2,ADC時(shí)鐘 = PCLK / 2;RCC_PCLK2_Div4,ADC時(shí)鐘 = PCLK / 4;
//RCC_PCLK2_Div6,ADC時(shí)鐘 = PCLK / 6;RCC_PCLK2_Div8,ADC時(shí)鐘 = PCLK / 8
#ifdef STM32F10X_CL
void RCC_I2S2CLKConfig(uint32_tRCC_I2S2CLKSource); //                                 
void RCC_I2S3CLKConfig(uint32_tRCC_I2S3CLKSource);//
#endif /* STM32F10X_CL*/
voidRCC_LSEConfig(uint8_t RCC_LSE);// 設(shè)置外部低速晶振(LSE)
//輸入:RCC_LSE_OFF,LSE晶振OFF;RCC_LSE_ON,LSE晶振ON;
//RCC_LSE_Bypass,LSE晶振被外部時(shí)鐘旁路
voidRCC_LSICmd(FunctionalState NewState);// 使能或者失能內(nèi)部低速晶振(LSI)
//輸入:ENABLE或者DISABLE   (IWDG運(yùn)行的話,LSI不能被失能)
voidRCC_RTCCLKConfig(uint32_t RCC_RTCCLKSource);//設(shè)置RTC時(shí)鐘(RTCCLK)源(RTC時(shí)鐘一經(jīng)選定即不能更改,除非復(fù)位后備域)
//輸入:RCC_RTCCLKSource_LSE,選擇LSE作為RTC時(shí)鐘;RCC_RTCCLKSource_LSI,選擇LSI作為RTC時(shí)鐘;RCC_RTCCLKSource_HSE_Div128,選擇HSE時(shí)鐘頻率除以128作為RTC時(shí)鐘
voidRCC_RTCCLKCmd(FunctionalState NewState);// 使能或者失能RTC時(shí)鐘
//輸入:ENABLE或者DISABLE
voidRCC_GetClocksFreq(RCC_ClocksTypeDef* RCC_Clocks);// 返回時(shí)鐘的頻率
//輸入:指向結(jié)構(gòu)RCC_ClocksTypeDef的指針,包含了各個(gè)時(shí)鐘的頻率(單位為Hz)
voidRCC_AHBPeriphClockCmd(uint32_t RCC_AHBPeriph, FunctionalState NewState);// 使能或者失能AHB外設(shè)時(shí)鐘
//輸入:RCC_AHBPeriph_DMA,DMA時(shí)鐘->ENABLE或者DISABLE;
//RCC_AHBPeriph_SRAM,SRAM時(shí)鐘;RCC_AHBPeriph_FLITF,F(xiàn)LITF時(shí)鐘
//RCC_AHBPeriph_DMA1,DMA1時(shí)鐘;RCC_AHBPeriph_DMA2,DMA2時(shí)鐘
//RCC_AHBPeriph_CRC,CRC時(shí)鐘;RCC_AHBPeriph_FSMC,F(xiàn)SMC時(shí)鐘
//RCC_AHBPeriph_SDIO,SDIO時(shí)鐘
voidRCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);// 使能或者失能APB2外設(shè)時(shí)鐘
//輸入:RCC_APB2Periph_AFIO,功能復(fù)用IO時(shí)鐘->ENABLE或者DISABLE;
//RCC_APB2Periph_GPIOA,GPIOA時(shí)鐘;RCC_APB2Periph_GPIOB,GPIOB時(shí)鐘;
//RCC_APB2Periph_GPIOC,GPIOC時(shí)鐘;RCC_APB2Periph_GPIOD,GPIOD時(shí)鐘;
//RCC_APB2Periph_GPIOE,GPIOE時(shí)鐘;RCC_APB2Periph_ADC1,ADC1時(shí)鐘;
//RCC_APB2Periph_ADC2,ADC2時(shí)鐘;RCC_APB2Periph_TIM1,TIM1時(shí)鐘;
//RCC_APB2Periph_SPI1,SPI1時(shí)鐘;RCC_APB2Periph_USART1,USART1時(shí)鐘;
//RCC_APB2Periph_ALL,全部APB2外設(shè)時(shí)鐘
voidRCC_APB1PeriphClockCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);// 使能或者失能APB1外設(shè)時(shí)鐘
//輸入:RCC_APB1Periph_TIM2,TIM2時(shí)鐘->ENABLE或者DISABLE;
//RCC_APB1Periph_TIM3,TIM3時(shí)鐘;RCC_APB1Periph_TIM4,TIM4時(shí)鐘
//RCC_APB1Periph_WWDG,WWDG時(shí)鐘;RCC_APB1Periph_SPI2,SPI2時(shí)鐘
//RCC_APB1Periph_USART2,USART2時(shí)鐘;RCC_APB1Periph_USART3,USART3時(shí)鐘
//RCC_APB1Periph_I2C1,I2C1時(shí)鐘;RCC_APB1Periph_I2C2,I2C2時(shí)鐘
//RCC_APB1Periph_USB,USB時(shí)鐘;RCC_APB1Periph_CAN,CAN時(shí)鐘
//RCC_APB1Periph_BKP,BKP時(shí)鐘;RCC_APB1Periph_PWR,PWR時(shí)鐘
//RCC_APB1Periph_ALL,全部APB1外設(shè)時(shí)鐘
#ifdef STM32F10X_CL
voidRCC_AHBPeriphResetCmd(uint32_t RCC_AHBPeriph, FunctionalState NewState);//
#endif /* STM32F10X_CL*/
voidRCC_APB2PeriphResetCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);// 強(qiáng)制或者釋放高速APB(APB2)外設(shè)復(fù)位
//輸入:同voidRCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);函數(shù)的值
voidRCC_APB1PeriphResetCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);// 強(qiáng)制或者釋放低速APB(APB1)外設(shè)復(fù)位
//輸入:同void RCC_APB1PeriphClockCmd(uint32_tRCC_APB1Periph, FunctionalState NewState);函數(shù)的值
//例:/* Enter theSPI1 peripheral to reset */
//RCC_APB2PeriphResetCmd(RCC_APB2Periph_SPI1,ENABLE);
/* Exit the SPI1peripheral from reset */
//RCC_APB2PeriphResetCmd(RCC_APB2Periph_SPI1,DISABLE);
voidRCC_BackupResetCmd(FunctionalState NewState);// 強(qiáng)制或者釋放后備域復(fù)位
voidRCC_ClockSecuritySystemCmd(FunctionalState NewState);//使能或者失能時(shí)鐘安全系統(tǒng)
//輸入:ENABLE或者DISABLE
voidRCC_MCOConfig(uint8_t RCC_MCO);// 選擇在MCO管腳上輸出的時(shí)鐘源
//輸入:RCC_MCO_NoClock 無時(shí)鐘被選中 ;RCC_MCO_SYSCLK 選中系統(tǒng)時(shí)鐘;
//RCC_MCO_HSI選中HSI ;RCC_MCO_HSE 選中HSE ;
//RCC_MCO_PLLCLK_Div2選中PLL時(shí)鐘除以2
//警告:當(dāng)選中系統(tǒng)時(shí)鐘作為MCO管腳的輸出時(shí),注意它的時(shí)鐘頻率不超過50MHz(最大I/O速率)。
FlagStatusRCC_GetFlagStatus(uint8_t RCC_FLAG);// 檢查指定的RCC標(biāo)志位設(shè)置與否
//輸入:待檢查的RCC標(biāo)志位


//RCC_FLAG_HSIRDY ,HSI晶振就緒;RCC_FLAG_HSERDY,HSE晶振就緒;
//RCC_FLAG_PLLRDY ,PLL就緒;RCC_FLAG_LSERDY ,LSI晶振就緒;
//RCC_FLAG_LSIRDY ,LSE晶振就緒;RCC_FLAG_PINRST,管腳復(fù)位 ;
//RCC_FLAG_PORRST ,POR/PDR復(fù)位;RCC_FLAG_SFTRST ,軟件復(fù)位 ;
//RCC_FLAG_IWDGRST ,IWDG復(fù)位;RCC_FLAG_WWDGRST ,WWDG復(fù)位;
//RCC_FLAG_LPWRRST,低功耗復(fù)位
//返回值:RCC_FLAG的新狀態(tài)(SET或者RESET)
//例:/* Test if the PLL clock is readyor not */
//FlagStatus Status;
//Status = RCC_GetFlagStatus(RCC_FLAG_PLLRDY);
//if(Status == RESET)
//{
//...
//}
//else
voidRCC_ClearFlag(void);// 清除RCC的復(fù)位標(biāo)志位
//(可以清除的復(fù)位標(biāo)志位有:RCC_FLAG_PINRST,RCC_FLAG_PORRST, //RCC_FLAG_SFTRST, RCC_FLAG_IWDGRST, RCC_FLAG_WWDGRST,RCC_FLAG_LPWRRST)
ITStatusRCC_GetITStatus(uint8_t RCC_IT);// 檢查指定的RCC中斷發(fā)生與否
//輸入:RCC_IT_LSIRDY,LSI晶振就緒中斷;RCC_IT_LSERDY,LSE晶振就緒中斷
//RCC_IT_HSIRDY,HSI晶振就緒中斷;RCC_IT_HSERDY,HSE晶振就緒中斷
//RCC_IT_PLLRDY,PLL就緒中斷;RCC_IT_CSS,時(shí)鐘安全系統(tǒng)中斷
//返回值:RCC_IT的新狀態(tài)
//例:
/* Test if the PLL Readyinterrupt has occurred or not */
//ITStatus Status;
//Status =RCC_GetITStatus(RCC_IT_PLLRDY);
//if(Status == RESET)
//{
//...
//}
//else
//{
//...
//}
voidRCC_ClearITPendingBit(uint8_t RCC_IT);// 清除RCC的中斷待處理位
//RCC_IT_LSIRDY,LSI晶振就緒中斷;RCC_IT_LSERDY,LSE晶振就緒中斷
//RCC_IT_HSIRDY,HSI晶振就緒中斷;RCC_IT_HSERDY,HSE晶振就緒中斷
//RCC_IT_PLLRDY,PLL就緒中斷;RCC_IT_CSS,時(shí)鐘安全系統(tǒng)中斷
五、實(shí)例詳解
#if defined (STM32F10X_LD_VL)|| (defined STM32F10X_MD_VL)|| (defined STM32F10X_HD_VL)//如果定義了這些系統(tǒng)時(shí)鐘將設(shè)為24M,如果沒有定義則為72M
/* #define SYSCLK_FREQ_HSE    HSE_VALUE */
#define SYSCLK_FREQ_24MHz  24000000
#else
/* #define SYSCLK_FREQ_HSE    HSE_VALUE */
/* #define SYSCLK_FREQ_24MHz  24000000 */
/* #define SYSCLK_FREQ_36MHz  36000000 */
/* #define SYSCLK_FREQ_48MHz  48000000 */
/* #define SYSCLK_FREQ_56MHz  56000000 */
#define SYSCLK_FREQ_72MHz 72000000      //系統(tǒng)時(shí)鐘默認(rèn)值的定義 ,如果沒有定義外部高速時(shí)鐘則用內(nèi)部高速時(shí)鐘,為8000000
/*只需修改以上幾句就可以自動(dòng)設(shè)置使用外部倍頻作為系統(tǒng)時(shí)鐘,如果以上宏都未定義則在下邊把內(nèi)部高速時(shí)鐘作為系統(tǒng)時(shí)鐘*/
#endif
/*!< Uncomment the following line if you need touse external SRAM mounted
     on STM3210E-EVAL board (STM32 High density andXL-density devices) or on
     STM32100E-EVAL board (STM32 High-density value linedevices) as data memory */
#if defined (STM32F10X_HD) || (defined STM32F10X_XL) || (definedSTM32F10X_HD_VL)//內(nèi)外部SRAM選擇
/* #define DATA_IN_ExtSRAM */
#endif
/*!< Uncomment the following line if you need torelocate your vector Table in
     Internal SRAM. */
/* #define VECT_TAB_SRAM */
#define VECT_TAB_OFFSET  0x0 /*!< Vector Table base offset field. //向量表的基址偏移量
                                 This value must be a multiple of 0x100. */

/**
  * @}
  */
/** @addtogroup STM32F10x_System_Private_Macros
  * @{
  */
/**
  * @}
  */
/** @addtogroup STM32F10x_System_Private_Variables
  * @{
  */
/*******************************************************************************
*  Clock Definitions;以下為把系統(tǒng)時(shí)鐘的定義值傳給系統(tǒng)內(nèi)核時(shí)鐘變量,如果沒有定義外部高速時(shí)鐘則用內(nèi)部高速時(shí)鐘,為8M
*******************************************************************************/
#ifdef SYSCLK_FREQ_HSE
  uint32_t SystemCoreClock        = SYSCLK_FREQ_HSE;        /*!< SystemClock Frequency (Core Clock) */
#elif defined SYSCLK_FREQ_24MHz
  uint32_t SystemCoreClock        = SYSCLK_FREQ_24MHz;        /*!< SystemClock Frequency (Core Clock) */
#elif defined SYSCLK_FREQ_36MHz
  uint32_t SystemCoreClock        = SYSCLK_FREQ_36MHz;        /*!< SystemClock Frequency (Core Clock) */
#elif defined SYSCLK_FREQ_48MHz
  uint32_t SystemCoreClock        = SYSCLK_FREQ_48MHz;        /*!< SystemClock Frequency (Core Clock) */
#elif defined SYSCLK_FREQ_56MHz
  uint32_t SystemCoreClock        = SYSCLK_FREQ_56MHz;        /*!< SystemClock Frequency (Core Clock) */
#elif defined SYSCLK_FREQ_72MHz
  uint32_t SystemCoreClock        = SYSCLK_FREQ_72MHz;        /*!< SystemClock Frequency (Core Clock) */
#else /*!< HSI Selected as System Clocksource */
  uint32_t SystemCoreClock        = HSI_VALUE;        /*!< System ClockFrequency (Core Clock) 如果沒有定義外部高速時(shí)鐘則用內(nèi)部高速時(shí)鐘,為8000000*/
#endif
__I uint8_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0,0, 1, 2, 3, 4, 6, 7, 8, 9};//AHB配方表
/**
  * @}
  */
/** @addtogroupSTM32F10x_System_Private_FunctionPrototypes
  * @{
  */
/*********************************************************************************
              以下為函數(shù)聲明
*********************************************************************************/
static void SetSysClock(void); //設(shè)置系統(tǒng)時(shí)鐘的函數(shù)聲明
//以下為根據(jù)不同的系統(tǒng)時(shí)鐘的定義來聲明用到的相應(yīng)的函數(shù),為后面的函數(shù)調(diào)用做好準(zhǔn)備
#ifdef SYSCLK_FREQ_HSE
  static void SetSysClockToHSE(void);
#elif defined SYSCLK_FREQ_24MHz
  static void SetSysClockTo24(void);
#elif defined SYSCLK_FREQ_36MHz
  static void SetSysClockTo36(void);
#elif defined SYSCLK_FREQ_48MHz
  static void SetSysClockTo48(void);
#elif defined SYSCLK_FREQ_56MHz
  static void SetSysClockTo56(void);  
#elif defined SYSCLK_FREQ_72MHz
  static void SetSysClockTo72(void);
#endif
#ifdef DATA_IN_ExtSRAM //外部SRAM選擇后的初始化函數(shù)聲明
  static void SystemInit_ExtMemCtl(void);
#endif /* DATA_IN_ExtSRAM */
/**
  * @}
  */
/** @addtogroup STM32F10x_System_Private_Functions
  * @{
  */
/**
  * @brief  Setup the microcontroller system
  *         Initialize theEmbedded Flash Interface, the PLL and update the
  *         SystemCoreClockvariable.
  * @note   This function should be used only after reset.
  * @param  None
  * @retval None
  */
void SystemInit (void)//系統(tǒng)初始化函數(shù),設(shè)置系統(tǒng)的時(shí)鐘及時(shí)鐘中斷(在startup_stm32f10x_md.s中調(diào)用)(復(fù)位RCC時(shí)鐘配置為默認(rèn)狀態(tài),直到設(shè)置時(shí)鐘函數(shù))
{
  /* Reset the RCC clock configuration to the default reset state(fordebug purpose) */
  /* Set HSION bit */
  RCC->CR |= (uint32_t)0x00000001; //內(nèi)部高速時(shí)鐘使能,內(nèi)部8MHz時(shí)鐘開啟
  /* Reset SW, HPRE, PPRE1, PPRE2, ADCPRE and MCObits */
#ifndef STM32F10X_CL
  RCC->CFGR &= (uint32_t)0xF8FF0000;//MCO微控制器沒有時(shí)鐘輸出(對(duì)外部引腳),ADC預(yù)分頻PCLK2 2分頻后作為ADC時(shí)鐘,APB預(yù)分頻HCLK不分頻,AHB預(yù)分頻SYSCLK不分頻,HSI作為系統(tǒng)時(shí)鐘
                                   //HSI作為系統(tǒng)時(shí)鐘輸出(已輸出),SYSCLK=PCLK=PCLK1=PCLK2=8M,ADCCLK=1/2(PCLK2)=4M
#else
  RCC->CFGR &= (uint32_t)0xF0FF0000;//同上;RCC->CFGR的27位為保留位始終為0 ,HSI作為系統(tǒng)時(shí)鐘輸出(未輸出原因?yàn)槲淳幾g)
#endif /* STM32F10X_CL */   
  
  /* Reset HSEON, CSSON and PLLON bits */
  RCC->CR &= (uint32_t)0xFEF6FFFF;//時(shí)鐘監(jiān)測器關(guān)閉,HSE振蕩器關(guān)閉
  /* Reset HSEBYP bit */
  RCC->CR &= (uint32_t)0xFFFBFFFF;//外部4-25MHz振蕩器沒有旁路
  /* Reset PLLSRC, PLLXTPRE, PLLMUL andUSBPRE/OTGFSPRE bits */
  RCC->CFGR &= (uint32_t)0xFF80FFFF; //PLL時(shí)鐘1.5倍分頻作為USB時(shí)鐘,PLL 2倍頻輸出,HSE不分頻,HSI時(shí)鐘2分頻后作為PLL輸入時(shí)鐘
                                    //PLLCLK=HSICLK=8M(還未輸出),HSECLK=HSEOSC,USBCLK=PLLCLK/1.5 ,除PLL外其他分頻系數(shù)都為0
#ifdef STM32F10X_CL
  /* Reset PLL2ON and PLL3ON bits */
  RCC->CR &= (uint32_t)0xEBFFFFFF;//CR中的26和28位置0
  /* Disable all interrupts and clear pendingbits  */
  RCC->CIR = 0x00FF0000;//清除中斷標(biāo)志,關(guān)閉一些中斷
  /* Reset CFGR2 register */
  RCC->CFGR2 = 0x00000000; //沒有此寄存器
#elif defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || (definedSTM32F10X_HD_VL)
  /* Disable all interrupts and clear pending bits  */
  RCC->CIR = 0x009F0000;//清除中斷標(biāo)志,關(guān)閉一些中斷
  /* Reset CFGR2 register */
  RCC->CFGR2 = 0x00000000; //沒有此寄存器     
#else
  /* Disable all interrupts and clear pending bits  */
  RCC->CIR = 0x009F0000; //清除中斷標(biāo)志,關(guān)閉一些中斷
#endif /* STM32F10X_CL */
   


………………………………
………………………………
………………………………
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表