0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

單片機中斷程序是如何被中斷的?

麥克泰技術 ? 來源:靈動MM32 MCU ? 2023-05-16 14:06 ? 次閱讀

你有沒有想過一個問題:如果外部中斷來的頻率足夠快,上一個中斷沒有處理完成,新來的中斷該如何處理?

中斷一般是由硬件(例如外設、外部引腳)產(chǎn)生,當某種內(nèi)部或外部事件發(fā)生時,MCU的中斷系統(tǒng)將迫使 CPU 暫停正在執(zhí)行的程序,轉(zhuǎn)而去進行中斷事件的處理,中斷處理完畢后,又返回被中斷的程序處,繼續(xù)執(zhí)行下去,所有的Cortex-M 內(nèi)核系統(tǒng)都有一個用于中斷處理的組件NVIC,主要負責處理中斷,還處理其他需要服務的事件。嵌套向量式中斷控制器(NVIC: Nested Vectored Interrupt Controller)集成在Cortex-M0處理器里,它與處理器內(nèi)核緊密相連,并且提供了中斷控制功能以及對系統(tǒng)異常的支持。

處理器中的NVIC能夠處理多個可屏蔽中斷通道和可編程優(yōu)先級,中斷輸入請求可以是電平觸發(fā),也可以是最小的一個時鐘周期的脈沖信號。每一個外部中斷線都可以獨立的使能、清除或掛起,并且掛起狀態(tài)也可以手動地設置和清除。

主程序正在執(zhí)行,當遇到中斷請求(Interrupt Request)時,暫停主程序的執(zhí)行轉(zhuǎn)而去執(zhí)行中斷服務例程(Interrupt Service Routine,ISR),稱為響應,中斷服務例程執(zhí)行完畢后返回到主程序斷點處并繼續(xù)執(zhí)行主程序。多個中斷是可以進行嵌套的。正在執(zhí)行的較低優(yōu)先級中斷可以被較高優(yōu)先級的中斷所打斷,在執(zhí)行完高級中斷后返回到低級中斷里繼續(xù)執(zhí)行,采用“咬尾中斷”機制。

1b4a05b0-f3a2-11ed-90ce-dac502259ad0.png ?

內(nèi)核中斷(異常管理和休眠模式等),其中斷優(yōu)先級則由SCB寄存器來管理,IRQ的中斷優(yōu)先級是由NVIC來管理。

NVIC的寄存器經(jīng)過了存儲器映射,其寄存器的起始地址為0xE000E100,對其訪問必須是每次32bit。

SCB寄存器的起始地址:0xE000ED00,也是每次32bit訪問,SCB寄存器主要包含SysTick操作、異常管理和休眠模式控制。

NVIC具有以下特性:

靈活的中斷管理:使能清除、優(yōu)先級配置

硬件嵌套中斷支持

向量化的異常入口

中斷屏蔽

1. 中斷使能和清除使能

arm將處理器的中斷使能設置和清除設置寄存器分在兩個不同的地址,這種設計主要有如下優(yōu)勢:一方面這種方式減少了使能中斷所需要的步驟,使能一個中斷NVIC只需要訪問一次,同時也減少了程序代碼并且降低了執(zhí)行時間,另一方面當多個應用程序進程同時訪問寄存器或者在讀寫操作寄存器時有操作其他的中斷使能位,這樣就有可能導致寄存器丟失,設置和清除分成兩個寄存器能夠有效防止控制信號丟失。

1b686118-f3a2-11ed-90ce-dac502259ad0.png

因此我可以獨立的操作每一個中斷的使能和清除設置。

1.1 C代碼


*(volatileunsignedlong)(0xE000E100)=0x4;//使能#2中斷

*(volatileunsignedlong)(0xE000E180)=0x4;//清除#2中斷

1.2 匯編代碼

wKgZomRjHbmAY85fAAB75Iwx-Ms999.jpg

1.3 CMSIS標準設備驅(qū)動函數(shù)

wKgZomRjHdeAXJHbAAEJ3BvWQ24343.jpg

2. 中斷掛起和清除掛起

如果一個中斷發(fā)生了,卻無法立即處理,這個中斷請求將會被掛起。掛起狀態(tài)保存在一個寄存器中,如果處理器的當前優(yōu)先級還沒有降低到可以處理掛起的請求,并且沒有手動清除掛起狀態(tài),該狀態(tài)將會一直保持。

可以通過操作中斷設置掛起和中斷清除掛起兩個獨立的寄存器來訪問或者修改中斷掛起狀態(tài),中斷掛起寄存器也是通過兩個地址來實現(xiàn)設置和清除相關位。這使得每一個位都可以獨立修改,并且無需擔心在兩個應用程序進程競爭訪問時出現(xiàn)的數(shù)據(jù)丟失。

1b75f1f2-f3a2-11ed-90ce-dac502259ad0.png

中斷掛起狀態(tài)寄存器允許使用軟件來觸發(fā)中斷。如果中斷已經(jīng)使能并且沒有被屏蔽掉,當前還沒有更高優(yōu)先級的中斷在運行,這時中斷的服務程序就會立即得以執(zhí)行。

2.1 C代碼

wKgaomRjHfWAG0w9AABLY-88aMc508.jpg

2.2 匯編代碼

wKgaomRjHgeAGhqEAADvcSpnZFw058.jpg

2.3 CMSIS標準設備驅(qū)動函數(shù)

wKgaomRjHiKACoL4AAD-zupzdFk376.jpg





審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19032

    瀏覽量

    228448
  • 單片機
    +關注

    關注

    6026

    文章

    44452

    瀏覽量

    630827
  • 中斷控制器
    +關注

    關注

    0

    文章

    59

    瀏覽量

    9424
  • Cortex-M
    +關注

    關注

    2

    文章

    227

    瀏覽量

    29690

原文標題:好文推薦 | 單片機中斷程序是如何被中斷的?

文章出處:【微信號:麥克泰技術,微信公眾號:麥克泰技術】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關推薦

    單片機外部中斷的好處

    外部中斷單片機實時地處理外部事件的一種內(nèi)部機制。當外部事件發(fā)生時,單片機中斷系統(tǒng)將迫使CPU暫停正在執(zhí)行的程序,轉(zhuǎn)而去進行
    的頭像 發(fā)表于 10-31 15:58 ?2036次閱讀
    <b class='flag-5'>單片機</b>外部<b class='flag-5'>中斷</b>的好處

    51單片機定時器中斷_51單片機中斷系統(tǒng)_51單片機擴展中斷的四種方法

    中斷是為使單片機具有對外部或內(nèi)部隨機發(fā)生的事件進行處理而設置的。51單片機有5種中斷源,即有5種對應的情況發(fā)生時會使單片機去處理
    發(fā)表于 12-08 10:15 ?1.1w次閱讀
    51<b class='flag-5'>單片機</b>定時器<b class='flag-5'>中斷</b>_51<b class='flag-5'>單片機</b><b class='flag-5'>中斷</b>系統(tǒng)_51<b class='flag-5'>單片機</b>擴展<b class='flag-5'>中斷</b>的四種方法

    單片機中斷系統(tǒng)介紹_51單片機中斷系統(tǒng)結構

    單片機中斷就是當單片機正在執(zhí)行程序的時候,突然某個按鍵按下了(產(chǎn)生外部中斷),單片機就必須得去處
    發(fā)表于 01-10 17:29 ?1.2w次閱讀
    <b class='flag-5'>單片機</b><b class='flag-5'>中斷</b>系統(tǒng)介紹_51<b class='flag-5'>單片機</b><b class='flag-5'>中斷</b>系統(tǒng)結構

    單片機外部中斷程序下載

    單片機外部中斷程序和電路圖,通過按鍵控制計數(shù)和清零操作
    發(fā)表于 05-21 10:57 ?0次下載
    <b class='flag-5'>單片機</b>外部<b class='flag-5'>中斷</b><b class='flag-5'>程序</b>下載

    單片機中斷序號詳細說明

    單片機中斷序號決定該中斷中斷向量的位置(即中斷服務程序的入口地址)即
    發(fā)表于 08-19 17:31 ?5次下載
    <b class='flag-5'>單片機</b>的<b class='flag-5'>中斷</b>序號詳細說明

    51單片機有幾個中斷單片機中斷號對應的中斷類型說明

    51單片機通常有5個中斷,當中斷發(fā)生時,程序會跳到相應的中斷服務程序去執(zhí)行。為了區(qū)別不同的
    發(fā)表于 08-06 17:34 ?5次下載
    51<b class='flag-5'>單片機</b>有幾個<b class='flag-5'>中斷</b>?<b class='flag-5'>單片機</b>的<b class='flag-5'>中斷</b>號對應的<b class='flag-5'>中斷</b>類型說明

    單片機中斷程序如何運行

    單片機中斷就是類似的一個過程,發(fā)生中斷時,就會打斷正在執(zhí)行的主程序,先處理完中斷任務,返回主程序
    的頭像 發(fā)表于 01-27 17:11 ?1.1w次閱讀
    <b class='flag-5'>單片機</b>的<b class='flag-5'>中斷</b><b class='flag-5'>程序</b>如何運行

    單片機(AT89C51)中斷系統(tǒng)詳解和中斷系統(tǒng)應用實驗

    單片機中斷系統(tǒng)什么叫做單片機中斷?CPU暫時中止其正在執(zhí)行的程序,轉(zhuǎn)去執(zhí)行請求中斷的那個外設或
    發(fā)表于 11-17 11:06 ?14次下載
    <b class='flag-5'>單片機</b>(AT89C51)<b class='flag-5'>中斷</b>系統(tǒng)詳解和<b class='flag-5'>中斷</b>系統(tǒng)應用實驗

    51單片機中斷

    處理事件B,對事件B處理完畢后,再回到原來中斷的地方(即斷點),稱為 中斷返回。實現(xiàn)上述中斷功能的部件稱為中斷系統(tǒng)(
    發(fā)表于 11-19 09:06 ?18次下載
    51<b class='flag-5'>單片機</b>—<b class='flag-5'>中斷</b>

    關于單片機中斷的若干問題

    中斷技術概述中斷系統(tǒng)作用:實時測控,單片機能及時地響應和處理單片機外部事件或內(nèi)部事件所提出的中斷請求。
    發(fā)表于 11-19 10:36 ?12次下載
    關于<b class='flag-5'>單片機</b>的<b class='flag-5'>中斷</b>的若干問題

    謹慎處理單片機中斷,中斷等價于比主程序優(yōu)先級更高的線程

    ?有些小伙伴喜歡在單片機中斷里做任務,殊不知可能會因此遇到棘手的bug,然后查半天查不出個所以然。本文為了糾正這個不良習慣,對單片機中斷進行闡述。?無
    發(fā)表于 01-14 14:54 ?2次下載
    謹慎處理<b class='flag-5'>單片機</b><b class='flag-5'>中斷</b>,<b class='flag-5'>中斷</b>等價于比主<b class='flag-5'>程序</b>優(yōu)先級更高的線程

    51單片機中斷程序示例

    51單片機中斷程序示例
    發(fā)表于 05-17 18:03 ?0次下載

    基于單片機的外部中斷實驗 中斷系統(tǒng)知識介紹

    單片機中有兩個重要的概念分別叫做中斷、中斷系統(tǒng),那么他們分別又代表什么意義呢?當單片機CPU正在運行主程序時外界發(fā)生了緊急事件請求,要求
    的頭像 發(fā)表于 07-26 17:23 ?2294次閱讀
    基于<b class='flag-5'>單片機</b>的外部<b class='flag-5'>中斷</b>實驗 <b class='flag-5'>中斷</b>系統(tǒng)知識介紹

    單片機中斷功能及其應用

    單片機中斷功能及其應用? 單片機中斷是指在程序執(zhí)行過程中,根據(jù)特定的條件或事件自動暫時中斷當前
    的頭像 發(fā)表于 01-30 14:45 ?4343次閱讀

    單片機有哪些中斷類型

    單片機中斷是指在單片機執(zhí)行程序的過程中,當外部設備或內(nèi)部條件發(fā)生某個特定事件時,能夠暫停當前正在執(zhí)行的程序,轉(zhuǎn)而去執(zhí)行一個特定的服務
    的頭像 發(fā)表于 10-17 18:12 ?166次閱讀