計算機組成原理課程設(shè)計說明書_第1頁
已閱讀1頁,還剩35頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  計算機組成原理課程設(shè)計說明書</p><p>  題目:設(shè)計求負(fù)數(shù)平方和的CISC模型計算機</p><p>  院(系):計算機科學(xué)與工程學(xué)院</p><p>  專業(yè):計算機科學(xué)與技術(shù)</p><p><b>  目 錄</b></p><p>  1課

2、程設(shè)計的題目與內(nèi)容1</p><p><b>  1.1題目1</b></p><p><b>  1.2內(nèi)容1</b></p><p>  2系統(tǒng)總體設(shè)計2</p><p>  2.1CISC模型機數(shù)據(jù)通路框圖的設(shè)計2</p><p>  2.2操作控制

3、器的邏輯框圖的設(shè)計2</p><p>  2.3模型機的指令系統(tǒng)和所有指令的指令格式的設(shè)計3</p><p>  2.4時序產(chǎn)生電路的設(shè)計6</p><p>  2.5機器指令的微程序流程圖以及微指令的設(shè)計7</p><p>  2.6地址轉(zhuǎn)移邏輯電路的設(shè)計9</p><p>  2.7軟件清單9

4、</p><p>  2.8嵌入式CISC模型計算機的頂層電路圖28</p><p>  3匯編語言源程序29</p><p>  4機器語言源程序30</p><p>  5機器語言源程序的功能仿真波形圖及結(jié)果分析31</p><p>  6故障現(xiàn)象和故障分析33</p><p

5、><b>  7心得體會34</b></p><p>  課程設(shè)計的題目與內(nèi)容</p><p><b>  題目</b></p><p>  設(shè)計一臺嵌入式CISC模型計算機(采用定長CPU周期、聯(lián)合控制方式),并運行能完成一定功能的機器語言程序進行驗證,機器語言源程序功能如下:</p><p&

6、gt;  連續(xù)輸入5個有符號整數(shù)(用8位二進制補碼表示,十六進制數(shù)輸入),求所有負(fù)數(shù)的平方和并輸出顯示。</p><p><b>  說明:</b></p><p>  5個有符號數(shù)從外部輸入;</p><p>  一定要使用符號位(比如說SF),并且要使用負(fù)的時候轉(zhuǎn)移(比如說JS)或不為負(fù)的時候轉(zhuǎn)移(比如說JNS)指令;</p>

7、<p>  采用三數(shù)據(jù)總線結(jié)構(gòu)的運算器,采用RAM,先將輸入數(shù)據(jù)依次存放在RAM的某一連續(xù)的存儲區(qū)域內(nèi),再依次讀出判斷是否為負(fù)數(shù),若為負(fù)數(shù)再求其平方和。</p><p><b>  內(nèi)容</b></p><p>  完成系統(tǒng)的總體設(shè)計,畫出模型機數(shù)據(jù)通路框圖;</p><p>  設(shè)計微程序控制器(CISC模型計算機)的邏輯結(jié)構(gòu)框圖

8、; </p><p>  設(shè)計機器指令格式和指令系統(tǒng); </p><p>  設(shè)計時序產(chǎn)生器電路; </p><p>  設(shè)計所有機器指令的微程序流程圖; </p><p>  設(shè)計操作控制器單元;</p><p>  在CISC模型計算機中,設(shè)計的內(nèi)容包括微指令格式(建議采用全水平型微指令)、微指令代碼表(根據(jù)微程序

9、流程圖和微指令格式來設(shè)計)和微程序控制器硬件電路(包括地址轉(zhuǎn)移邏輯電路、微地址寄存器、微命令寄存器和控制存儲器等。具體電路根據(jù)微程序控制器的邏輯結(jié)構(gòu)框圖、微指令格式和微指令代碼來設(shè)計)。</p><p>  設(shè)計模型機的所有單元電路,并用VHDL語言(也可使用GDF文件----圖形描述文件)對模型機中的各個部件進行編程,并使之成為一個統(tǒng)一的整體,即形成頂層電路或頂層文件; </p><p>

10、;  由給出的題目和設(shè)計的指令系統(tǒng)編寫相應(yīng)的匯編語言源程序;</p><p>  根據(jù)設(shè)計的指令格式,將匯編語言源程序手工轉(zhuǎn)換成機器語言源程序,并將其設(shè)計到模型機中的ROM中去;</p><p>  使用EDA軟件進行功能仿真,要保證其結(jié)果滿足題目的要求;(其中要利用EDA軟件提供的波形編輯器,選擇合適的輸入輸出信號及中間信號進行調(diào)試。)</p><p>  器件編

11、程,并在EDA實驗平臺上進行操作演示。</p><p><b>  系統(tǒng)總體設(shè)計</b></p><p>  CISC模型機數(shù)據(jù)通路框圖的設(shè)計</p><p>  操作控制器的邏輯框圖的設(shè)計</p><p>  模型機的指令系統(tǒng)和所有指令的指令格式的設(shè)計</p><p><b>  I/

12、O指令</b></p><p>  輸入指令(IN1)格式:</p><p>  輸出指令(OUT1)格式:</p><p><b>  轉(zhuǎn)移指令</b></p><p>  非零條件轉(zhuǎn)移指令(JNZ)格式:</p><p>  非負(fù)條件轉(zhuǎn)移指令(JNS)格式:</p>

13、<p>  無條件轉(zhuǎn)移指令(JMP)格式:</p><p><b>  MOV指令</b></p><p><b>  MOV指令格式:</b></p><p><b>  相加指令</b></p><p>  相加指令(ADD)格式:</p><

14、p><b>  有符號乘法指令</b></p><p>  乘法指令(IMUL)格式:</p><p><b>  加1指令</b></p><p>  加1指令(INC)格式:</p><p><b>  減1指令</b></p><p>  減

15、1指令(DEC)格式:</p><p><b>  相與指令</b></p><p>  相與指令(AND)格式:</p><p><b>  字符串存儲指令</b></p><p>  乘法指令(STO)格式:</p><p><b>  字符串存儲指令</

16、b></p><p>  乘法指令(STOI)格式:</p><p><b>  取數(shù)指令</b></p><p>  取數(shù)指令(LAD)格式:</p><p><b>  指令系統(tǒng)表:</b></p><p>  其中,對源寄存器Rs與目的寄存器Rd的規(guī)定如下:<

17、;/p><p>  模型機規(guī)定數(shù)據(jù)的表示采用定點整數(shù)補碼表示,單字長為8位,其格式如下: </p><p><b>  時序產(chǎn)生電路的設(shè)計</b></p><p>  T1、T2、T3、T4與CLR、Q之間的關(guān)系圖如圖 1所示。</p><p><b>  圖 1</b></p><

18、p>  機器指令的微程序流程圖以及微指令的設(shè)計</p><p>  要設(shè)計微程序控制器,首先要設(shè)計微程序流程圖以及微指令,其次再設(shè)計地址轉(zhuǎn)移邏輯電路以及其它邏輯單元電路,設(shè)計步驟如下:</p><p>  根據(jù)指令格式和指令系統(tǒng)設(shè)計所有機器指令的微程序流程圖,并確定每條微指令的微地址和后繼微地址;</p><p>  設(shè)計微指令格式和微指令代碼表;</p

19、><p>  設(shè)計地址轉(zhuǎn)移邏輯電路;</p><p>  設(shè)計微程序控制器中的其它邏輯單元電路,包括微地址寄存器、微命令寄存器和控制存儲器。</p><p>  其中,微程序流程圖設(shè)計如下圖所示:</p><p>  微指令流程圖設(shè)計完成后,開始設(shè)計微指令格式和微指令代碼表,按照要求,CISC模型機系統(tǒng)使用的微指令采用全水平型微指令,字長為28位

20、,其中微命令字段為19位,P字段為3位,后繼微地址為6位,其格式如下:</p><p>  LOAD LDPC LDAR LDIR LDRi LDPSW RS_B S2 S1 S0 ALU_B SW_B LED_B RD_D CS_D RAM_B CS_I ADDR_B CS_I P1 P2 P3 u5-uO</p><p>  按照以上格式,依據(jù)自身設(shè)計的微指令流程圖,可以得到以下的微指

21、令代碼表:</p><p>  地址轉(zhuǎn)移邏輯電路的設(shè)計</p><p>  地址轉(zhuǎn)移邏輯電路是根據(jù)微程序流程圖中的棱形框部分及多個分支微地址,利用微地址寄存器的異步置“1”端,實現(xiàn)微地址的多路轉(zhuǎn)移。</p><p>  由于微地址寄存器中的觸發(fā)器異步置“1”端低電平有效,與µA5~µA0對應(yīng)的異步置“1”控制信號SE6~SE1的邏輯表達式為:&l

22、t;/p><p>  SE6= ZF·P(3)·T4</p><p>  SE5=ZF·P(2)·T4</p><p>  SE4=I15·P(1)·T4</p><p>  SE3=I14·P(1)·T4</p><p>  SE2=I13&

23、#183;P(1)·T4</p><p>  SE1=I12·P(1)·T4</p><p><b>  軟件清單</b></p><p><b>  ALU設(shè)計:</b></p><p>  其中S2,S1,S0表示的是算術(shù)邏輯運算單元ALU,其功能表為:</p

24、><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_ARITH.ALL;</p><p>  USE IEEE.STD_L

25、OGIC_SIGNED.all;</p><p>  ENTITY ALU IS</p><p><b>  PORT(</b></p><p>  X: IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  Y: IN STD_LOGIC_VECTOR(7 DOWNTO 0);</

26、p><p>  S2,S1,S0: IN STD_LOGIC;</p><p>  ALUOUT: OUT STD_LOGIC_VECTOR(7 DOWNTO 0) ;</p><p>  SF,ZF: OUT STD_LOGIC</p><p><b>  );</b></p><p><b&

27、gt;  END ALU;</b></p><p>  ARCHITECTURE A OF ALU IS</p><p>  SIGNAL AA,BB,TEMP:STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b>  BEGIN </b></p><p><b>  

28、PROCESS</b></p><p><b>  BEGIN </b></p><p>  IF(S2='0' AND S1='0' AND S0='0') THEN--ADD</p><p><b>  AA<=X;</b></p>&l

29、t;p><b>  BB<=Y;</b></p><p>  TEMP<=AA+BB;</p><p>  ALUOUT<=TEMP(7 DOWNTO 0);</p><p>  SF<=TEMP(7);</p><p>  IF (TEMP="10000000" OR

30、TEMP="00000000")THEN</p><p><b>  ZF<='1';</b></p><p><b>  ELSE</b></p><p><b>  ZF<='0';</b></p><p>&

31、lt;b>  END IF;</b></p><p>  ELSIF(S2='0' AND S1='0' AND S0='1') THEN --CMP(SUB)</p><p>  ALUOUT<=X-Y;</p><p>  IF(X<Y) THEN</p><

32、p><b>  SF<='1';</b></p><p><b>  ZF<='0';</b></p><p>  ELSIF(X=Y) THEN</p><p><b>  SF<='0';</b></p><

33、;p><b>  ZF<='1';</b></p><p><b>  ELSE </b></p><p><b>  SF<='0';</b></p><p><b>  ZF<='0';</b></

34、p><p><b>  END IF;</b></p><p>  ELSIF(S2='0' AND S1='1' AND S0='0') THEN --INC</p><p><b>  AA<=Y;</b></p><p>  TEMP&

35、lt;=AA+1;</p><p>  ALUOUT<=TEMP(7 DOWNTO 0);</p><p>  SF<=TEMP(7);</p><p>  IF (TEMP="10000000" OR TEMP="00000000") THEN</p><p><b>  ZF&

36、lt;='1';</b></p><p><b>  ELSE</b></p><p><b>  ZF<='0';</b></p><p><b>  END IF;</b></p><p>  ELSIF(S2='0

37、' AND S1='1' AND S0='1') THEN --DEC</p><p><b>  AA<=Y;</b></p><p>  TEMP<=AA-1;</p><p>  ALUOUT<=TEMP(7 DOWNTO 0);</p><p> 

38、 SF<=TEMP(7);</p><p>  IF (TEMP="10000000" OR TEMP="00000000") THEN</p><p><b>  ZF<='1';</b></p><p><b>  ELSE</b></p>

39、<p><b>  ZF<='0';</b></p><p><b>  END IF;</b></p><p>  ELSIF(S2='1' AND S1='0' AND S0='0') THEN --AND</p><p>  

40、TEMP<=Y AND Y;</p><p>  ALUOUT<=TEMP;</p><p>  SF<=TEMP(7);</p><p>  IF (TEMP="10000000" OR TEMP="00000000") THEN</p><p><b>  ZF<=

41、'1';</b></p><p><b>  ELSE</b></p><p><b>  ZF<='0';</b></p><p><b>  END IF;</b></p><p>  ELSIF(S2='1'

42、; AND S1='0' AND S0='1') THEN --OR</p><p>  TEMP<=X OR Y;</p><p>  ALUOUT<=TEMP;</p><p>  SF<=TEMP(7);</p><p>  IF (TEMP="10000000&quo

43、t; OR TEMP="00000000") THEN</p><p><b>  ZF<='1';</b></p><p><b>  ELSE</b></p><p><b>  ZF<='0';</b></p><

44、;p><b>  END IF;</b></p><p>  ELSIF(S2='1' AND S1='1' AND S0='0') THEN --Rd->BUS</p><p>  ALUOUT<=Y;</p><p><b>  SF<=Y(7);&l

45、t;/b></p><p>  ELSIF(S2='1' AND S1='1' AND S0='1') THEN --IMUL</p><p>  TEMP<=Y *Y;</p><p>  SF<=TEMP(7);</p><p>  ALUOUT<=TEMP;

46、</p><p>  IF (TEMP="10000000" OR TEMP="00000000") THEN</p><p><b>  ZF<='1';</b></p><p><b>  ELSE</b></p><p><b

47、>  ZF<='0';</b></p><p><b>  END IF;</b></p><p><b>  ELSE</b></p><p>  ALUOUT<="00000000" ;</p><p><b>  ZF

48、<='0';</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p><b>  END A;</b></p><p>  算術(shù)邏輯單元ALU電路圖如圖 2所示:</p><p&g

49、t;<b>  圖 2</b></p><p>  4選1數(shù)據(jù)選擇器MUX4</p><p><b>  VHDL源程序</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  

50、ENTITY MUX4_1 IS</p><p><b>  PORT(</b></p><p>  R0,R1,R2,R3:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  X:OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  I11,I10:I

51、N STD_LOGIC</p><p><b>  );</b></p><p>  END MUX4_1;</p><p>  ARCHITECTURE A OF MUX4_1 IS</p><p><b>  BEGIN</b></p><p><b>  PR

52、OCESS</b></p><p><b>  BEGIN </b></p><p>  IF(I11='0' AND I10='0') THEN </p><p><b>  X<=R0;</b></p><p>  ELSIF(I1

53、1='0' AND I10='1')THEN </p><p><b>  X<=R1;</b></p><p>  ELSIF(I11='1' AND I10='0')THEN </p><p><b>  X<=R2;</b><

54、;/p><p><b>  ELSE</b></p><p><b>  X<=R3;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p><b>  END A;<

55、/b></p><p>  4選1選擇器MUX4電路圖如圖 3所示:</p><p><b>  圖 3</b></p><p>  5選1數(shù)據(jù)選擇器MUX5</p><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;

56、 </p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY MUX5 IS</p><p><b>  PORT(</b></p><p>  SW_B,RS_B,RAM_B,ADDR_B,ALU_B : IN STD_LOGIC;<

57、;/p><p>  SW,RS,RAM,ADDR,ALU: IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  W: OUT STD_LOGIC_VECTOR(7 DOWNTO 0)</p><p><b>  );</b></p><p><b>  END MUX5;</

58、b></p><p>  ARCHITECTURE A OF MUX5 IS</p><p>  SIGNAL SEL:STD_LOGIC_VECTOR(4 DOWNTO 0);</p><p><b>  BEGIN </b></p><p>  SEL<=SW_B&RS_B&RAM_B&a

59、mp;ADDR_B&ALU_B;</p><p>  PROCESS(SEL)</p><p><b>  BEGIN</b></p><p>  IF(SEL="01111")THEN </p><p><b>  W<=SW;</b></p>&l

60、t;p>  ELSIF(SEL="10111")THEN </p><p><b>  W<=RS;</b></p><p>  ELSIF(SEL="11011")THEN </p><p><b>  W<=RAM;</b></p><p&g

61、t;  ELSIF(SEL="11101")THEN </p><p><b>  W<=ADDR;</b></p><p>  ELSIF(SEL="11110")THEN </p><p><b>  W<=ALU;</b></p><p>&

62、lt;b>  ELSE</b></p><p><b>  NULL;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p><b>  END A;</b></p><p

63、>  5選1數(shù)據(jù)選擇器電路圖如圖 4所示:</p><p><b>  圖 4</b></p><p><b>  狀態(tài)字器存器PSW</b></p><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;

64、 </p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY PSW IS</p><p><b>  PORT(</b></p><p>  LDPSW : IN STD_LOGIC;</p><p>  ZI,SI: IN STD

65、_LOGIC;</p><p>  FZ,FS: OUT STD_LOGIC</p><p><b>  );</b></p><p><b>  END PSW;</b></p><p>  ARCHITECTURE A OF PSW IS</p><p><b>

66、;  BEGIN </b></p><p>  PROCESS(LDPSW)</p><p><b>  BEGIN</b></p><p>  IF(LDPSW'EVENT AND LDPSW='1')THEN</p><p><b>  FZ<=ZI;</b&

67、gt;</p><p><b>  FS<=SI;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p><b>  END A;</b></p><p>  狀態(tài)字寄存器PSW電

68、路圖如圖 5所示:</p><p><b>  圖 5</b></p><p>  微程序控制器CROM</p><p>  CROM的電路圖如圖 6所示:</p><p><b>  圖 6</b></p><p>  其內(nèi)部電路圖如圖 7所示:</p>&l

69、t;p><b>  圖 7</b></p><p>  其組成的部件有以下:</p><p>  地址轉(zhuǎn)移邏輯ADDR</p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY ADDR I

70、S </p><p><b>  PORT(</b></p><p>  I15,I14,I13,I12:IN STD_LOGIC;</p><p>  FZ,FS,T4,P1,P2,P3:IN STD_LOGIC;</p><p>  SE6,SE5,SE4,SE3,SE2,SE1:OUT STD_LOGIC</

71、p><p><b>  );</b></p><p><b>  END ADDR;</b></p><p>  ARCHITECTURE A OF ADDR IS</p><p><b>  BEGIN</b></p><p>  SE6<=NOT

72、((NOT FS) AND P3 AND T4); </p><p>  SE5<=NOT ((NOT FZ) AND P2 AND T4);</p><p>  SE4<=NOT ( I15 AND P1 AND T4);</p><p>  SE3<=NOT (I14 AND P1 AND T4);</p><p> 

73、 SE2<=NOT (I13 AND P1 AND T4);</p><p>  SE1<=NOT (I12 AND P1 AND T4);</p><p><b>  END A;</b></p><p>  ?地址轉(zhuǎn)移邏輯ADDR電路圖如圖 8所示:</p><p><b>  圖 8</

74、b></p><p>  微命令寄存器MCOMMAND</p><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC

75、_ARITH.ALL;</p><p>  USE IEEE.STD_LOGIC_SIGNED.ALL;</p><p>  ENTITY MCOMMAND IS</p><p><b>  PORT(</b></p><p>  T2,T3,T4:IN STD_LOGIC; </p><p> 

76、 D:IN STD_LOGIC_VECTOR(20 DOWNTO 0);</p><p>  LOAD,LDPC,LDAR,LDIR,LDRI,LDPSW,RS_B,S2,S1,S0:OUT STD_LOGIC;</p><p>  ALU_B,SW_B,LED_B,RD_D,CS_D,RAM_B,CS_I,ADDR_B,P1,P2,P3:OUT STD_LOGIC <

77、/p><p><b>  );</b></p><p>  END MCOMMAND;</p><p>  ARCHITECTURE A OF MCOMMAND IS</p><p>  SIGNAL DATAOUT:STD_LOGIC_VECTOR(20 DOWNTO 0);</p><p>&l

78、t;b>  BEGIN </b></p><p>  PROCESS(T2)</p><p><b>  BEGIN</b></p><p>  IF(T2'EVENT AND T2='1') THEN</p><p>  DATAOUT(20 DOWNTO 0)<=D(2

79、0 DOWNTO 0);</p><p><b>  END IF;</b></p><p>  LOAD<=DATAOUT(20);</p><p>  LDPC<=DATAOUT(19) AND T4;</p><p>  LDAR<=DATAOUT(18) AND T3;</p>&

80、lt;p>  LDIR<=DATAOUT(17) AND T3;</p><p>  LDRI<=DATAOUT(16) AND T4;</p><p>  LDPSW<=DATAOUT(15) AND T4;</p><p>  RS_B<=DATAOUT(14);</p><p>  S2<=DATAO

81、UT(13);</p><p>  S1<=DATAOUT(12);</p><p>  S0<=DATAOUT(11);</p><p>  ALU_B<=DATAOUT(10);</p><p>  SW_B<=DATAOUT(9);</p><p>  LED_B<=DATAOUT(

82、8);</p><p>  RD_D<=NOT(NOT DATAOUT(7) AND (T2 OR T3));</p><p>  CS_D<=NOT(NOT DATAOUT(6) AND T3);</p><p>  RAM_B<=DATAOUT(5);</p><p>  CS_I<=DATAOUT(4);<

83、/p><p>  ADDR_B<=DATAOUT(3);</p><p>  P1<=DATAOUT(2);</p><p>  P2<=DATAOUT(1);</p><p>  P3<=DATAOUT(0);</p><p>  END PROCESS;</p><p>

84、<b>  END A;</b></p><p>  ?微命令寄存器MCOMMAND電路圖如圖 9所示:</p><p><b>  圖 9</b></p><p><b>  微地址寄存器aa</b></p><p><b>  VHDL源程序</b>

85、</p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY MMM IS </p><p><b>  PORT(</b></p><p>  SE:IN STD_LOGIC; </p

86、><p>  T2:IN STD_LOGIC; </p><p>  D:IN STD_LOGIC; </p><p>  CLR:IN STD_LOGIC; </p><p>  UA:OUT STD_LOGIC </p><p><b>  );</b></p>

87、<p><b>  END MMM;</b></p><p>  ARCHITECTURE A OF MMM IS</p><p><b>  BEGIN</b></p><p>  PROCESS(CLR,SE,T2)</p><p><b>  BEGIN</b&g

88、t;</p><p>  IF(CLR='0') THEN </p><p><b>  UA<='0';</b></p><p>  ELSIF(SE='0')THEN </p><p><b>  UA<='1';</b>

89、;</p><p>  ELSIF(T2'EVENT AND T2='1') THEN </p><p><b>  UA<=D;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p

90、><b>  END A;</b></p><p>  微程序寄存器內(nèi)部電路圖如圖 10所示:</p><p><b>  圖 10</b></p><p>  微地址寄存器aa合成圖如圖 11所示:</p><p><b>  圖 11</b></p>&

91、lt;p><b>  微地址轉(zhuǎn)換器F1</b></p><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY F1 IS </p>

92、<p><b>  PORT(</b></p><p>  UA5,UA4,UA3,UA2,UA1,UA0: IN STD_LOGIC;</p><p>  D:OUT STD_LOGIC_VECTOR(5 DOWNTO 0)</p><p><b>  );</b></p><p>

93、<b>  END F1;</b></p><p>  ARCHITECTURE A OF F1 IS</p><p><b>  BEGIN</b></p><p>  D(5)<=UA5;</p><p>  D(4)<=UA4;</p><p>  D(3)

94、<=UA3;</p><p>  D(2)<=UA2;</p><p>  D(1)<=UA1;</p><p>  D(0)<=UA0;</p><p><b>  END A;</b></p><p>  ?微地址轉(zhuǎn)換器F1電路圖如圖 12所示:</p>

95、<p><b>  圖 12</b></p><p>  控制存儲器CONROM</p><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p>&l

96、t;p>  USE IEEE.STD_LOGIC_ARITH.ALL;</p><p>  USE IEEE.STD_LOGIC_SIGNED.ALL;</p><p>  ENTITY CONTROM IS</p><p>  PORT(ADDR: IN STD_LOGIC_VECTOR(5 DOWNTO 0);</p><p>  

97、UA:OUT STD_LOGIC_VECTOR(5 DOWNTO 0);</p><p>  O:OUT STD_LOGIC_VECTOR(20 DOWNTO 0)</p><p><b>  );</b></p><p>  END CONTROM;</p><p>  ARCHITECTURE A OF CONTRO

98、M IS</p><p>  SIGNAL DATAOUT: STD_LOGIC_VECTOR(26 DOWNTO 0);</p><p><b>  BEGIN </b></p><p><b>  PROCESS</b></p><p><b>  BEGIN</b><

99、;/p><p>  CASE ADDR IS </p><p>  WHEN "000000" => DATAOUT<="110100100011111101100000000";</p><p>  WHEN "000001" => DATAOUT<="10001010

100、0010111111000000000";</p><p>  WHEN "000010" => DATAOUT<="100010100011111110000000000";</p><p>  WHEN "000011" => DATAOUT<="101000000011111111

101、000001111";</p><p>  WHEN "000100" => DATAOUT<="100011100001111111000000000";</p><p>  WHEN "000101" => DATAOUT<="100011101001111111000000000&

102、quot;;</p><p>  WHEN "000110" => DATAOUT<="100011101101111111000000000";</p><p>  WHEN "000111" => DATAOUT<="100000100011111111010000000";<

103、/p><p>  WHEN "001000" => DATAOUT<="101000100011111110000010001";</p><p>  WHEN "001001" => DATAOUT<="010000100011111110000000000";</p>&l

104、t;p>  WHEN "001010" => DATAOUT<="100000000011011111000000000";</p><p>  WHEN "001011" => DATAOUT<="101000111001111111000010001";</p><p>  W

105、HEN "001100" => DATAOUT<="100011111101111111000000000";</p><p>  WHEN "001101" => DATAOUT<="100011110001111111000000000";</p><p>  WHEN "

106、001110" => DATAOUT<="100000100011111111001000000";</p><p>  WHEN "001111" => DATAOUT<="100010100011110011000000000";</p><p>  WHEN "010000&quo

107、t; => DATAOUT<="010000100011111110000000000";</p><p>  WHEN "010001" => DATAOUT<="100000000011100111000000000";</p><p>  WHEN "100000" => D

108、ATAOUT<="010000100011111110000000000";</p><p>  WHEN OTHERS => DATAOUT<="100000100011111111000000000";</p><p><b>  END CASE;</b></p><p>  

109、UA(5 DOWNTO 0)<=DATAOUT(5 DOWNTO 0);</p><p>  O(20 DOWNTO 0)<=DATAOUT(26 DOWNTO 6);</p><p>  END PROCESS;</p><p><b>  END A;</b></p><p>  ?控制存儲器CONRO

110、M電路圖如圖 13所示:</p><p><b>  圖 13</b></p><p><b>  ROM芯片的設(shè)計</b></p><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;</p><p>  USE

111、 IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_ARITH.ALL;</p><p>  USE IEEE.STD_LOGIC_SIGNED.ALL;</p><p>  ENTITY ROM IS </p><p><b>  PORT(</b></p

112、><p>  DOUT:OUT STD_LOGIC_VECTOR(15 DOWNTO 0);</p><p>  ADDR:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  CS_I:IN STD_LOGIC</p><p><b>  );</b></p><p>

113、;<b>  END ROM;</b></p><p>  ARCHITECTURE A OF ROM IS</p><p><b>  BEGIN</b></p><p>  DOUT<="0010000100010001" WHEN ADDR="00000000" AND

114、CS_I='0' ELSE</p><p>  "0010001000000101" WHEN ADDR="00000001" AND CS_I='0' ELSE</p><p>  "0001000000000000" WHEN ADDR="00000010" AND CS_I

115、='0' ELSE</p><p>  "1011000100000000" WHEN ADDR="00000011" AND CS_I='0' ELSE</p><p>  "0101000100000000" WHEN ADDR="00000100" AND CS_I=

116、9;0' ELSE</p><p>  "0110001000000000" WHEN ADDR="00000101" AND CS_I='0' ELSE</p><p>  "0111000000000010" WHEN ADDR="00000110" AND CS_I='0&

117、#39; ELSE</p><p>  "0010000000000000" WHEN ADDR="00000111" AND CS_I='0' ELSE</p><p>  "0010000100010001" WHEN ADDR="00001000" AND CS_I='0'

118、 ELSE</p><p>  "0010001000000101" WHEN ADDR="00001001" AND CS_I='0' ELSE</p><p>  "0011011100000000" WHEN ADDR="00001010" AND CS_I='0' ELS

119、E</p><p>  "0101000100000000" WHEN ADDR="00001011" AND CS_I='0' ELSE</p><p>  "1101111100000000" WHEN ADDR="00001100" AND CS_I='0' ELSE<

120、;/p><p>  "1110000000010000" WHEN ADDR="00001101" AND CS_I='0' ELSE</p><p>  "1100111100000000" WHEN ADDR="00001110" AND CS_I='0' ELSE</p&

121、gt;<p>  "0100110000000000" WHEN ADDR="00001111" AND CS_I='0' ELSE</p><p>  "0110001000000000" WHEN ADDR="00010000" AND CS_I='0' ELSE</p>

122、<p>  "0111000000001010" WHEN ADDR="00010001" AND CS_I='0' ELSE</p><p>  "1000000000010000" WHEN ADDR="00010010" AND CS_I='0' ELSE</p><

123、;p>  "1010000000000000" WHEN ADDR="00010011" AND CS_I='0' ELSE</p><p>  "1001000000010011" WHEN ADDR="00010100" AND CS_I='0' ELSE</p><p&g

124、t;  "0000000000000000";</p><p><b>  END A;</b></p><p><b>  ?</b></p><p>  ROM芯片的設(shè)計電路圖如圖 14所示:</p><p><b>  圖 14</b></p&g

125、t;<p><b>  程序計數(shù)器PC</b></p><p><b>  程序計數(shù)器功能表:</b></p><p><b>  VHDL源程序:</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_

126、1164.ALL;</p><p>  USE IEEE.STD_LOGIC_ARITH.ALL;</p><p>  USE IEEE.STD_LOGIC_SIGNED.ALL;</p><p>  ENTITY PC IS</p><p><b>  PORT(</b></p><p>  L

127、OAD,LDPC,CLR:IN STD_LOGIC;</p><p>  D:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  O:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)</p><p><b>  );</b></p><p><b>  END

128、PC;</b></p><p>  ARCHITECTURE A OF PC IS</p><p>  SIGNAL QOUT:STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  PROCESS(LDPC,CLR,LOAD)</

129、p><p><b>  BEGIN</b></p><p>  IF(CLR='0')THEN</p><p>  QOUT<="00000000";</p><p>  ELSIF(LDPC'EVENT AND LDPC='1')THEN</p>

130、<p>  IF(LOAD='0')THEN</p><p><b>  QOUT<=D;</b></p><p><b>  ELSE</b></p><p>  QOUT<=QOUT+1;</p><p><b>  END IF;</b

131、></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p><b>  O<=QOUT;</b></p><p><b>  END A; </b></p><p>  程序計數(shù)器PC

132、電路圖如圖 15所示:</p><p><b>  圖 15</b></p><p><b>  RAM芯片的設(shè)計</b></p><p><b>  RAM芯片功能表:</b></p><p><b>  VHDL源程序:</b></p>

133、<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_SIGNED.ALL;</p><p>  ENTITY RAM IS <

134、;/p><p><b>  PORT(</b></p><p>  RD_D,CS_D:IN STD_LOGIC;</p><p>  DIN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  ADDR:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p>

135、<p>  DOUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)</p><p><b>  );</b></p><p><b>  END RAM;</b></p><p>  ARCHITECTURE A OF RAM IS</p><p>  TYPE ME

136、MORY IS ARRAY(0 TO 31) OF STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  PROCESS(CS_D)</p><p>  VARIABLE MEM:MEMORY;</p><p><b>  BEGIN&l

137、t;/b></p><p>  IF(CS_D'EVENT AND CS_D='0') THEN</p><p>  IF(RD_D='0') THEN</p><p>  MEM(CONV_INTEGER(ADDR(4 DOWNTO 0))):=DIN;</p><p><b>  E

138、LSE</b></p><p>  DOUT<=MEM(CONV_INTEGER(ADDR(4 DOWNTO 0)));</p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p

139、><p><b>  END A;</b></p><p>  ?RAM芯片的設(shè)計電路圖如圖 16所示:</p><p><b>  圖 16</b></p><p>  1:2分配器單元FEN2</p><p><b>  VHDL源程序:</b><

140、;/p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY FEN2 IS</p><p><b>  PORT(</b></p><p>  LED_B:IN STD_LOGIC;</p>

141、<p>  DBUS:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  FENOUT,OUTBUS:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)</p><p><b>  );</b></p><p><b>  END FEN2;</b></p

142、><p>  ARCHITECTURE A OF FEN2 IS</p><p><b>  BEGIN</b></p><p><b>  PROCESS</b></p><p><b>  BEGIN </b></p><p>  IF(LED_B=&#

143、39;0') THEN </p><p>  OUTBUS<=DBUS;</p><p><b>  ELSE </b></p><p>  FENOUT<=DBUS;</p><p><b>  END IF;</b></p><p>

144、;  END PROCESS;</p><p><b>  END A;</b></p><p>  ?1:2分配器單元FEN2電路圖如圖 17所示:</p><p><b>  圖 17</b></p><p>  時序產(chǎn)生器COUNTER</p><p><b&g

145、t;  VHDL源程序:</b></p><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_SIGNED.ALL;</p

146、><p>  ENTITY COUNTER IS </p><p><b>  PORT(</b></p><p>  CLK,CLR:IN STD_LOGIC;</p><p>  T2,T3,T4:OUT STD_LOGIC</p><p><b>  );</b></

147、p><p>  END COUNTER;</p><p>  ARCHITECTURE A OF COUNTER IS</p><p>  SIGNAL X: STD_LOGIC_VECTOR(1 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  PROCESS

148、(CLK,CLR)</p><p><b>  BEGIN</b></p><p>  IF(CLR='0') THEN</p><p><b>  T2<='0';</b></p><p><b>  T3<='0';</

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論