国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

PIC中檔單片機的中斷總結

發布時間:2010-9-21 20:48    發布者:eetech
關鍵詞: PIC , 單片機 , 中斷
一、中斷活動的過程

對于PIC單片機來說,一次中斷的過程大致有下列階段:

為了使得說明形象和直觀,本文采用一些詼諧的語句來比喻說明:  

中斷請求---------比喻成申請買經濟適用房的請求  

中斷標志-------一份申請書  

本中斷使能xxIE-----本單位領導  

PEIE-------------戶口辦公室主任  

GIE--------------銀行的管理信貸的科長  

中斷請求:房子太少,兒子要結婚了,得買房了,可資源和財力有限,不能賣商品房,只好按特殊情況處理,寫一份申請書(中斷標志位IF置1);  

本單位領導xxIE看了之后,如果給你蓋了一個戳:(即該中斷使能位IE=1),那么恭喜你,這份申請書可以提交到更高一級的部門;如果沒蓋(xxIE= 0),那么對不起,先放我這里吧,等我們研究研究好后再說。如果你不開心,要拿回申請書撕掉,呵呵,那么IF=0;你的購房請求之夢破滅;  

xxIE領導將根據戶口,將這些請求書給分類,一類是外地遷來的戶口,提交給戶口辦公室PEIE主任審查,PEIE主任如果給你蓋了個戳(PEIE= 1),那么,他將會把申請書提交給銀行的GIE科長批準,否則就是放在這里再研究研究或者你要回來撕毀;一類是本地戶口,可直接提交給銀行的GIE科長批準,然后你將申請書帶到GIE科長的辦公室。  

GIE科長蓋了章之后(GIE=1),然后,你就可以拿著申請書去找房地產商要房子了(此時PC指針=0004H),因為GIE科長有很多事情要做,所以他每蓋了一次戳之后(注意是一次不是一個,因為也許有多個中斷同時發生,也就是說有其他地方的人來請GIE蓋戳),就在辦公室門外掛了個牌子:請勿打擾。他自己則休息去了,直到接到RETFIE的電話或者有人打他的手機。  

房地產商準備給房子了,不過你最好得先把各項手續給填好,叫5w押金,另外協議阿,合同阿,都得自己搞定,這叫“保護現場”。  

房地產商開始上班了,于是挨個查“申請書”是誰提交的,以便給你安排你預定的房子。這個叫“中斷查詢”。  

查到是你的后,然后打電話讓你過來,帶你去看房子,把鑰匙給你。這個交“中斷處理”。  

鑰匙交給你之后,房子你是到手了,不過這份申請書就失效了,房地產商將該申請書銷毀。這個叫“清除中斷標志”。  

好啦,現在你可以去房地產商自己去要回以前交的押金,身份證啊等等。這個叫“恢復現場”。  

最后,房地產商辦完了,讓RETFIE小姐打個電話給GIE科長(執行RETFIE指令),GIE科長才起來,把“請勿打擾”的牌子取下,讓其他的帶著申請書的人進來。當然,如果你的事情還沒搞定,GIE科長的關系戶打了他的手機(你在辦事時-處理中斷時,若有GIE被置1),他也會開門取下“請勿打擾” 的牌子,讓關系戶進來,給他蓋好章。這下就對不起了,人家有關系,所以你的事情要馬上停下來,先等關系戶辦完他的事情之后,再給你辦你的事情。這個叫“中斷嵌套”,要注意GIE科長有8個關系戶(硬件堆棧的深度為8級)哦。  

二、需要注意的問題:  

1. 中斷現場的保護(可以參考以前的帖子,在xieyubing版主的指點下,有恰當的例子);  

2. 初次上電復位、電源跌落復位和其他情況下的復位,均使得全局中斷位GIE和其他中斷使能位xxIE=0;  

3. 中斷標志位的狀態與該中斷源是否被屏蔽無關,與全局中斷使能位GIE也無關。  

4. 當開放某一中斷源時,該中斷源就是通過中斷標志向CPU申請中斷的,無論什么原因,只要標志位IF置1(可以用軟件強行置1),均會產生中斷請求。  

5. 當中斷標志位為1,如果該中斷被屏蔽或者被禁止了,只要不清除標志位,那么該中斷請求會被潛伏下來,一旦屏蔽解除,立即產生中斷響應。反之,如果在屏蔽/禁止條件解除之前清除了該標志位,那么則無中斷請求。  

6. 當CPU響應任一中斷時,全局中斷使能位GIE會自動清零;當中斷返回時,它有自動置1。如果在中斷處理期間,用軟件將已經清零的GIE位又重新置位,這個時候若再出現中斷請求,就可以形成了中斷嵌套。即:在處理某一中斷期間又響應了其他中斷請求,就形成了中斷嵌套,此時,前一中斷處理過程會被暫停而進入新的中斷處理,當新中斷處理完畢后,才會繼續處理前一個被擱置的中斷。此方式可以形成多級嵌套,但不能超過硬件堆棧的深度8級,以免造成堆棧溢出而不能正常返回。  

7. 如果同時發生多個中斷請求,則中斷處理的順序取決于中斷程序中的檢查中斷源的順序。  

8. 若要防止中斷請求被丟失:則要注意下面兩種情況:如果同一中斷源的中斷發生間隔時間大于該中斷服務的處理時間,則可能出現中斷事件被忽略(體現在中斷服務的過程中,標志位被連續發生來兩次置位),例如:中斷事件發生的時間間隔為30ms,中斷服務處理加上跳轉判斷的時間為50ms,則情況將會如下所示:

[中斷次數----------1][中斷次數----------2][中斷次數----------3][中斷次數----------4]  

[處理次數------------------------1][處理次數------------------------2][處理次數------------------------4]  

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

另外,即使中斷出現的時間間隔大于中斷服務的時間間隔,如果清除中斷標志位的指令安排在中斷服務子程序的尾部,就有可能造成丟失該中斷請求(即兩次中斷標志置位的事件只對應一條清除指令和一次中斷處理。  

9. 在進行查表操作時必
須禁止CPU響應中斷,以避免中斷返回時跳轉到不希望的地址上去。  

三、一個疑惑  

一個疑問:一些書上提到:如果對寄存器INTCON進行“讀-改-寫”操作的時候,要事先將GIE清0,再對INTCON進行操作,然后將GIE恢復為1  

即BCF INTCON,GIE
BSF INTCON,XX
BSF INTCON,GIE

所提到的理由是:當CPU正在執行一條對INTCON寄存器進行“讀-改-寫”操作的指令時,如果恰好發生了中斷請求,則中斷服務程序會被執行兩次。這是因為當中斷請求發生后INTCON寄存器的GIE寄存器會被硬件自動清零(屏蔽所有中斷),并且程序轉入中斷例程入口(0004h)。當GIE被清零后,這時如果CPU正在執行一條對INTCON“讀-改-寫”的指令時,則GIE位還會被寫會操作重新置1,這樣就會造成CPU兩次進入中斷服務程序。  

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

顯然,作者提到的“當GIE被清零后,這時如果CPU正在執行一條對INTCON“讀-改-寫”的指令時,則GIE位還會被寫會操作重新置1,這樣就會造成CPU兩次進入中斷服務程序。”的解釋存在下面的問題:GIE被硬件自動清零時的那個周期,是一個空運行周期,CPU并不執行指令,下一個周期也是空運行周期,不過是完成將0004h地址中的代碼取指操作。然后就開始了0004h地址的代碼的執行操作和0005h地址代碼的取指過程。那么GIE 在被硬件自動清零后要想置會1,只有兩種方法:RETFIE指令使GIE自動置1;通過軟件指令對GIE人為置1。顯然,如果對GIE人為置1的指令執行在對該標志位清零前,那么會出現前文所述的中斷嵌套(設該中斷為A),如果沒有其他中斷發生且執行順序先于中斷A且對中斷A的標志清零的話,那么中斷A的嵌套是一個死循環。就不是執行兩次的問題了----因為同一個中斷嵌套時,GIE在自動清零被軟件置一永遠都發生在清除IF之前,那么IF一直得不到清除,而GIE又幾乎一直都是1。  

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

如果不是這樣的話,那么作者的解釋就自相矛盾:“當CPU正在執行一條對INTCON寄存器的‘讀-改-寫’操作的指令時,如果恰好發生了中斷請求 ”與“當GIE被清零后,這是如果CPU正在執行一條對INTCON‘讀-改-寫’的指令時”相互矛盾。
本文地址:http://m.qingdxww.cn/thread-28583-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • 使用SAM-IoT Wx v2開發板演示AWS IoT Core應用程序
  • 使用Harmony3加速TCP/IP應用的開發培訓教程
  • 集成高級模擬外設的PIC18F-Q71家族介紹培訓教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿澤電子(Mouser)專區

相關在線工具

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 八戒八戒在线播放免费观看5 | 草逼综合| 日韩免费高清一级毛片久久 | 国产一区二区三区播放 | 麻豆果冻 | www.4虎.com| 日韩网站在线 | 国产在线精品成人一区二区三区 | 欧美午夜精品久久久久免费视 | 大蕉香蕉国产在线视频 | 久热这里有精品 | 色老二精品视频在线观看 | 蜜桃成人精品 | 黄色在线观看视频免费 | 日木毛片 | 日韩伦理在线看不卡 | 四虎在线影视在线影库 | 日本黄色不卡视频 | 日韩免费专区 | 最新国产三级在线不卡视频 | 欧美a图| 99视频在线精品免费 | 日韩精品一区二区三区视频网 | 在线天堂在线 | 亚洲一区中文字幕 | 老子影院午夜久久亚洲 | 最新99国产成人精品视频免费 | 天天操大逼 | 男人天堂网2022 | 九九热在线免费视频 | 久久久久这里只有精品 | 日本www在线观看 | 日韩城人免费 | 香蕉久热| 久久蜜桃视频 | www.四虎影院在线观看 | 亚洲国产欧美在线人网站 | 午夜香蕉 | 国产在线观看午夜不卡 | 91精品视频在线播放 | 伊人俺去久久涩五月综合 |