版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第5章MCS-51單片機(jī)中斷系統(tǒng)5.1中斷概述5.2MCS-51中斷系統(tǒng)5.3響應(yīng)中斷的條件和過程5.4關(guān)于外部中斷5.5應(yīng)用舉例一、中斷概述1.1中斷的概念 中斷是單片機(jī)實時地處理內(nèi)部或外部事件的一種內(nèi)部機(jī)制。當(dāng)某種內(nèi)部或外部事件發(fā)生時,單片機(jī)的中斷系統(tǒng)將迫使CPU暫停正在執(zhí)行的程序,轉(zhuǎn)而去進(jìn)行中斷事件的處理,中斷處理完畢后,又返回被中斷的程序處,繼續(xù)執(zhí)行下去。幾個例子生活中的例子打印機(jī)中斷網(wǎng)絡(luò)中斷軟中斷幾個名詞 CPU在處理某一事件A時,發(fā)生了另一事件B請求CPU迅速去處理(中斷發(fā)生); CPU暫時中斷當(dāng)前的工作,轉(zhuǎn)去處理事件B(中斷響應(yīng)和中斷服務(wù)); 待CPU將事件B處理完畢后,再回到原來事件A被中斷的地方繼續(xù)處理事件A(中斷返回)。引起CPU中斷的根源,稱為中斷源。中斷源向CPU提出的中斷請求。CPU暫時中斷原來的事務(wù)A,轉(zhuǎn)去處理事件B。對事件B處理完畢后,再回到原來被中斷的地方(即斷點),稱為中斷返回。實現(xiàn)上述中斷功能的部件稱為中斷系統(tǒng)(中斷機(jī)構(gòu))。
隨著計算機(jī)技術(shù)的應(yīng)用,人們發(fā)現(xiàn)中斷技術(shù)不僅解決了快速主機(jī)與慢速I/O設(shè)備的數(shù)據(jù)傳送問題,而且還具有如下優(yōu)點:
分時操作。CPU可以分時為多個I/O設(shè)備服務(wù),提高了計算機(jī)的利用率;實時響應(yīng)。CPU能夠及時處理應(yīng)用系統(tǒng)的隨機(jī)事件,系統(tǒng)的實時性大大增強(qiáng);可靠性高。CPU具有處理設(shè)備故障及掉電等突發(fā)性事件能力,從而使系統(tǒng)可靠性提高。中斷的特點和優(yōu)點二、80C51中斷系統(tǒng)的結(jié)構(gòu)
80C51的中斷系統(tǒng)有5個中斷源(8052有6個)
,2個優(yōu)先級,可實現(xiàn)二級中斷嵌套。
2.1簡介
中斷示意圖80C51的中斷源
中斷源詳解1、(P3.2)??捎蒊T0(TCON.0)選擇其為低電平有效還是下降沿有效。當(dāng)CPU檢測到P3.2引腳上出現(xiàn)有效的中斷信號時,中斷標(biāo)志IE0(TCON.1)置1,向CPU申請中斷。2、(P3.3)??捎蒊T1(TCON.2)選擇其為低電平有效還是下降沿有效。當(dāng)CPU檢測到P3.3引腳上出現(xiàn)有效的中斷信號時,中斷標(biāo)志IE1(TCON.3)置1,向CPU申請中斷。
3、TF0(TCON.5),片內(nèi)定時/計數(shù)器T0溢出中斷請求標(biāo)志。當(dāng)定時/計數(shù)器T0發(fā)生溢出時,置位TF0,并向CPU申請中斷。
4、TF1(TCON.7),片內(nèi)定時/計數(shù)器T1溢出中斷請求標(biāo)志。當(dāng)定時/計數(shù)器T1發(fā)生溢出時,置位TF1,并向CPU申請中斷。
5、RI(SCON.0)或TI(SCON.1),串行口中斷請求標(biāo)志。當(dāng)串行口接收完一幀串行數(shù)據(jù)時置位RI或當(dāng)串行口發(fā)送完一幀串行數(shù)據(jù)時置位TI,向CPU申請中斷。
2.2、中斷相關(guān)寄存器TCON的中斷標(biāo)志IT0(TCON.0),外部中斷0觸發(fā)方式控制位。當(dāng)IT0=0時,為電平觸發(fā)方式。當(dāng)IT0=1時,為邊沿觸發(fā)方式(下降沿有效)。IE0(TCON.1),外部中斷0中斷請求標(biāo)志位。IT1(TCON.2),外部中斷1觸發(fā)方式控制位。IE1(TCON.3),外部中斷1中斷請求標(biāo)志位。TF0(TCON.5),定時/計數(shù)器T0溢出中斷請求標(biāo)志位。TF1(TCON.7),定時/計數(shù)器T1溢出中斷請求標(biāo)志位。
SCON的中斷標(biāo)志RI(SCON.0),串行口接收中斷標(biāo)志位。當(dāng)允許串行口接收數(shù)據(jù)時,每接收完一個串行幀,由硬件置位RI。同樣,RI必須由軟件清除。TI(SCON.1),串行口發(fā)送中斷標(biāo)志位。當(dāng)CPU將一個發(fā)送數(shù)據(jù)寫入串行口發(fā)送緩沖器時,就啟動了發(fā)送過程。每發(fā)送完一個串行幀,由硬件置位TI。CPU響應(yīng)中斷時,不能自動清除TI,TI必須由軟件清除。
中斷允許控制CPU對中斷系統(tǒng)所有中斷以及某個中斷源的開放和屏蔽是由中斷允許寄存器IE控制的。EX0(IE.0),外部中斷0允許位;ET0(IE.1),定時/計數(shù)器T0中斷允許位;EX1(IE.2),外部中斷0允許位;ET1(IE.3),定時/計數(shù)器T1中斷允許位;ES(IE.4),串行口中斷允許位;EA(IE.7),CPU中斷允許(總允許)位。中斷優(yōu)先級控制80C51單片機(jī)有兩個中斷優(yōu)先級,即可實現(xiàn)二級中斷服務(wù)嵌套。每個中斷源的中斷優(yōu)先級都是由中斷優(yōu)先級寄存器IP中的相應(yīng)位的狀態(tài)來規(guī)定的
。PX0(IP.0),外部中斷0優(yōu)先級設(shè)定位;PT0(IP.1),定時/計數(shù)器T0優(yōu)先級設(shè)定位;PX1(IP.2),外部中斷0優(yōu)先級設(shè)定位;PT1(IP.3),定時/計數(shù)器T1優(yōu)先級設(shè)定位;PS(IP.4),串行口優(yōu)先級設(shè)定位;PT2(IP.5),定時/計數(shù)器T2優(yōu)先級設(shè)定位。
同一優(yōu)先級中的中斷申請不止一個時,則有中斷優(yōu)先權(quán)排隊問題。同一優(yōu)先級的中斷優(yōu)先權(quán)排隊,由中斷系統(tǒng)硬件確定的自然優(yōu)先級形成,其排列如所示:同級優(yōu)先級序號中斷請求標(biāo)志中斷源1IE0外部中斷02TF0定時器/計數(shù)器0溢出中斷3IE1外部中斷14TF1定時器/計數(shù)器1溢出中斷5RI+TI串口通訊中斷6TF2+EXF2定時器/計數(shù)器1溢出中斷
高低80C51單片機(jī)的中斷優(yōu)先級有三條原則:CPU同時接收到幾個中斷時,首先響應(yīng)優(yōu)先級別最高的中斷請求。正在進(jìn)行的中斷過程不能被新的同級或低優(yōu)先級的中斷請求所中斷。正在進(jìn)行的低優(yōu)先級中斷服務(wù),能被高優(yōu)先級中斷請求所中斷。為了實現(xiàn)上述后兩條原則,中斷系統(tǒng)內(nèi)部設(shè)有兩個用戶不能尋址的優(yōu)先級狀態(tài)觸發(fā)器。其中一個置1,表示正在響應(yīng)高優(yōu)先級的中斷,它將阻斷后來所有的中斷請求;另一個置1,表示正在響應(yīng)低優(yōu)先級中斷,它將阻斷后來所有的低優(yōu)先級中斷請求。遇以下任一條件,硬件將受阻,不產(chǎn)生LCALL指令:CPU正在處理同級或高優(yōu)先級中斷;當(dāng)前查詢的機(jī)器周期不是所執(zhí)行指令的最后一個機(jī)器周期。即在完成所執(zhí)行指令前,不會響應(yīng)中斷,從而保證指令在執(zhí)行過程中不被打斷;正在執(zhí)行的指令為RET、RETI或任何訪問IE或IP寄存器的指令。即只有在這些指令后面至少再執(zhí)行一條指令時才能接受中斷請求。
若由于上述條件的阻礙中斷未能得到響應(yīng),當(dāng)條件消失時該中斷標(biāo)志卻已不再有效,那么該中斷將不被響應(yīng)。就是說,中斷標(biāo)志曾經(jīng)有效,但未獲響應(yīng),查詢過程在下個機(jī)器周期將重新進(jìn)行。三、響應(yīng)中斷的條件和過程3.1中斷響應(yīng)條件中斷源有中斷請求;此中斷源的中斷允許位為1;CPU開中斷(即EA=1)。同時滿足時,CPU才有可能響應(yīng)中斷。中斷服務(wù)的進(jìn)入:CPU執(zhí)行程序過程中,在每個機(jī)器周期的S5P2期間,中斷系統(tǒng)對各個中斷源進(jìn)行采樣。這些采樣值在下一個機(jī)器周期內(nèi)按優(yōu)先級和內(nèi)部順序被依次查詢。如果某個中斷標(biāo)志在上一個機(jī)器周期的S5P2時被置成了1,那么它將于現(xiàn)在的查詢周期中及時被發(fā)現(xiàn)。接著CPU便執(zhí)行一條由中斷系統(tǒng)提供的硬件LCALL指令,轉(zhuǎn)向被稱作中斷向量的特定地址單元,進(jìn)入相應(yīng)的中斷服務(wù)程序。
3.2中斷響應(yīng)時間某中斷的響應(yīng)時序如圖:若M1周期的S5P2前某中斷生效,在S5P2期間其中斷請求被鎖存到相應(yīng)的標(biāo)志位中去;M2恰逢指令的最后一個機(jī)器周期,且該指令不是RETI或訪問IE、IP的指令。于是,M3和M4便可以執(zhí)行硬件LCALL指令,M5周期將進(jìn)入了中斷服務(wù)程序。80C51的中斷響應(yīng)時間(從標(biāo)志置1到進(jìn)入相應(yīng)的中斷服務(wù)),至少要3個完整的機(jī)器周期。
3.3中斷響應(yīng)的過程將相應(yīng)的優(yōu)先級狀態(tài)觸發(fā)器置1(以阻斷后來的同級或低級的中斷請求)。執(zhí)行一條硬件LCALL指令,即把程序計數(shù)器PC的內(nèi)容壓入堆棧保存,再將相應(yīng)的中斷服務(wù)程序的入口地址送入PC。執(zhí)行中斷服務(wù)程序。
中斷響應(yīng)過程的前兩步是由中斷系統(tǒng)內(nèi)部自動完成的,而中斷服務(wù)程序則要由用戶編寫程序來完成。
中斷返回RETI指令的具體功能是:將中斷響應(yīng)時壓入堆棧保存的斷點地址從棧頂彈出送回PC,CPU從原來中斷的地方繼續(xù)執(zhí)行程序;將相應(yīng)中斷優(yōu)先級狀態(tài)觸發(fā)器清0,通知中斷系統(tǒng),中斷服務(wù)程序已執(zhí)行完畢。
注意,不能用RET指令代替RETI指令。在中斷服務(wù)程序中PUSH指令與POP指令必須成對使用,否則不能正確返回斷點。四、外部中斷和由外部產(chǎn)生并輸入中斷請求信號,故稱為
外部中斷電平觸發(fā)方式若外部中斷定義為電平觸發(fā)方式,中斷標(biāo)志位的狀態(tài)隨CPU在每個機(jī)器周期采樣到的外部中斷輸入引腳的電平變化而變化,這樣能提高CPU對外部中斷請求的響應(yīng)速度。但外部中斷源若有請求,必須把有效的低電平保持到請求獲得響應(yīng)時為止,不然就會漏掉;而在中斷服務(wù)程序結(jié)束之前,中斷源又必須撤消其有效的低電平,否則中斷返回之后將再次產(chǎn)生中斷。跳變觸發(fā)方式
若外部中斷定義為邊沿觸發(fā)方式,在相繼連續(xù)的兩次采樣中,一個周期采樣到外部中斷輸入為高電平,下一個周期采樣到為低電平,則在IE0或IE1中將鎖存一個邏輯1。即便是CPU暫時不能響應(yīng),中斷申請標(biāo)志也不會丟失,直到CPU響應(yīng)此中斷時才清零。這樣,為保證下降沿能被可靠地采樣到,外中斷引腳上的高低電平(負(fù)脈沖的寬度)均至少要保持一個機(jī)器周期(若晶振為12MHz時,為1微秒)。
五、中斷程序舉例
ORG0000HSTART:LJMPMAIN;跳轉(zhuǎn)到主程序ORG0003HLJMPINTO;轉(zhuǎn)向中斷服務(wù)程序ORG0030H;主程序MAIN:CLRIT0;設(shè)為電平觸發(fā)方式SETBEA;CPU開放中斷SETBEX0;允許中斷MOVDPTR,#1000H;設(shè)置數(shù)據(jù)區(qū)地址指針……ORG0200H;中斷服務(wù)程序INT0:PUSHPSW;保護(hù)現(xiàn)場PUSHACCCLRP3.0;由P3.0輸出0NOPNOPSETBP3.0;由P3.0輸出1,撤除MOVA,P1;輸入數(shù)據(jù)MOVX@DPTR,A;存入數(shù)據(jù)存儲器INCDPTR;修改數(shù)據(jù)指針,指向下一個單元……POPACC;恢復(fù)現(xiàn)場POPPSWRETI;中斷返回
例多外部中斷源的系統(tǒng)示例。設(shè)有5個外部中斷源,中斷優(yōu)先級排隊順序為:XI0、XI1、XI2、XI3、XI4。試設(shè)計它們與80C51單片機(jī)的接口。ORG0003HLJMPINSE0;轉(zhuǎn)外部中斷0服務(wù)程序入口ORG0013HLJMPINSE1;轉(zhuǎn)外部中斷1服務(wù)程序入口…………INSE0:PUSHPSW;XI0中斷服務(wù)程序PUSHACC…………
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 水樣除油預(yù)處理工藝流程
- 分包合同爭端處理案例分析
- 技術(shù)服務(wù)合同風(fēng)險防范策略
- 焊錫絲采購合同簽訂雙方的合同執(zhí)行
- 學(xué)生個人嚴(yán)于律己勤奮學(xué)習(xí)保證書
- 全新員工忠誠與權(quán)益保證
- 簡化人力資源承包協(xié)議
- 銀行擔(dān)保合作協(xié)議
- 初中生文明行為保證書
- 商品交易合同案例
- 廣東省廣州市2023-2024學(xué)年七年級上學(xué)期語文期中試卷(含答案)
- 水利工程檔案管理實施細(xì)則
- 2024至2030年中國芯片原子鐘行業(yè)調(diào)查及市場前景咨詢報告
- 部編人教版道德與法治八年級上冊 引用的名言警句1
- 藏傳佛教因明學(xué)通論
- 監(jiān)控驗收單完整版本
- 2024湖南株洲市天元區(qū)招聘社區(qū)專職工作者筆試歷年典型考題及考點剖析附答案帶詳解
- 弱電智能化工程技術(shù)方案
- TZSA 225-2024 高導(dǎo)熱膜用石墨烯材料應(yīng)用指南
- 第七課《循環(huán)程序》教學(xué)設(shè)計 2023-2024學(xué)年新世紀(jì)版(2018)初中信息技術(shù)八年級上冊
- 人教版八年級音樂上冊 第二單元 《動物世界》片頭曲教案
評論
0/150
提交評論