EDA考试题目+答案.doc
精选优质文档-倾情为你奉上简答:1.VHDL中变量与信号的主要区别一、 变量是一个局部量,只能在进程和子程序,无延时,立即发生,主要作用是在进程中作为临时的数据存储单元。二、 信号是一个全局量,有延时,进程只对信号敏感,不对变量敏感比较对象信号SIGNAL 变量VARIABLE基本用法用于作为电路中的信号连线用于作为进程中局部数据存储单元与Verilog对比信号赋值类似于非阻塞式赋值变量赋值类似于阻塞式赋值适用范围 在整个结构体内的任何地方都适用只能在所定义的进程中使用行为特性 在进程最后才对信号赋值,有延时立即赋值,无延时从VHDL语句功能和行为仿真来看,信号与变量的差异主要表现在接受信息的方式和信息保持与传递的区域大小上。(1)如:信号可以设置传输延迟量,而变量则不能;(2) 如:信号可作为模块间的信息载体,如在结构体中个进程间传递信息;变量只能作为局部的信息载体,如只能在所定义的进程中有效。(3) 变量的设置有时只是一种过渡,最后的信息传输和界面间的通信都是靠信号来完成综合后的信号将对应更多的硬件结构。 2.ASIC、FPGA、EDA、ISP的含义 ASIC:专用集成电路 FPGA:可编程逻辑器件 EDA:电子设计自动化 ISP:因特网服务提供商3.常用的库的名称(IEEE STD WORK VITAL)5.进程语句的特点(1)进程与进程,或其它并行语句之间的并行性,体现硬件电路并行运行特征。(2)进程内部的顺序语句具有顺序与并行双重性。顺序行为体现硬件的逻辑功能,并行行为体现硬件特征。 进程内部使用顺序语句,对一个系统进行算法、行为和逻辑功能进行描述,可以具有高抽象性的特点,可以与具体的硬件没有关联。 这种顺序仅是指语句执行上的顺序(针对于HDL的行为仿真),并不意味着PROCESS语句在综合后所对应的硬件逻辑行为也同样具有顺序性。 VHDL程序无法进行诸如软件语言那样的“单步”调试,因为整个程序是一个整体,不能割裂每一句,只能通过仿真波形来了解程序的问题。(3)进程有启动与挂起两种状态。(4)进程与进程,或其它并行语句之间通过信号交流。(5)时序电路必须由进程中的顺序语句描述,而此顺序语句必须由不完整的条件语句构成。推荐在一个进程中只描述针对同一时钟的同步时序逻辑,而异步时序逻辑或多时钟逻辑必须由多个进程来表达。6.实体定义时端口方向OUT与BUFFER有何不同?OUT:输出端口。定义的通道为单向输出(写)模式,即通过此端口只能将实体内的数据流向外部。BUFFER:缓冲端口。其功能与INOUT类似,区别在于当需要输入数据时,只允许内部回读输出的信号,即允许反馈。如:在计数器的设计中,将计数器输出的计数信号回读,作为下一次计数的初值。与OUT模式相比,BUFFER回读信号不是由外部输入的,而是由内部产生、向外输出信号。即OUT结构体内部不能再使用,BUFFER结构体内部可再使用。半加器的完整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;改错1PROCESS END PROCESS;BEGINWITH s SELECTyout<=0 WHEN “00”; 1 WHEN “01”; 2 WHEN “10”; 'Z' 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.什么是函数的重载?举例说明。VHDL允许以相同的函数名定义函数,但要求函数中定义的操作数具有不同的数据类型,以便调用时用以分辨不同功能的同名函数,以此定义的函数称为重载函数 LIBRARY IEEE ; USE IEEE.STD_LOGIC_1164.ALL ;PACKAGE packexp IS FUNCTION max( a,b :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型状态机与Mealy型状态机有何区别从输出时序上看,前者属于同步输出状态机,而后者属于异步输出状态机。 Moore型状态机的输出仅为当前状态的函数,这类状态机在输入发生变化时还必须等待时钟的到来,时钟使状态发生变化后才导致输出的变化,所以比Mealy机要多等待一个时钟周期。 Mealy型状态机的输出是当前状态和所有输入信号的函数,它的输出是在输入变化后立即发生,不依赖时钟的同步。 编程: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(sel,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); 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<=reg8;END behav;31进制计数器 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 ISBEGIN 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 =>'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位奇偶校验电路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;ARCHITECTURE 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; 编程实现下图所示的控制时序,K为输入信号;处于状态St2时输出信号yout=1,其他状态下yout=0。(此题也会反过来考,给出程序要求画出对应时序图)K=0K=0K=0K=1K=1St1St0St2C_Sinputn-soutputst0k=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,st1,st2); SIGNAL current_state,next_state: FSM_ST;BEGINREG: PROCESS (reset,clk) BEGIN IF reset = '1' THEN current_state <= st0; -检测异步复位信号 ELSIF clk='1' AND clk'EVENT THEN current_state <= next_state; END IF;END PROCESS;COM:PROCESS(current_state, state_Inputs) -主控组合进程 BEGIN 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_outputs<= '1' IF state_inputs = '0' THEN next_state <= st2; ELSE next_state <= st0; END IF; END case;END PROCESS;END behv;: 4位二进制加法计数器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 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多选择语句自顶向下的优先特性。LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY priority83 ISPORT (y0,y1,y2,y3,y4,y5,y6,y7: IN STD_LOGIC; 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 (y4='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_LOGIC_1164.ALL;ENTITY jkff1 ISPORT(clk,j,k: IN STD_LOGIC; q,qn: BUFFER STD_LOGIC);END jkff1;ARCHITECTURE hav OF jkff1 ISBEGINPROCESS(clk,j,k)VARIABLE D : std_logic; BEGIN IF (clk'event AND clk ='1') THEN IF (j='1' AND k='0') THEN D:='1' ELSIF (j='0' AND k='1') THEN D:='0' ELSIF (j='0' AND k='0') THEN D:= D; ELSE D:= NOT D; END IF;END IF;q <= D; qn <= NOT D; END PROCESS;END hav;(下面门电路)LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALLENTITY gate ISPORT (a,b :IN STD_LOGIC; yand,yor,ynand,ynor,ynot,yxor);END gate;ARCHITECTURE art OF gate ISBEGINyand<=a AND b;yor<= a OR b;ynand<= a NAND b;ynor<= a NOR b;ynot<= NOT b;yxor <= a XOR b;END art;专心-专注-专业