電子產(chǎn)業(yè)一站式賦能平臺(tái)

PCB聯(lián)盟網(wǎng)

搜索
查看: 61|回復(fù): 0
收起左側(cè)

單片機(jī)中斷程序,如何被中斷?

[復(fù)制鏈接]

478

主題

478

帖子

2427

積分

三級(jí)會(huì)員

Rank: 3Rank: 3

積分
2427
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2024-8-19 07:42:00 | 只看該作者 |只看大圖 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式

- Q$ `# ]6 J' _( p8 p4 L6 W' x點(diǎn)擊上方名片關(guān)注了解更多
$ n; o: P/ F5 Y. }. g% S: n) O7 I8 [4 |0 [+ X- V: v4 O
來(lái)源 | 技術(shù)社區(qū)
' R; T, P: [" X9 i. o2 \很多同學(xué)都存在這樣的疑惑:如果外部中斷來(lái)的頻率足夠快,上一個(gè)中斷沒(méi)有處理完成,新來(lái)的中斷該如何處理?
: L3 l% x8 o3 H4 E9 A中斷一般是由硬件(例如外設(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)異常的支持。
* `5 C( n+ J* M, h( M4 a8 M2 c處理器中的NVIC能夠處理多個(gè)可屏蔽中斷通道和可編程優(yōu)先級(jí),中斷輸入請(qǐng)求可以是電平觸發(fā),也可以是最小的一個(gè)時(shí)鐘周期的脈沖信號(hào)。每一個(gè)外部中斷線都可以獨(dú)立的使能、清除或掛起,并且掛起狀態(tài)也可以手動(dòng)地設(shè)置和清除。: [0 k& ?( u2 ?1 i+ I
主程序正在執(zhí)行,當(dāng)遇到中斷請(qǐng)求(Interrupt Request)時(shí),暫停主程序的執(zhí)行轉(zhuǎn)而去執(zhí)行中斷服務(wù)例程(Interrupt Service Routine,ISR),稱為響應(yīng),中斷服務(wù)例程執(zhí)行完畢后返回到主程序斷點(diǎn)處并繼續(xù)執(zhí)行主程序。多個(gè)中斷是可以進(jìn)行嵌套的。正在執(zhí)行的較低優(yōu)先級(jí)中斷可以被較高優(yōu)先級(jí)的中斷所打斷,在執(zhí)行完高級(jí)中斷后返回到低級(jí)中斷里繼續(xù)執(zhí)行,采用“咬尾中斷”機(jī)制。
8 z6 H% `/ G: g. k" [% _ ( u* z5 g/ `- A" @) \+ {4 E4 e  I
內(nèi)核中斷(異常管理和休眠模式等),其中斷優(yōu)先級(jí)則由SCB寄存器來(lái)管理,IRQ的中斷優(yōu)先級(jí)是由NVIC來(lái)管理。# L# V! h- F' K( {1 J- ]8 L' m0 k% U3 B
NVIC的寄存器經(jīng)過(guò)了存儲(chǔ)器映射,其寄存器的起始地址為0xE000E100,對(duì)其訪問(wèn)必須是每次32bit。; q0 ?& Z1 S# c. n+ C: ?* O
SCB寄存器的起始地址:0xE000ED00,也是每次32bit訪問(wèn),SCB寄存器主要包含SysTick操作、異常管理和休眠模式控制。
6 C- x+ {/ T% d0 }) B' mNVIC具有以下特性:
  _5 W* l/ n% I9 Q& Z靈活的中斷管理:使能\清除、優(yōu)先級(jí)配置硬件嵌套中斷支持向量化的異常入口中斷屏蔽1. 中斷使能和清除使能* P- O( e# A  d: ^' K
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)寄存器或者在讀寫操作寄存器時(shí)有操作其他的中斷使能位,這樣就有可能導(dǎo)致寄存器丟失,設(shè)置和清除分成兩個(gè)寄存器能夠有效防止控制信號(hào)丟失。( }2 x: F( F1 G9 S0 w
7 _* q' j. n' }
因此我可以獨(dú)立的操作每一個(gè)中斷的使能和清除設(shè)置。
  E0 X' s$ Z; X1.1 C代碼*(volatile unsigned long) (0xE000E100) = 0x4 ; //使能#2中斷  Y0 k/ o  ^' h! U! P
*(volatile unsigned long) (0xE000E180) = 0x4 ; //清除#2中斷1.2 匯編代碼__asm void Interrupt_Enable()2 @* ]# h5 c6 t4 v, e% ?
{3 V' L( \% B9 s# K/ b
LDR R0, =0xE000E100  ;  //ISER寄存器的地址
! ^( ]$ Y, e( [3 @- X! Q MOVS R1, #04         ;  //設(shè)置#2中斷7 ~/ s1 N7 i0 W$ @* o' v. i
STR R1, [R0]         ;  //使能中斷#26 E% f# w2 f& z
}) b- P) k  C$ P2 Q
__asm void Interrupt_Disable()
0 J, @# e0 e: O+ i) U1 @$ Y{( a: t4 P% {4 O4 l3 L2 m% Q' v
LDR R0, =0xE000E180  ;  //ICER寄存器的地址
, J3 F* K+ t7 p$ n2 J MOVS R1, #04         ;  //設(shè)置#2中斷
4 a+ G2 q9 w$ M5 O/ | STR R1, [R0]         ;  //使能中斷#2
. q8 |( [( K$ _/ n5 [/ u8 J}1.3 CMSIS標(biāo)準(zhǔn)設(shè)備驅(qū)動(dòng)函數(shù)//使能中斷#IRQn1 k- y( T0 x4 v2 t; A2 V- X+ r6 R
__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn)
9 q8 a) Y; z( a6 K( K# v$ w" X{5 b0 x" h* S$ f6 c0 l' B
    if ((int32_t)(IRQn) >= 0) {
; w: C0 W! S7 t4 I7 }" J& k8 l& p        NVIC->ISER[0U] = (uint32_t)(1UL = 0) {& U' R! k4 a$ y% Z+ v
        NVIC->ICER[0U] = (uint32_t)(1UL = 0) {. }: w, ]; \2 j  A% s: J
        return((uint32_t)(((NVIC->ISER[0U] & (1UL 2. 中斷掛起和清除掛起
% \% A1 t. r7 C+ W+ p如果一個(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ì)一直保持。# }% u4 V: H* H$ Q0 o. r' ?
可以通過(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ù)丟失。6 Q* t8 e* E1 I

! G! F: v  H, N" ^6 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代碼*(volatile unsigned long)(0xE000E100) = 0x4 ; //使能中斷#29 Q9 H- [" U( ]' P, V( ~' `3 ]" ]
*(volatile unsigned long)(0xE000E200) = 0x4 ; //掛起中斷#2' t, _, [4 t7 J% l: T; K0 t7 F
*(volatile unsigned long)(0xE000E280) = 0x4 ; //清除中斷#2的掛起狀態(tài)2.2 匯編代碼__asm void Interrupt_Set_Pending()" a2 \5 w& {  ]- _  r0 ~
{
% [9 [2 ^( q2 s$ m* n LDR R0, =0xE000E100   ;  //設(shè)置使能中斷寄存器地址
1 g3 X" _  P$ |2 U9 V6 g1 m7 F MOVS R1, #0x4         ;  //中斷#2
9 H; U1 R! e6 J. F9 J STR R1, [R0]          ;  //使能#2中斷
+ ]0 z) r7 s9 X% Q2 R LDR R0, =0xE000E200   ; //設(shè)置掛起中斷寄存器地址# H, o3 m; P5 M$ A! X
MOVS R1, #0x4         ;  //中斷#2$ t& `! s) f$ `% n( |* M
STR R1, [R0]          ;  //掛起#2中斷
+ _. L: u. z/ ]0 k, v( E& I}/ R% s% |1 r) }* K8 q
__asm void Interrupt_Clear_Pending()
8 o# |" y3 }: Y$ t{
- |+ D3 }# ]/ R7 _+ O$ W( s LDR R0, =0xE000E100   ;  //設(shè)置使能中斷寄存器地址3 P$ N- c" o7 m: {, K0 `
MOVS R1, #0x4         ;  //中斷#2) N# Z5 L9 L2 v/ W5 c
STR R1, [R0]          ;  //使能#2中斷
, d9 G# R5 Z2 e5 e9 a! b LDR R0, =0xE000E280   ; //設(shè)置清除中斷掛起寄存器地址
2 D" X$ a( }( @; @& d& n' _. q MOVS R1, #0x4         ;  //中斷#2
% X5 S8 E% u1 A& {' N! O/ _  _ STR R1, [R0]          ;  //清除#2的掛起狀態(tài)1 b" U/ E- @" ]' ~9 K
}2.3 CMSIS標(biāo)準(zhǔn)設(shè)備驅(qū)動(dòng)函數(shù)//設(shè)置一個(gè)中斷掛起
3 n- p/ d, p5 B. }) t6 I6 q__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn)
8 `( Y, W# F: M5 B* s6 c5 ~( k{; U* S  j  K- v- y2 F
    if ((int32_t)(IRQn) >= 0) {: z% j: k8 w1 x; o# P
        NVIC->ISPR[0U] = (uint32_t)(1UL = 0) {4 K. I. s! P* ~1 |
        NVIC->ICPR[0U] = (uint32_t)(1UL = 0) {
' t9 y$ P  \$ v7 `9 i" X        return((uint32_t)(((NVIC->ISPR[0U] & (1UL NVIC屬于處理器內(nèi)核部分,因此在MM32 MCU芯片的用戶手冊(cè)中只有簡(jiǎn)單的提及,沒(méi)有重點(diǎn)講述,需要深入了解相關(guān)寄存器和功能需要參考《Cortex-M0技術(shù)參考手冊(cè)》。
# Z  o7 v# e. ?* Q 2 U4 O! z7 S' V# L' R# n# Y

  U+ i; q# W2 _" T: ]: n, B聲明:9 c) M4 I$ `& K/ ~& ?' n
聲明:本號(hào)對(duì)所有原創(chuàng)、轉(zhuǎn)載文章的陳述與觀點(diǎn)均保持中立,推送文章僅供讀者學(xué)習(xí)和交流。文章、圖片等版權(quán)歸原作者享有,如有侵權(quán),聯(lián)系刪除。投稿/招聘/推廣/宣傳 請(qǐng)加微信:woniu26a推薦閱讀▼: t" W! d5 s- h& v% m  n! v/ V
電路設(shè)計(jì)-電路分析0 t/ h# C, ?1 J# \* u9 K
emc相關(guān)文章
2 G: e8 ^6 O  V/ @' y電子元器件+ J% b; P" n6 c7 e# M' I5 F
后臺(tái)回復(fù)“加群”,管理員拉你加入同行技術(shù)交流群。

發(fā)表回復(fù)

本版積分規(guī)則


聯(lián)系客服 關(guān)注微信 下載APP 返回頂部 返回列表