STM32的嵌套中斷系統(tǒng)NVIC和RCC詳細(xì)整理
一、綜述:
1、STM32 (Cortex-M3) 中的優(yōu)先級(jí)概念
1. 何為占先式優(yōu)先級(jí)(pre-emption priority)
2. 何為副優(yōu)先級(jí)(subpriority)
3. 判斷中斷是否會(huì)被響應(yīng)的依據(jù)
4. 優(yōu)先級(jí)沖突的處理
5.Cortex-M3中對(duì)中斷優(yōu)先級(jí)的定義
所有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í)
最高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í)的定義
第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í)
第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
#define NVIC_PriorityGroup_0
#define NVIC_PriorityGroup_1
#define NVIC_PriorityGroup_2
#define NVIC_PriorityGroup_3
#define NVIC_PriorityGroup_4
NVIC_PriorityGroup_0=> 選擇第0組
NVIC_PriorityGroup_1 => 選擇第1組
NVIC_PriorityGroup_2 => 選擇第2組
NVIC_PriorityGroup_3 => 選擇第3組
NVIC_PriorityGroup_4 => 選擇第4組
NVIC_PriorityGroup_1 => 選擇第1組
NVIC_PriorityGroup_2 => 選擇第2組
NVIC_PriorityGroup_3 => 選擇第3組
NVIC_PriorityGroup_4 => 選擇第4組
// 選擇使用優(yōu)先級(jí)分組第1組
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
//定義NVIC的結(jié)構(gòu)體變量
NVIC_InitTypeDef NVIC_InitStructure;
// 使能EXTI0中斷
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPrio rity = 1; //指定搶占式優(yōu)先級(jí)別1
//
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPrio
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_IRQChannelPreemptionPrio rity = 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);
-------------------------------------------------------------------------------
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
// 使能EXTI9_5中斷
NVIC_InitStructure.NVIC_IRQChannel = EXTI9_5_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPrio
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;// 指定響應(yīng)優(yōu)先級(jí)別1
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
-------------------------------------------------------------------------------
2、開關(guān)總中斷
PRIMASK位:只允許NMI和hardfault異常,其他中斷/異常都被屏蔽(當(dāng)前CPU優(yōu)先級(jí)=0)。
FAULTMASK位:只允許NMI,其他所有中斷/異常都被屏蔽(當(dāng)前CPU優(yōu)先級(jí)=-1)。
FAULTMASK位:只允許NMI,其他所有中斷/異常都被屏蔽(當(dāng)前CPU優(yōu)先級(jí)=-1)。
下面兩個(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、…………………………
…………………………
…………………………
五、實(shí)例詳解
void NVIC_config()//配置中斷
{
NVIC_InitTypeDef NVIC_InitStructure;
//NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);//選擇中斷分組1
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//選擇串口1中斷
NVIC_InitStructure.NVIC_IRQChannelPreemptionPrio rity= 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大模塊使用:
需要注意的是定時(shí)器的倍頻器,當(dāng) APB 的分頻為 1 時(shí),它的倍頻值為 1 ,否則它的倍頻值就為 2 。
file:///C:/DOCUME~1/LU/LOCALS~1/Temp/msohtml1/01/clip_image002.jpg
2、APB1和APB2連接的模塊
①連接在 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
{
#ifdefSTM32F10X_CL
#endif
#if defined(STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined(STM32F10X_HD_VL)
#endif
}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ù)流程如下:
設(shè)置系統(tǒng)時(shí)鐘: RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
判斷 PLL 是否是系統(tǒng)時(shí)鐘: while(RCC_GetSYSCLKSource()!= 0x08);
1、使用庫(kù)函數(shù)進(jìn)行時(shí)鐘系統(tǒng)初始化配置voidRCC_config()//如果外部晶振為8M,PLLCLK=SYSCLK=72M,HCLK=72M,//P2CLK=72M,P1CLK=36M,ADCCLK=36M,USBCLK=48M,TIMCLK=72M
{
//外部時(shí)鐘不分頻,為HSE的9倍頻8MHz * 9 =72MHz
2、使用寄存器進(jìn)行RCC時(shí)鐘初始化配置
voidRCC_init(u8 PLL)//輸入PLL的倍頻值2—16倍頻
//HCLK=PLLCLK=SYSCLK=P2CLK=P1CLK*2=ADCCLK*2=TIMCLK=USBCLK*2/3
{
}
四、相關(guān)庫(kù)函數(shù)解析
1、庫(kù)中所涉及到的結(jié)構(gòu)體
typedef struct
{
}RCC_ClocksTypeDef;
2、庫(kù)函數(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_AdjustHSICalibrationValu e(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);//
關(guān)鍵詞:
STM32中斷系統(tǒng)NVICRC
相關(guān)推薦
技術(shù)專區(qū)
- FPGA
- DSP
- MCU
- 示波器
- 步進(jìn)電機(jī)
- Zigbee
- LabVIEW
- Arduino
- RFID
- NFC
- STM32
- Protel
- GPS
- MSP430
- Multisim
- 濾波器
- CAN總線
- 開關(guān)電源
- 單片機(jī)
- PCB
- USB
- ARM
- CPLD
- 連接器
- MEMS
- CMOS
- MIPS
- EMC
- EDA
- ROM
- 陀螺儀
- VHDL
- 比較器
- Verilog
- 穩(wěn)壓電源
- RAM
- AVR
- 傳感器
- 可控硅
- IGBT
- 嵌入式開發(fā)
- 逆變器
- Quartus
- RS-232
- Cyclone
- 電位器
- 電機(jī)控制
- 藍(lán)牙
- PLC
- PWM
- 汽車電子
- 轉(zhuǎn)換器
- 電源管理
- 信號(hào)放大器
評(píng)論