中斷及中斷處理過程

中斷及中斷處理過程

ID:37101604

大小:293.25 KB

頁數(shù):24頁

時間:2019-05-11

中斷及中斷處理過程_第1頁
中斷及中斷處理過程_第2頁
中斷及中斷處理過程_第3頁
中斷及中斷處理過程_第4頁
中斷及中斷處理過程_第5頁
資源描述:

《中斷及中斷處理過程》由會員上傳分享,免費在線閱讀,更多相關內容在教育資源-天天文庫。

1、3-1中斷及中斷處理過程所謂中斷是指某事件的發(fā)生引起CPU暫停當前程序的運行,轉入對所發(fā)生事件的處理,處理結束又回到原程序被打斷處接著執(zhí)行這樣一個過程。3-1中斷及中斷處理過程中斷源分類1、外中斷源2、內部中斷源I/O設備數(shù)據(jù)通道實時鐘故障源CPU執(zhí)行指令產生的異常執(zhí)行INT軟件中斷指令1、外部中斷2、內部中斷軟件中斷沒有隨機性,類似于普通子程序的調用硬件中斷具有隨機性分為可屏蔽中斷與不可屏蔽中斷兩種中斷分類3.1.2中斷處理過程中斷請求—→中斷優(yōu)先級判定—→中斷響應—→中斷處理—→中斷返回1、中斷請求2、中斷優(yōu)先級判定多中斷

2、請求的優(yōu)先級判定實現(xiàn)多層中斷嵌套①信號形式應滿足CPU要求。②中斷請求信號應被有效地記錄,以便CPU能夠檢測到它。③一旦CPU對某中斷源的請求提供了服務,則該中斷源的請求信號應及時撤消。3.1.2中斷處理過程3、中斷響應?獲得中斷類型號保護狀態(tài)標志屏蔽新的INTR中斷和單步中斷保存斷點信息?根據(jù)中斷類型,獲得中斷服務程序的入口地址?進入中斷服務程序CPU狀態(tài)字中IF=1,開中斷;IF=0,關中斷CPU復位,IF=0,TF=0;用STI開中斷,CLI關中斷CPU響應中斷后,自動實現(xiàn)關中斷,若要實現(xiàn)中斷嵌套,在中斷服務程序中要用S

3、TI開中斷圖1微機系統(tǒng)中實現(xiàn)中斷的基本模型圖2有中斷產生的情況下CPU運行程序的軌跡3.1.2中斷處理過程4、中斷處理?保護現(xiàn)場開中斷中斷服務?關中斷?恢復現(xiàn)場中斷處理程序中,最后應有IRET指令恢復斷點信息恢復標志寄存器FR4、中斷返回3.2中斷優(yōu)先權①軟件查詢。②硬件鏈式優(yōu)先級排隊電路。③硬件優(yōu)先級編碼比較電路。④利用可編程中斷控制器。3.2.1軟件查詢3.2.2硬件排優(yōu)2可編程中斷控制器中斷優(yōu)先權管理電路中斷請求鎖存器中斷類型寄存器中斷屏蔽寄存器當前中斷服務寄存器3.380X86中斷系統(tǒng)3.3.1中斷結構8086(88)

4、中斷系統(tǒng)可以容納最多256個中斷源,所有中斷源統(tǒng)一編碼,每個中斷源用一個字節(jié)型編碼標識,它是CPU識別中斷源的標記。256個中斷源分為兩大類:(1)內部中斷由CPU內部事件及執(zhí)行軟中斷指令產生。已定義的內部中斷有:①除法錯中斷,0型中斷。②單步中斷,1型中斷③斷點中斷,3型中斷,用于調試插入斷點。④溢出中斷,4型中斷,INTO指令。⑤指令中斷,INTn指令①中斷在處理過程中,CPU自動將標志FR入棧,然后清TF和IF②IF的值可以通過指令STI和指令CLI改變③沒有直接改變TF值的指令,需要編程PUSHFPOPAXORAX,0

5、100HPUSHAXPOPFOFDFIFTFSFZFAFPFCFFR:注意:(2)外部中斷3.3.1中斷結構由外部中斷源產生對CPU的請求而引發(fā)的。8086(88)中斷系統(tǒng)將外部中斷源又分為兩種。①非屏蔽中斷。②可屏蔽中斷2型中斷。當NMI引腳出現(xiàn)上升沿觸發(fā),表示有非屏蔽中斷請求信號的有效高電平應持續(xù)2個時鐘周期以上用來處理系統(tǒng)突發(fā)事件當INTR引腳出現(xiàn)高電平,表示有可屏蔽中斷請求只有在IF=1時,CPU才響應此中斷CPU響應后,會執(zhí)行兩個響應周期,分別送兩個INTA負脈沖信號,以獲得該中斷源的中斷類型碼3.3.2中斷向量表中

6、斷向量:中斷服務程序的入口地址。8086(88)在內存的最低1K字節(jié)建了一個中斷向量表,用以存放256個中斷類型的中斷向量(中斷服務程序的地址)存放方法:每個中斷向量占4個字節(jié),前2個字節(jié)是IP,后兩個字節(jié)是CS。按中斷向量碼的序號排列.圖7中斷向量表中斷向量地址指針中斷向量地址指針=4×中斷類型碼如:中斷類型碼為20H的中斷向量,存放在0000:0080H開始的四個單元中。1、絕對地址置入2、使用串指令置入3.3.3中斷向量表的建立中斷服務程序的入口地址該怎么置入中斷向量表中?INT-TBLSEGMENTAT0ORGn×4D

7、DINT-VCEINT-TBLENDSINT-VCEPROCFARIRET……CLIMOVAX,0MOVES,0;置向量表段地址MOVDI,n*4;置向量表偏移地址MOVAX,OFFSETINT-VCE;置中斷服務程序偏移地址CLD;清除方向標志STOSWMOVAX,SEGINT-VCE;置中斷服務程序段地址STOSWSTI3.3.3中斷向量表的建立3、使用DOS系統(tǒng)功能調用INT21H1)使用25H功能系統(tǒng)功能調用:a)把調用號放入AH中,設置入口參數(shù)b)執(zhí)行INT21H25H功能:根據(jù)中斷號更新中斷服務程序的入口地址a)A

8、L=中斷號b)DS:DX=中斷服務程序新的入口地址的段、偏移地址PUSHDSMOVDX,SEGINT60H;置中斷服務程序段地址MOVDS,DXMOVDX,OFFSETINT60H;置中斷服務程序偏移地址MOVAL,60HMOVAH,25HINT21HPOPDS35H功能:查

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內容,確認文檔內容符合您的需求后進行下載,若出現(xiàn)內容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網絡波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。