<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > PIC單片機(jī)的中斷問答

          PIC單片機(jī)的中斷問答

          作者: 時(shí)間:2013-05-11 來源:網(wǎng)絡(luò) 收藏

          7. 如果同時(shí)發(fā)生多個(gè)中斷請(qǐng)求,則中斷處理的順序取決于中斷程序中的檢查順序。

          8. 若要防止中斷請(qǐng)求被丟失:則要注意下面兩種情況:如果同一中斷發(fā)生間隔時(shí)間大于該中斷服務(wù)的處理時(shí)間,則可能出現(xiàn)中斷事件被忽略(體現(xiàn)在中斷服務(wù)的過程中,標(biāo)志位被連續(xù)發(fā)生來兩次置位),例如:中斷事件發(fā)生的時(shí)間間隔為30ms,中斷服務(wù)處理加上跳轉(zhuǎn)判斷的時(shí)間為50ms,則情況將會(huì)如下所示:

          [中斷次數(shù)----------1][中斷次數(shù)----------2][中斷次數(shù)----------3][中斷次數(shù)----------4]

          [處理次數(shù)------------------------1][處理次數(shù)------------------------2][處理次數(shù)------------------------4]

          如果在中斷處理一開始就清除IF,那么如上圖所示,中斷事件3、4 在處理次數(shù)2的過程中發(fā)生來兩次,那么即使IF清除發(fā)生在中斷次數(shù)3發(fā)生之前,也將丟失第三次中斷。

          另外,即使中斷出現(xiàn)的時(shí)間間隔大于中斷服務(wù)的時(shí)間間隔,如果清除中斷標(biāo)志位的指令安排在中斷服務(wù)子程序的尾部,就有可能造成丟失該中斷請(qǐng)求(即兩次中斷標(biāo)志置位的事件只對(duì)應(yīng)一條清除指令和一次中斷處理。

          9. 在進(jìn)行查表操作時(shí)必須禁止CPU響應(yīng)中斷,以避免中斷返回時(shí)跳轉(zhuǎn)到不希望的地址上去。

          三、一個(gè)疑惑

          一個(gè)疑問:一些書上提到:如果對(duì)寄存器INTCON進(jìn)行“讀-改-寫”操作的時(shí)候,要事先將GIE清0,再對(duì)INTCON進(jìn)行操作,然后將GIE恢復(fù)為1

          即BCF INTCON,GIE

          BSF INTCON,XX

          BSF INTCON,GIE

          所提到的理由是:當(dāng)CPU正在執(zhí)行一條對(duì)INTCON寄存器進(jìn)行“讀-改-寫”操作的指令時(shí),如果恰好發(fā)生了中斷請(qǐng)求,則中斷服務(wù)程序會(huì)被執(zhí)行兩次。這是因?yàn)楫?dāng)中斷請(qǐng)求發(fā)生后INTCON寄存器的GIE寄存器會(huì)被硬件自動(dòng)清零(屏蔽所有中斷),并且程序轉(zhuǎn)入中斷例程入口(0004h)。當(dāng)GIE被清零后,這時(shí)如果CPU正在執(zhí)行一條對(duì)INTCON“讀-改-寫”的指令時(shí),則GIE位還會(huì)被寫會(huì)操作重新置1,這樣就會(huì)造成CPU兩次進(jìn)入中斷服務(wù)程序。

          該段解釋晦澀難懂,根據(jù)中斷發(fā)生過程的時(shí)序(PICmicro中檔單片機(jī)系列參考手冊(cè)的第8-2頁):在第n個(gè)指令周期里,CPU檢測到IF標(biāo)志位為1,則在n+1個(gè)周期內(nèi)將自動(dòng)使得GIE=0,該周期內(nèi)既不取指也不執(zhí)行指令,然后在n+2個(gè)指令周期里,0004h指針裝入PC指針,該周期也不運(yùn)行其他指令,只完成0004H->(PC)的取指過程,第n+3個(gè)指令周期里,CPU執(zhí)行0004h地址的指令碼,并同時(shí)取0005h的指令碼。

          顯然,作者提到的“當(dāng)GIE被清零后,這時(shí)如果CPU正在執(zhí)行一條對(duì)INTCON“讀-改-寫”的指令時(shí),則GIE位還會(huì)被寫會(huì)操作重新置1,這樣就會(huì)造成CPU兩次進(jìn)入中斷服務(wù)程序?!钡慕忉尨嬖谙旅娴膯栴}:GIE被硬件自動(dòng)清零時(shí)的那個(gè)周期,是一個(gè)空運(yùn)行周期,CPU并不執(zhí)行指令,下一個(gè)周期也是空運(yùn)行周期,不過是完成將0004h地址中的代碼取指操作。然后就開始了0004h地址的代碼的執(zhí)行操作和0005h地址代碼的取指過程。那么GIE在被硬件自動(dòng)清零后要想置會(huì)1,只有兩種方法:RETFIE指令使GIE自動(dòng)置1;通過軟件指令對(duì)GIE人為置1。顯然,如果對(duì)GIE人為置1的指令執(zhí)行在對(duì)該標(biāo)志位清零前,那么會(huì)出現(xiàn)前文所述的中斷嵌套(設(shè)該中斷為A),如果沒有其他中斷發(fā)生且執(zhí)行順序先于中斷A且對(duì)中斷A的標(biāo)志清零的話,那么中斷A的嵌套是一個(gè)死循環(huán)。就不是執(zhí)行兩次的問題了----因?yàn)橥粋€(gè)中斷嵌套時(shí),GIE在自動(dòng)清零被軟件置一永遠(yuǎn)都發(fā)生在清除IF之前,那么IF一直得不到清除,而GIE又幾乎一直都是1。

          作者所說的情況似乎是這樣的:讀改寫INTCON指令按如下過程分解:讀INTCON的時(shí)候,GIE先是為1的,此時(shí)發(fā)生了中斷,GIE被硬件清零,開始執(zhí)行中斷服務(wù)程序,然后再IF標(biāo)志沒有清除之前,執(zhí)行INTCON的其他位的修改和寫回操作,也將中斷發(fā)生前的GIE讀為1的信息寫回GIE,這樣,CPU被迫發(fā)生了第二次中斷。顯然,這樣是將BSF INTCON, XX指令分解得支離破碎---本來一個(gè)指令周期可以完成的指令被跨了多個(gè)指令周期;而且一個(gè)指令周期的指令被CPU在不同地址處分解執(zhí)行讀改寫過程。

          如果不是這樣的話,那么作者的解釋就自相矛盾:“當(dāng)CPU正在執(zhí)行一條對(duì)INTCON寄存器的‘讀-改-寫’操作的指令時(shí),如果恰好發(fā)生了中斷請(qǐng)求 ”與“當(dāng)GIE被清零后,這是如果CPU正在執(zhí)行一條對(duì)INTCON‘讀-改-寫’的指令時(shí)”相互矛盾。

          總之,我對(duì)這里的理解存在一些疑惑,請(qǐng)斑竹及各位前輩指點(diǎn)。


          上一頁 1 2 3 下一頁

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();