單片機CPU在處理某一事件A時,發生了另一事件B請求CPU迅速去處理(中斷發生);CPU暫時中斷當前的工作,轉去處理事件B(中斷響應和中斷服務);待CPU將事件B處理完畢后,再回到原來事件A被中斷的地方繼續處理事件A(中斷返回),這一過程稱為中斷。
例如當你正在洗衣時,突然手機響了(中斷發生),你暫時中斷洗衣的工作,轉去接電話(中斷響應和中斷服務),待你接完后,再回來繼續洗衣(中斷返回),這一過程就是中斷。
單片機中斷分為內部中斷和外部中斷兩大類,外部中斷由單片機外部設備產生,中斷產生后通過單片機的外部管腳傳遞給單片機,傳遞這個中斷信號最簡單的方法就是規定單片機的管腳在什么狀態下有外部中斷產生,這樣單片機通常是有一個或多個IO口當在輸入狀態時可以用來檢測外部中斷信號。有外部中斷產生的條件通常也就是這五種:IO口輸入為高、IO口輸入為低、IO口輸入由高變為低、IO口輸入由低變為高、IO口輸入由高變低或者由低變高。一個連接到單片機的外部設備,如果想要使用單片機的外部中斷,就必須在自己請求單片機中斷響應的時候給單片機提供單片機在這五種信號中所支持的類型來觸發單片機中斷。程序運轉中,一個中斷不是只產生一次,一般都會間隔持續產生,這五種外部中斷觸發信號前四種都有一個問題,就是外設發出請求中斷信號后如果信號請求線狀態不改變,外設會無法向單片機提供下一次中斷請求信號。讓我們來看看以單片機和外部設備采用負跳變觸發中斷為例的觸發情況。外部設備以負跳變觸發單片機中斷,第一次中斷請求外部設備的中斷請求輸出腳可以從高變低,觸發單片機中斷,第一次中斷請求發生后中斷請求腳保持輸出低,外部設備無法產生第二次中斷的觸發負跳變信號。圖1 外設只能產生一次中斷請求信號示意圖將外部設備的中斷請求信號做出修改,原來為需要中斷時只是輸出從高到低變化,現在改為輸出先從高變到低,經過一小段時間后自己從低變回高,這樣就可以每次需要中斷時都能向單片機輸出負跳變觸發信號。
圖2 外設可連續產生中斷請求信號示意圖一或者是由外部設備提供某種接口,單片機通過該接口可以對外部設備進行中斷清除操作,中斷清除操作可以讓外部設備的中斷請求輸出腳恢復到高。
圖3 外設可連續產生中斷請求信號示意圖二外部中斷觸發還有一些特殊方式,比如外部脈沖寬度測量、外部脈沖計數等,這些方式都是在前面幾種基本觸發方式上進行功能擴展得來的,外部脈沖寬度測量就是當中斷信號線跳變時會啟動內部一個計時器,到下一次中斷信號線跳變時通過計時器得到脈沖寬度并重新啟動計時器,這些方式很少會使用到,不做詳述。內部中斷是指單片機內部的功能模塊產生中斷信號,只要是單片機內部在CPU外圍能獨立工作的功能模塊都會提供中斷功能,常見的內部中斷類型有時鐘Timer、串口UART、模數轉換ADC等。內部中斷的工作流程和外部中斷沒太多區別,只是中斷請求信號是在單片機內部進行傳輸,中斷信號不是管腳上的電平狀態,而是一個寄存器里面的相應標志位,通常當某個內部中斷產生中斷請求時就會將相應標志位置為1,CPU響應中斷時將這個標志位清0。
圖4 內部中斷觸發示意圖單片機對中斷標志位的處理方法沒有統一標準,具體的約定方法要看單片機文檔。大部分是標志位為1有中斷產生,但有少數單片機是標志位為0有中斷產生;有的單片機對中斷標志位是CPU寫入什么就是給改寫成什么,有的則是規定必須通過寫1或寫0來實現清除操作,還有少數只要讀一下中斷標志位就會自動清除掉該標志位。如果單片機不想被外部中斷觸發,大不了將用于連接外部中斷觸發信號的管腳接成不會觸發中斷的電壓狀態就可以,但內部中斷無法去改變內部連線,所以單片機為了可以選擇中斷是否可以被除法,在其內部會有相關的寄存器來進行選擇,通過里面的控制標志位開發人員可以根據實際情況決定是否使用中斷。通常單片機里面有一個總控制位,這個位可以控制所有中斷的開與關,然后每一種中斷自己還有一個獨立的控制位決定自己的開與關,如果想使用某個中斷,就需要將總中斷開關和對應中斷的開關都打開。當單片機有中斷信號產生時,就會觸發對應中斷,不同的中斷源會需要不同的響應方法,也就是說不同的中斷產生的時候,需要單片機程序依照不同的中斷源做出不同的響應,這就是中斷服務程序。如果是UART收到新數據產生中斷,應該是UART中斷服務程序將數據讀回來并做處理,如果是ADC轉換完成產生的中斷,需要的則是ADC中斷服務程序將數據讀回來并做處理。如果需要清中斷標志位動作,一般都是在中斷服務程序里面完成。不同的中斷源需要與之對應的中斷服務程序,實際開發中并不是所有的中斷都會被用到,開發人員為了節約程序代碼空間會只寫出自己要使用到的中斷服務程序,也就是說會有一些中斷沒有與之對應的中斷服務程序,如果觸發了這樣的中斷,單片機程序會運行出錯,前面中斷各自獨立的控制位就排上用場,將這些控制位關掉,相應中斷就不會被觸發。單片機開始上電的時候,如果控制中斷是否被打開的寄存器控制標志位被打開,可能會出現中斷被誤觸發的情況,而這個中斷如果沒有與之相對應的中斷服務程序的話程序就會跑飛,所以單片機上電的時候一般會自動將這些寄存器里面的標志位都關掉,以免誤觸發。中斷服務程序是單片機程序的一部分,具體內容由開發人員決定,這樣中斷服務程序的大小在單片機程序中的位置就不固定,當單片機的中斷被觸發后,單片機需要知道中斷服務程序在什么位置才能執行它,單片機通過中斷跳轉表(中斷向量表)來解決這個問題。雖然中斷服務程序的大小和在整個程序中的位置會不固定,但程序只要被燒進單片機系統,對于這個程序來說其中斷服務程序的大小和在整個程序中的位置就會被固定下來,如果對單片機程序空間分配我們做出一些約定,將一個絕對固定地址專門分配給中斷使用,程序編譯時會將中斷服務程序的起始地址(或者是跳轉到中斷服務程序的指令)填到這個絕對固定地址所在的空間,當中斷產生時候,單片機先將絕對固定地址所在位置里面的內容讀出,根據所讀內容就可以跳轉到中斷服務程序。
圖5 中斷響應示意圖簡單的單片機所提供的中斷種類有限,為了簡化程序,會給每一個中斷分配一個用來存放中斷服務程序地址的地址空間,這種方法其實沒什么不好的地方,只是單片機技術發展到現在遇到了瓶頸,高端單片機越來越復雜,于是一些專業廠商開始合作共享技術資源,例如ARM公司利用他們在CPU架構體系上的技術優勢專門給另外的廠商提供CPU內核,另外的廠商在ARM內核的CPU外圍增加功能模塊,這些功能模塊大都支持中斷。
圖6 ARM內核單片機架構圖不同廠家在相同CPU內核基礎上設計出來的單片機外圍的功能模塊會各不相同,從而中斷的種類和個數也各不相同,而CPU處理中斷的方法是一樣的,如果延續簡單的單片機給每個中斷都分配一個地址空間的做法顯然有問題,CPU無法知道到底有多少種中斷需要支持,這些中斷又分別對應什么模塊,于是采用另外一種中斷處理方法,將所有中斷地址都指向同一個,并將所有中斷依次編號,中斷產生時候CPU會告訴中斷服務程序當前中斷編號是多少,然后中斷服務程序根據中斷編號做出相應響應。
圖7 公用中斷入口中斷響應流程圖
圖8 獨立中斷入口中斷響應流程圖所有中斷使用同一個中斷向量地址然后通過中斷號判斷中斷類別的方法雖然解決了通用CPU內核中斷不能直接對應中斷向量地址的問題,但把它中斷處理的流程和具有獨立中斷向量表的單片機相比就會發現中斷的響應速度會變慢。具有獨立中斷向量表的單片機只要一條跳轉指令就可以直接進入中斷程序,而沒有獨立中斷向量表的單片機需要先跳轉到中斷公共入口,然后通過代碼判定中斷類別,確定中斷類別后才跳轉到真正的中斷程序中去。C語言的代碼會讓這種情況更加惡化,所以如果是沒有獨立中斷向量表的單片機一般采用匯編查表的方法加快中斷響應速度。
圖9 匯編中斷快速跳轉表中斷程序執行完畢后回返回繼續執行主程序,這樣就要求中斷不改變主程序的運行狀態,所以中斷響應時需要將程序當前運行的狀態信息保存起來,比如程序運行到什么位置、當前CPU狀態寄存器的狀態等信息。當中斷程序執行完畢,可以通過這些信息將CPU狀態寄存器恢復原來狀態,并能返回原程序繼續執行。不同的單片機對此的處理方式也會有不同,一種是完全由硬件來完成,并不需要程序來進行管理;另外一種是將狀態信息用相應指令保存在特定位置,返回時再用相應指令恢復原來狀態。
單片機中斷還有中斷優先級和中斷嵌套的概念,但不是所有的單片機都會支持這兩種功能。中斷優先級是不同的中斷會有不同的優先級別,如果同時有兩個中斷產生,單片機會先響應優先級高的中斷。中斷嵌套是指在中斷響應當中又有新的中斷產生,單片機可以暫停當前的中斷程序執行去響應新的中斷,新中斷程序執行完以后在接著執行當前中斷程序。一般中斷嵌套是高優先級的中斷可以插入低優先級中斷響應程序,同級或低級的中斷不能插入當前中斷響應程序。
圖10 中斷嵌套示意圖
步驟①保存主程序現場,執行中斷1服務程序
步驟②保存中斷1服務程序現場,執行中斷2服務程序
步驟③恢復中斷1服務程序現場,繼續執行中斷1服務程序
步驟④恢復主程序現場,準備繼續執行主程序,有新中斷不能繼續執行主程序
步驟⑤保存主程序現場,執行中斷3服務程序
步驟⑥恢復主程序現場,準備繼續執行主程序,有新中斷不能繼續執行主程序
步驟⑦保存主程序現場,執行中斷4服務程序
步驟⑧恢復主程序現場,無中斷產生繼續執行主程序有的單片機一進入中斷函數就會自動將中斷的總控制位關掉,需要開發人員在中斷程序中用程序再次打開,否則一次中斷后所有的中斷就不能繼續使用。對于中斷標志位,在寫單片機程序的時候要依據單片機文檔進行清除標志為操作,不然有可能會一旦產生某個中斷就會連續不停的反復響應這個中斷,導致主程序不能繼續運行。-
單片機
+關注
關注
6043文章
44622瀏覽量
638548 -
中斷
+關注
關注
5文章
900瀏覽量
41752
原文標題:不懂中斷你就別玩單片機
文章出處:【微信號:edn-china,微信公眾號:EDN電子技術設計】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論