計(jì)算機(jī)組成原理課程設(shè)計(jì)---簡(jiǎn)單計(jì)算機(jī)的設(shè)計(jì)_第1頁(yè)
已閱讀1頁(yè),還剩53頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  計(jì)算機(jī)組成原理課程設(shè)計(jì)</p><p><b>  (Ver 3.1)</b></p><p>  計(jì)算機(jī)科學(xué)與工程學(xué)院</p><p><b>  2007年7月</b></p><p>  1、課程設(shè)計(jì)目的2</p><p><b>  

2、2、儀器設(shè)備2</b></p><p>  3、基于微控器的模型機(jī)設(shè)計(jì)部分2</p><p>  3.1、設(shè)計(jì)步驟2</p><p>  3.2、準(zhǔn)備知識(shí)4</p><p>  3.3、設(shè)計(jì)內(nèi)容4</p><p>  題目一:設(shè)計(jì)一個(gè)具有帶進(jìn)位加法和立即數(shù)尋址方式的模型機(jī)4</p>

3、<p>  題目二:設(shè)計(jì)一個(gè)具有帶進(jìn)位加法和條件跳轉(zhuǎn)的模型機(jī)4</p><p>  題目三:設(shè)計(jì)一個(gè)具有循環(huán)左移功能的模型機(jī)4</p><p>  題目四:設(shè)計(jì)一個(gè)具有帶借位減法和存儲(chǔ)功能的模型機(jī)4</p><p>  4、可編程邏輯器件設(shè)計(jì)部分4</p><p>  4.1、設(shè)計(jì)步驟4</p><p

4、>  4.2、準(zhǔn)備知識(shí)4</p><p>  4.3、設(shè)計(jì)內(nèi)容4</p><p>  題目五:利用CPLD設(shè)計(jì)一個(gè)并行加法器4</p><p>  題目六:陣列乘法器設(shè)計(jì)4</p><p>  題目七:硬聯(lián)控制器設(shè)計(jì)4</p><p>  5、具有中斷處理功能的模型機(jī)設(shè)計(jì)4</p>&l

5、t;p>  5.1、設(shè)計(jì)內(nèi)容4</p><p>  5.2、準(zhǔn)備知識(shí)4</p><p>  5.3、設(shè)計(jì)步驟4</p><p>  6、課程設(shè)計(jì)任務(wù)及要求4</p><p><b>  7、考核辦法4</b></p><p><b>  8、參考資料4</b>

6、;</p><p><b>  9、附錄4</b></p><p>  附錄1(數(shù)據(jù)通路):4</p><p>  附錄2(系統(tǒng)連線(xiàn)參考圖)4</p><p>  附錄3(實(shí)驗(yàn)系統(tǒng)主要單元電路)4</p><p>  附錄4(ispDesignEXPERT軟件使用)4</p>

7、<p>  VIII.把設(shè)計(jì)適配到Lattice器件中4</p><p>  IX.層次化操作方法4</p><p>  《計(jì)算機(jī)組成原理》課程設(shè)計(jì)</p><p><b>  1、課程設(shè)計(jì)目的</b></p><p>  通過(guò)對(duì)一個(gè)簡(jiǎn)單計(jì)算機(jī)的設(shè)計(jì),對(duì)計(jì)算機(jī)的基本組成,部件的設(shè)計(jì)、部件間的連接、微程

8、序控制器的設(shè)計(jì)、微指令和微程序的編制與調(diào)試等過(guò)程有更深的了解,在此基礎(chǔ)上完成一臺(tái)基本計(jì)算機(jī)的組成設(shè)計(jì),從而加深對(duì)理論課程的理解,鍛煉學(xué)生的獨(dú)立思考和動(dòng)手能力。</p><p><b>  2、儀器設(shè)備</b></p><p>  硬件環(huán)境為PC-386以上微機(jī),西安唐都科教儀器公司的TDN-CM+計(jì)算機(jī)組成原理實(shí)驗(yàn)臺(tái)。軟件環(huán)境采用WINDOWS操作系統(tǒng),西安唐都科教儀

9、器公司的TDN-CM+計(jì)算機(jī)組成原理實(shí)驗(yàn)軟件。</p><p>  3、基于微控器的模型機(jī)設(shè)計(jì)部分</p><p><b>  3.1、設(shè)計(jì)步驟</b></p><p>  設(shè)計(jì)一臺(tái)完整的計(jì)算機(jī),大致需按如下的順序來(lái)考慮:</p><p><b>  確定設(shè)計(jì)目標(biāo)</b></p>&l

10、t;p>  確定所設(shè)計(jì)計(jì)算機(jī)的功能和用途。</p><p><b>  確定指令系統(tǒng)</b></p><p>  確定數(shù)據(jù)的表示格式、位數(shù)、指令的編碼、類(lèi)型、需要設(shè)計(jì)哪些指令及使用的尋址方式,并給出具體的編碼,比如指令的操作碼,地址碼等的位數(shù)及各種編碼的含義。</p><p>  確定總體結(jié)構(gòu)(寄存器、加法器、選擇器的設(shè)置與數(shù)據(jù)通路的設(shè)計(jì)

11、)</p><p>  總體結(jié)構(gòu)設(shè)計(jì)包含確定各部件設(shè)置以及它們之間的數(shù)據(jù)通路結(jié)構(gòu)。在此基礎(chǔ)上,就可以擬出各種信息傳輸路徑,以及實(shí)現(xiàn)這些傳輸所需要的微命令。</p><p>  對(duì)于部件設(shè)置,比如要確定運(yùn)算器部件采用什么結(jié)構(gòu),控制器是微程序控制還是硬聯(lián)控制等。</p><p>  綜合考慮計(jì)算機(jī)的速率、性能價(jià)格比、可靠性等要求,設(shè)計(jì)合理的數(shù)據(jù)通路結(jié)構(gòu),確定采用何種方案

12、的內(nèi)總線(xiàn)及外總線(xiàn)。數(shù)據(jù)通路不同,執(zhí)行指令所需要的操作就不同,計(jì)算機(jī)的結(jié)構(gòu)也就不一樣。</p><p><b>  設(shè)計(jì)指令執(zhí)行流程</b></p><p>  數(shù)據(jù)通路確定后,就可以設(shè)計(jì)指令系統(tǒng)中每條指令的執(zhí)行流程。</p><p>  根據(jù)指令的復(fù)雜程度,確定每條指令所需要的機(jī)器周期數(shù)。對(duì)于微程序控制的計(jì)算機(jī),根據(jù)總線(xiàn)結(jié)構(gòu),需考慮哪些微操作可

13、以安排在同一條微指令中,哪些微操作不能安排在同一條微指令中。</p><p><b>  確定微程序地址</b></p><p>  確定后續(xù)微地址的形成方法,確定每個(gè)微程序地址及分支轉(zhuǎn)移地址,畫(huà)出微程序流程圖。</p><p><b>  微指令代碼化</b></p><p>  根據(jù)微指令格式,

14、將微程序流程圖中的所有微指令代碼化。首先寫(xiě)出每個(gè)微地址以及該地址對(duì)應(yīng)的微指令代碼(共24位二進(jìn)制信息),如下表所示:</p><p>  然后將每個(gè)微地址和對(duì)應(yīng)的微指令轉(zhuǎn)換成16進(jìn)制,并寫(xiě)在一行,格式為:</p><p>  $M********,前面2個(gè)‘*’表示該微指令的在微控制器中的地址,后面6個(gè)‘*’表示該微指令代碼。如上述表中的四條微指令寫(xiě)成:</p><p&

15、gt;  $M00018110:表示在控制存儲(chǔ)器地址00h處的代碼是018110h。</p><p>  $M0101ED82:表示在控制存儲(chǔ)器地址01h處的代碼是01ED82h。</p><p>  $M0200C048:表示在控制存儲(chǔ)器地址02h處的代碼是00C048h。</p><p>  $M0300E004:表示在控制存儲(chǔ)器地址03h處的代碼是00E004

16、h。</p><p>  編寫(xiě)工作程序并代碼化</p><p>  編寫(xiě)測(cè)試用的工作程序(注:測(cè)試程序要能覆蓋設(shè)計(jì)的所有指令),并寫(xiě)出內(nèi)存映像,用二進(jìn)制表示。然后代碼化用16進(jìn)制來(lái)表示,格式為:$P****,前面2個(gè)‘*’表示該內(nèi)存的地址,后面2個(gè)‘*’表示該地址的數(shù)據(jù)。例如:</p><p>  $P0044:表示在內(nèi)存地址00h處的數(shù)據(jù)是44h。</p&g

17、t;<p>  $P0146:表示在內(nèi)存地址01h處的數(shù)據(jù)是46h。</p><p><b>  聯(lián)機(jī)操作文件的建立</b></p><p>  為了從PC機(jī)下載工作程序和微程序,需要建立聯(lián)機(jī)操作文件,該文件是普通的文本文件,擴(kuò)展名為T(mén)XT,可用記事本來(lái)建立的,要求:</p><p>  測(cè)試用的工作程序排在文件的前面,每個(gè)內(nèi)存地

18、址及代碼占一行;</p><p>  微指令代碼排在文件的后面,每個(gè)微地址及微指令代碼占一行;</p><p>  例如,下面是一個(gè)實(shí)驗(yàn)的文件(文件名:sample.txt):</p><p><b>  連接實(shí)驗(yàn)線(xiàn)路</b></p><p>  根據(jù)附錄2的線(xiàn)路圖連接模型機(jī)實(shí)驗(yàn)線(xiàn)路。</p><p&

19、gt;<b>  系統(tǒng)與PC機(jī)聯(lián)機(jī)</b></p><p>  實(shí)驗(yàn)系統(tǒng)安裝有一個(gè)標(biāo)準(zhǔn)的DB型9針RS-232C串口插座,使用配套的串行通信電纜分別插在實(shí)驗(yàn)系統(tǒng)及PC機(jī)的串口,即可實(shí)現(xiàn)系統(tǒng)與PC機(jī)的聯(lián)機(jī)操作。</p><p>  下載工作程序和微程序</p><p>  使用唐都軟件將工作程序和微程序下載到實(shí)驗(yàn)箱的內(nèi)存和控制存儲(chǔ)器中。其中,自帶

20、電源線(xiàn)的實(shí)驗(yàn)箱用NCMP53軟件,啟動(dòng)軟件后使用F4[裝載]進(jìn)行下載;外接電源線(xiàn)的實(shí)驗(yàn)箱用CMPP軟件,啟動(dòng)軟件后在菜單中選擇[轉(zhuǎn)儲(chǔ)]/[裝載]進(jìn)行下載。</p><p>  調(diào)試(調(diào)試時(shí)用的測(cè)試數(shù)據(jù)要包括普通數(shù)據(jù)及臨界點(diǎn)數(shù)據(jù))</p><p>  在總調(diào)試前,先按功能模塊進(jìn)行組裝和分調(diào),因?yàn)橹挥懈鞴δ苣K工作正常后,才能保證整機(jī)的正常運(yùn)行??梢允褂每刂婆_(tái)命令SWA、SWB的不同取值,或使

21、用聯(lián)機(jī)軟件檢查內(nèi)存程序是否正確,微程序是否正確。</p><p>  當(dāng)所有功能模塊都調(diào)試正常后,進(jìn)入總調(diào)試??梢允褂脝尾轿⒅噶罘绞綀?zhí)行工作程序,也可以直接使用連續(xù)方式執(zhí)行程序。在執(zhí)行過(guò)程中,可以通過(guò)聯(lián)機(jī)軟件的數(shù)據(jù)通路圖查看信息在計(jì)算機(jī)中的傳送路徑,更有利于掌握數(shù)據(jù)的通路結(jié)構(gòu)。這樣也可以直接驗(yàn)證程序和微程序的正確性。</p><p>  如果運(yùn)行結(jié)果不正確,需要返回來(lái)修改程序或微程序,每次

22、修改后,需要重新完成第11步,將程序和微程序下載到實(shí)驗(yàn)箱中。</p><p><b>  3.2、準(zhǔn)備知識(shí)</b></p><p>  微程序控制器的基本任務(wù)是完成當(dāng)前指令的翻譯和執(zhí)行,即將當(dāng)前指令的功能轉(zhuǎn)換成可以控制硬件邏輯部件工作的微命令序列,以完成數(shù)據(jù)傳輸和各種處理操作。它的執(zhí)行方法就是將控制各部件動(dòng)作的微命令的集合進(jìn)行編碼,即將微命令的集合仿照機(jī)器指令一樣,用

23、數(shù)字代碼的形式表示,這種表示稱(chēng)為微指令。這樣就可以用一個(gè)微指令序列表示一條機(jī)器指令,這種微指令序列稱(chēng)為微程序。微程序存儲(chǔ)在一種專(zhuān)用的存儲(chǔ)器中,該存儲(chǔ)器稱(chēng)為控制存儲(chǔ)器。</p><p> ?。?)TDN-CM+計(jì)算機(jī)組成原理實(shí)驗(yàn)臺(tái)主要單元電路見(jiàn)附錄三。</p><p>  (2)微程序控制電路</p><p>  微程序控制電路如圖1所示。其中控制存儲(chǔ)器采用3片281

24、6E2PROM,具有電保護(hù)功能,微命令寄存器18位,用兩片8D觸發(fā)器(273)和一片4D(175)觸發(fā)組成。微地址寄存器6位,用三片正沿觸發(fā)的雙D觸發(fā)器(74)組成,它們帶有清“0”端和預(yù)置端。在不判別測(cè)試的情況下,T2時(shí)刻打入微地址寄存器的內(nèi)容即為下一條微指令地址。當(dāng)T4時(shí)刻進(jìn)行測(cè)試判別時(shí),轉(zhuǎn)移邏輯滿(mǎn)足條件后輸出的負(fù)脈沖通過(guò)強(qiáng)制將某一觸發(fā)器置為“1”狀態(tài),完成地址修改。</p><p>  在該實(shí)驗(yàn)電路中設(shè)有一

25、個(gè)編程開(kāi)關(guān)(位于實(shí)驗(yàn)板右上方),它具有三種狀態(tài):PROM(編程)、READ(校驗(yàn))、RUN(運(yùn)行)。當(dāng)處于“編程狀態(tài)”時(shí),學(xué)生可根據(jù)微地址和微指令格式將微指令二進(jìn)制代碼寫(xiě)入到控制存儲(chǔ)器2816中。當(dāng)處于“校驗(yàn)狀態(tài)”時(shí)可以對(duì)寫(xiě)入控制存儲(chǔ)器中的二進(jìn)制代碼進(jìn)行驗(yàn)證,從而可以判斷寫(xiě)入的二進(jìn)制代碼是否正確。當(dāng)處于“運(yùn)行狀態(tài)”時(shí),只要給出微程序的入口微地址,則可根據(jù)微程序流程圖自動(dòng)執(zhí)行微程序。圖中微地址寄存器輸出端增加了一組三態(tài)門(mén),目的是隔離觸發(fā)器

26、的輸出,增加抗干擾能力,并用來(lái)驅(qū)動(dòng)微地址顯示燈。</p><p>  圖1:微程序控制電路</p><p><b> ?。?)微指令格式</b></p><p>  微指令字長(zhǎng)共24位,其控制位順序如下表所示:</p><p>  表中uA0~uA5為6位的下一條微指令的地址,A、B、C為3個(gè)譯碼字段,分別由三個(gè)控制位譯

27、碼出多位。C字段中的P(1)~P(4)是四個(gè)測(cè)試字位。其功能是根據(jù)機(jī)器指令及相應(yīng)微代碼進(jìn)行譯碼,使微程序轉(zhuǎn)入相應(yīng)的微地址入口,從而實(shí)現(xiàn)微程序的順序、分支、循環(huán)運(yùn)行,其原理如圖2所示。圖中I7~I2為指令寄存器的7~2位輸出,SE5~SE1為微控器單元微地址鎖存器的強(qiáng)制端輸出。AR為算術(shù)運(yùn)算是否影響進(jìn)位及判零標(biāo)志控制位,其為零有效。B字段中的RS-B、R0-B、RI-B分別為源寄存器選通信號(hào)、目的寄存器選通信號(hào)及變址寄存器選通信號(hào),其功能

28、是根據(jù)機(jī)器指令進(jìn)行三個(gè)工作寄存器R0、R1及R2的選通譯碼,其原理圖如圖3所示,圖中I0~I3為指令積存器的第0~3位,LDRi為打入工作寄存器信號(hào)的譯碼器使能控制位。</p><p><b>  圖2:指令譯碼電路</b></p><p><b>  圖3: 寄存器譯碼</b></p><p><b> ?。?

29、)控制臺(tái)</b></p><p>  為了向RAM中裝入程序和數(shù)據(jù),檢查寫(xiě)入是否正確,并能啟動(dòng)程序執(zhí)行,還必須設(shè)計(jì)三個(gè)控制臺(tái)操作微程序。</p><p>  存儲(chǔ)器讀操作(KRD):撥動(dòng)總清開(kāi)關(guān)CLR后,控制臺(tái)開(kāi)關(guān)SWB、SWA為"00"時(shí),按START微動(dòng)開(kāi)關(guān),可對(duì)RAM連續(xù)手動(dòng)讀操作。</p><p>  存儲(chǔ)器寫(xiě)操作(KDE):

30、撥動(dòng)總清開(kāi)關(guān)CLR后,控制臺(tái)開(kāi)關(guān)SWB、SWA置為"01"時(shí),按START微動(dòng)開(kāi)關(guān)可對(duì)RAM進(jìn)行連續(xù)手動(dòng)寫(xiě)入。</p><p>  啟動(dòng)程序:撥動(dòng)總清開(kāi)關(guān)CLR后,控制臺(tái)開(kāi)關(guān)SWB、SWA置為"1l"時(shí),按START微動(dòng)開(kāi)關(guān),即可轉(zhuǎn)入到第01號(hào)“取址”微指令,啟動(dòng)程序運(yùn)行。</p><p>  上述三條控制臺(tái)指令用兩個(gè)開(kāi)關(guān)SWB、SWA的狀態(tài)來(lái)設(shè)置,

31、其定義如下:</p><p>  控制臺(tái)操作微程序如圖4所示:</p><p>  控制臺(tái)操作為P(4)測(cè)試,它以控制臺(tái)開(kāi)關(guān)SWB、SWA作為測(cè)試條件,出現(xiàn)了三路分支,占用三個(gè)固定微地址單元。當(dāng)分支微地址單元固定后,剩下的其他單元就可以一條微指令占用控制存儲(chǔ)器一個(gè)微地址單元,其單元地址隨意填寫(xiě)。注意:微程序流程圖上的單元地址為八進(jìn)制。</p><p><b&g

32、t;  3.3、設(shè)計(jì)內(nèi)容</b></p><p>  題目一:設(shè)計(jì)一個(gè)具有帶進(jìn)位加法和立即數(shù)尋址方式的模型機(jī)</p><p><b>  1、設(shè)計(jì)內(nèi)容:</b></p><p>  設(shè)計(jì)一臺(tái)具有輸入、輸出、帶進(jìn)位加法、存儲(chǔ)和跳轉(zhuǎn)功能的模型計(jì)算機(jī),并寫(xiě)出工作程序和測(cè)試數(shù)據(jù)驗(yàn)證所設(shè)計(jì)的指令系統(tǒng)。</p><p>

33、<b>  2、設(shè)計(jì)要求</b></p><p>  所設(shè)計(jì)模型計(jì)算機(jī)的指令系統(tǒng)共包含五條機(jī)器指令:IN(輸入)、OUT(輸出)、ADC(帶進(jìn)位加法)、STA(存數(shù))、JMP(無(wú)條件轉(zhuǎn)移),加法指令的尋址方式為立即數(shù)尋址。其中IN指令為單字長(zhǎng)(8位),其余為雙字長(zhǎng)指令。使用R0寄存器作為工作寄存器。</p><p><b>  提示:</b>&l

34、t;/p><p>  模型機(jī)的指令系統(tǒng)及指令格式如下(前4位為操作碼):</p><p>  立即數(shù)在機(jī)器指令碼中以補(bǔ)碼形式出現(xiàn)。</p><p>  題目二:設(shè)計(jì)一個(gè)具有帶進(jìn)位加法和條件跳轉(zhuǎn)的模型機(jī)</p><p><b>  1、設(shè)計(jì)內(nèi)容</b></p><p>  設(shè)計(jì)一臺(tái)具有輸入、輸出、數(shù)據(jù)傳

35、送、帶進(jìn)位加法、條件跳轉(zhuǎn),停機(jī)功能的模型計(jì)算機(jī),并寫(xiě)出工作程序和測(cè)試程序驗(yàn)證所設(shè)計(jì)的指令系統(tǒng)。</p><p><b>  2、設(shè)計(jì)要求</b></p><p>  所設(shè)計(jì)模型計(jì)算機(jī)的指令系統(tǒng)共包含六條機(jī)器指令:IN(輸入)、ADC(帶進(jìn)位加法)、OUT(輸出)、BZC(條件轉(zhuǎn)移)、MOV(數(shù)據(jù)傳送)、HALT(停機(jī)),其中條件轉(zhuǎn)移指令的尋址方式為直接尋址,其余指令的

36、尋址方式為寄存器尋址。</p><p><b>  提示:</b></p><p>  模型機(jī)的指令系統(tǒng)及指令格式如下(前4位為操作碼):</p><p>  其中,rs為源寄存器,rd為目的寄存器,并規(guī)定:</p><p>  題目三:設(shè)計(jì)一個(gè)具有循環(huán)左移功能的模型機(jī)</p><p><

37、b>  1、設(shè)計(jì)內(nèi)容</b></p><p>  設(shè)計(jì)一臺(tái)具有輸入、輸出、數(shù)據(jù)傳送、帶進(jìn)位加法,循環(huán)左移、停機(jī)等功能的模型機(jī),并寫(xiě)出工作程序和測(cè)試程序驗(yàn)證所設(shè)計(jì)的指令系統(tǒng)。</p><p><b>  2、設(shè)計(jì)要求</b></p><p>  所設(shè)計(jì)模型計(jì)算機(jī)的指令系統(tǒng)共包含六條機(jī)器指令:IN(輸入)、ADC(帶進(jìn)位加法)、O

38、UT(輸出)、RLC(循環(huán)左移)、MOV(數(shù)據(jù)傳送)、HALT(停機(jī)),各條指令的尋址方式為寄存器尋址,且都為單字節(jié)指令。</p><p><b>  提示:</b></p><p>  本模型機(jī)中各條指令的格式和功能如下:</p><p>  其中,rs為源寄存器,rd為目的寄存器,并規(guī)定:</p><p>  題目四

39、:設(shè)計(jì)一個(gè)具有帶借位減法和存儲(chǔ)功能的模型機(jī)</p><p><b>  1、設(shè)計(jì)內(nèi)容</b></p><p>  設(shè)計(jì)一臺(tái)具有輸入、輸出、數(shù)據(jù)傳送、帶進(jìn)位減法,存數(shù)、取數(shù)等功能的模型機(jī),并寫(xiě)出工作程序和測(cè)試程序驗(yàn)證所設(shè)計(jì)的指令系統(tǒng)。</p><p><b>  2、設(shè)計(jì)要求</b></p><p>

40、  所設(shè)計(jì)模型計(jì)算機(jī)的指令系統(tǒng)共包含六條機(jī)器指令:IN(輸入)、OUT(輸出)、SBC(帶借位減法)、LDA(取數(shù))、STA(存數(shù))、MOV(數(shù)據(jù)傳送),其中存數(shù)、取數(shù)指令的尋址方式為間接尋址。</p><p><b>  提示:</b></p><p>  本模型機(jī)中各條指令的格式和功能如下:</p><p>  其中,rs為源寄存器,rd為

41、目的寄存器,并規(guī)定:</p><p>  4、可編程邏輯器件設(shè)計(jì)部分</p><p><b>  4.1、設(shè)計(jì)步驟</b></p><p>  采用ispDesignEXPERT軟件來(lái)對(duì)可編程邏輯器件進(jìn)行編程設(shè)計(jì)實(shí)現(xiàn)所需的數(shù)字系統(tǒng)功能一般要經(jīng)過(guò)如下步驟:</p><p><b>  建立新工程</b>

42、;</p><p>  輸入原理圖或硬件描述語(yǔ)言進(jìn)行設(shè)計(jì)</p><p><b>  對(duì)源程序進(jìn)行編譯</b></p><p><b>  連接下載電纜</b></p><p>  將生成的JED文件下載到可編程邏輯器件中</p><p><b>  連接實(shí)驗(yàn)電路&

43、lt;/b></p><p>  在實(shí)驗(yàn)板上驗(yàn)證所設(shè)計(jì)系統(tǒng)的邏輯功能</p><p><b>  4.2、準(zhǔn)備知識(shí)</b></p><p>  PLD是可編程邏輯器件(ProgramableLogicDevice)的簡(jiǎn)稱(chēng),PLD是電子設(shè)計(jì)領(lǐng)域中最具活力和發(fā)展前途的一項(xiàng)技術(shù),它的影響絲毫不亞于70年代單片機(jī)的發(fā)明和使用。PLD能做什么呢?可

44、以毫不夸張的講,PLD能完成任何數(shù)字器件的功能,上至高性能CPU,下至簡(jiǎn)單的74電路,都可以用PLD來(lái)實(shí)現(xiàn)。PLD如同一張白紙或是一堆積木,工程師可以通過(guò)傳統(tǒng)的原理圖輸入法,或是硬件描述語(yǔ)言自由的設(shè)計(jì)一個(gè)數(shù)字系統(tǒng)。通過(guò)軟件仿真,我們可以事先驗(yàn)證設(shè)計(jì)的正確性。在PCB完成以后,還可以利用PLD的在線(xiàn)修改能力,隨時(shí)修改設(shè)計(jì)而不必改動(dòng)硬件電路。使用PLD來(lái)開(kāi)發(fā)數(shù)字電路,可以大大縮短設(shè)計(jì)時(shí)間,減少PCB面積,提高系統(tǒng)的可靠性。PLD的這些優(yōu)點(diǎn)使

45、得PLD技術(shù)在90年代以后得到飛速的發(fā)展,同時(shí)也大大推動(dòng)了EDA軟件和硬件描述語(yǔ)言(HDL)的進(jìn)步。當(dāng)前應(yīng)用廣泛的有復(fù)雜可編程邏輯器件(CPLD)和現(xiàn)場(chǎng)可編程門(mén)陣列(FPGA)等。</p><p>  目前有多家公司生產(chǎn)CPLD/FPGA,最大的三家是:ALTERA,XILINX,Lattice。許多PLD公司都還提供免費(fèi)試用軟件,如Altera公司的Maxplus2(Baseline版或E+MAX版),Xili

46、nx公司的WebPack,Lattice的ispDesignEXPERT等。</p><p>  實(shí)驗(yàn)系統(tǒng)中采用的器件是Lattice公司的ispLSI1032芯片,isp芯片具有“在系統(tǒng)可編程功能”,這種功能可隨時(shí)對(duì)系統(tǒng)進(jìn)行邏輯重構(gòu)和修改,而且只需要一條簡(jiǎn)單的編程電纜和一臺(tái)PC機(jī)就可以完成器件大編程。</p><p>  IspLSI1032芯片的等效邏輯門(mén)為6000門(mén),具有128個(gè)宏單

47、元,192個(gè)觸發(fā)器和`64個(gè)鎖存器,共有84個(gè)引腳,ispLSI1032芯片的結(jié)構(gòu)圖如圖5所示。</p><p>  圖5ispLSI1032芯片結(jié)構(gòu)圖</p><p>  對(duì)該器件的邏輯系統(tǒng)設(shè)計(jì)是通過(guò)使用硬件描述語(yǔ)言或原理圖輸入來(lái)實(shí)現(xiàn)的,硬件描述語(yǔ)言有ABEL、VHDL等多種語(yǔ)言。</p><p>  實(shí)驗(yàn)系統(tǒng)中可采用ispDesignEXPERT軟件來(lái)對(duì)可編程邏

48、輯器件ispLS1032進(jìn)行編程設(shè)計(jì)實(shí)現(xiàn)。IspDesignEXPERT可采用原理圖或硬件描述語(yǔ)言或這兩種方法的混合輸入共三種方式來(lái)進(jìn)行設(shè)計(jì)輸入,并能對(duì)所設(shè)計(jì)的數(shù)字電子系統(tǒng)進(jìn)行功能仿真和時(shí)序仿真。其編譯器是此次軟件所需要的熔絲圖文件。該軟件支持所有Lattice公司的ispLSI器件。</p><p>  下載電纜的連接方法如下:</p><p>  在打開(kāi)PC機(jī)和實(shí)驗(yàn)系統(tǒng)的電源之前,將下

49、載電纜的一端與PC機(jī)的并行口相連,另一端與TDN-CM+系統(tǒng)的ispLSI1032器件的編程接口相連。</p><p>  ispDesignEXPERT軟件的使用見(jiàn)附錄4。</p><p><b>  4.3、設(shè)計(jì)內(nèi)容</b></p><p>  題目五:利用CPLD設(shè)計(jì)一個(gè)并行加法器</p><p><b>

50、;  1、設(shè)計(jì)內(nèi)容</b></p><p>  使用大規(guī)模可編程邏輯器件CPLD設(shè)計(jì)實(shí)現(xiàn)一個(gè)4位并行進(jìn)位加法器,并驗(yàn)證設(shè)計(jì)的正確性。</p><p><b>  2、設(shè)計(jì)要求</b></p><p>  采用ispDesignEXPERT軟件來(lái)對(duì)可編程邏輯器件ispLSI1032進(jìn)行編程設(shè)計(jì),要求用原理圖輸入方式來(lái)進(jìn)行設(shè)計(jì)輸入,并對(duì)

51、所設(shè)計(jì)的加法器進(jìn)行功能和時(shí)序仿真,最后在西安唐都科教儀器公司的TDCM+計(jì)算機(jī)組成原理實(shí)驗(yàn)臺(tái)上驗(yàn)證所設(shè)計(jì)器件的邏輯功能。</p><p><b>  提示:</b></p><p>  在實(shí)驗(yàn)臺(tái)上進(jìn)行邏輯功能驗(yàn)證時(shí),可以借助使用INPUTDEVICE單元輸入加數(shù)和被加數(shù),進(jìn)位輸入可由SWITCHUNIT單元的一個(gè)開(kāi)關(guān)來(lái)給出,可用總線(xiàn)單元的發(fā)光二極管來(lái)顯示運(yùn)算結(jié)果。&l

52、t;/p><p>  題目六:陣列乘法器設(shè)計(jì)</p><p><b>  1、設(shè)計(jì)內(nèi)容</b></p><p>  使用大規(guī)??删幊踢壿嬈骷﨏PLD設(shè)計(jì)實(shí)現(xiàn)一個(gè)4*4位不帶符號(hào)乘法器,并驗(yàn)證設(shè)計(jì)的正確性。</p><p><b>  2、設(shè)計(jì)要求</b></p><p>  采用

53、ispDesignEXPERT軟件來(lái)對(duì)可編程邏輯器件ispLSI1032進(jìn)行編程設(shè)計(jì),要求用VHDL語(yǔ)言編寫(xiě)功能描述程序,并對(duì)所設(shè)計(jì)的乘法器進(jìn)行功能和時(shí)序仿真,最后在西安唐都科教儀器公司的TDCM+計(jì)算機(jī)組成原理實(shí)驗(yàn)臺(tái)上驗(yàn)證所設(shè)計(jì)器件的邏輯功能。</p><p><b>  提示:</b></p><p>  對(duì)于一個(gè)4*4位二進(jìn)制數(shù)相乘,有如下算式:</p&g

54、t;<p>  在實(shí)驗(yàn)臺(tái)上進(jìn)行邏輯功能驗(yàn)證時(shí),可以借助使用INPUTDEVICE單元輸入乘數(shù)和被乘數(shù),而相乘的結(jié)果可在OUTPUTDEVICE單元中的數(shù)碼管中以十六進(jìn)制形式顯示。</p><p>  題目七:硬聯(lián)控制器設(shè)計(jì)</p><p><b>  1、設(shè)計(jì)內(nèi)容</b></p><p>  使用大規(guī)??删幊踢壿嬈骷﨏PLD設(shè)計(jì)一

55、個(gè)簡(jiǎn)單的硬聯(lián)控制器,實(shí)現(xiàn)下面表中三條指令,用開(kāi)關(guān)置不同的指令,觸發(fā)時(shí)序,就可以實(shí)現(xiàn)不同的指令操作。</p><p><b>  2、設(shè)計(jì)要求</b></p><p>  采用ispDesignEXPERT軟件來(lái)對(duì)可編程邏輯器件ispLSI1032進(jìn)行編程設(shè)計(jì),要求用VHDL語(yǔ)言編寫(xiě)程序,并在西安唐都科教儀器公司的TDCM+計(jì)算機(jī)組成原理實(shí)驗(yàn)臺(tái)上驗(yàn)證所設(shè)計(jì)器件的邏輯功能

56、。</p><p><b>  提示:</b></p><p>  用CPLD設(shè)計(jì)此控制邏輯的功能描述,各控制信號(hào)在ispLSI1032中對(duì)應(yīng)的引腳可參考如下:</p><p>  有三個(gè)部件需要控制:ALU、INPUTDEVICE和OUTPUTDEVICE。它們的控制信號(hào)由指令碼I1、I0和時(shí)序信號(hào)T4、T3、T2、T1組合產(chǎn)生。編程所實(shí)現(xiàn)的

57、功能就是根據(jù)這些輸入信號(hào)產(chǎn)生實(shí)現(xiàn)不同的指令時(shí)這三個(gè)部件所需要的控制信號(hào)。</p><p>  下面連線(xiàn)圖可供參考:</p><p>  5、具有中斷處理功能的模型機(jī)設(shè)計(jì)</p><p><b>  5.1、設(shè)計(jì)內(nèi)容</b></p><p>  在構(gòu)成一臺(tái)完整模型機(jī)的基礎(chǔ)上,外擴(kuò)一片8259接口芯片,完成中斷處理功能。要求

58、本模型機(jī)設(shè)計(jì)九條基本指令及三個(gè)控制臺(tái)操作指令,各條指令的格式和功能如下:</p><p>  其中D為立即數(shù),P為外設(shè)的端口地址:RS為源寄存器,RD為目的寄存器,并規(guī)定如下:</p><p>  三個(gè)控制臺(tái)指令用兩個(gè)開(kāi)關(guān)SWA、SWB的狀態(tài)來(lái)設(shè)置,定義如下:</p><p><b>  5.2、準(zhǔn)備知識(shí)</b></p><

59、p>  8259芯片引腳分配如下圖所示:</p><p>  D7-D0為雙向三態(tài)數(shù)據(jù)線(xiàn)。</p><p><b>  為片選信號(hào)線(xiàn)。</b></p><p>  A0用來(lái)選擇芯片內(nèi)部不同的寄存器,通常接至地址總線(xiàn)的A0。</p><p>  為讀信號(hào)線(xiàn),為低電平有效,當(dāng)其有效時(shí),控制信息從8259芯片讀至CPU。

60、</p><p>  為寫(xiě)信號(hào)線(xiàn),為低電平有效,當(dāng)其有效時(shí),控制信息從CPU寫(xiě)入至8259芯片。</p><p>  /用來(lái)從程序/允許緩沖。</p><p><b>  為中斷響應(yīng)輸入。</b></p><p><b>  INT為中斷輸出。</b></p><p>  I

61、R0-IR7為八條外界中斷請(qǐng)求輸入線(xiàn)。</p><p>  CAS2-CAS0為級(jí)連信號(hào)線(xiàn)</p><p>  、A0、、、D4、D3位的電平與8259芯片的操作關(guān)系如下表所示。</p><p><b>  提示:</b></p><p>  根據(jù)指令系統(tǒng)要求,設(shè)計(jì)微程序流程及確定微地址,可參考下圖所示:</p&g

62、t;<p>  本設(shè)計(jì)需要端點(diǎn)保護(hù),需設(shè)置一個(gè)堆棧,可設(shè)R2寄存器專(zhuān)門(mén)做堆棧指針。</p><p>  設(shè)計(jì)中CPU還需要一個(gè)INTA信號(hào)、ICF指令執(zhí)行完成標(biāo)志,可以由微代碼中的M23、M24位來(lái)定義。將ALU的控制信號(hào)S3、S2、S1、S0簡(jiǎn)化為只有S1、S0控制,而ALU單元的S3、S2、S1、S0均由CPLD輸出。LDDR2控制信號(hào)也簡(jiǎn)化掉。這樣,微指令格式可按下表所示設(shè)計(jì)。其中,M24為I

63、CF標(biāo)志,M23為INTA信號(hào),其為高電平有效,A字段原來(lái)的LDDR2由LDR2代替,R2-B代替B字段原RI-B。</p><p><b>  </b></p><p>  本設(shè)計(jì)還要增加中斷響應(yīng),所以指令譯碼電路需重新設(shè)計(jì)。它們?nèi)坑靡黄珻PLD芯片描述。相應(yīng)的原理圖如下所示:</p><p><b>  指令譯碼電路</

64、b></p><p><b>  寄存器譯碼</b></p><p>  其中指令譯碼電路全由CPLD來(lái)描述。而寄存器譯碼是在LOGUNIT單元的譯碼電路的基礎(chǔ)上,增加一個(gè)或門(mén),即LOGUNIT單元輸出的LDR2和微代碼的LDR2(原微代碼A字段的LDDR2位)相或后的輸出LDR2,這個(gè)或門(mén)是由CPLD描述的。</p><p><b

65、>  5.3、設(shè)計(jì)步驟</b></p><p>  用ABEL語(yǔ)言編寫(xiě)上述設(shè)計(jì)的中斷響應(yīng)及指令譯碼電路邏輯,其在CPLD的1032芯片中的相應(yīng)引腳分配可參考下圖。</p><p>  參考接線(xiàn)圖如下圖所示。接至SWITCHUNIT單元的SWB開(kāi)關(guān)為中斷請(qǐng)求信號(hào),為高電平有效。</p><p>  根據(jù)微指令格式,參照微程序流程圖,將每條微指令代碼化

66、,并編寫(xiě)一段機(jī)器指令。</p><p>  裝入機(jī)器指令及微程序,運(yùn)行程序,檢驗(yàn)所設(shè)計(jì)的中斷控制及指令系統(tǒng)。</p><p>  6、課程設(shè)計(jì)任務(wù)及要求</p><p>  1、任務(wù):在一周內(nèi)必須完成一道模型機(jī)部分題目和一道可編程邏輯器件設(shè)計(jì)題目。</p><p><b>  2、要求:</b></p>&

67、lt;p>  同學(xué)們?cè)趯?shí)驗(yàn)前應(yīng)該認(rèn)真準(zhǔn)備實(shí)驗(yàn)。</p><p>  每個(gè)題目完成后,回答實(shí)驗(yàn)指導(dǎo)老師的提問(wèn),由教師記錄完成情況。</p><p>  周末提交課程設(shè)計(jì)報(bào)告書(shū),主要根據(jù)設(shè)計(jì)步驟的要求,寫(xiě)出每一步驟的結(jié)果。</p><p><b>  7、考核辦法</b></p><p>  課程設(shè)計(jì)成績(jī)?cè)u(píng)定的依據(jù)有課

68、程設(shè)計(jì)報(bào)告書(shū)、具體完成情況、答辯情況及課程設(shè)計(jì)考勤登記表。</p><p>  具體評(píng)分細(xì)則為:參加實(shí)驗(yàn):1分</p><p>  完成所要求的設(shè)計(jì)1分</p><p>  正確進(jìn)行操作并回答問(wèn)題1.5分</p><p>  課程設(shè)計(jì)報(bào)告書(shū):1.5分</p><p>  實(shí)驗(yàn)結(jié)束由實(shí)驗(yàn)指導(dǎo)教師根據(jù)實(shí)驗(yàn)記錄,算出成績(jī)。&

69、lt;/p><p>  4.8分~5.5分及格</p><p>  5.6分~6.3分中等</p><p>  6.4分~7.1分良好</p><p><b>  7.2分以上優(yōu)秀</b></p><p><b>  8、參考資料</b></p><p>

70、  1、計(jì)算機(jī)組成與結(jié)構(gòu)(第3阪)王愛(ài)英主編清華大學(xué)出版社</p><p>  2、計(jì)算機(jī)組成原理上機(jī)實(shí)驗(yàn)指導(dǎo)書(shū)重慶工學(xué)院</p><p><b>  3、</b></p><p><b>  9、附錄</b></p><p>  附錄1(數(shù)據(jù)通路):</p><p>  附

71、錄2(系統(tǒng)連線(xiàn)參考圖)</p><p>  附錄3(實(shí)驗(yàn)系統(tǒng)主要單元電路)</p><p>  圖中虛線(xiàn)框內(nèi)的線(xiàn)已在線(xiàn)路板上連好,虛線(xiàn)框上的信號(hào)線(xiàn)為引出線(xiàn),在裝置中可找到相應(yīng)的絲印字。</p><p><b>  運(yùn)算單元電路</b></p><p><b>  寄存器堆單元電路</b></p

72、><p><b>  移位控制電路</b></p><p>  程序計(jì)數(shù)器與地址寄存器單元</p><p><b>  指令寄存器單元</b></p><p><b>  時(shí)序單元電路</b></p><p><b>  主存儲(chǔ)器單元</b&

73、gt;</p><p><b>  總線(xiàn)單元</b></p><p>  附錄4(ispDesignEXPERT軟件使用)</p><p>  1.ispDesignEXPERTSystem的原理圖輸入</p><p>  啟動(dòng)ispDesignExpertSystem(按Start=>Programs=>L

74、atticeSemiconductor=>ispDesignEXPERTSystem菜單)</p><p>  創(chuàng)建一個(gè)新的設(shè)計(jì)項(xiàng)目</p><p><b>  選擇菜單File。</b></p><p>  選擇NewProject...。</p><p>  鍵入項(xiàng)目名c:\user\demo.syn。<

75、/p><p>  你可以看到默的項(xiàng)目名和器件型號(hào):</p><p>  UntitledandispLSI5384V-125LB388。</p><p><b>  項(xiàng)目命名</b></p><p>  用鼠標(biāo)雙擊Untitled。</p><p>  在Title文本框中輸入“DemoProject

76、”,并選OK。</p><p><b>  選擇器件</b></p><p>  雙擊ispLSIispLSI5384V-125LB388,你會(huì)看到ChooseDevice對(duì)話(huà)框(如下圖所示)。</p><p>  在ChooseDevice窗口中選擇ispLSI1000項(xiàng)。</p><p>  按動(dòng)器件目錄中的滾動(dòng)條,

77、直到找到并選中器件</p><p>  ispLSI1032E-70LJ84。</p><p>  撳OK按鈕,選擇這個(gè)器件。</p><p>  在設(shè)計(jì)中增加源文件一個(gè)設(shè)計(jì)項(xiàng)目由一個(gè)或多個(gè)源文件組成。這些源文件可以是原理圖文件(*.sch)、ABELHD文件(*.abl)、VHDL設(shè)計(jì)文件(*.vhd)、VerilogHDL設(shè)計(jì)文件(*.v)、測(cè)試向量文件(*.

78、abv)或者是文字文件(*.doc,*.wri,*.txt)。在以下操作步驟中,你要在設(shè)計(jì)項(xiàng)目中添加一張空白的原理圖紙。</p><p>  從菜單上選擇Source項(xiàng)。</p><p><b>  選擇New...。</b></p><p>  在對(duì)話(huà)框中,選擇Schematic(原理圖),并按OK。</p><p>

79、  選擇路徑:c:\user并輸入文件名demo.sch。</p><p><b>  確認(rèn)后撳OK。</b></p><p>  原理圖輸入你現(xiàn)在應(yīng)該進(jìn)入原理圖編輯器。在下面的步驟中,你將要在原理圖中畫(huà)上幾個(gè)元件符號(hào),并用引線(xiàn)將它們相互連接起來(lái)。</p><p>  從菜單欄選擇Add,然后選擇Symbol,你會(huì)看到如下圖所示的對(duì)話(huà)框:&l

80、t;/p><p>  選擇GATES.LIB庫(kù),然后選擇G_2AND元件符號(hào)。</p><p>  將鼠標(biāo)移回到原理圖紙上,注意此刻AND門(mén)粘連在你的光標(biāo)上,并隨之移動(dòng)。</p><p>  單擊鼠標(biāo)左鍵,將符號(hào)放置在合適的位置。</p><p>  再在第一個(gè)AND門(mén)下面放置另外一個(gè)AND門(mén)。</p><p>  將鼠標(biāo)

81、移回到元件庫(kù)的對(duì)話(huà)框,并選擇G_2OR元件。</p><p>  將OR門(mén)放置在兩個(gè)AND門(mén)的右邊。</p><p>  現(xiàn)在選擇Add菜單中的Wire項(xiàng)。</p><p>  單擊上面一個(gè)AND門(mén)的輸出引腳,并開(kāi)始畫(huà)引線(xiàn)。</p><p>  隨后每次單擊鼠標(biāo),便可彎折引線(xiàn)(雙擊便終止連線(xiàn))。</p><p>  將

82、引線(xiàn)連到OR門(mén)的一個(gè)輸入腳。</p><p>  重復(fù)上述步驟,連接下面一個(gè)AND門(mén)。</p><p>  添加更多的元件符號(hào)和連線(xiàn)</p><p>  采用上述步驟,從REGS.LIB庫(kù)中選一個(gè)g_d寄存器,并從IOPADS.LIB庫(kù)中選擇G_OUTPUT符號(hào)。</p><p>  將它們互相連接,實(shí)現(xiàn)如下的原理圖:</p>

83、<p><b>  完成你的設(shè)計(jì)</b></p><p>  在這一節(jié),通過(guò)為連線(xiàn)命名和標(biāo)注I/OMarkers來(lái)完成原理圖。</p><p>  當(dāng)要為連線(xiàn)加信號(hào)名稱(chēng)時(shí),你可以使用ispDesignEXPERT的特點(diǎn),同時(shí)完成兩件事-----同時(shí)添加連線(xiàn)和連線(xiàn)的信號(hào)名稱(chēng)。這是一個(gè)很有用的特點(diǎn),可以節(jié)省設(shè)計(jì)時(shí)間。I/OMarkers是特殊的元件符號(hào),它指明了

84、進(jìn)入或離開(kāi)這張?jiān)韴D的信號(hào)名稱(chēng)。注意連線(xiàn)不能被懸空(dangling),它們必需連接到I/OMarker或邏輯符號(hào)上。這些標(biāo)記采用與之相連的連線(xiàn)的名字,與I/OPad符號(hào)不同,將在下面定義屬性(AddAttributes)的步驟中詳細(xì)解釋。</p><p>  為了完成這個(gè)設(shè)計(jì),選擇Add菜單中的NetName項(xiàng)。</p><p>  屏幕底下的狀態(tài)欄將要提示你輸入的連線(xiàn)名,輸入‘A’并按

85、Enter鍵,連線(xiàn)名會(huì)粘連在鼠標(biāo)的光標(biāo)上。</p><p>  將光標(biāo)移到最上面的與門(mén)輸入端,并在引線(xiàn)的末連接端(也即輸入腳左端的紅色方塊),按鼠標(biāo)左鍵,并向左邊拖動(dòng)鼠標(biāo)。這可以在放置連線(xiàn)名稱(chēng)的同時(shí),畫(huà)出一根輸入連線(xiàn)。</p><p>  輸入信號(hào)名稱(chēng)現(xiàn)在應(yīng)該是加注到引線(xiàn)的末端。</p><p>  重復(fù)這一步驟,直至加上全部的輸入‘B’,’C’,’D’和‘CK’,

86、以及輸出‘OUT’。</p><p>  現(xiàn)在A(yíng)dd菜單的I/OMarker項(xiàng)。</p><p>  將會(huì)出現(xiàn)一個(gè)對(duì)話(huà)框,請(qǐng)選擇Input。</p><p>  將鼠標(biāo)的光標(biāo)移至輸入連線(xiàn)的末端(位于連線(xiàn)和連線(xiàn)名之間),并單擊鼠標(biāo)的左鍵。這時(shí)回出現(xiàn)一個(gè)輸入I/OMarker,標(biāo)記里面是連線(xiàn)名。</p><p>  鼠標(biāo)移至下一個(gè)輸入,重復(fù)上述步

87、驟,直至所有的輸入都有I/OMarker。</p><p>  現(xiàn)在請(qǐng)?jiān)趯?duì)話(huà)框中選擇Output,然后單擊輸出連線(xiàn)端,加上一個(gè)輸出I/OMarker。</p><p>  至此原理圖就基本完成,它應(yīng)該如下圖所示。</p><p>  定義ispLSI器件的屬性(Attributes)你可以為任何一個(gè)元件符號(hào)或連線(xiàn)定義屬性。在這個(gè)例子中,你可以為輸出端口符號(hào)添加引腳

88、鎖定LOCK的屬性。請(qǐng)注意,在ispDesignEXPERT中,引腳的屬性實(shí)際上是加到I/OPad符號(hào)上,而不是加到I/OMarker上。同時(shí)也請(qǐng)注意,只有當(dāng)你需要為一個(gè)引腳增加屬性時(shí),才需要I/OPad符號(hào),否則,你只需要一個(gè)I/OMarker.</p><p>  在菜單條上選擇Edit=>Attribute=>SymbolAttribute項(xiàng),這時(shí)會(huì)出現(xiàn)一個(gè)SymbolAttributeEdit

89、or對(duì)話(huà)框。</p><p>  單擊需要定義屬性的輸出I/OPad.</p><p>  對(duì)話(huà)框里會(huì)出現(xiàn)一系列可供選擇的屬性。</p><p>  選擇SynarioPin屬性,并且把文本框中的‘*’替換成‘4’.</p><p><b>  關(guān)閉對(duì)話(huà)框。</b></p><p>  請(qǐng)注意,此

90、時(shí)數(shù)字‘4’出現(xiàn)在I/OPad符號(hào)內(nèi)。</p><p><b>  保存以完成的設(shè)計(jì)</b></p><p>  從菜單條上選擇File,并選Save命令。再選Exit命令。</p><p>  2.關(guān)于A(yíng)BEL語(yǔ)言</p><p>  這一節(jié),你要建立一個(gè)簡(jiǎn)單的ABELHDL語(yǔ)言輸入的設(shè)計(jì),并且將其與上一節(jié)中完成的原理

91、圖進(jìn)行合并,以層次結(jié)構(gòu)的方式,畫(huà)在頂層的原理圖上。然后對(duì)這個(gè)完整的設(shè)計(jì)進(jìn)行仿真、編譯,最后適配到ispLSI器件中。</p><p><b>  現(xiàn)在我們就開(kāi)始吧!</b></p><p>  I啟動(dòng)ispDesignEXPERTSystem如果你在上一節(jié)的練習(xí)后退出了ispDesignEXPERTSystem,點(diǎn)擊Start=>Programs=>La

92、tticeSemiconductor=>ispDesignEXPERTSystem菜單,屏幕上你的項(xiàng)目管理器應(yīng)該如下圖所示。</p><p>  II建立頂層的原理圖</p><p>  仍舊選擇1032E器件,從菜單條上選Source。</p><p><b>  選擇New...</b></p><p>  在

93、對(duì)話(huà)框中選Schematic,并按OK。</p><p>  選擇路徑:c:\user然后在文本框中輸入文件名top.sch,并按OK。</p><p>  現(xiàn)在你就進(jìn)入了原理圖編輯器。</p><p>  調(diào)用上節(jié)中創(chuàng)建的元件符號(hào)。選擇Add菜單中的Symbol項(xiàng),這時(shí)會(huì)出現(xiàn)SymbolLibraries對(duì)話(huà)框,選擇Local的庫(kù),你會(huì)注意到在下部的文本框中有一個(gè)

94、叫demo的元件符號(hào),這就是你在上一節(jié)中自行建立的元件符號(hào)。</p><p>  選擇demo元件符號(hào),并放到原理圖上的合適位置。</p><p>  建立內(nèi)含ABEL語(yǔ)言的邏輯元件符號(hào)現(xiàn)在你要為ABELHDL設(shè)計(jì)文件建立一個(gè)元件符號(hào)。只要知道了接口信息,你就可以為下一層的設(shè)計(jì)模塊創(chuàng)建一個(gè)元件符號(hào)。而實(shí)際的ABEL設(shè)計(jì)文件可以在以后再完成。</p><p>  在

95、原理圖編輯器里,選擇ADD菜單里的NewBlockSymbol...命令。</p><p>  這時(shí)候會(huì)出現(xiàn)一個(gè)對(duì)話(huà)框,提示你輸入ABEL模塊名稱(chēng)及其</p><p>  輸入信號(hào)名和輸出信號(hào)名。請(qǐng)按照下圖所示輸入信息:</p><p>  當(dāng)你完成信號(hào)名的輸入,撳Run按鈕,就會(huì)產(chǎn)生一個(gè)元件符號(hào),并放在本地元件庫(kù)中。同時(shí)元件符號(hào)還粘連在光標(biāo)上,隨之移動(dòng)。</

96、p><p>  把這個(gè)符號(hào)放在demo符號(hào)的左邊。</p><p>  單擊鼠標(biāo)右鍵,就會(huì)顯示SymbolLibraries的對(duì)話(huà)框。請(qǐng)注意abeltop符號(hào)出現(xiàn)在Local庫(kù)中。</p><p>  關(guān)閉對(duì)話(huà)框。你的原理圖應(yīng)該如下圖所示:</p><p><b>  完成原理圖</b></p><p&

97、gt;  現(xiàn)在請(qǐng)你添加必需的連線(xiàn),連線(xiàn)名稱(chēng),以及I/O標(biāo)記,來(lái)完成頂層原理圖,使其看上去如下圖所示。如果你需要幫助,請(qǐng)參考第二節(jié)中有關(guān)添加連線(xiàn)和符號(hào)的指導(dǎo)方法。當(dāng)你畫(huà)完后,請(qǐng)存盤(pán)再退出。</p><p>  建立ABEL-HDL源文件現(xiàn)在你需要建立一個(gè)ABEL源文件,并把它鏈接到頂層原理圖對(duì)應(yīng)的符號(hào)上。項(xiàng)目管理器使這些步驟簡(jiǎn)化了:</p><p>  你當(dāng)前的管理器應(yīng)該如下圖所示:<

98、;/p><p>  請(qǐng)注意abeltop左邊的紅色“?”圖標(biāo)。這意味著目前這個(gè)源文件還是個(gè)未知數(shù),因?yàn)槟氵€沒(méi)有建立它。同時(shí)也請(qǐng)注意源文件框中的層次結(jié)構(gòu),abeltop和demo源文件位于top原理圖的下面并且偏右,這說(shuō)明它們是top原理圖的底層源文件。這也是ispDesignEXPERTSystem項(xiàng)目管理器另外一個(gè)有用的特點(diǎn)。</p><p>  為了建立所需的源文件,請(qǐng)選擇abeltop,

99、然后選擇Source菜單中的New...命令。</p><p>  在NewSource對(duì)話(huà)框中,選擇ABEL-HDLModule并按OK。</p><p>  下一個(gè)對(duì)話(huà)框會(huì)問(wèn)你模塊名,文件名,以及模塊的標(biāo)題。為了將源文件與符號(hào)相鏈接,模塊名必須與符號(hào)名一致,而文件名沒(méi)有必要與符號(hào)名一致。但為了簡(jiǎn)單,你可以給它們?nèi)∠嗤拿帧0聪聢D所示,填寫(xiě)相應(yīng)的欄目:</p><p

100、>  按OK。你就進(jìn)入了TextEditor,而且可以可見(jiàn)ABELHDL設(shè)計(jì)文件的框架已經(jīng)呈現(xiàn)在你的面前。</p><p>  輸入下列的代碼。確保你的輸入代碼位于TITLE語(yǔ)句和END語(yǔ)句之間。</p><p>  當(dāng)你完成后,選擇File菜單中的Save命令。</p><p><b>  退出文本編輯器。</b></p>

101、;<p>  請(qǐng)注意項(xiàng)目管理器中abeltop源文件左邊的圖標(biāo)已經(jīng)改變了。這就意味著你已經(jīng)有了一個(gè)與此源文件相關(guān)的ABEL文件,并且已經(jīng)建立了正確的鏈接。</p><p><b>  編譯ABELHDL</b></p><p>  選擇abeltop源文件。</p><p>  在處理過(guò)程列表中,雙擊ReduceLogic過(guò)程。你

102、會(huì)看到項(xiàng)目管理器在執(zhí)行ReduceLogic過(guò)程之前,先去執(zhí)行CompileLogic過(guò)程。當(dāng)處理過(guò)程結(jié)束后,你的項(xiàng)目管理器應(yīng)該如上圖所示。</p><p><b>  VII.仿真</b></p><p>  你現(xiàn)在可以對(duì)整個(gè)設(shè)計(jì)進(jìn)行仿真。為此,你需要一個(gè)新的測(cè)試矢量文件。在這個(gè)例子中你只需要修改當(dāng)前的測(cè)試矢量文件。</p><p>  雙

103、擊demo.abv源文件,就會(huì)出現(xiàn)文本編輯器。</p><p>  按照下圖修改測(cè)試矢量文件:</p><p><b>  完成后,存盤(pán)退出。</b></p><p>  仍舊選擇測(cè)試矢量源文件,雙擊FunctionalSimulation過(guò)程,進(jìn)行功能仿真。</p><p>  現(xiàn)進(jìn)入SimulationControl

104、Panel窗口。按Windows=>WaveformViewer窗口,打開(kāi)波形觀(guān)測(cè)器準(zhǔn)備查看仿真結(jié)果。</p><p>  為了看波形,你必須在SimulationControlPanel窗口中按Debug鈕,使SimulationControlPanel窗口進(jìn)入Debug模式。</p><p>  在A(yíng)vailableSignals欄中選擇CLK,TOPIN1,TOPIN2,TOP

105、IN3和TOPOUT信號(hào),并且按Monitor鈕。這些信號(hào)名都可以在波形觀(guān)測(cè)器中觀(guān)察到。再按Run鈕進(jìn)行仿真,其結(jié)果如下圖所示:</p><p>  在步驟D中,如雙擊TimingSimulation過(guò)程,即可進(jìn)入時(shí)序仿真流程,以下仿真步驟與功能仿真相同。</p><p>  VIII.把設(shè)計(jì)適配到Lattice器件中</p><p>  現(xiàn)在你已經(jīng)完成了原理圖和A

106、BEL語(yǔ)言的混合設(shè)計(jì)及其仿真。剩下的步驟只是將你的設(shè)計(jì)放入LatticeispLSI/pLSI器件中。因?yàn)槟阋呀?jīng)在第一節(jié)中選擇了器件,你可以直接執(zhí)行下面的步驟:</p><p>  在源文件窗口中選擇ispLSI1032E-70LJ84器件作為編譯對(duì)象,并注意觀(guān)察對(duì)應(yīng)的處理過(guò)程。</p><p>  雙擊處理過(guò)程CompileDesign。這將迫使項(xiàng)目管理器完成對(duì)源文件的編譯,然后連接所有

107、的源文件,最后進(jìn)行邏輯分割,布局和布線(xiàn),將設(shè)計(jì)適配到所選擇的Lattice器件中。</p><p>  當(dāng)這些都完成后,你可以雙擊ispDesignEXPERTCompilerReport,查看一下設(shè)計(jì)報(bào)告和有關(guān)統(tǒng)計(jì)數(shù)據(jù)。</p><p>  祝賀!!你現(xiàn)在已經(jīng)完成了設(shè)計(jì)例子,并且掌握了ispDesignEXPERTSystem的主要功能。</p><p><

108、b>  層次化操作方法</b></p><p>  層次化操作是ispDesignEXPERT系統(tǒng)項(xiàng)目管理器的重要功能,它能夠簡(jiǎn)化層次化設(shè)計(jì)的操作。</p><p>  在項(xiàng)目管理器的源文件窗口中,選擇最頂層原理圖“top.sch”.此時(shí)在項(xiàng)目管理器右邊的操作流程清單中必定有NavigationHierarchy過(guò)程。</p><p>  雙擊Na

109、vigationHierarchy過(guò)程,即會(huì)彈出最頂層原理圖“top.sch”。</p><p>  選擇View菜單中的Push/Pop命令,光標(biāo)就變成十字形狀。</p><p>  用十字光標(biāo)單擊頂層原理圖中的abeltop符號(hào),即可彈出描述abeltop邏輯的文本文件abeltop.abl。此時(shí)可以瀏覽或編輯ABELHDL設(shè)計(jì)文件。瀏覽完畢后用File菜單中的Exit命令退回頂層原理

110、圖。</p><p>  用十字光標(biāo)單擊頂層原理圖中的demo符號(hào),即可彈出描述demo邏輯的底層原理圖demo.sch。此時(shí)可以瀏覽或編輯底層原理圖。</p><p>  若欲編輯底層原理圖,可以利用Edit菜單中的Schematic命令進(jìn)入原理圖編輯器。編譯完畢后用File菜單中的Save和Exit命令退出原理圖編輯器。</p><p>  底層原理圖瀏覽完畢后

111、用十字光標(biāo)單擊圖中任意空白處即可退回上一層原理圖。</p><p>  若某一設(shè)計(jì)為多層次化結(jié)構(gòu),則可在最高層逐層進(jìn)入其底層,直至最底一層;退出時(shí)亦可以從最底層逐層退出,直至最高一層。</p><p>  層次化操作結(jié)束后用File菜單中的Exit命令退回項(xiàng)目管理器。</p><p>  注意:將Y1端口定義成時(shí)鐘輸入端的方法</p><p&g

112、t;  ispLSI1016和ispLSI2032兩種器件的Y1端是功能復(fù)用的。如果不加任何控制,適配軟件在編譯時(shí)將Y1默認(rèn)為是系統(tǒng)復(fù)位端口(RESET)。若欲將Y1端用作時(shí)鐘輸入端,必須通過(guò)編譯器控制參數(shù)來(lái)進(jìn)行定義。</p><p>  3.關(guān)于ispDesignEXPERT系統(tǒng)中VHDL語(yǔ)言的設(shè)計(jì)方法</p><p>  除了支持原理圖和ABEL-HDL語(yǔ)言輸入外,商業(yè)版的ispDes

113、ignEXPERT系統(tǒng)中提供了VHDL和Verilog語(yǔ)言的設(shè)計(jì)人口。用戶(hù)的VHDL或Verilog設(shè)計(jì)可以經(jīng)ispDesignEXPERT系統(tǒng)提供的綜合器進(jìn)行編譯綜合,生成EDIF格式的網(wǎng)表文件,然后可進(jìn)行邏輯或時(shí)序仿真,最后進(jìn)行適配,生成可下載的JEDEC文件。</p><p>  VHDL設(shè)計(jì)輸入的操作步驟</p><p>  A. 在ispDesignEXPERTSystemPro

114、jectNavigator主窗口中,按File=>NewProject菜單建立一個(gè)新的工程文件,此時(shí)會(huì)彈出如下圖所示的對(duì)話(huà)框。請(qǐng)注意:在該對(duì)話(huà)框中的ProjectType欄中,必須根據(jù)您的設(shè)計(jì)類(lèi)型選擇相應(yīng)的工程文件的類(lèi)型。本例中,選擇VHDL類(lèi)型。若是Verilog設(shè)計(jì)輸入,則選擇VerilogHDL類(lèi)型。</p><p>  將該工程文件存盤(pán)為demo.syn。</p><p> 

115、 在ispDesignEXPERTSystemProjectNavigator主窗口中,選擇Source=>New菜單。在彈出的NewSource對(duì)話(huà)框中,選擇VHDLModule類(lèi)型。</p><p>  此時(shí),軟件會(huì)產(chǎn)生一個(gè)如下圖所示的NewVHDLSource對(duì)話(huà)框:</p><p>  在對(duì)話(huà)框的各欄中,分別填入如上圖所示的信息。按OK鈕后,進(jìn)入文本編輯器-TextEdito

116、r編輯VHDL文件。</p><p>  在TextEditor中輸入如下的VHDL設(shè)計(jì),并存盤(pán)。</p><p>  libraryieee;</p><p>  useieee.std_logic_1164.all;</p><p>  entitydemois</p><p>  port(A,B,C,D,CK:

117、instd_logic;</p><p>  OUTP:outstd_logic);</p><p><b>  enddemo;</b></p><p>  architecturedemo_architectureofdemois</p><p>  signalINP:std_logic;</p>

118、<p><b>  begin</b></p><p>  Process(INP,CK)</p><p><b>  begin</b></p><p>  if(rising_edge(CK))then</p><p>  OUTP<=INP;</p><p

119、><b>  endif;</b></p><p>  endprocess;</p><p>  INP<=(AandB)or(CandD);</p><p>  enddemo_architecture;</p><p>  此VHDL設(shè)計(jì)所描述的電路與本教材第二節(jié)所輸入的原理圖相同,只不過(guò)將輸出端口OU

120、T改名為OUTP(因?yàn)镺UT為VHDL語(yǔ)言保留字)。</p><p>  此時(shí),在ispDesignEXPERTSystemProjectNavigator主窗口左側(cè)的源程序區(qū)中,demo.vhd文件被自動(dòng)調(diào)入。單擊源程序區(qū)中的ispLSI1032E-125LT100欄,此時(shí)的ispDesignEXPERTSystemProjectNavigator主窗口如下圖所示:</p><p>  

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論