版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 計(jì)算機(jī)組成原理課程設(shè)計(jì)報(bào)告</p><p> 題目全稱: VC++仿真中斷 </p><p> 課程名稱: VC++仿真中斷 </p><p> 指導(dǎo)老師: </p><p&
2、gt; 任課老師: </p><p> ?。ㄗⅲ簩W(xué)生姓名填寫按學(xué)生對(duì)該課程設(shè)計(jì)的貢獻(xiàn)及工作量由高到底排列,分?jǐn)?shù)按排名依次遞減。序號(hào)排位為“1”的學(xué)生成績(jī)最高,排位為“10”的學(xué)生成績(jī)最低。)</p><p><b> 指導(dǎo)老師評(píng)語:</b></p><p> 簽字:
3、 </p><p><b> 摘 要</b></p><p> 程序中斷傳送方式(中斷方式)是一種I/O傳送的控制方式。這種方式定義當(dāng)CPU收到隨機(jī)的中斷請(qǐng)求后,暫時(shí)中止現(xiàn)行程序的執(zhí)行,抓取執(zhí)行為該隨機(jī)事件服務(wù)的中斷處理程序,處理完畢后自動(dòng)回復(fù)原程序的執(zhí)行。在當(dāng)今的大多數(shù)計(jì)算機(jī)中,I/O傳送控制方式多采用中斷方式。了解并且掌握中斷方式的機(jī)制對(duì)于理解計(jì)算
4、機(jī)的I/O傳送控制方式有著相當(dāng)重要的作用。</p><p> 本文利用高級(jí)語言VC++開發(fā)模擬中斷控制器的中斷執(zhí)行過程仿真軟件。該軟件可以詳細(xì)地將中斷整個(gè)過程給以清晰的動(dòng)態(tài)界面描述,更便于理解和掌握中斷過程。</p><p> 關(guān)鍵詞:中斷,中斷控制器</p><p><b> 目錄</b></p><p><
5、;b> 第一章 緒論1</b></p><p> 1.1 選題背景及意義1</p><p> 1.2 國(guó)內(nèi)外研究現(xiàn)狀1</p><p> 1.3 主要內(nèi)容2</p><p> 第二章 課程設(shè)計(jì)的需求分析3</p><p> 2.1 環(huán)境需求3</p><p&
6、gt; 2.2 功能需求3</p><p> 2.3 性能需求3</p><p> 2.3 本章小結(jié)3</p><p> 第三章 ****的設(shè)計(jì)5</p><p> 3.1 總體設(shè)計(jì)5</p><p> 3.2 功能模塊設(shè)計(jì)5</p><p> 3.3 本章小結(jié)5&l
7、t;/p><p> 第四章 ****的實(shí)現(xiàn)7</p><p> 4.1 開發(fā)環(huán)境介紹7</p><p> 4.2 主要功能模塊的實(shí)現(xiàn)7</p><p> 4.3 本章小結(jié)7</p><p> 第五章 測(cè)試及成果展示9</p><p> 5.1 測(cè)試環(huán)境9</p>
8、<p> 5.2 測(cè)試用例和結(jié)果9</p><p> 5.3 成果展示9</p><p> 5.4 本章小結(jié)9</p><p> 第六章 總結(jié)與展望11</p><p><b> 參考文獻(xiàn)12</b></p><p><b> 第一章 緒論</b&
9、gt;</p><p> 1.1 選題背景及意義</p><p> 計(jì)算機(jī)的硬件部分通常包含了三大部件:CPU、存儲(chǔ)器(主存儲(chǔ)器和外部存儲(chǔ)器)、I/O設(shè)備。這些部件之間必須有連接的通路,才能組成一個(gè)完整的計(jì)算機(jī)系統(tǒng),以便相互交換信息,協(xié)調(diào)一致地工作,實(shí)現(xiàn)計(jì)算機(jī)的基本功能,即執(zhí)行程序。在主機(jī)和外設(shè)之間如果要進(jìn)行數(shù)據(jù)的交換,需要一套機(jī)制來對(duì)該交換過程提供控制信號(hào)。在當(dāng)前的計(jì)算機(jī)系統(tǒng)中,主機(jī)
10、和外部設(shè)備之間的輸入/輸出操作可采用三種常用的技術(shù),即直接程序傳送方式、程序中斷方式、存儲(chǔ)器直接訪問(DMA)方式。其中,程序中斷方式常簡(jiǎn)稱為中斷方式,它是幾乎所有的計(jì)算機(jī)系統(tǒng)都應(yīng)具備的一種重要的工作機(jī)制,在實(shí)際工作中被廣泛地應(yīng)用。</p><p> 在中斷方式中需要進(jìn)行一系列的隱指令操作:保存斷點(diǎn)、讀取服務(wù)程序入口地址;以及在轉(zhuǎn)入服務(wù)程序后首先應(yīng)執(zhí)行的操作,如保護(hù)源程序的現(xiàn)場(chǎng)信息;在返回原程序前,還需回復(fù)現(xiàn)場(chǎng)
11、、讀取返回地址等。這使得中斷方式一般適用于處理中、低速的I/O操作和隨機(jī)請(qǐng)求,所處理的對(duì)象可以是復(fù)雜的隨機(jī)事態(tài)。具體來講,中斷方式常有以下六種典型應(yīng)用:①以中斷方式管理中低速I/O操作,使CPU與外部設(shè)備并行工作;②軟中斷;③故障處理;④實(shí)時(shí)處理;⑤多機(jī)通信;⑥人機(jī)對(duì)話。</p><p> 在中斷過程中,當(dāng)外部提出中斷請(qǐng)求后,CPU是否響應(yīng),或者存在多個(gè)中斷請(qǐng)求時(shí),CPU應(yīng)該首先響應(yīng)哪個(gè)中斷請(qǐng)求。這兩種情況決定
12、了中斷系統(tǒng)應(yīng)該具有相應(yīng)的優(yōu)先級(jí)判斷邏輯和優(yōu)先級(jí)動(dòng)態(tài)調(diào)整的手段。</p><p> 中斷方式由于其實(shí)質(zhì)上是通過執(zhí)行程序來進(jìn)行對(duì)事件的服務(wù)處理,處理程序可以根據(jù)需要進(jìn)行擴(kuò)展,使得程序中斷方式的處理能力很強(qiáng),可以處理復(fù)雜事態(tài)。而在實(shí)時(shí)控制系統(tǒng)中,許多實(shí)質(zhì)性的功能模塊就是以中斷處理程序形態(tài)實(shí)現(xiàn)的,而主控制程序僅僅是一個(gè)組織各個(gè)模塊的框架。正是由于這一原因,使得中斷控制方式在當(dāng)今的計(jì)算機(jī)系統(tǒng)中得到了極為廣泛的應(yīng)用。<
13、;/p><p> 1.2 國(guó)內(nèi)外研究現(xiàn)狀</p><p> 在微型計(jì)算機(jī)中,廣泛使用一種中斷控制器集成芯片,如Intel 8259A。它將中斷請(qǐng)求信號(hào)的寄存、匯集、屏蔽、排優(yōu)、編碼等邏輯集中在一塊芯片之中。在設(shè)計(jì)中斷系統(tǒng)時(shí),使用這種芯片就非常方便,不必了解芯片內(nèi)究竟使用何種具體的排優(yōu)邏輯。</p><p><b> 1.3 主要內(nèi)容</b>&
14、lt;/p><p> 本課題通過利用高級(jí)VC++語言,設(shè)計(jì)開發(fā)了一款中斷過程仿真軟件。其主要為了通過高級(jí)語言的仿真,將中斷過程利用動(dòng)態(tài)的界面形象地展現(xiàn)出來,從而更加深入地理解和體會(huì)中斷方式的處理過程。</p><p> 第二章 課程設(shè)計(jì)的需求分析</p><p><b> 2.1 環(huán)境需求</b></p><p>
15、PC機(jī)一臺(tái),裝有VS2010.</p><p><b> 2.2 功能需求</b></p><p> 能夠模擬中斷控制器中斷過程。</p><p><b> 2.3 性能需求</b></p><p><b> 設(shè)計(jì)中斷屏蔽。</b></p><p&g
16、t; 在短時(shí)間內(nèi)判斷是否響應(yīng)中斷。</p><p><b> 能夠進(jìn)行中斷判優(yōu)。</b></p><p><b> 2.3 本章小結(jié)</b></p><p> 本章說明了環(huán)境需求,功能需求,和性能需求。</p><p> 第三章 中斷控制器的設(shè)計(jì)</p><p>&
17、lt;b> 3.1 總體設(shè)計(jì)</b></p><p> 程序中斷方式(中斷方式)即是指:在計(jì)算機(jī)的運(yùn)行過程中,如果發(fā)生某種隨機(jī)事態(tài),CPU將暫停執(zhí)行現(xiàn)行的程序,轉(zhuǎn)去執(zhí)行中斷程序,為該隨機(jī)事態(tài)服務(wù),并在服務(wù)完畢后自動(dòng)回復(fù)原程序的執(zhí)行。中斷方式的過程具體如圖所示。由其本質(zhì)可以推知,中斷方式具有程序切換和隨機(jī)性兩大重要特征。</p><p><b> 中斷方式&
18、lt;/b></p><p> 3.2 功能模塊設(shè)計(jì)</p><p> 1.終端系統(tǒng)的組成:</p><p> 中斷系統(tǒng)即是與中斷功能有關(guān)的硬件、軟件的統(tǒng)稱。從硬件角度而言,在接口方面,中斷接口需要具有請(qǐng)求、傳遞、判優(yōu)邏輯。在CPU方面,需要有響應(yīng)中斷請(qǐng)求的響應(yīng)邏輯。而從軟件角度而言,需要有服務(wù)程序、以及管理中斷源的中斷向量表。并且,由于中斷請(qǐng)求出現(xiàn)的隨
19、機(jī)性,無法在主程序的預(yù)定位置進(jìn)行處理,需要獨(dú)立地編制中斷處理程序。通過這樣的軟件組織方法,中斷服務(wù)程序時(shí)獨(dú)立于主程序?qū)崿F(xiàn)編制的。在編制用戶主程序時(shí),只需要提供允許中的可能(如開中斷),不必細(xì)致考慮何時(shí)中斷、如何處理等問題,大大地簡(jiǎn)化了設(shè)計(jì)方式。一旦發(fā)生中斷請(qǐng)求,可以通過硬件中斷請(qǐng)求信號(hào)或軟中斷指令提供的中斷號(hào),轉(zhuǎn)化為向量地址,從中斷向量表中找到相應(yīng)的服務(wù)程序入口地址,從而轉(zhuǎn)入中斷服務(wù)程序執(zhí)行。</p><p>
20、 2. 中斷請(qǐng)求的提出與傳遞</p><p> 一個(gè)中斷請(qǐng)求的提出,需要同時(shí)具備以下兩種邏輯關(guān)系:</p><p> ①外部設(shè)備有中斷請(qǐng)求的需要。例如“準(zhǔn)備就緒”或者“完成了一次操作”,可以將完成狀態(tài)標(biāo)志位設(shè)置為1,表示外設(shè)工作完成,有中斷請(qǐng)求的需要。</p><p> ?、贑PU沒有對(duì)該中斷源屏蔽,允許提出中斷請(qǐng)求。在中斷控制器中,設(shè)置了對(duì)低優(yōu)先級(jí)中斷的屏蔽,
21、如中斷請(qǐng)求優(yōu)先級(jí)低于當(dāng)前正在執(zhí)行的任務(wù)的優(yōu)先級(jí),則該中斷會(huì)被屏蔽,不會(huì)被送往CPU,反之,則有中斷控制器發(fā)送一個(gè)公共的中斷請(qǐng)求信號(hào)INT,并將此信號(hào)送往CPU進(jìn)行下一步處理。</p><p> 使用中斷控制器的中斷系統(tǒng)中,中斷請(qǐng)求的傳遞采用公共請(qǐng)求線的結(jié)構(gòu),如圖2-2所示。由中斷控制器產(chǎn)生的中斷公共信號(hào)INT通過公共的請(qǐng)求線傳送給CPU。</p><p><b> 中斷請(qǐng)求傳
22、遞結(jié)構(gòu)</b></p><p><b> 3. 中斷判優(yōu)</b></p><p> 中斷的判優(yōu)主要有以下兩種情況: </p><p> ?、貱PU與中斷請(qǐng)求之間的判優(yōu)。第一種方法可以利用CPU的“允許中斷”標(biāo)志位的手段進(jìn)行CPU與中斷請(qǐng)求之間的判優(yōu)。CPU設(shè)置了一個(gè)“允許中斷”標(biāo)志位,指令系統(tǒng)提供開中斷與關(guān)中斷的功能,開中斷時(shí)標(biāo)
23、志位為1,關(guān)中斷時(shí)標(biāo)志位為0。如果關(guān)中斷,則CPU不響應(yīng)任何外中斷請(qǐng)求。反之,開中斷時(shí),可以響應(yīng)外部中斷請(qǐng)求。第二種方法則是通過CPU設(shè)置程序狀態(tài)字的優(yōu)先級(jí)字段,為現(xiàn)行的程序賦予優(yōu)先級(jí)。當(dāng)該優(yōu)先級(jí)低于中斷請(qǐng)求的優(yōu)先級(jí)時(shí),CPU響應(yīng)中斷請(qǐng)求;反之,如果該優(yōu)先級(jí)高于中斷請(qǐng)求的優(yōu)先級(jí),CPU不響應(yīng)中斷請(qǐng)求。</p><p> ②中斷請(qǐng)求之間的判優(yōu)。按請(qǐng)求的性質(zhì),一般的優(yōu)先順序?yàn)椋汗收弦l(fā)的中斷請(qǐng)求、DMA請(qǐng)求、外部設(shè)
24、備中斷請(qǐng)求。按中斷請(qǐng)求要求的數(shù)據(jù)傳送方向,一般的原則是讓輸入操作的請(qǐng)求優(yōu)先于輸出操作的請(qǐng)求。然而,在目前多數(shù)的計(jì)算機(jī)中,一方面采用硬件邏輯實(shí)現(xiàn)優(yōu)先級(jí)判別,如利用中斷控制器集中解決請(qǐng)求信號(hào)的接收、屏蔽、判優(yōu)、編碼等問題。另一方面,計(jì)算機(jī)又可以改用軟件查詢方式體現(xiàn)優(yōu)先級(jí)判別。這讓計(jì)算機(jī)可以動(dòng)態(tài)地調(diào)整優(yōu)先級(jí),使得中斷處理過程更加的靈活。</p><p><b> 4.中斷響應(yīng)</b></p
25、><p> 當(dāng)外設(shè)有中斷請(qǐng)求,并且沒有被屏蔽,CPU處于開中斷狀態(tài),一條指令(非停機(jī)指令)結(jié)束;沒有比該中斷請(qǐng)求優(yōu)先級(jí)更高的請(qǐng)求時(shí),CPU即可響應(yīng)該中斷請(qǐng)求。在CPU響應(yīng)中斷請(qǐng)求后,通過執(zhí)行中斷服務(wù)程序進(jìn)行中斷處理。服務(wù)程序?qū)崿F(xiàn)存放在主存中,為了轉(zhuǎn)向中斷服務(wù)程序,關(guān)鍵要獲得該服務(wù)程序的入口地址。獲得中斷服務(wù)程序的入口地址依照中斷方式的不同主要有以下兩種方法:</p><p><b>
26、; ①非向量中斷</b></p><p> 非向量中斷是指:CPU響應(yīng)中斷時(shí)只產(chǎn)生一個(gè)固定的地址,由此讀取中斷查詢程序的入口地址,然后轉(zhuǎn)向查詢程序并執(zhí)行;通過軟件查詢方式,確定被優(yōu)先批準(zhǔn)的中斷源,然后獲取與之對(duì)應(yīng)的中斷服務(wù)程序的入口地址,分支進(jìn)入相應(yīng)的中斷服務(wù)程序。</p><p><b> ?、谙蛄恐袛?lt;/b></p><p>
27、; 向量中斷是指:將各個(gè)中斷服務(wù)程序的入口地址(包括狀態(tài)字)組織成中斷向量表;響應(yīng)中斷時(shí),由硬件直接產(chǎn)生對(duì)應(yīng)于中斷源的向量地址;按該地址訪問中斷向量表,從中讀取服務(wù)程序的入口地址,并由此轉(zhuǎn)向服務(wù)程序。這種方式可以根據(jù)中斷請(qǐng)求信號(hào)快速地直接轉(zhuǎn)向?qū)?yīng)的中斷服務(wù)程序。</p><p> 在獲取了中斷服務(wù)程序的入口地址之后,CPU就可轉(zhuǎn)向程序運(yùn)行狀態(tài),以開始執(zhí)行中斷服務(wù)程序。整體的響應(yīng)過程如圖所示。</p>
28、;<p><b> 中斷響應(yīng)過程</b></p><p><b> 5. 中斷處理</b></p><p> 當(dāng)進(jìn)入中斷服務(wù)服務(wù)程序之后,CPU通過執(zhí)行程序,按照中斷請(qǐng)求的需要進(jìn)行相應(yīng)的處理。如保護(hù)現(xiàn)場(chǎng)、開/關(guān)中斷、多重中斷與單級(jí)中斷、恢復(fù)現(xiàn)場(chǎng)與返回等。</p><p> 對(duì)于單級(jí)中斷,CPU相應(yīng)后只
29、處理一個(gè)中斷源的請(qǐng)求,處理完畢后才能響應(yīng)新的中斷請(qǐng)求。而對(duì)于多重中斷,在某次中斷服務(wù)過程中,允許CPU響應(yīng)處理更高級(jí)別的中斷請(qǐng)求。它們的具體處理流程如圖所示。</p><p> 單級(jí)中斷處理流程 多重中斷處理流程</p><p><b> 3.3 本章小結(jié)</b></p><p> 本章介紹了中斷控制器的總體設(shè)計(jì)和各個(gè)功能模塊的
30、設(shè)計(jì)。</p><p> 第四章 中斷控制器的實(shí)現(xiàn)</p><p> 4.1 開發(fā)環(huán)境介紹</p><p> PC機(jī)一臺(tái),裝有VS2010。</p><p> 4.2 主要功能模塊的實(shí)現(xiàn)</p><p><b> 1.數(shù)據(jù)結(jié)構(gòu):</b></p><p><b
31、> (1)中斷開關(guān) </b></p><p><b> bool IF</b></p><p><b> (2)中斷請(qǐng)求信號(hào)</b></p><p> class INTR </p><p><b> {</b></p><p&g
32、t;<b> public:</b></p><p> string Source; 中斷源</p><p> int Time; 中斷執(zhí)行時(shí)間</p><p> int PRI; 中斷優(yōu)先級(jí)</p><p><b> }</b></p><p><b>
33、 2.中斷請(qǐng)求:</b></p><p> 中斷請(qǐng)求采用按鍵盤中斷的方式。</p><p><b> 3.中斷屏蔽</b></p><p> (1)判斷IF的值,IF為0時(shí)關(guān)中斷,IF為1時(shí)開中斷。只有在運(yùn)行系統(tǒng)時(shí)才允許開關(guān)中斷。</p><p> (2)比較當(dāng)前運(yùn)行程序與中斷請(qǐng)求優(yōu)先級(jí),如中斷請(qǐng)求
34、優(yōu)先級(jí)高于當(dāng)前程序,則執(zhí)行中斷程序,反之屏蔽中斷。</p><p><b> 4.代碼:</b></p><p><b> 主函數(shù):</b></p><p> int main()</p><p><b> {</b></p><p> sra
35、nd(time(0));</p><p> string c_in;</p><p><b> int n_in;</b></p><p> cout<<"************************************"<<endl;</p><p> cou
36、t<<endl<<" 開中斷在中斷源處輸入OPEN";</p><p> cout<<endl<<" 關(guān)中斷在中斷源處輸入CLOSE";</p><p> cout<<endl<<" (任意鍵繼續(xù))"<<endl<<endl;
37、</p><p> cout<<"************************************"<<endl;</p><p><b> getch();</b></p><p> system("cls");</p><p><b&
38、gt; while(1)</b></p><p><b> {</b></p><p> Display();</p><p> if(kbhit())</p><p><b> {</b></p><p> CleanKB();//用于清除鍵盤緩沖區(qū)
39、</p><p> cout<<"************************************"<<endl;</p><p> cout<<endl<<" 輸入中斷源和運(yùn)行時(shí)間"<<endl<<endl;</p><p> cout&
40、lt;<" 中斷源:";</p><p> cin>>c_in;</p><p><b> //開關(guān)中斷</b></p><p> if(c_in == "OPEN" || c_in == "CLOSE")</p><p><b&
41、gt; {</b></p><p> if(c_in == "OPEN")</p><p><b> {</b></p><p><b> IF = 1;</b></p><p> system("cls");</p>&l
42、t;p> cout<<"************************************"<<endl;</p><p> cout<<endl<<" 開中斷成功!"<<endl<<endl;</p><p> cout<<"*****
43、*******************************"<<endl;</p><p> Sleep(1000);</p><p> system("cls");</p><p><b> }</b></p><p><b> else</b>
44、;</p><p><b> {</b></p><p><b> IF = 0;</b></p><p> system("cls");</p><p> cout<<"************************************&qu
45、ot;<<endl;</p><p> cout<<endl<<" 關(guān)中斷成功!"<<endl<<endl;</p><p> cout<<"************************************"<<endl;</p><
46、p> Sleep(1000);</p><p> system("cls");</p><p><b> }</b></p><p><b> continue;</b></p><p><b> }</b></p><p
47、> cout<<" 運(yùn)行時(shí)間:";</p><p> cin>>n_in;</p><p><b> //判斷是否開中斷</b></p><p> if(IF == 0)</p><p><b> {</b></p><
48、;p> system("cls");</p><p> cout<<"************************************"<<endl;</p><p> cout<<endl<<" 系統(tǒng)為關(guān)中斷狀態(tài)!";</p><p>
49、 cout<<endl<<" 不能響應(yīng)中斷!"<<endl<<endl;</p><p> cout<<"************************************"<<endl;</p><p> Sleep(1000);</p><p
50、> system("cls");</p><p><b> continue;</b></p><p><b> }</b></p><p> //建立中斷請(qǐng)求信號(hào)</p><p> INTR t(c_in, n_in, RandInt(1,10));//隨機(jī)產(chǎn)生
51、1~10的優(yōu)先級(jí)</p><p> cout<<endl;</p><p> cout<<"************************************"<<endl;</p><p> Sleep(500);</p><p> system("cls&qu
52、ot;);</p><p><b> //中斷</b></p><p><b> Break(t);</b></p><p><b> }</b></p><p><b> }</b></p><p><b>
53、return 0;</b></p><p><b> }</b></p><p><b> 中斷函數(shù):</b></p><p> void Break(INTR &t)</p><p><b> {</b></p><p>
54、 string c_in;</p><p><b> int n_in;</b></p><p> cout<<"************************************"<<endl;</p><p> cout<<endl<<" 開始執(zhí)行中
55、斷程序"<<endl<<endl;</p><p> cout<<"************************************"<<endl;</p><p> Sleep(1000);</p><p> system("cls");</p&g
56、t;<p> for(; t.Time>0; t.Time--)</p><p><b> {</b></p><p> if(kbhit())</p><p><b> {</b></p><p> CleanKB();//用于清除鍵盤緩沖區(qū)</p>&
57、lt;p> //建立中斷請(qǐng)求信號(hào)</p><p> cout<<"************************************"<<endl;</p><p> cout<<endl<<" 輸入中斷源和運(yùn)行時(shí)間"<<endl<<endl;</p&g
58、t;<p> cout<<" 中斷源:";</p><p> cin>>c_in;</p><p> cout<<" 運(yùn)行時(shí)間:";</p><p> cin>>n_in;</p><p> cout<<endl;&
59、lt;/p><p> cout<<"************************************"<<endl;</p><p> Sleep(500);</p><p> system("cls");</p><p> INTR t2(c_in, n_in, R
60、andInt(1,10));//隨機(jī)產(chǎn)生1~10的優(yōu)先級(jí)</p><p><b> //中斷判優(yōu)</b></p><p> if(Higher(t2, t))</p><p><b> {</b></p><p><b> //執(zhí)行中斷</b></p>&
61、lt;p> Break(t2);</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> cout<<"***************************
62、*********"<<endl;</p><p> cout<<endl<<" 中斷程序優(yōu)先級(jí)低于當(dāng)前程序!";</p><p> cout<<endl<<" 不能響應(yīng)中斷!"<<endl<<endl;</p><p>
63、cout<<"************************************"<<endl;</p><p> Sleep(1000);</p><p> system("cls");</p><p><b> }</b></p><p>&
64、lt;b> }</b></p><p> cout<<"************************************"<<endl;</p><p> cout<<" 中斷程序正在執(zhí)行..."<<endl;</p><p> cout<
65、;<" (按任意鍵中斷)"<<endl;</p><p> cout<<" 中斷源: "<<t.Source<<endl<<" 剩余時(shí)間: "<<t.Time<<endl;</p><p> cout<<"
66、優(yōu)先級(jí):"<<t.PRI<<endl;</p><p> cout<<"************************************"<<endl;</p><p> Sleep(1000);</p><p> system("cls");</p
67、><p><b> }</b></p><p> cout<<"************************************"<<endl;</p><p> cout<<endl<<" 繼續(xù)執(zhí)行中斷前程序"<<endl<&
68、lt;endl;</p><p> cout<<"************************************"<<endl;</p><p> Sleep(1000);</p><p> system("cls");</p><p><b> }&
69、lt;/b></p><p><b> 中斷判優(yōu):</b></p><p> bool Higher(INTR &a, INTR &b)</p><p><b> {</b></p><p> return a.PRI > b.PRI;</p>&l
70、t;p><b> }</b></p><p><b> 工具函數(shù):</b></p><p> 用于產(chǎn)生i-j的隨機(jī)數(shù)。在隨機(jī)生成中斷優(yōu)先級(jí)時(shí)用到。</p><p> int RandInt(int i, int j)</p><p><b> {</b><
71、/p><p> return rand()%(j+i-1)+i;</p><p><b> }</b></p><p> 由于使用kbhit()函數(shù)判斷是否中斷,此用于清除鍵盤緩沖區(qū)。</p><p> void CleanKB()//用于清除鍵盤緩沖區(qū)</p><p><b>
72、{</b></p><p> while(kbhit())</p><p><b> getch();</b></p><p><b> }</b></p><p><b> 4.3 本章小結(jié)</b></p><p> 本章詳細(xì)介紹
73、了開發(fā)環(huán)境、中斷控制器的各個(gè)功能和詳細(xì)實(shí)現(xiàn)。</p><p> 第五章 測(cè)試及成果展示</p><p><b> 5.1 測(cè)試環(huán)境</b></p><p> PC機(jī)一臺(tái),裝有VS2010。</p><p> 5.2 測(cè)試用例和結(jié)果</p><p><b> 此時(shí)系統(tǒng)允許中斷。&
74、lt;/b></p><p><b> 測(cè)試關(guān)中斷功能:</b></p><p> 關(guān)中斷成功,此時(shí)IF為0,不能響應(yīng)中斷。</p><p><b> 開中斷:</b></p><p> 此時(shí)IF為1,可以響應(yīng)中斷。</p><p><b> 終端測(cè)
75、試:</b></p><p><b> 此時(shí)嘗試中斷。</b></p><p><b> 成功中斷。</b></p><p><b> 嘗試下一次中斷</b></p><p> 由于中斷優(yōu)先級(jí)低于正在執(zhí)行程序,所以中斷不能被響應(yīng)。</p>&l
76、t;p> 當(dāng)前中斷執(zhí)行完畢后,繼續(xù)執(zhí)行中斷前的程序,直到?jīng)]有中斷程序時(shí),回到系統(tǒng)。</p><p><b> 5.3 本章小結(jié)</b></p><p> 本章說明了測(cè)試環(huán)境,給出了測(cè)試用例和測(cè)試過程及結(jié)果。</p><p><b> 第六章 總結(jié)與展望</b></p><p> 過一
77、周的討論和設(shè)計(jì)工作,我們小組成功地完成了設(shè)計(jì)內(nèi)容,達(dá)到了設(shè)計(jì)目標(biāo)。</p><p> 在學(xué)習(xí)和設(shè)計(jì)的過程中,通過翻閱資料、文獻(xiàn),小組成員共同學(xué)習(xí),加深了對(duì)中斷處理技術(shù)的了解。同時(shí),我們還簡(jiǎn)略的討論了多種中斷控制處理方式,多方面的了解各種中斷方法。</p><p> 在課程設(shè)計(jì)的過程中,盡管在此之前,團(tuán)隊(duì)人員也進(jìn)行過項(xiàng)目的合作,具有一定的默契和經(jīng)驗(yàn),但仍然遇到了一定的困難。比如對(duì)中斷過程
78、的具體掌握理解不夠,導(dǎo)致很難寫項(xiàng)目設(shè)計(jì)要求。但是,通過團(tuán)隊(duì)其心協(xié)力的努力與隊(duì)長(zhǎng)的合理分工,我們經(jīng)過激烈的討論,逐漸地理解了中斷的處理過程,一步步地克服了困難,明確了設(shè)計(jì)目標(biāo)。</p><p> 在項(xiàng)目結(jié)束之際,我們抒發(fā)了自己在課設(shè)中的體會(huì),積累了很多對(duì)以后學(xué)習(xí)工作很有價(jià)值的經(jīng)驗(yàn)。</p><p><b> 參考文獻(xiàn)</b></p><p>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 《計(jì)算機(jī)組成原理》課程設(shè)計(jì)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)--計(jì)算機(jī)組成原理算法實(shí)現(xiàn)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)---模型機(jī)組成設(shè)計(jì)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)組成原理-課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)日志
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)組成原理課程設(shè)計(jì) (2)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)論文
- 計(jì)算機(jī)組成原理-課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)--基本模型計(jì)算機(jī)
- 計(jì)算機(jī)組成原理課程設(shè)計(jì)報(bào)告--簡(jiǎn)單計(jì)算機(jī)
評(píng)論
0/150
提交評(píng)論