本文選自極術(shù)專欄《靈動MM32MCU》的文章,授權(quán)轉(zhuǎn)自微信公眾號靈動MM32MCU。本系列將介紹Cortex-M0中斷控制知識。
在前幾天有客戶問了一個問題:如果外部中斷來的頻率足夠快,上一個中斷沒有處理完成,新來的中斷該如何處理?
在研究了arm的官方手冊后,了解中斷有使能、清除或掛起等實(shí)現(xiàn)方式,今天分享給大家。
中斷一般是由硬件(例如外設(shè)、外部引腳)產(chǎn)生,當(dāng)某種內(nèi)部或外部事件發(fā)生時,MCU的中斷系統(tǒng)將迫使 CPU 暫停正在執(zhí)行的程序,轉(zhuǎn)而去進(jìn)行中斷事件的處理,中斷處理完畢后,又返回被中斷的程序處,繼續(xù)執(zhí)行下去,所有的Cortex-M 內(nèi)核系統(tǒng)都有一個用于中斷處理的組件NVIC,主要負(fù)責(zé)處理中斷,還處理其他需要服務(wù)的事件。嵌套向量式中斷控制器(NVIC: Nested Vectored Interrupt Controller)集成在Cortex-M0處理器里,它與處理器內(nèi)核緊密相連,并且提供了中斷控制功能以及對系統(tǒng)異常的支持。
處理器中的NVIC能夠處理多個可屏蔽中斷通道和可編程優(yōu)先級,中斷輸入請求可以是電平觸發(fā),也可以是最小的一個時鐘周期的脈沖信號。每一個外部中斷線都可以獨(dú)立的使能、清除或掛起,并且掛起狀態(tài)也可以手動地設(shè)置和清除。
主程序正在執(zhí)行,當(dāng)遇到中斷請求(Interrupt Request)時,暫停主程序的執(zhí)行轉(zhuǎn)而去執(zhí)行中斷服務(wù)例程(Interrupt Service Routine,ISR),稱為響應(yīng),中斷服務(wù)例程執(zhí)行完畢后返回到主程序斷點(diǎn)處并繼續(xù)執(zhí)行主程序。多個中斷是可以進(jìn)行嵌套的。正在執(zhí)行的較低優(yōu)先級中斷可以被較高優(yōu)先級的中斷所打斷,在執(zhí)行完高級中斷后返回到低級中斷里繼續(xù)執(zhí)行,采用“咬尾中斷”機(jī)制。
內(nèi)核中斷(異常管理和休眠模式等),其中斷優(yōu)先級則由SCB寄存器來管理,IRQ的中斷優(yōu)先級是由NVIC來管理。
NVIC的寄存器經(jīng)過了存儲器映射,其寄存器的起始地址為0xE000E100,對其訪問必須是每次32bit。
SCB寄存器的起始地址:0xE000ED00,也是每次32bit訪問,SCB寄存器主要包含SysTick操作、異常管理和休眠模式控制。
NVIC具有以下特性:
-
靈活的中斷管理:使能清除、優(yōu)先級配置
-
硬件嵌套中斷支持
-
向量化的異常入口
-
中斷屏蔽
一、中斷使能和清除中斷
arm將處理器的中斷使能設(shè)置和清除設(shè)置寄存器分在兩個不同的地址,這種設(shè)計主要有如下優(yōu)勢:一方面這種方式減少了使能中斷所需要的步驟,使能一個中斷NVIC只需要訪問一次,同時也減少了程序代碼并且降低了執(zhí)行時間,另一方面當(dāng)多個應(yīng)用程序進(jìn)程同時訪問寄存器或者在讀寫操作寄存器時有操作其他的中斷使能位,這樣就有可能導(dǎo)致寄存器丟失,設(shè)置和清除分成兩個寄存器能夠有效防止控制信號丟失。
因此我可以獨(dú)立的操作每一個中斷的使能和清除設(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ū)動函數(shù)
//使能中斷#IRQn
__STATIC_INLINEvoid__NVIC_EnableIRQ(IRQn_TypeIRQn)
{
if((int32_t)(IRQn)>=0){
NVIC->ISER[0U]=(uint32_t)(1UL<=0){
NVIC->ICER[0U]=(uint32_t)(1UL<=0){
return((uint32_t)(((NVIC->ISER[0U]&(1UL<
二、中斷掛起和清除掛起
如果一個中斷發(fā)生了,卻無法立即處理,這個中斷請求將會被掛起。掛起狀態(tài)保存在一個寄存器中,如果處理器的當(dāng)前優(yōu)先級還沒有降低到可以處理掛起的請求,并且沒有手動清除掛起狀態(tài),該狀態(tài)將會一直保持。
可以通過操作中斷設(shè)置掛起和中斷清除掛起兩個獨(dú)立的寄存器來訪問或者修改中斷掛起狀態(tài),中斷掛起寄存器也是通過兩個地址來實(shí)現(xiàn)設(shè)置和清除相關(guān)位。這使得每一個位都可以獨(dú)立修改,并且無需擔(dān)心在兩個應(yīng)用程序進(jìn)程競爭訪問時出現(xiàn)的數(shù)據(jù)丟失。

中斷掛起狀態(tài)寄存器允許使用軟件來觸發(fā)中斷。如果中斷已經(jīng)使能并且沒有被屏蔽掉,當(dāng)前還沒有更高優(yōu)先級的中斷在運(yùn)行,這時中斷的服務(wù)程序就會立即得以執(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ū)動函數(shù)
//設(shè)置一個中斷掛起
__STATIC_INLINEvoid__NVIC_SetPendingIRQ(IRQn_TypeIRQn)
{
if((int32_t)(IRQn)>=0){
NVIC->ISPR[0U]=(uint32_t)(1UL<=0){
NVIC->ICPR[0U]=(uint32_t)(1UL<=0){
return((uint32_t)(((NVIC->ISPR[0U]&(1UL<
NVIC屬于處理器內(nèi)核部分,因此在MM32 MCU芯片的用戶手冊中只有簡單的提及,沒有重點(diǎn)講述,需要深入了解相關(guān)寄存器和功能需要參考《Cortex-M0技術(shù)參考手冊》。
在下一章節(jié)中,我們將和大家一起學(xué)習(xí)中斷優(yōu)先級的實(shí)現(xiàn)方式。
審核編輯 :李倩
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
處理器
+關(guān)注
關(guān)注
68
文章
19935
瀏覽量
236370
-
mcu
+關(guān)注
關(guān)注
146
文章
18028
瀏覽量
369186
-
系統(tǒng)控制
+關(guān)注
關(guān)注
0
文章
34
瀏覽量
16438
發(fā)布評論請先 登錄
相關(guān)推薦
熱點(diǎn)推薦
靈動微課堂 (第175講) | Cortex-M0中斷控制和系統(tǒng)控制(一)
Controller)集成在Cortex-M0處理器里,它與處理器內(nèi)核緊密相連,并且提供了中斷控制功能以及對系統(tǒng)異常的支持。處理器中的NV
發(fā)表于 07-29 17:14
靈動微課堂 (第176講) | Cortex-M0中斷控制和系統(tǒng)控制(二)
每一個外部中斷都有一個對應(yīng)的優(yōu)先級寄存器,Cortex-M0中NVIC-IPR共有8個寄存器,而每個寄存器管理4個IRQ
發(fā)表于 07-29 18:49
靈動微課堂 (第177講) | Cortex-M0中斷控制和系統(tǒng)控制(三)
和脈沖輸入Cortex-M0處理器鎖存所有中斷,外圍中斷成為等待其中一個原因是:NVIC檢測到中斷信號被置位并且對應(yīng)的
發(fā)表于 07-29 18:51
靈動微課堂 (第178講) | Cortex-M0中斷控制和系統(tǒng)控制(四)
Cortex-M0系統(tǒng)控制塊(SCB)是內(nèi)核外設(shè)的主要模塊之一,提供系統(tǒng)控制以及系統(tǒng)執(zhí)行信息,包括配置,
發(fā)表于 08-06 14:49
靈動微課堂 (第180講) | Cortex-M0中斷控制和系統(tǒng)控制(六)
調(diào)用,相互之間的狀態(tài)切換開銷幾乎為零。Cortex-M0處理器基于ARMv6-M架構(gòu),是一款功耗和性能較為均衡的處理器。Cortex-M0只支持56條指令的小指令集,其中大部分指令是1
發(fā)表于 08-23 11:02
基于Cortex-M0中斷系統(tǒng)的IP集成與中斷服務(wù)函數(shù)設(shè)計
為極術(shù)線上技術(shù)分享干貨匯總(含PPT下載及視頻回放及線下活動資料下載,持續(xù)更新,歡迎收藏~整理:極術(shù)社區(qū)集創(chuàng)賽Arm杯彭吉安-(集創(chuàng)賽)基于Cortex-M0中斷系統(tǒng)的IP集成與中斷服
發(fā)表于 12-14 07:15
恩智浦推出基于Cortex-M0微控制LPC1100微控制器
恩智浦推出基于Cortex-M0微控制LPC1100微控制器系列
恩智浦半導(dǎo)體(NXP Semiconductors)今天宣布,旗下基于ARM Cortex-M0的LPC1100微
發(fā)表于 11-18 09:04
?1684次閱讀
Cortex-M0中斷控制和系統(tǒng)控制(四)
ARMv7-M和ARMv6-M都有的SCB寄存器名稱相同,但是ARMv7-M寄存器數(shù)量和有效控制bit位比ARMv6-M豐富了不少。
發(fā)表于 02-08 15:41
?0次下載
Cortex-M0中斷控制和系統(tǒng)控制(二)
每一個外部中斷都有一個對應(yīng)的優(yōu)先級寄存器,Cortex-M0中NVIC-IPR共有8個寄存器,而每個寄存器管理4個IRQ
發(fā)表于 02-08 15:48
?3次下載
Cortex-M0中斷控制和系統(tǒng)控制(一)
處理器中的NVIC能夠處理多個可屏蔽中斷通道和可編程優(yōu)先級,中斷輸入請求可以是電平觸發(fā),也可以是最小的一個時鐘周期的脈沖信號。
發(fā)表于 02-08 15:51
?0次下載
Cortex-M0中斷控制和系統(tǒng)控制
Cortex-M0采用Armv6-M架構(gòu),優(yōu)先級寄存器配置位有8位,但是有效位只有最高2位,這個地方很多人使用了Cortex-M3后一直也認(rèn)為Cor
Cortex-M0中斷控制和系統(tǒng)控制知識點(diǎn)
每一個外部中斷都有一個對應(yīng)的優(yōu)先級寄存器,Cortex-M0中NVIC-IPR共有8個寄存器,而每個寄存器管理4個IRQ
Cortex-M0系統(tǒng)控制塊(SCB)介紹
Cortex-M0系統(tǒng)控制塊(SCB)是內(nèi)核外設(shè)的主要模塊之一,提供系統(tǒng)控制以及系統(tǒng)執(zhí)行信息,包括配置,
評論