1简答:1.VHDL中变量与信号的主要区别一、变量是一个局部量,只能在进程和子程序,无延时,立即发生,主要作用是在进程中作为临时的数据存储单元。二、信号是一个全局量,有延时,进程只对信号敏感,不对变量敏感比较对象信号SIGNAL变量VARIABLE基本用法用于作为电路中的信号连线用于作为进程中局部数据存储单元与Verilog对比信号赋值类似于非阻塞式赋值变量赋值类似于阻塞式赋值适用范围在整个结构体内的任何地方都适用只能在所定义的进程中使用行为特性在进程最后才对信号赋值,有延时立即赋值,无延时从VHDL语句功能和行为仿真来看,信号与变量的差异主要表现在接受信息的方式和信息保持与传递的区域大小上。(1)如:信号可以设置传输延迟量,而变量则不能;(2)如:信号可作为模块间的信息载体,如在结构体中个进程间传递信息;变量只能作为局部的信息载体,如只能在所定义的进程中有效。(3)变量的设置有时只是一种过渡,最后的信息传输和界面间的通信都是靠信号来完成综合后的信号将对应更多的硬件结构。2.ASIC、FPGA、EDA、ISP的含义ASIC:专用集成电路FPGA:可编程逻辑器件EDA:电子设计自动化ISP:因特网服务提供商3.常用的库的名称(IEEESTDWORKVITAL)5.进程语句的特点(1)进程与进程,或其它并行语句之间的并行性,体现硬件电路并行运行特征。(2)进程内部的顺序语句具有顺序与并行双重性。顺序行为体现硬件的逻辑功能,并行行为体现硬件特征。进程内部使用顺序语句,对一个系统进行算法、行为和逻辑功能进行描述,可以具有高抽象性的特点,可以与具体的硬件没有关联。这种顺序仅是指语句执行上的顺序(针对于HDL的行为仿真),并不意味着PROCESS语句在综合后所对应的硬件逻辑行为也同样具有顺序性。VHDL程序无法进行诸如软件语言那样的“单步”调试,因为整个程序是一个整体,不能割裂每一句,只能通过仿真波形来了解程序的问题。(3)进程有启动与挂起两种状态。(4)进程与进程,或其它并行语句之间通过信号交流。(5)时序电路必须由进程中的顺序语句描述,而此顺序语句必须由不完整的条件语句构成。推荐在一个进程中只描述针对同一时钟的同步时序逻辑,而异步时序逻辑或多时钟逻辑必须由多个进程来表达。6.实体定义时端口方向OUT与BUFFER有何不同?OUT:输出端口。定义的通道为单向输出(写)模式,即通过此端口只能将实体内的数据流向外部。BUFFER:缓冲端口。其功能与INOUT类似,区别在于当需要输入数据时,只允许内部回读输出的信号,即允许反馈。如:在计数器的设计中,将计数器输出的计数信号回读,作为下一次计数的初值。与OUT模式相比,BUFFER回读信号不是由外部输入的,而是由内部产生、向外输出信号。即OUT结构体内部不能再使用,BUFFER结构体内部可再使用。2半加器的完整VHDL描述ENTITYhalf_adderISPORT(x,y:INBIT;s:OUTBIT;c:OUTBIT);ENDENTITYhalf_adder;ARCHITECTUREdataflowOFhalf_adderISBEGINs=xXORy;c=xANDy;ENDARCHITECTUREdataflow;改错1.PROCESS……ENDPROCESS;BEGINWITHsSELECTyout=0WHEN“00”;1WHEN“01”;2WHEN“10”;'Z'WHENothers2.SIGNALq:INTEGERrange0to50;……CASEqISWHEN0TO15=sel=”001”;WHEN16TO50=sel=”110”;ENDCASE;4.什么是函数的重载?举例说明。VHDL允许以相同的函数名定义函数,但要求函数中定义的操作数具有不同的数据类型,以便调用时用以分辨不同功能的同名函数,以此定义的函数称为重载函数LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;PACKAGEpackexpISFUNCTIONmax(a,b:INSTD_LOGIC_VECTOR)RETURNSTD_LOGIC_VECTOR;FUNCTIONmax(a,b:INBIT_VECTOR)RETURNBIT_VECTOR;FUNCTIONmax(a,b:ININTEGER)RETURNINTEGER;END;7.Moore型状态机与Mealy型状态机有何区别从输出时序上看,前者属于同步输出状态机,而后者属于异步输出状态机。Moore型状态机的输出仅为当前状态的函数,这类状态机在输入发生变化时还必须等待时钟的到来,时钟使状态发生变化后才导致输出的变化,所以比Mealy机要多等待一个时钟周期。Mealy型状态机的输出是当前状态和所有输入信号的函数,它的输出是在输入变化后立即发生,不依赖时钟的同步。3编程:3-8译码器LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;USEIEEE.STD_LOGIC_UNSIGNED.ALL;ENTITYdec38ISPORT(sel:INSTD_LOGIC_VECTOR(2DOWNTO0);en:INSTD_LOGIC;y:OUTSTD_LOGIC_VECTOR(7DOWNTO0));ENDdec38;ARCHITECTURErt1OFdec38ISBEGINPROCESS(sel,en)BEGINIF(en='1')THENy=(OTHERS='0');y(CONV_INTEGER(sel))='1';ENDIF;ENDPROCESS;ENDrt1;8位移位寄存器LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;ENTITYshiftISPORT(clk,load:INSTD_LOGIC;din:INSTD_LOGIC_VECTOR(7DOWNTO0);dout:OUTSTD_LOGIC_VECTOR(7DOWNTO0);qb:OUTSTD_LOGIC);ENDshift;ARCHITECTUREbehavOFshiftISSIGNALreg8:STD_LOGIC_VECTOR(7DOWNTO0);BEGINPROCESS(clk,load)BEGINIFclk'EVENTANDclk='1'THENIFload='1'THENreg8=din;ELSEreg8(6DOWNTO0)=reg8(7DOWNTO1);ENDIF;ENDIF;ENDPROCESS;qb=reg8(0);dout=reg8;ENDbehav;431进制计数器LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;USEIEEE.STD_LOGIC_UNSIGNED.ALL;ENTITYCNT31ISPORT(CLK,RST,EN,LOAD:INSTD_LOGIC;DATA:INSTD_LOGIC_VECTOR(4DOWNTO0);DOUT:OUTSTD_LOGIC_VECTOR(4DOWNTO0);COUT:OUTSTD_LOGIC);ENDENTITYCNT31;ARCHITECTUREbehavOFCNT31ISBEGINPROCESS(CLK,RST,EN,LOAD)VARIABLEQ:STD_LOGIC_VECTOR(4DOWNTO0);BEGINIFRST='0'THENQ:=(OTHERS='0');ELSIFCLK'EVENTANDCLK='1'THENIFEN='1'THENIF(LOAD='0')THENQ:=DATA;ELSEIFQ30THENQ:=Q+1;ELSEQ:=(OTHERS='0');ENDIF;ENDIF;ENDIF;ENDIF;IFQ=30THENCOUT='1';ELSECOUT='0';ENDIF;DOUT=Q;ENDPROCESS;ENDbehav;8位奇偶校验电路LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;ENTITYparity_checkISPORT(a:INSTD_LOGIC_VECTOR(7DOWNTO0);y:OUTSTD_LOGIC);ENDparity_check;ARCHITECTUREarchOFparity_checkISBEGINPROCESS(a)VARIABLEtemp:STD_LOGIC;BEGINtemp:='0';FORiIN0TO7LOOPtemp:=tempXORa(i);ENDLOOP;y=temp;ENDPROCESS;ENDarch;5编程实现下图所示的控制时序,K为输入信号;处于状态St2时输出信号yout=’1’,其他状态下yout=’0’。(此题也会反过来考,给出程序要求画出对应时序图)C_Sinputn-soutputst0k=0st00k=1st2st1k=0st20k=1st0st2k=0st21k=1st0LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;ENTITYs_machineISPORT(clk,reset:INSTD_LOGIC;k:INSTD_LOGIC_VECTOR(1DOWNTO0);comb_outputs:OUTSTD_LOGIC_VECTOR(3DOWNTO0));ENDENTITYs_machine;ARCHITECTUREbehvOFs_machineISTYPEFSM_STIS(st0,st1,st2);SIGNALcurrent_state,next_state:FSM_ST;BEGINREG:PROCESS(reset,clk)BEGINIFreset='1'THENcurrent_state=st0;--检测异步复位信号ELSIFclk='1'ANDclk'EVENTTHENcurrent_state=next_state;ENDIF;ENDPROCESS;COM:PROCESS(current_state,state_Inputs)--主控组合进程BEGINCASEcurrent_stateISWHENst0=comb_outputs='0'IFk='0'THENnext_state=st0;ELSEnext_state=st2;ENDIF;WHENst1=comb_outputs='0';IFstate_inputs='0'THENnext_state=st2;ELSEnext_state=st0;ENDIF;WHENst2=comb_outputs='1';IFstate_inputs='0'THENnext_state=st2;ELSEnext_state=st0;ENDIF;ENDcase;ENDPROCESS;ENDbehv;K=’0’K=’0’K=’0’K=’1’K=’1’St1St0St26:4位二进制加法计数器LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;USEIEEE.STD_LOGIC_ARITH.ALL;ENTITYcnt4ISPORT(clk:INSTD_LOGIC;P:INOUTSTD_LOGIC_VECTOR(3DOWNTO0));ENDcnt4;ARCHITECTUREbehvOFcnt4ISBEGINPROCESS(clk)BEGINIFclk=’1’ANDclk’EVENTTHENP=CONV_STD_LOGIC_VECTOR(CONV_INTEGER(P)+1,4);ENDIFENDPROCESS;ENDbehv;(利用IF多选择语句自顶向下的优先特性。LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;ENTITYpriority83ISPORT(y0,y1,y2,y3,y4,y5,y6,y7:INSTD_LOGIC;vec:OUTSTD_LOGIC_VECTOR(2DOWNTO0));ENDpriority8