如果外部中斷來(lái)的頻率足夠快,上一個(gè)中斷沒(méi)有處理完成,新來(lái)的中斷該如何處理?
中斷一般是由硬件(例如外設(shè)、外部引腳)產(chǎn)生,當(dāng)某種內(nèi)部或外部事件發(fā)生時(shí),MCU的中斷系統(tǒng)將迫使 CPU 暫停正在執(zhí)行的程序,轉(zhuǎn)而去進(jìn)行中斷事件的處理,中斷處理完畢后,又返回被中斷的程序處,繼續(xù)執(zhí)行下去,所有的Cortex-M 內(nèi)核系統(tǒng)都有一個(gè)用于中斷處理的組件NVIC,主要負(fù)責(zé)處理中斷,還處理其他需要服務(wù)的事件。嵌套向量式中斷控制器(NVIC: Nested Vectored Interrupt Controller)集成在Cortex-M0處理器里,它與處理器內(nèi)核緊密相連,并且提供了中斷控制功能以及對(duì)系統(tǒng)異常的支持。 處理器中的NVIC能夠處理多個(gè)可屏蔽中斷通道和可編程優(yōu)先級(jí),中斷輸入請(qǐng)求可以是電平觸發(fā),也可以是最小的一個(gè)時(shí)鐘周期的脈沖信號(hào)。每一個(gè)外部中斷線都可以獨(dú)立的使能、清除或掛起,并且掛起狀態(tài)也可以手動(dòng)地設(shè)置和清除。 主程序正在執(zhí)行,當(dāng)遇到中斷請(qǐng)求(Interrupt Request)時(shí),暫停主程序的執(zhí)行轉(zhuǎn)而去執(zhí)行中斷服務(wù)例程(Interrupt Service Routine,ISR),稱(chēng)為響應(yīng),中斷服務(wù)例程執(zhí)行完畢后返回到主程序斷點(diǎn)處并繼續(xù)執(zhí)行主程序。多個(gè)中斷是可以進(jìn)行嵌套的。正在執(zhí)行的較低優(yōu)先級(jí)中斷可以被較高優(yōu)先級(jí)的中斷所打斷,在執(zhí)行完高級(jí)中斷后返回到低級(jí)中斷里繼續(xù)執(zhí)行,采用“咬尾中斷”機(jī)制。
?內(nèi)核中斷(異常管理和休眠模式等),其中斷優(yōu)先級(jí)則由SCB寄存器來(lái)管理,IRQ的中斷優(yōu)先級(jí)是由NVIC來(lái)管理。
NVIC的寄存器經(jīng)過(guò)了存儲(chǔ)器映射,其寄存器的起始地址為0xE000E100,對(duì)其訪問(wèn)必須是每次32bit。
SCB寄存器的起始地址:0xE000ED00,也是每次32bit訪問(wèn),SCB寄存器主要包含SysTick操作、異常管理和休眠模式控制。
NVIC具有以下特性:
- 靈活的中斷管理:使能清除、優(yōu)先級(jí)配置
- 硬件嵌套中斷支持
- 向量化的異常入口
- 中斷屏蔽
1. 中斷使能和清除使能
arm將處理器的中斷使能設(shè)置和清除設(shè)置寄存器分在兩個(gè)不同的地址,這種設(shè)計(jì)主要有如下優(yōu)勢(shì):一方面這種方式減少了使能中斷所需要的步驟,使能一個(gè)中斷NVIC只需要訪問(wèn)一次,同時(shí)也減少了程序代碼并且降低了執(zhí)行時(shí)間,另一方面當(dāng)多個(gè)應(yīng)用程序進(jìn)程同時(shí)訪問(wèn)寄存器或者在讀寫(xiě)操作寄存器時(shí)有操作其他的中斷使能位,這樣就有可能導(dǎo)致寄存器丟失,設(shè)置和清除分成兩個(gè)寄存器能夠有效防止控制信號(hào)丟失。
因此我可以獨(dú)立的操作每一個(gè)中斷的使能和清除設(shè)置。1.1 C代碼
*(volatileunsignedlong)(0xE000E100)=0x4;//使能#2中斷 *(volatileunsignedlong)(0xE000E180)=0x4;//清除#2中斷1.2 匯編代碼
__asmvoidInterrupt_Enable() { LDRR0,=0xE000E100;//ISER寄存器的地址 MOVSR1,#04;//設(shè)置#2中斷 STRR1,[R0];//使能中斷#2 } __asmvoidInterrupt_Disable() { LDRR0,=0xE000E180;//ICER寄存器的地址 MOVSR1,#04;//設(shè)置#2中斷 STRR1,[R0];//使能中斷#2 }1.3 CMSIS標(biāo)準(zhǔn)設(shè)備驅(qū)動(dòng)函數(shù)
//使能中斷#IRQn __STATIC_INLINEvoid__NVIC_EnableIRQ(IRQn_TypeIRQn) { if((int32_t)(IRQn)>=0){ NVIC->ISER[0U]=(uint32_t)(1UL<(((uint32_t)(int32_t)IRQn)?&?0x1FUL)); ????} } //清除中斷#IRQn __STATIC_INLINE?void?__NVIC_DisableIRQ(IRQn_Type?IRQn)? { ????if?((int32_t)(IRQn)?>=0){ NVIC->ICER[0U]=(uint32_t)(1UL<(((uint32_t)(int32_t)IRQn)?&?0x1FUL)); ????????__DSB(); ????????__ISB(); ????} } //讀取使能中斷#IRQn __STATIC_INLINE?uint32_t?__NVIC_GetEnableIRQ(IRQn_Type?IRQn) { ????if?((int32_t)(IRQn)?>=0){ return((uint32_t)(((NVIC->ISER[0U]&(1UL<(((uint32_t)(int32_t)IRQn)?&?0x1FUL)))?!=?0UL)???1UL?:?0UL)); ????} ????else?{ ????????return(0U); ????} }2. 中斷掛起和清除掛起
如果一個(gè)中斷發(fā)生了,卻無(wú)法立即處理,這個(gè)中斷請(qǐng)求將會(huì)被掛起。掛起狀態(tài)保存在一個(gè)寄存器中,如果處理器的當(dāng)前優(yōu)先級(jí)還沒(méi)有降低到可以處理掛起的請(qǐng)求,并且沒(méi)有手動(dòng)清除掛起狀態(tài),該狀態(tài)將會(huì)一直保持。可以通過(guò)操作中斷設(shè)置掛起和中斷清除掛起兩個(gè)獨(dú)立的寄存器來(lái)訪問(wèn)或者修改中斷掛起狀態(tài),中斷掛起寄存器也是通過(guò)兩個(gè)地址來(lái)實(shí)現(xiàn)設(shè)置和清除相關(guān)位。這使得每一個(gè)位都可以獨(dú)立修改,并且無(wú)需擔(dān)心在兩個(gè)應(yīng)用程序進(jìn)程競(jìng)爭(zhēng)訪問(wèn)時(shí)出現(xiàn)的數(shù)據(jù)丟失。
中斷掛起狀態(tài)寄存器允許使用軟件來(lái)觸發(fā)中斷。如果中斷已經(jīng)使能并且沒(méi)有被屏蔽掉,當(dāng)前還沒(méi)有更高優(yōu)先級(jí)的中斷在運(yùn)行,這時(shí)中斷的服務(wù)程序就會(huì)立即得以執(zhí)行。2.1 C代碼
*(volatileunsignedlong)(0xE000E100)=0x4;//使能中斷#2 *(volatileunsignedlong)(0xE000E200)=0x4;//掛起中斷#2 *(volatileunsignedlong)(0xE000E280)=0x4;//清除中斷#2的掛起狀態(tài)2.2 匯編代碼
__asmvoidInterrupt_Set_Pending() { LDRR0,=0xE000E100;//設(shè)置使能中斷寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//使能#2中斷 LDRR0,=0xE000E200;//設(shè)置掛起中斷寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//掛起#2中斷 } __asmvoidInterrupt_Clear_Pending() { LDRR0,=0xE000E100;//設(shè)置使能中斷寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//使能#2中斷 LDRR0,=0xE000E280;//設(shè)置清除中斷掛起寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//清除#2的掛起狀態(tài) }2.3 CMSIS標(biāo)準(zhǔn)設(shè)備驅(qū)動(dòng)函數(shù)
//設(shè)置一個(gè)中斷掛起 __STATIC_INLINEvoid__NVIC_SetPendingIRQ(IRQn_TypeIRQn) { if((int32_t)(IRQn)>=0){ NVIC->ISPR[0U]=(uint32_t)(1UL<(((uint32_t)(int32_t)IRQn)?&?0x1FUL)); ????} } //清除中斷掛起 __STATIC_INLINE?void?__NVIC_ClearPendingIRQ(IRQn_Type?IRQn)? { ????if?((int32_t)(IRQn)?>=0){ NVIC->ICPR[0U]=(uint32_t)(1UL<(((uint32_t)(int32_t)IRQn)?&?0x1FUL)); ????} } //讀取中斷掛起狀態(tài) __STATIC_INLINE?uint32_t?__NVIC_GetPendingIRQ(IRQn_Type?IRQn)? { ????if?((int32_t)(IRQn)?>=0){ return((uint32_t)(((NVIC->ISPR[0U]&(1UL<(((uint32_t)(int32_t)IRQn)?&?0x1FUL)))?!=?0UL)???1UL?:?0UL)); ????} ????else?{ ????????return(0U); ????} }NVIC屬于處理器內(nèi)核部分,因此在MM32 MCU芯片的用戶(hù)手冊(cè)中只有簡(jiǎn)單的提及,沒(méi)有重點(diǎn)講述,需要深入了解相關(guān)寄存器和功能需要參考《Cortex-M0技術(shù)參考手冊(cè)》。
------------END------------
審核編輯 :李倩
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。
舉報(bào)投訴
-
處理器
+關(guān)注
關(guān)注
68文章
20323瀏覽量
254637 -
單片機(jī)
+關(guān)注
關(guān)注
6078文章
45565瀏覽量
673242
原文標(biāo)題:?jiǎn)纹瑱C(jī)中斷程序,如何被中斷?
文章出處:【微信號(hào):strongerHuang,微信公眾號(hào):strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
熱點(diǎn)推薦
單片機(jī)外部中斷的好處
外部中斷是單片機(jī)實(shí)時(shí)地處理外部事件的一種內(nèi)部機(jī)制。當(dāng)外部事件發(fā)生時(shí),單片機(jī)的中斷系統(tǒng)將迫使CPU暫停正在執(zhí)行的
51單片機(jī)定時(shí)器中斷_51單片機(jī)中斷系統(tǒng)_51單片機(jī)擴(kuò)展中斷的四種方法
中斷是為使單片機(jī)具有對(duì)外部或內(nèi)部隨機(jī)發(fā)生的事件進(jìn)行處理而設(shè)置的。51單片機(jī)有5種中斷源,即有5種對(duì)應(yīng)的情況發(fā)生時(shí)會(huì)使
發(fā)表于 12-08 10:15
?1.2w次閱讀
單片機(jī)中斷系統(tǒng)介紹_51單片機(jī)中斷系統(tǒng)結(jié)構(gòu)
單片機(jī)中斷就是當(dāng)單片機(jī)正在執(zhí)行程序的時(shí)候,突然某個(gè)按鍵按下了(產(chǎn)生外部中斷),單片機(jī)就必須得去
發(fā)表于 01-10 17:29
?1.3w次閱讀
單片機(jī)的中斷源有哪些及單片機(jī)中斷的資料和程序說(shuō)明
中斷是為使單片機(jī)具有對(duì)外或內(nèi)部隨機(jī)發(fā)生的事件實(shí)時(shí)處理的能力而設(shè)置的,中斷功能的存在,很大程度上提高了單片機(jī)
發(fā)表于 09-25 17:17
?1次下載
單片機(jī)的中斷序號(hào)詳細(xì)說(shuō)明
單片機(jī)的中斷序號(hào)決定該中斷的中斷向量的位置(即中斷服務(wù)程序
發(fā)表于 08-19 17:31
?5次下載
51單片機(jī)有幾個(gè)中斷?單片機(jī)的中斷號(hào)對(duì)應(yīng)的中斷類(lèi)型說(shuō)明
51單片機(jī)通常有5個(gè)中斷,當(dāng)中斷發(fā)生時(shí),程序會(huì)跳到相應(yīng)的中斷服務(wù)程序去執(zhí)行。為了區(qū)別不同的
發(fā)表于 08-06 17:34
?5次下載
單片機(jī)的中斷程序如何運(yùn)行
單片機(jī)的中斷就是類(lèi)似的一個(gè)過(guò)程,發(fā)生中斷時(shí),就會(huì)打斷正在執(zhí)行的主程序,先處理完中斷任務(wù),返回主
單片機(jī)(AT89C51)中斷系統(tǒng)詳解和中斷系統(tǒng)應(yīng)用實(shí)驗(yàn)
單片機(jī)中斷系統(tǒng)什么叫做單片機(jī)的中斷?CPU暫時(shí)中止其正在執(zhí)行的程序,轉(zhuǎn)去執(zhí)行請(qǐng)求中斷的那個(gè)外設(shè)或
發(fā)表于 11-17 11:06
?14次下載
51單片機(jī)—中斷
事件B,對(duì)事件B處理完畢后,再回到原來(lái)被中斷的地方(即斷點(diǎn)),稱(chēng)為 中斷返回。實(shí)現(xiàn)上述中斷功能的部件稱(chēng)為中斷系統(tǒng)(
發(fā)表于 11-19 09:06
?18次下載
關(guān)于單片機(jī)的中斷的若干問(wèn)題
中斷技術(shù)概述中斷系統(tǒng)作用:實(shí)時(shí)測(cè)控,單片機(jī)能及時(shí)地響應(yīng)和處理單片機(jī)外部事件或內(nèi)部事件所提出的中斷
發(fā)表于 11-19 10:36
?12次下載
單片機(jī)中斷程序是如何處理器新來(lái)的中斷?
如果一個(gè)中斷發(fā)生了,卻無(wú)法立即處理,這個(gè)中斷請(qǐng)求將會(huì)被掛起。掛起狀態(tài)保存在一個(gè)寄存器中,如果處理器的當(dāng)前優(yōu)先級(jí)還沒(méi)有降低到可以處理掛起的請(qǐng)
發(fā)表于 05-13 12:24
?765次閱讀
基于單片機(jī)的外部中斷實(shí)驗(yàn) 中斷系統(tǒng)知識(shí)介紹
在單片機(jī)中有兩個(gè)重要的概念分別叫做中斷、中斷系統(tǒng),那么他們分別又代表什么意義呢?當(dāng)單片機(jī)CPU正在運(yùn)行主程序時(shí)外界發(fā)生了緊急事件請(qǐng)求,要求
單片機(jī)中斷功能及其應(yīng)用
事件的響應(yīng)和處理。它具有實(shí)時(shí)性好、可靠性高、效率高等優(yōu)點(diǎn),廣泛應(yīng)用于各種電子設(shè)備和系統(tǒng)中。 一、單片機(jī)中斷的基本概念 單片機(jī)中斷是一種可以在
單片機(jī)有哪些中斷類(lèi)型
單片機(jī)中斷是指在單片機(jī)執(zhí)行程序的過(guò)程中,當(dāng)外部設(shè)備或內(nèi)部條件發(fā)生某個(gè)特定事件時(shí),能夠暫停當(dāng)前正在執(zhí)行的程序,轉(zhuǎn)而去執(zhí)行一個(gè)特定的服務(wù)
單片機(jī)中斷程序新來(lái)的中斷該如何處理?
評(píng)論