版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> ******</b></p><p> 設(shè) 計 性 實 驗(報告)</p><p> 題 目: 簡單16位CPU設(shè)計</p><p> 課 程: 計算機(jī)系統(tǒng)結(jié)構(gòu)</p><p> 院 (部): 計算機(jī)科學(xué)與技術(shù)學(xué)院</p&g
2、t;<p> 專 業(yè): 計算機(jī)科學(xué)與技術(shù)專業(yè)</p><p> 班 級: ***</p><p> 學(xué)生姓名: ***</p><p> 學(xué) 號: ******</p><p> 指導(dǎo)教師: ***</p>
3、<p> 完成日期: 2010-12-8</p><p> *******計算機(jī)科學(xué)與技術(shù)學(xué)院</p><p> 簡單16位CPU設(shè)計</p><p><b> 一、實驗內(nèi)容</b></p><p> 完成從指令系統(tǒng)到CPU的設(shè)計,編寫測試程序,通過運(yùn)行測試程序?qū)PU設(shè)計進(jìn)行正確性
4、評定。具體內(nèi)容包括:典型指令系統(tǒng)(包括運(yùn)算類、轉(zhuǎn)移類、訪存類)設(shè)計;CPU結(jié)構(gòu)設(shè)計;CPU的VHDL程序代碼編寫;規(guī)則文件與調(diào)試程序設(shè)計;CPU調(diào)試及測試程序運(yùn)行。</p><p><b> 二、實驗?zāi)康募耙?lt;/b></p><p> 1.加深對計算機(jī)的基本概念、基本原理和基本結(jié)構(gòu)的理解;</p><p> 2.掌握計算機(jī)組成與系統(tǒng)結(jié)構(gòu)
5、方面的基本設(shè)計、分析與實現(xiàn)方法;</p><p> 3.掌握典型16CPU設(shè)計方法;</p><p> 4.熟練掌握VHDL語言及應(yīng)用,完成對CPU各功能模塊的代碼描述,實現(xiàn)各個功能模塊部分的連接,從而形成一個完整的CPU體系結(jié)構(gòu);</p><p> 5.學(xué)會利用先進(jìn)的硬件設(shè)計工具軟件Quartus II對程序進(jìn)行仿真和調(diào)試;</p><p
6、> 6.掌握基于“TEC-CA試驗教學(xué)系統(tǒng)”進(jìn)行CPU調(diào)試的方法。</p><p><b> 實驗儀器設(shè)備</b></p><p> ?。?)TEC-CA試驗教學(xué)系統(tǒng);</p><p> ?。?)虛擬儀器平臺;</p><p><b> ?。?)計算機(jī)。</b></p>&l
7、t;p><b> ?。?)實驗環(huán)境</b></p><p><b> 實驗方案設(shè)計</b></p><p><b> 指令系統(tǒng)設(shè)計</b></p><p> 指令系統(tǒng)的作用和地位</p><p> 指令系統(tǒng)是從程序設(shè)計者看到的機(jī)器的主要屬性,是軟、硬件的主要界面。
8、</p><p> 指令系統(tǒng)是計算機(jī)系統(tǒng)結(jié)構(gòu)的主要組成部分。</p><p> 指令系統(tǒng)是軟件與硬件分界面的一個主要標(biāo)志。</p><p> 指令系統(tǒng)是軟件與硬件之間互相溝通的橋梁。</p><p><b> 指令系統(tǒng)的設(shè)計規(guī)范</b></p><p> 設(shè)計的原則:支持編譯系統(tǒng)能高效、
9、簡易地將源程序翻譯成目標(biāo)代碼。</p><p> 正交性:指令字段編碼相互獨立。</p><p> 規(guī)整性:相似操作有相同的規(guī)定。</p><p> 可擴(kuò)充性:操作碼冗余。</p><p> 對稱性:A-B=》A;A-B=》B,便于編譯。</p><p> CPU中操作數(shù)的存儲方法</p>&l
10、t;p> CPU中操作數(shù)的存儲方法是各種指令集結(jié)構(gòu)之間最主要的區(qū)別所在,其影響運(yùn)算器的組織。</p><p> CPU中用來存儲操作數(shù)的存儲單元主要有:</p><p><b> ?。?)堆棧; </b></p><p><b> ?。?)累加器;</b></p><p><b>
11、; ?。?)一組寄存器;</b></p><p> 通用寄存器型指令集結(jié)構(gòu)的主要優(yōu)點:</p><p> ?。?)使編譯器有效地使用寄存器;</p><p> ?。?)在表達(dá)式求值方面,比其它類型指令集結(jié)構(gòu),具有更大的靈活性;</p><p> (3)寄存器可以用來存放變量;</p><p> a.減
12、少存儲器的訪問量,加快程序的執(zhí)行速度。(因為寄存器比存儲器快)</p><p> b.可以用更少的地址位來尋址寄存器,從而可以有效改進(jìn)程序的目標(biāo)代碼大小。</p><p> 由于通用寄存器型指令系統(tǒng)存在諸多的優(yōu)點因此我們選擇通用寄存器型指令結(jié)構(gòu)。</p><p><b> 指令格式與功能</b></p><p>&
13、lt;b> ADD DR,SR</b></p><p><b> 指令編碼:</b></p><p> 功能:DR DR+SR,影響C和Z標(biāo)志,PC PC+1。</p><p><b> INC DR</b></p><p><b> 指令編碼
14、:</b></p><p> 功能:DR DR+1,影響C和Z標(biāo)志,PC PC+1</p><p><b> SUB DR,SR</b></p><p><b> 指令編碼:</b></p><p> 功能: DR DR-SR,影響C和Z標(biāo)志,PC
15、PC+1</p><p><b> DEC DR</b></p><p><b> 指令編碼:</b></p><p> 功能:DR DR-1,影響C和Z標(biāo)志,PC PC+1</p><p><b> AND DR,SR</b></p>&
16、lt;p><b> 指令編碼:</b></p><p> 功能:DR DR and SR,影響Z標(biāo)志,PC PC+1</p><p><b> OR DR,SR</b></p><p><b> 指令編碼:</b></p><p> 功能:DR
17、 DR or SR,影響Z標(biāo)志,PC PC+1</p><p><b> NOT DR</b></p><p><b> 指令編碼:</b></p><p> 功能:DR not SR,影響Z標(biāo)志,PC PC+1</p><p><b> MOV DR
18、,SR</b></p><p><b> 指令編碼:</b></p><p> 功能:功能:DR SR,不影響標(biāo)志位,PC PC+1</p><p><b> JMP ADR</b></p><p><b> 指令編碼:</b></p&
19、gt;<p> 功能:PC ADR</p><p><b> JNC ADR</b></p><p><b> 指令編碼:</b></p><p> 功能:如果C=0,則PC ADR;如果C=1,則PC PC+1</p><p><b> J
20、NZ ADR</b></p><p><b> 指令編碼:</b></p><p> 功能:如果Z=0,則PC ADR;如果C=1,則PC PC+1</p><p> MVRD DR,DATA</p><p><b> 指令編碼:</b></p>&
21、lt;p> 功能:DR DATA,PC PC+2</p><p><b> LDR DR,SR</b></p><p><b> 指令編碼:</b></p><p> 功能:DR [SR],PC PC+1</p><p><b> STR
22、SR,DR</b></p><p><b> 指令編碼:</b></p><p> 功能:[DR] SR,PC PC+1</p><p><b> NOP</b></p><p><b> 指令編碼:</b></p><
23、p> 功能:PC PC+1</p><p><b> 16、補(bǔ)充:</b></p><p><b> 指令編碼</b></p><p> CPU為16位:CPU的并行處理能力16位,總線寬度為16位,指令長度至少16位。</p><p> 采用對稱式寄存器結(jié)構(gòu):無累加器的概
24、念,形成的通用寄存器組有兩個輸出端口(讀端口)、一個輸入端口(寫端口)。共設(shè)有4個R(R0-R3)。</p><p> 指令分類:運(yùn)算類、轉(zhuǎn)移類、訪存類。</p><p> 用兩位編碼: IR15, IR14 </p><p> 運(yùn)算類: 0 0</p><p> 轉(zhuǎn)移類:
25、 1 0</p><p> 訪存類: 1 1</p><p><b> 運(yùn)算類:</b></p><p> (IR15=0) IR14, IR13, IR12</p><p> ADD 0 0
26、 0</p><p> INC 0 0 1</p><p> SUB 0 1 0</p><p> DEC 0 1 1</p><p> AND
27、 1 0 0</p><p> OR 1 0 1</p><p> NOT 1 1 0</p><p> NOP 1 1 1</p
28、><p> 結(jié)果處理(送R或送M)</p><p> 兩種選擇,1位編碼: IR0=1:送DR;</p><p> 影響Z標(biāo)志否, 1位編碼:IR1=1,影響;</p><p> 影響C標(biāo)志否, 1位編碼:IR2=1,影響。</p><p> 沒用的位設(shè)為0(保留位) </p><p>
29、<b> 指令機(jī)器碼:</b></p><p> 說明:(1)本CPU中含有4個通用寄存器,用R0,R1,R2,和R3表示。源寄存器用SR表示,目的寄存器用DR表示,因此DR和SR在指令編碼中各用2bit編碼。</p><p> ?。?)指令編碼中的@代表該指令當(dāng)前的PC值。</p><p> ?。?)設(shè)計指令系統(tǒng)時首要考慮的是指令要滿足功
30、能的需求。這個指令系統(tǒng)還包括PUSH、POP、以上指令包括運(yùn)算指令、轉(zhuǎn)移指令和存儲指令3類。這三類指令根據(jù)</p><p><b> 、進(jìn)行分類:</b></p><p><b> 為0時運(yùn)算指令;</b></p><p> 、為10時轉(zhuǎn)移指令;</p><p> 、為11時存儲指令。<
31、;/p><p> ?。?)考慮指令譯碼方便,減少硬件資源的消耗:</p><p> ①算術(shù)邏輯指令的—對應(yīng)運(yùn)算器ALU的3位運(yùn)算操作碼</p><p> ?、诋?dāng)=1時,本指令中對DR的寫操作</p><p> ?、郛?dāng)=1時,本指令影響標(biāo)志位Z</p><p> ?、墚?dāng)=1時,本指令影響標(biāo)志位C</p>&l
32、t;p> ?、軳OP指令實際上是一條“MOV ,”指令,只是不改變目的寄存器的內(nèi)容。</p><p> (二)設(shè)計指令流程;</p><p> 1、時序部件(電路)</p><p><b> ?。?)概述 </b></p><p> CPU工作的關(guān)鍵部件,產(chǎn)生計算機(jī)執(zhí)行機(jī)器指令所需的時序信號。計算機(jī)的工作過
33、程:一個指令周期接一個指令周期;在一個指令周期內(nèi)是一個機(jī)器周期接一個機(jī)器周期;在一個機(jī)器周期內(nèi)是一個節(jié)拍接一個節(jié)拍;在一個節(jié)拍內(nèi)產(chǎn)生哪些微操作信號取決于指令操作流程。伴隨著指令的執(zhí)行,計算機(jī)內(nèi)部有兩股信息在流動:一股是數(shù)據(jù)流,流過不同的部件完成不同處理;一股是控制信號流,控制數(shù)據(jù)從何處流出、經(jīng)過何地(運(yùn)算處理部件)、流往何處,微控制信號的產(chǎn)生由指令操作流程規(guī)定(操作碼),控制信號有效狀態(tài)的先后順序由節(jié)拍控制。</p>&l
34、t;p><b> ?。?)機(jī)器周期</b></p><p> 目標(biāo):一個機(jī)器周期執(zhí)行一條單字指令。</p><p> 如:ADD DR,SR</p><p> 執(zhí)行過程:1)取指;2)譯碼分析;3)執(zhí)行(運(yùn)算);4)寫結(jié)果。</p><p> 可合并為三個階段:1)取指;2)分析、執(zhí)行;3)寫結(jié)果(存儲
35、器、寄存器)</p><p><b> ?。?)節(jié)拍</b></p><p> 三個階段(取指、分析執(zhí)行、寫結(jié)果)對應(yīng)三個節(jié)拍。</p><p> t1:取指—t1上升沿MADDR?PC,t2上升沿指令送IR;PC+1(temp)</p><p> t2:譯碼分析、運(yùn)算處理(Z、C—TEMP);</p>
36、<p> t3:存儲器、寄存器讀寫,下降沿寫寄存器,改變C、Z、PC等。</p><p> 1、ADD DR,SR</p><p> t1 t2 t3</p><p> Madd<=pc Result<=DR+SR</p><p> R/W<=1 Z_T
37、EMP PC<=pc_t</p><p> Dread<=ob C_TEMP DR<=Result</p><p> IR<=Dread Z<=Z_TEMP</p><p> PC_t<=PC+1 C<=C_TEMP</p>
38、<p><b> 2、INC DR</b></p><p> t1 t2 t3</p><p> Madd<=pc Result<=DR+1</p><p> R/W<=1 Z_TEMP PC<=pc_t</p><p>
39、; Dread<=ob C_TEMP DR<=Result</p><p> IR<=Dread Z<=Z_TEMP</p><p> PC_t<=PC+1 C<=C_TEMP</p><p> 3、SUB DR,SR</p><p>
40、 t1 t2 t3</p><p> Madd<=pc Result<=DR-SR</p><p> R/W<=1 Z_TEMP PC<=pc_t</p><p> Dread<=ob C_TEMP DR<=Result</p><
41、p> IR<=Dread Z<=Z_TEMP</p><p> PC_t<=PC+1 C<=C_TEMP</p><p><b> 4、DEC DR</b></p><p> t1 t2 t3</p>
42、;<p> Madd<=pc Result<=DR-1</p><p> R/W<=1 Z_TEMP PC<=pc_t</p><p> Dread<=ob C_TEMP DR<=Result</p><p> IR<=Dread Z
43、<=Z_TEMP</p><p> PC_t<=PC+1 C<=C_TEMP</p><p> 5、AND DR,SR</p><p> t1 t2 t3</p><p> Madd<=pc Result<=DR and SR</p>
44、;<p> R/W<=1 Z_TEMP PC<=pc_t</p><p> Dread<=ob DR<=Result</p><p> IR<=Dread Z<=Z_TEMP</p><p> PC_t<=PC+1
45、 </p><p> 6、OR DR,SR</p><p> t1 t2 t3</p><p> Madd<=pc Result<=DR or SR</p><p> R/W<=1 Z_TEMP PC<=pc_t</p>
46、;<p> Dread<=ob DR<=Result</p><p> IR<=Dread Z<=Z_TEMP</p><p> PC_t<=PC+1 </p><p><b> 7、NOT DR&
47、lt;/b></p><p> t1 t2 t3</p><p> Madd<=pc Result<=not DR</p><p> R/W<=1 Z_TEMP PC<=pc_t</p><p> Dread<=ob DR&l
48、t;=Result</p><p> IR<=Dread Z<=Z_TEMP</p><p> PC_t<=PC+1</p><p> 8、MOV DR,SR</p><p> t1 t2 t3</p><p> Madd<=pc
49、 Result<= SR</p><p> R/W<=1 PC<=pc_t</p><p> Dread<=ob DR<=Result</p><p> IR<=Dread </p><p
50、> PC_t<=PC+1</p><p> 9、JMP ADR</p><p> t1 t2 t3</p><p> Madd<=pc Madd<= PC_t R/W=1</p><p> R/W<=1 Dread<=ob</p&
51、gt;<p> Dread<=ob PC<=Dread</p><p> IR<=Dread </p><p> PC_t<=PC+1</p><p> 10、JNC ADR</p><p> t1
52、 t2 t3</p><p> Madd<=pc generate if c_z_j_f=1</p><p> R/W<=1 c_z_j_f then PC<=sjmp_a</p><p> Dread<=ob sjmp_a else PC<=PC_t</p><p>
53、 IR<=Dread </p><p> PC_t<=PC+1</p><p> 11、JNZ ADR</p><p> t1 t2 t3</p><p> Madd<=pc generate if c_z_j_f=
54、1</p><p> R/W<=1 c_z_j_f then PC<=sjmp_a</p><p> Dread<=ob sjmp_a else PC<=PC_t</p><p> IR<=Dread </p><p> PC_t
55、<=PC+1</p><p> 12、MVRD DR,DATA</p><p> t1 t2 t3</p><p> Madd<=pc Madd<= PC_t R/W=1 </p><p> R/W<=1 Dread<=ob</p>
56、<p> Dread<=ob DR<=Dread</p><p> IR<=Dread PC<=PC+2 </p><p> PC_t<=PC+1</p><p> 13、LRD DR,SR</p><p> t1 t2
57、 t3</p><p> Madd<=pc Madd<= SR R/W=1 </p><p> R/W<=1 Dread<=ob</p><p> Dread<=ob DR<=Dread</p><p> IR&
58、lt;=Dread PC<=PC_t </p><p> PC_t<=PC+1</p><p> 14、STR SR,DR</p><p> t1 t2 t3</p><p> Madd<=pc Madd<= DR R/W=0 </
59、p><p> R/W<=1 ob<=SR</p><p> Dread<=ob </p><p> IR<=Dread PC<=PC_t </p><p> PC_t<=PC+1<
60、/p><p><b> 15、NOP</b></p><p> t1 t2 t3</p><p> Madd<=pc </p><p> R/W<=1 </p><p
61、> Dread<=ob </p><p> IR<=Dread PC<=PC_t </p><p> PC_t<=PC+1</p><p><b> 說明:</b></p><p> Mem_Ad
62、dr是存儲器地址總線。</p><p> Ob是存儲器數(shù)據(jù)總線。</p><p> We是存儲器讀寫信號,為0時寫存儲器,為1時讀存儲器。</p><p> Z_tmp是運(yùn)算產(chǎn)生的結(jié)果為0的標(biāo)志,z_out是本條指令執(zhí)行完成后的結(jié)果為0的標(biāo)志。</p><p> C_tem是運(yùn)算產(chǎn)生的進(jìn)位標(biāo)志,c_out是本條指令執(zhí)行完成后的進(jìn)位標(biāo)志
63、。</p><p><b> IR是指令寄存器。</b></p><p> C_z_j_flag是條件轉(zhuǎn)移指令“JNC ADR”或者“JNZ ADR”產(chǎn)生的條件轉(zhuǎn)移指令</p><p> Sjmp_addr是條件轉(zhuǎn)移指令“JNC ADR”或者“JNZ ADR”產(chǎn)生的條件轉(zhuǎn)移地址。</p><p> Result是
64、運(yùn)算器產(chǎn)生的運(yùn)算結(jié)果。</p><p> (三)CPU結(jié)構(gòu)設(shè)計</p><p> 一條指令需要3拍時間 </p><p> ?。?)t1:取指。t1上升沿MADDR PC,t2上升沿指令送IR;PC+1(temp)</p><p> (2)t2:譯碼分析、運(yùn)算處理(Z、C—TEMP);</p><p>
65、?。?)t3:存儲器、寄存器讀寫,下降沿寫寄存器,改變C、Z、PC等。</p><p> 三周期指令:包括所有的算術(shù)邏輯指令:ADD,SUB,DEC,INC,CMP,AND,OR,XOR,TEST,SHL,SHR,SAR。除了絕對轉(zhuǎn)移指令JMPA外的所有控制轉(zhuǎn)移指令:JR,JRC,JRNC,JRZ,JRNZ。一條數(shù)據(jù)傳送指令:MOV。這些指令只需三個周期就可以完成,其中,前兩個周期用于取指。這些指令都可以用操作
66、碼前兩位都是00,所以很容易和其它指令區(qū)別。見下圖:</p><p><b> 三周期指令時序圖</b></p><p> 2.簡單CPU結(jié)構(gòu):</p><p> 無流水、無Cache;主要部件有:運(yùn)算單元ALU;通用寄存器組;控制器(譯碼);取指操作(時序電路);存儲器操作。</p><p> CPU由5部分組
67、成:取指部分instru_fetch、指令譯碼部分decoder_unit、執(zhí)行部分exe_unit、存儲器部分memory_unit、和通用寄存器組regfile。另外,還需設(shè)計一個程序包exe_cpu_components,將各底層設(shè)計實體作為元件存儲,供各設(shè)計實體使用。頂層設(shè)計實體exe_cpu完成CPU 的5個組成部分的連接。</p><p><b> 3、整體結(jié)構(gòu)設(shè)計</b>&l
68、t;/p><p> 我們在設(shè)計整體結(jié)構(gòu)時,依據(jù)的是各指令的數(shù)據(jù)通路。然后采用自頂向下,逐步分解細(xì)化的方法進(jìn)行設(shè)計。先整體模塊,后局部模塊。</p><p><b> CPU整體結(jié)構(gòu)</b></p><p> 串行指令CPU整體結(jié)構(gòu)圖</p><p> 4、 各分模塊結(jié)構(gòu)設(shè)計</p><p>&
69、lt;b> 控制器結(jié)構(gòu)</b></p><p> 串行指令CPU控制器結(jié)構(gòu)圖</p><p><b> 運(yùn)算器結(jié)構(gòu)</b></p><p> 串行指令CPU運(yùn)算器結(jié)構(gòu)圖</p><p> ?。ㄋ模〤PU設(shè)計實現(xiàn)</p><p> 1、通用寄存器組regfile</
70、p><p> 通用寄存器組內(nèi)包含4個16位寄存器。這是一個具有寫入端口,2個讀出端口的通用寄存器組。寫入端口將指令執(zhí)行后得到的目的寄存器的值在的下降沿寫入目的寄存器中。只有具有寫目的寄存器功能的指令執(zhí)行結(jié)束時才寫目的寄存器。有些指令,如JMP指令等執(zhí)行結(jié)束后不會改變通用寄存器組的值。通用寄存器組的2個讀出端口,一個是目的寄存器讀出端口,一個是源寄存器讀出端口,從這2個端口讀出的內(nèi)容供執(zhí)行部分exe_unit和存儲器
71、部分memory_unit使用。</p><p> 通用寄存組內(nèi)還有2個標(biāo)志位:z_out和c_out,在的下降沿根據(jù)指令執(zhí)行的結(jié)果改變或者不改變它們的值。這2個標(biāo)志位的值送執(zhí)行部分exe_unit使用。</p><p> 通用寄存器組各引腳結(jié)構(gòu)如下圖:</p><p><b> 圖regfile</b></p><p
72、> 通用寄存器組是通過4個寄存器、2個2-4譯碼器和1個4-1選擇器構(gòu)成,其各個部分連接關(guān)系如下圖所示:</p><p> 圖regfile組成</p><p> 通用寄存器組部分regifile源代碼:</p><p><b> 寄存器reg</b></p><p> regfile的引腳如下圖所示:&
73、lt;/p><p><b> 圖regfile</b></p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> entity reg is port</p><p> (reset: instd_logi
74、c;</p><p> d_input: instd_logic_vector(15 downto 0);</p><p> clk:instd_logic;</p><p> write: instd_logic;</p><p> sel: instd_logic;</p><p>
75、q_output: outstd_logic_vector(15 downto 0)</p><p><b> );</b></p><p><b> end reg;</b></p><p> architecture a OF reg is</p><p><b> beg
76、in</b></p><p> process(reset,clk)</p><p><b> begin</b></p><p> IF reset = '0' then</p><p> q_output <= x"0000"; elsif clk&
77、#39;event and clk = '0' then --時鐘下降沿觸發(fā)</p><p> if sel ='1' and write = '1' then</p><p> q_output <= d_input;</p><p><b> end if;</b></p&
78、gt;<p><b> end if;</b></p><p> end process;</p><p><b> end a;</b></p><p> 2-4譯碼器decoder_2_to_4</p><p> 2-4譯碼器的引腳如下圖所示:</p>&l
79、t;p><b> 圖2-4譯碼器</b></p><p> Library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> entity decoder_2_to_4 is</p><p><b> port (</b>&l
80、t;/p><p> sel: in std_logic_vector(1 downto 0);</p><p> sel00: out std_logic;</p><p> sel01: out std_logic;</p><p> sel02: out std_logic;</p><p> sel03:
81、 out std_logic );</p><p> end decoder_2_to_4;</p><p> architecture Behavioral of decoder_2_to_4 is</p><p><b> begin</b></p><p> sel00 <= (not sel(1))
82、 and (not sel(0));</p><p> sel01 <= (not sel(1)) and sel(0) ;</p><p> sel02 <= sel(1) and (not sel(0)) ;</p><p> sel03 <= sel(1) and sel(0) ;</p><p> end B
83、ehavioral;</p><p> 4選1選擇器mux_4_to_1</p><p> 4-1 選擇器的引腳如下圖所示:</p><p><b> 圖4-1選擇器</b></p><p> library ieee;</p><p> use ieee.std_logic_1164.
84、all;</p><p> entity mux_4_to_1 is</p><p><b> port (</b></p><p><b> input0,</b></p><p><b> input1,</b></p><p><b&
85、gt; input2,</b></p><p> input3: in std_logic_vector(15 downto 0);</p><p> sel: in std_logic_vector(1 downto 0);</p><p> out_put: out std_logic_vector(15 downto 0))
86、;</p><p> end mux_4_to_1;</p><p> architecture Behavioral of mux_4_to_1 is</p><p><b> begin</b></p><p> mux: process(sel, input0, input1, input2, input3
87、)</p><p><b> begin</b></p><p> case sel is </p><p> when "00" => </p><p> out_put <= input0;</p><p> when "01" =
88、> </p><p> out_put <= input1;</p><p> when "10" => </p><p> out_put <= Input2;</p><p> when "11" => </p><p> out_pu
89、t <= Input3;</p><p><b> end case;</b></p><p> end process;</p><p> end Behavioral;</p><p> 通用寄存器組regfile</p><p> library ieee;</p>
90、;<p> use ieee.std_logic_1164.all;</p><p> use work.exp_cpu_components.all;</p><p> entity regfile is</p><p> port ( DR: in std_logic_vector(1 downto 0); --源寄存器號<
91、/p><p> SR: in std_logic_vector(1 downto 0); --目的寄存器號 </p><p> reset: in std_logic;</p><p> write: in std_logic;--寫寄存器信號 </p><p>
92、 clk: in std_logic;</p><p> d_input: in std_logic_vector(15 downto 0); --寫寄存器的數(shù)據(jù)</p><p> change_z: in std_logic;--如果為1,則重新設(shè)置z標(biāo)志</p><p> change_c: in std_logic;</p>
93、<p> c_in: in std_logic;</p><p> z_in: in std_logic;</p><p> R0,R1,R2,R3: out std_logic_vector(15 downto 0);</p><p> output_DR: out std_logic_vector(15 downto 0
94、); </p><p> output_SR: out std_logic_vector(15 downto 0);</p><p> c_out: out std_logic;</p><p> z_out: out std_logic );</p><p> end regfile;<
95、;/p><p> architecture struct of regfile is</p><p> signal reg00, reg01, reg02,reg03: std_logic_vector(15 downto 0);</p><p> signal sel00, sel01, sel02, sel03: std_logic;</p>
96、<p><b> begin</b></p><p> R0 <= reg00;</p><p> R1 <= reg01;</p><p> R2 <= reg02;</p><p> R3 <= reg03;</p><p> z_c_proc:
97、process(reset,clk) --對指令執(zhí)行結(jié)束后的z、c標(biāo)志進(jìn)行處理</p><p><b> begin</b></p><p> if reset = '0' then</p><p> z_out <= '0';</p><p> c_out <= &
98、#39;0';</p><p> elsif clk'event and clk = '0' then if change_z = '1' then</p><p> z_out <= z_in;</p><p><b> end if;</b></p><p&g
99、t; if change_c = '1' then</p><p> c_out <= c_in;</p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;</p>&
100、lt;p> Areg00: reg port map(--寄存器R0</p><p> reset=> reset,</p><p> d_input=> d_input,</p><p> clk=> clk,</p><p> write=> write,</p>
101、<p> sel=> sel00,</p><p> q_output=> reg00);</p><p> Areg01: reg port map(--寄存器R1</p><p> reset=> reset,</p><p> d_input=> d_input,</p
102、><p> clk=> clk,</p><p> write=> write,</p><p> sel => sel01,</p><p> q_output=> reg01);</p><p> Areg02: reg port map(--寄存器R2<
103、/p><p> reset=> reset,</p><p> d_input=> d_input,</p><p> clk=> clk,</p><p> write=> write,</p><p> sel=> sel02,</p>&
104、lt;p> q_output=> reg02);</p><p> Areg03: reg port map(--寄存器R3</p><p> reset=> reset,</p><p> d_input=> d_input,</p><p> clk=> clk,<
105、/p><p> write=> write,</p><p> sel=> sel03,</p><p> q_output=> reg03);</p><p> des_decoder: decoder_2_to_4 port map(--2 — 4譯碼器</p><p> se
106、l => DR,</p><p> sel00 => sel00,</p><p> sel01 => sel01,</p><p> sel02 => sel02,</p><p> sel03 => sel03 );</p><p> muxB: mux_4_to_
107、1 port map(--目的寄存器讀出4選1選擇器</p><p> input0 => reg00,</p><p> input1 => reg01,</p><p> input2 => reg02,</p><p> input3 => reg03,</p><p&g
108、t; sel => DR,</p><p> out_put => output_DR);</p><p> muxA: mux_4_to_1 PORT MAP(--源寄存器讀出4選1選擇器</p><p> input0 => reg00,</p><p> input1 => reg0
109、1,</p><p> input2 => reg02,</p><p> input3 => reg03,</p><p> sel => SR,</p><p> out_put => output_SR);</p><p> end struct;</p>&
110、lt;p> 2、取指部分instru_fetch</p><p> 取指部分完成4項工作:</p><p> (1)產(chǎn)生時鐘信號、和,供實驗CPU各部分使用</p><p> ?。?)在復(fù)位信號reset為低時將PC復(fù)位為0;在一條指令執(zhí)行結(jié)束后,根據(jù)指令執(zhí)行的結(jié)果在的下降沿改變PC的值。</p><p> ?。?)將從存儲器讀出
111、的指令的堆一個字在的上升沿送至指令寄存器IR中。</p><p> (4)計算PC+1的值pc_inc,為雙字指令取第二個指令字做準(zhǔn)備。</p><p> 取指部分instru_fetch源代碼</p><p> 取指部分的各引腳關(guān)系如圖:</p><p> 圖instru_fetch</p><p> li
112、brary ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_arith.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> use work.exp_cpu_components.
113、all;</p><p> entity instru_fetch is</p><p> port(reset,clk:in std_logic;</p><p> data_read: in std_logic_vector(15 downto 0); --存儲器讀出的數(shù)</p><p> lj_instruct: in st
114、d_logic; --長轉(zhuǎn)移指令</p><p> DW_intruct:in std_logic;</p><p> c_z_j_flag: in std_logic; --為1時進(jìn)行條件轉(zhuǎn)移</p><p> sjmp_addr: in std_logic_vector(15 downto 0); --條件轉(zhuǎn)移指令的轉(zhuǎn)移地址</p>&l
115、t;p> t1,t2,t3: buffer std_logic;</p><p> pc: buffer std_logic_vector(15 downto 0);</p><p> pc_inc: buffer std_logic_vector(15 downto 0);</p><p> IR: out std_logic_v
116、ector(15 downto 0));</p><p> end instru_fetch;</p><p> architecture behav of instru_fetch is signal start:std_logic;</p><p><b> begin</b></p><p> IR_p
117、oc: process(reset,t2)</p><p><b> begin</b></p><p> if reset = '0' then</p><p> IR <= x"7000"; --nop指令</p><p> elsif t2'event a
118、nd t2 = '1' then</p><p> IR <= data_read;</p><p><b> end if;</b></p><p> end process;</p><p> process(reset,clk)</p><p><b>
119、; begin</b></p><p> if reset = '0' then</p><p> start <= '1';</p><p><b> else</b></p><p> if clk'event and clk ='0'
120、; then start <= '0';</p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;</p><p> process(reset,clk)</p>
121、<p><b> begin</b></p><p> if reset = '0' then</p><p> t1 <= '0';</p><p> t2 <= '0';</p><p> t3 <= '0';&l
122、t;/p><p> elsif clk'event and clk = '1' then t1 <= start or t3;</p><p><b> t2 <= t1;</b></p><p><b> t3 <= t2;</b></p><p>&
123、lt;b> end if;</b></p><p> end process;</p><p> pc_inc <= pc + '1';--為取雙字指令的第2個字或者計算相對轉(zhuǎn)移地址做準(zhǔn)備</p><p> PC_proc:process(reset,t3)</p><p><b&g
124、t; begin</b></p><p> if reset = '0' then</p><p> pc <= x"0000";</p><p> elsif t3'event and t3 = '0' then</p><p> if lj_instr
125、uct = '1' then</p><p> pc <= data_read;</p><p> elsif c_z_j_flag ='1' then</p><p> pc <= sjmp_addr;</p><p> elsif DW_intruct = '1' the
126、n</p><p> pc <= pc + "10";</p><p><b> else</b></p><p> pc <= pc_inc;</p><p><b> end if;</b></p><p><b> e
127、nd if;</b></p><p> end process;</p><p> end behav;</p><p> 指令譯碼部分decoder_unit</p><p> 指令譯碼部分根據(jù)指令寄存器IR的值產(chǎn)生實驗CPU所需要的各種控制信號和其他信號:</p><p> SR:源寄存器號(
128、編址)</p><p> DR:目的寄存器號(編址)</p><p> Op_code:控制ALU進(jìn)行8種運(yùn)算操作的3位編碼</p><p> Zj_instruct:為1表示本條指令是條“JNZ ADR”指令</p><p> Cj_instruct: 為1表示本條指令是條“JNC ADR”指令</p><p&g
129、t; Lj_instruct: 為1表示本條指令是條“JMP ADR”指令</p><p> DRWr:為1表示在的下降沿將本條指令的執(zhí)行結(jié)果寫入目的寄存器</p><p> Mem_Write:為1表示本條指令有存儲器寫操作,存儲器的地址是源寄存器的內(nèi)容。</p><p> DW_instruct:為1表示本條指令是雙字指令</p><
130、p> Change_z:為1表示本條指令可能改變Z(結(jié)果為0)標(biāo)志</p><p> Change_c:為1表示本條指令可能改變C(進(jìn)位)標(biāo)志</p><p> Sel_memdata:為1表四本條指令寫入目的寄存器的值來自讀寄存器</p><p> R_sjmp_addr:計算條件轉(zhuǎn)移地址所需要的16位相對地址。它是由條件轉(zhuǎn)移指令中的8位相對地址經(jīng)過
131、符號擴(kuò)展生成的。</p><p> 指令譯碼器在傳統(tǒng)上屬于控制器部分,是控制器的核心。所謂組合邏輯控制器是指指令譯碼器是有組合邏輯構(gòu)成的,所謂微程序控制器是指指令譯碼器主要由控制存儲器ROM和少許組合邏輯構(gòu)成的。</p><p> 指令譯碼部分decoder_unit源代碼:</p><p> decoder_unit的引腳關(guān)系如下圖:</p>
132、<p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_arith.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> use work.exp_cp
133、u_components.all;</p><p> entity decoder_unit is</p><p> port (IR: in std_logic_vector(15 downto 0);</p><p> SR: out std_logic_vector(1 downto 0);</p><p> D
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 16位cpu綜合設(shè)計 計算機(jī)組成原理課程設(shè)計
- 計算機(jī)組成原理課程設(shè)計---簡單計算機(jī)系統(tǒng)設(shè)計與實現(xiàn)
- 計算機(jī)組成原理課程設(shè)計---簡單計算機(jī)系統(tǒng)設(shè)計與實現(xiàn)
- 計算機(jī)組成原理課程設(shè)計--簡單計算機(jī)系統(tǒng)設(shè)計與實現(xiàn)
- 計算機(jī)系統(tǒng)綜合課程設(shè)計
- 16位精簡指令cpu設(shè)計—計算機(jī)組成原理課程設(shè)計
- 課程設(shè)計--微型計算機(jī)系統(tǒng)設(shè)計
- 計算機(jī)系統(tǒng)綜合課程設(shè)計doc
- 計算機(jī)組成與系統(tǒng)結(jié)構(gòu)課程設(shè)計--單周期32位cpu的設(shè)計
- 計算機(jī)系統(tǒng)算法設(shè)計與分析報告課程設(shè)計
- 計算機(jī)系統(tǒng)綜合課程設(shè)計2ppt
- 計算機(jī)系統(tǒng)綜合課程設(shè)計報告模版doc
- 計算機(jī)系統(tǒng)結(jié)構(gòu)課程介紹
- 計算機(jī)組成原理課程設(shè)計--簡單計算機(jī)的設(shè)計
- 計算機(jī)系課程設(shè)計--一個簡單的文件系統(tǒng)的詳細(xì)設(shè)計
- 計算機(jī)硬件課程設(shè)計報告---簡單計算機(jī)的設(shè)計
- 計算機(jī)組成原理課程設(shè)計---簡單計算機(jī)的設(shè)計
- 計算機(jī)系統(tǒng)算法設(shè)計與分析報告課程設(shè)計 _0
- 計算機(jī)組成原理課程設(shè)計報告--簡單計算機(jī)
- 課程設(shè)計-基于微程序控制器的簡單計算機(jī)系統(tǒng)設(shè)計與實現(xiàn)
評論
0/150
提交評論