考試題目答案_第1頁(yè)
考試題目答案_第2頁(yè)
考試題目答案_第3頁(yè)
考試題目答案_第4頁(yè)
考試題目答案_第5頁(yè)
已閱讀5頁(yè),還剩2頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、簡(jiǎn)答:1.VHDL中變量與信號(hào)的主要區(qū)別一、 變量是一個(gè)局部量,只能在進(jìn)程和子程序,無(wú)延時(shí),立即發(fā)生,主要作用是在進(jìn)程中作為臨時(shí)的數(shù)據(jù)存儲(chǔ)單元。二、 信號(hào)是一個(gè)全局量,有延時(shí),進(jìn)程只對(duì)信號(hào)敏感,不對(duì)變量敏感比較對(duì)象信號(hào)SIGNAL 變量VARIABLE基本用法用于作為電路中的信號(hào)連線用于作為進(jìn)程中局部數(shù)據(jù)存儲(chǔ)單元與Verilog對(duì)比信號(hào)賦值類似于非阻塞式賦值變量賦值類似于阻塞式賦值適用范圍 在整個(gè)結(jié)構(gòu)體內(nèi)的任何地方都適用只能在所定義的進(jìn)程中使用行為特性 在進(jìn)程最后才對(duì)信號(hào)賦值,有延時(shí)立即賦值,無(wú)延時(shí)從VHDL語(yǔ)句功能和行為仿真來(lái)看,信號(hào)與變量的差異主要表現(xiàn)在接受信息的方式和信息保持與傳遞的區(qū)域

2、大小上。(1)如:信號(hào)可以設(shè)置傳輸延遲量,而變量則不能;(2) 如:信號(hào)可作為模塊間的信息載體,如在結(jié)構(gòu)體中個(gè)進(jìn)程間傳遞信息;變量只能作為局部的信息載體,如只能在所定義的進(jìn)程中有效。(3) 變量的設(shè)置有時(shí)只是一種過(guò)渡,最后的信息傳輸和界面間的通信都是靠信號(hào)來(lái)完成綜合后的信號(hào)將對(duì)應(yīng)更多的硬件結(jié)構(gòu)。 2.ASIC、FPGA、EDA、ISP的含義 ASIC:專用集成電路 FPGA:可編程邏輯器件 EDA:電子設(shè)計(jì)自動(dòng)化 ISP:因特網(wǎng)服務(wù)提供商3.常用的庫(kù)的名稱(IEEE STD WORK VITAL)5.進(jìn)程語(yǔ)句的特點(diǎn)(1)進(jìn)程與進(jìn)程,或其它并行語(yǔ)句之間的并行性,體現(xiàn)硬件電路并行運(yùn)行特征。(2)進(jìn)

3、程內(nèi)部的順序語(yǔ)句具有順序與并行雙重性。順序行為體現(xiàn)硬件的邏輯功能,并行行為體現(xiàn)硬件特征。 進(jìn)程內(nèi)部使用順序語(yǔ)句,對(duì)一個(gè)系統(tǒng)進(jìn)行算法、行為和邏輯功能進(jìn)行描述,可以具有高抽象性的特點(diǎn),可以與具體的硬件沒(méi)有關(guān)聯(lián)。 這種順序僅是指語(yǔ)句執(zhí)行上的順序(針對(duì)于HDL的行為仿真),并不意味著PROCESS語(yǔ)句在綜合后所對(duì)應(yīng)的硬件邏輯行為也同樣具有順序性。 VHDL程序無(wú)法進(jìn)行諸如軟件語(yǔ)言那樣的“單步”調(diào)試,因?yàn)檎麄€(gè)程序是一個(gè)整體,不能割裂每一句,只能通過(guò)仿真波形來(lái)了解程序的問(wèn)題。(3)進(jìn)程有啟動(dòng)與掛起兩種狀態(tài)。(4)進(jìn)程與進(jìn)程,或其它并行語(yǔ)句之間通過(guò)信號(hào)交流。(5)時(shí)序電路必須由進(jìn)程中的順序語(yǔ)句描述,而此順序

4、語(yǔ)句必須由不完整的條件語(yǔ)句構(gòu)成。推薦在一個(gè)進(jìn)程中只描述針對(duì)同一時(shí)鐘的同步時(shí)序邏輯,而異步時(shí)序邏輯或多時(shí)鐘邏輯必須由多個(gè)進(jìn)程來(lái)表達(dá)。6.實(shí)體定義時(shí)端口方向OUT與BUFFER有何不同?OUT:輸出端口。定義的通道為單向輸出(寫(xiě))模式,即通過(guò)此端口只能將實(shí)體內(nèi)的數(shù)據(jù)流向外部。BUFFER:緩沖端口。其功能與INOUT類似,區(qū)別在于當(dāng)需要輸入數(shù)據(jù)時(shí),只允許內(nèi)部回讀輸出的信號(hào),即允許反饋。如:在計(jì)數(shù)器的設(shè)計(jì)中,將計(jì)數(shù)器輸出的計(jì)數(shù)信號(hào)回讀,作為下一次計(jì)數(shù)的初值。與OUT模式相比,BUFFER回讀信號(hào)不是由外部輸入的,而是由內(nèi)部產(chǎn)生、向外輸出信號(hào)。即OUT結(jié)構(gòu)體內(nèi)部不能再使用,BUFFER結(jié)構(gòu)體內(nèi)部可再使

5、用。半加器的完整VHDL描述ENTITY half_adder ISPORT (x,y : IN BIT; s: OUT BIT; c: OUT BIT);END ENTITY half_adder;ARCHITECTURE dataflow OF half_adder IS BEGIN s <= x XOR y; c <= x AND y;END ARCHITECTURE dataflow;改錯(cuò)1PROCESS END PROCESS;BEGINWITH s SELECTyout<=0 WHEN “00”; 1 WHEN “01”; 2 WHEN “10”; 'Z&

6、#39; WHEN others 2SIGNAL q:INTEGER range 0 to 50;CASE q ISWHEN 0 TO 15=>sel<=”001”;WHEN 16TO 50 =>sel<=”110”;END CASE;4.什么是函數(shù)的重載?舉例說(shuō)明。VHDL允許以相同的函數(shù)名定義函數(shù),但要求函數(shù)中定義的操作數(shù)具有不同的數(shù)據(jù)類型,以便調(diào)用時(shí)用以分辨不同功能的同名函數(shù),以此定義的函數(shù)稱為重載函數(shù) LIBRARY IEEE ; USE IEEE.STD_LOGIC_1164.ALL ;PACKAGE packexp IS FUNCTION max( a,b

7、:IN STD_LOGIC_VECTOR) RETURN STD_LOGIC_VECTOR ;FUNCTION max( a,b :IN BIT_VECTOR) RETURN BIT_VECTOR ;FUNCTION max( a,b :IN INTEGER ) RETURN INTEGER ;END; 7.Moore型狀態(tài)機(jī)與Mealy型狀態(tài)機(jī)有何區(qū)別從輸出時(shí)序上看,前者屬于同步輸出狀態(tài)機(jī),而后者屬于異步輸出狀態(tài)機(jī)。 Moore型狀態(tài)機(jī)的輸出僅為當(dāng)前狀態(tài)的函數(shù),這類狀態(tài)機(jī)在輸入發(fā)生變化時(shí)還必須等待時(shí)鐘的到來(lái),時(shí)鐘使?fàn)顟B(tài)發(fā)生變化后才導(dǎo)致輸出的變化,所以比Mealy機(jī)要多等待一個(gè)時(shí)鐘周期。 Me

8、aly型狀態(tài)機(jī)的輸出是當(dāng)前狀態(tài)和所有輸入信號(hào)的函數(shù),它的輸出是在輸入變化后立即發(fā)生,不依賴時(shí)鐘的同步。 編程:3-8譯碼器 LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY dec38 ISPORT(sel: IN STD_LOGIC_VECTOR(2 DOWNTO 0); en: IN STD_LOGIC; y: OUT STD_LOGIC_VECTOR(7 DOWNTO 0);END dec38;ARCHITECTURE rt1 OF dec38 ISBEGINPROCESS(se

9、l,en)BEGIN IF(en='1') THEN y<=(OTHERS=>'0'); y(CONV_INTEGER(sel)<='1' END IF;END PROCESS;END rt1;8位移位寄存器 LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY shift ISPORT (clk,load:IN STD_LOGIC; din: IN STD_LOGIC_VECTOR(7 DOWNTO 0); dout: OUT STD_LOGIC_VECTOR(7 DOWNTO 0);

10、 qb: OUT STD_LOGIC);END shift;ARCHITECTURE behav OF shift ISSIGNAL reg8: STD_LOGIC_VECTOR(7 DOWNTO 0);BEGINPROCESS(clk,load)BEGINIF clk'EVENT AND clk='1' THENIF load='1' THEN reg8<=din;ELSE reg8(6 DOWNTO 0)<=reg8(7 DOWNTO 1);END IF;END IF;END PROCESS;qb<=reg8(0); dout<

11、;=reg8;END behav;31進(jìn)制計(jì)數(shù)器 LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY CNT31 IS PORT (CLK,RST,EN, LOAD : IN STD_LOGIC; DATA:IN STD_LOGIC_VECTOR(4 DOWNTO 0); DOUT:OUT STD_LOGIC_VECTOR(4 DOWNTO 0); COUT:OUT STD_LOGIC ); END ENTITY CNT31;ARCHITECTURE behav OF CNT31 ISB

12、EGIN PROCESS(CLK, RST, EN, LOAD) VARIABLE Q : STD_LOGIC_VECTOR(4 DOWNTO 0); BEGIN IF RST = '0' THEN Q:= (OTHERS =>'0') ; ELSIF CLK'EVENT AND CLK='1' THEN IF EN ='1' THEN IF (LOAD='0') THEN Q:=DATA; ELSE IF Q < 30 THEN Q := Q + 1; ELSE Q:= (OTHERS =&g

13、t;'0'); END IF; END IF; END IF;END IF; IF Q= 30 THEN COUT <= '1' ELSE COUT <='0'END IF;DOUT <= Q; END PROCESS;END behav;8位奇偶校驗(yàn)電路LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY parity_check ISPORT (a:IN STD_LOGIC_VECTOR (7 DOWNTO 0);y:OUT STD_LOGIC);END parity_check;A

14、RCHITECTURE arch OF parity_check ISBEGINPROCESS(a)VARIABLE temp:STD_LOGIC;BEGINtemp:='0' FOR i IN 0 TO 7 LOOPtemp:=temp XOR a(i);END LOOP;y<=temp;END PROCESS;END arch; 編程實(shí)現(xiàn)下圖所示的控制時(shí)序,K為輸入信號(hào);處于狀態(tài)St2時(shí)輸出信號(hào)yout=1,其他狀態(tài)下yout=0。(此題也會(huì)反過(guò)來(lái)考,給出程序要求畫(huà)出對(duì)應(yīng)時(shí)序圖)K=0K=0K=0K=1K=1St1St0St2C_Sinputn-soutputst0k

15、=0st00k=1st2st1k=0st20k=1st0st2k=0st21k=1st0LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY s_machine IS PORT ( clk,reset : IN STD_LOGIC; k : IN STD_LOGIC_VECTOR (1 DOWNTO 0); comb_outputs : OUT STD_LOGIC_VECTOR (3 DOWNTO 0);END ENTITY s_machine;ARCHITECTURE behv OF s_machine IS TYPE FSM_ST IS (st0,

16、st1,st2); SIGNAL current_state,next_state: FSM_ST;BEGINREG: PROCESS (reset,clk) BEGIN IF reset = '1' THEN current_state <= st0; -檢測(cè)異步復(fù)位信號(hào) ELSIF clk='1' AND clk'EVENT THEN current_state <= next_state; END IF;END PROCESS;COM:PROCESS(current_state, state_Inputs) -主控組合進(jìn)程 BEGIN

17、CASE current_state IS WHEN st0 => comb_outputs<='0' IF k = '0' THEN next_state<=st0; ELSE next_state<=st2; END IF; WHEN st1 => comb_outputs<= '0' IF state_inputs = '0' THEN next_state<=st2; ELSE next_state<=st0; END IF; WHEN st2 => comb_outp

18、uts<= '1' IF state_inputs = '0' THEN next_state <= st2; ELSE next_state <= st0; END IF; END case;END PROCESS;END behv;: 4位二進(jìn)制加法計(jì)數(shù)器LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_ARITH.ALL;ENTITY cnt4 ISPORT (clk: IN STD_LOGIC; P: INOUT STD_LOGIC_VECTOR (3 DOWNTO

19、0) );END cnt4;ARCHITECTURE behv OF cnt4 IS BEGIN PROCESS (clk) BEGIN IF clk=1 AND clkEVENT THEN P<=CONV_STD_LOGIC_VECTOR(CONV_INTEGER(P)+1 , 4 ); END IF END PROCESS;END behv;(利用IF多選擇語(yǔ)句自頂向下的優(yōu)先特性。LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY priority83 ISPORT (y0,y1,y2,y3,y4,y5,y6,y7: IN STD_LOGI

20、C; vec: OUT STD_LOGIC_VECTOR (2 DOWNTO 0);END priority83;ARCHITECTURE behavior OF priority83 ISBEGIN PROCESS(y0,y1,y2,y3,y4,y5,y6,y7)BEGIN IF (y7='1') THEN vec<="111" ELSIF (y6='1') THEN vec<="110" ELSIF (y5='1') THEN vec<="101" ELSIF (y

21、4='1') THEN vec<="100" ELSIF (y3='1') THEN vec<="011" ELSIF (y2='1') THEN vec<="010" ELSIF (y1='1') THEN vec<="001" ELSIF (y0='1') THEN vec<="000" ELSE vec<=“XXX" END IF;END PROCESS;END behavior;JKLIBRARY IEEE;USE IEEE.STD_LOG

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論