【導讀】中斷響應是CPU對中斷源中斷請求的響應,包括保護斷點和將程序轉向中斷服務程序的入口地址(通常稱矢量地址)。
中斷響應
中斷響應是CPU對中斷源中斷請求的響應,包括保護斷點和將程序轉向中斷服務程序的入口地址(通常稱矢量地址)。
中斷響應過程
中斷響應過程包括保護斷點和將程序轉向中斷服務程序的入口地址。首先,中斷系統(tǒng)通過硬件自動生成長調用指令(LACLL),該指令將自動把斷點地址壓入堆棧保護(不保護累加器A、狀態(tài)寄存器PSW和其它寄存器的內(nèi)容),然后,將對應的中斷入口地址裝入程序計數(shù)器PC(由硬件自動執(zhí)行),使程序轉向該中斷入口地址,執(zhí)行中斷服務程序。MCS-51系列單片機各中斷源的入口地址由硬件事先設定,分配如下:
中斷源 入口地址
外部中斷0 0003H
定時器T0中斷 000BH
外部中斷1 0013H
定時器T1中斷 001BH
串行口中斷 0023H
使用時,通常在這些中斷入口地址處存放一條絕對跳轉指令,使程序跳轉到用戶安排的中斷服務程序的起始地址上去。
中斷返回
中斷返回是指中斷服務完后,計算機返回原來斷開的位置(即斷點),繼續(xù)執(zhí)行原來的程序。中斷返回由中斷返回指令RETI來實現(xiàn)。該指令的功能是把斷點地址從堆棧中彈出,送回到程序計數(shù)器PC,此外,還通知中斷系統(tǒng)已完成中斷處理,并同時清除優(yōu)先級狀態(tài)觸發(fā)器。特別要注意不能用“RET”指令代替“RETI”指令。
中斷請求的撤除
CPU響應中斷請求后即進入中斷服務程序,在中斷返回前,應撤除該中斷請求,否則,會重復引起中斷而導致錯誤。MCS-51各中斷源中斷請求撤消的方法各不相同,分別為:
1)定時器中斷請求的撤除
對于定時器0或1溢出中斷,CPU在響應中斷后即由硬件自動清除其中斷標志位TF0或TF1,無需采取其它措施。
2)串行口中斷請求的撤除
對于串行口中斷,CPU在響應中斷后,硬件不能自動清除中斷請求標志位TI、RI,必須在中斷服務程序中用軟件將其清除。
3)外部中斷請求的撤除
外部中斷可分為邊沿觸發(fā)型和電平觸發(fā)型。
對于邊沿觸發(fā)的外部中斷0或1,CPU在響應中斷后由硬件自動清除其中斷標志位IE0或IE1,無需采取其它措施。
推薦閱讀:
簡單解析鋰電池負極存在的四大問題
雙極結型晶體管差分放大器的溫度補償
詳細解析基于射頻電路中各典型功能模塊
松下開發(fā)出識別能力接近肉眼的圖像傳感器
如何對高頻變壓器內(nèi)部進行emi布線?
推薦閱讀:
簡單解析鋰電池負極存在的四大問題
雙極結型晶體管差分放大器的溫度補償
詳細解析基于射頻電路中各典型功能模塊
松下開發(fā)出識別能力接近肉眼的圖像傳感器
如何對高頻變壓器內(nèi)部進行emi布線?