《《EDA技术实用教程(第四版)》习题答案.pdf》由会员分享,可在线阅读,更多相关《《EDA技术实用教程(第四版)》习题答案.pdf(36页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、EDA 技术实用教程(第四版)习题1 习题1-1EDA 技术与ASIC 设计和 FPGA 开发有什么关系?FPGA 在 ASIC 设计中有什么用途?P34 1-2 与软件描述语言相比,VHDL 有什么特点?P6 l-3什么是综合?有哪些类型?综合在电子设计自动化中的地位是什么?P5 1-4 在 EDA 技术中,自顶向下的设计方法的重要意义是什么?P710 1-5 IP 在 EDA 技术的应用和发展中的意义是什么?P2214 1-6叙述 EDA 的 FPGA/CPLD 设计流程,以及涉及的EDA 工具及其在整个流程中的作用。(P1113)2 习题2-1OLMC(输出逻辑宏单元)有何功能?说明 G
2、AL 是怎样实现可编程组合电路与时序电路的。P34362-2什么是基于乘积项的可编程逻辑结构?P3334,40什么是基于查找表的可编程逻辑结构?P4041 2-3FPGA 系列器件中的LAB 有何作用?P4345 2-5 解释编程与配置这两个概念。P582-6 请参阅相关资料,并回答问题:按本章给出的归类方式,将基于乘积项的可编程逻辑结构的PLD 器件归类为CPLD;将基于查找表的可编程逻辑结构的PLD 器什归类为FPGA,那么,APEX 系列属于什么类型PLD 器件?MAX II系列又属于什么类型的PLD 器件?为什么?P54563 习题3-1 画出与以下实体描述对应的原理图符号元件:ENT
3、ITY buf3s IS-实体 1:三态缓冲器PORT(input:IN STD_LOGIC;-输入端enable:IN STD_LOGIC;-使能端output:OUT STD_LOGIC);-输出端END buf3s;ENTITY mux21 IS-实体 2:2 选 1 多路选择器PORT(in0,in1,sel:IN STD_LOGIC;output:OUT STD_LOGIC);buf3s input output enable 3-2 图 3-16 所示的是4 选 1 多路选择器,试分别用IF_THEN 语句和 CASE 语句的表达方式写出此电路的VHDL 程序,选择控制信号s1 和
4、 s0 的数据类型为STD_LOGIC_VECTOR;当 s1=0,s0=0;s1=0,s0=1;s1=1,s0=0和 s1=1,s0=1时,分别执行y=a、y=b、y=c、y=d。图 3-16 4 选 1 多路选择器-解 1:用 IF_THEN 语句实现 4 选 1 多路选择器LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY mux41 IS PORT(a,b,c,d:IN STD_LOGIC;s0:IN STD_LOGIC;s1:IN STD_LOGIC;y:OUT STD_LOGIC);END ENTITY mux41;ARCHITECTUR
5、E if_mux41 OF mux41 IS SIGNAL s0s1:STD_LOGIC_VECTOR(1 DOWNTO 0);-定义标准逻辑位矢量数据BEGIN s0s1=s1&s0;-s1 相并 s0,即 s1 与 s0 并置操作PROCESS(s0s1,a,b,c,d)BEGIN IF s0s1=00 THEN y=a;ELSIF s0s1=01 THEN y=b;ELSIF s0s1=10 THEN y=c;ELSE y=d;END IF;END PROCESS;END ARCHITECTURE if_mux41;-解 2:用 CASE 语句实现4 选 1 多路选择器mux21 in0
6、 output in1 sel LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY mux41 IS PORT(a,b,c,d:IN STD_LOGIC;s0:IN STD_LOGIC;s1:IN STD_LOGIC;y:OUT STD_LOGIC);END ENTITY mux41;ARCHITECTURE case_mux41 OF mux41 IS SIGNAL s0s1:STD_LOGIC_VECTOR(1 DOWNTO 0);-定义标准逻辑位矢量数据类型BEGIN s0s1 y y y y NULL;END CASE;END PROCESS
7、;END ARCHITECTURE case_mux41;3-3 图 3-17 所示的是双2 选 1多路选择器构成的电路MUXK,对于其中 MUX21A,当 s=0和 s=1 时,分别有 y=a和 y y y NULL;END CASE;END PROCESS;u2:PROCESS(s1,a1,a2,a3,y)BEGIN CASE s1 IS-类似于真值表的case语句WHEN 0=outy outy NULL;END CASE;END PROCESS;END ARCHITECTURE case_mux31;3-4将例 3-20 程序的计数器改为十二进制计数器,程序用例3-21 的方式表述,并
8、且将复位 RST 改为同步清零控制,加载信号LOAD 改为异步控制方式。讨论例3-20 与例 3-21 的异同点。-解:十二进制计数器VHDL 程序设计。LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY CNT12 IS PORT(CLK,RST,EN,LOAD:IN STD_LOGIC;DATA:IN STD_LOGIC_VECTOR(3 DOWNTO 0);-4位预置数DOUT:OUT STD_LOGIC_VECTOR(3 DOWNTO 0);-计数值输出COUT:OUT STD_
9、LOGIC);-计数进位输出END CNT12;ARCHITECTURE behav OF CNT12 IS SIGNAL Q:STD_LOGIC_VECTOR(3 DOWNTO 0);BEGIN REG:PROCESS(CLK,RST,EN,LOAD,Q)BEGIN IF LOAD=0 THEN Q=DATA;-允许加载ELSIF CLKEVENT AND CLK=1 THEN-检测时钟上升沿IF RST=0 THEN Q0);-计数器异步复位ELSE IF EN=1 THEN-检测是否允许计数或加载(同步使能)IF LOAD=0 THEN Q=DATA;-允许加载ELSE IF Q12 T
10、HEN Q=Q+1;-允许计数,检测是否小于9 ELSE Q0);-大于等于9 时,计数值清零END IF;END IF;END IF;END IF;END IF;END PROCESS;COM:PROCESS(Q)BEGIN IF Q=12 THEN COUT=1;-计数大于9,输出进位信号ELSE COUT=0;END IF;DOUT 0);-计数器异步复位ELSIF CLKEVENT AND CLK=1 THEN-检测时钟上升沿IF ADD_EN=1THEN-检测是否允许计数(同步他能)IF CQI 0);-大于 65535,计数值清零END IF;IF CQI=16#FFFF#THEN
11、 COUT=1;-计数大于9,输出进位信号ELSE COUT 0 THEN CQI:=CQI-1;-允许计数,检测是否小于65535 ELSE CQI:=(OTHERS=1);-大于 65535,计数值清零END IF;IF CQI=0 THEN COUT=1;-计数大于9,输出进位信号ELSE COUT=0;END IF;END IF;END IF;CQ=CQI;-将计数值向端口输出END PROCESS;END ARCHITECTURE A_S_16;3-6 图 3-18 是一个含有上升沿触发的D 触发器的时序电路(sxdl),试写出此电路的VHDL设计文件。图 3-18 时序电路-解:实
12、现图4-19 电路的 VHDL 程序 t4_19.vhd LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY t4_19 IS PORT(CL,CLK0:IN STD_LOGIC;OUT1:OUT STD_LOGIC);END ENTITY t4_19;ARCHITECTURE sxdl OF t4_19 IS-时序电路sxdl SIGNAL Q:STD_LOGIC;BEGIN PROCESS(CLK0)BEGIN IF CLK0EVENT AND CLK0=1 THEN-检测时钟上升沿Q=NOT(Q OR CL);END IF;END PROCES
13、S;OUT1=NOT Q;END ARCHITECTURE sxdl;3-7 给出 1 位全减器的VHDL 描述;最终实现8 位全减器。要求:1)首先设计1 位半减器,然后用例化语句将它们连接起来,图 4-20 中 h_suber是半减器,diff 是输出差(diff=x-y),s_out是借位输出(s_out=1,xy),sub_in 是借位输入。图 3-19 1 位全加器xin yin a b diff_out c-解(1.1):实现 1 位半减器h_suber(diff=x-y;s_out=1,xy)LIBRARY IEEE;-半减器描述(1):布尔方程描述方法USE IEEE.STD_
14、LOGIC_1164.ALL;ENTITY h_suber IS PORT(x,y:IN STD_LOGIC;diff,s_out:OUT STD_LOGIC);END ENTITY h_suber;ARCHITECTURE hs1 OF h_suber IS BEGIN Diff=x XOR(NOT y);s_out xin,y=yin,diff=a,s_out=b);u2:h_suber PORT MAP(x=a,y=sub_in,diff=diff_out,s_out=c);sub_out x0,yin=y0,diff_out=diff0,sub_in=sin,sub_out=a0);u
15、1:f_suber PORT MAP(xin=x1,yin=y1,diff_out=diff1,sub_in=a0,sub_out=a1);u2:f_suber PORT MAP(xin=x2,yin=y2,diff_out=diff2,sub_in=a1,sub_out=a2);u3:f_suber PORT MAP(xin=x3,yin=y3,diff_out=diff3,sub_in=a2,sub_out=a3);u4:f_suber PORT MAP(xin=x4,yin=y4,diff_out=diff4,sub_in=a3,sub_out=a4);u5:f_suber PORT M
16、AP(xin=x5,yin=y5,diff_out=diff5,sub_in=a4,sub_out=a5);u6:f_suber PORT MAP(xin=x6,yin=y6,diff_out=diff6,sub_in=a5,sub_out=a6);u7:f_suber PORT MAP(xin=x7,yin=y7,diff_out=diff7,sub_in=a6,sub_out=sout);END ARCHITECTURE s8;3-8给出一个4 选 1 多路选择器的VHDL 描述。选通控制端有四个输入:S0、S1、S2、S3。当且仅当S0=0 时:Y=A;S1=0 时:Y=B;S2=0 时
17、:Y=C;S3=0 时:Y=D。-解:4 选 1 多路选择器VHDL 程序设计。LIBRARY IEEE;-图 3-20(c)RTL 图的 VHDL 程序顶层设计描述xin sub_out yin u0sub_in diff_out x0 y0 sin diff0 xin sub_out yin u1sub_in diff_out x1 y1 diff1 xin sub_out yin u7sub_in diff_out x7 y7 sout diff7.串行借位的8 位减法器a0 a1 a6 USE IEEE.STD_LOGIC_1164.ALL;ENTITY mux41a IS PORT(
18、A,B,C,D:IN STD_LOGIC;S0,S1,S2,S3:IN STD_LOGIC;Y:OUT STD_LOGIC);END ENTITY mux41a;ARCHITECTURE one OF mux41a IS SIGNAL S0_3:STD_LOGIC_VECTOR(3 DOWNTO 0);BEGIN S0_3=S0&S1&S2&S3;y=A WHEN S0_3=0111 ELSE B WHEN S0_3=1011 ELSE C WHEN S0_3=1101 ELSE D WHEN S0_3=1110 ELSE Z;END ARCHITECTURE one;3-9分频方法有多种,最
19、简单的是二分频和偶数分频甚至奇数分频,这用触发器或指定计数模的计数器即可办到。但对于现场实现指定分频比或小数分频率的分频电路的设计就不是很简单了。试对例 3-20 的设计稍作修改,将其进位输出COUT 与异步加载控制LOAD 连在一起,构成一个自动加载型16 位二进制数计数器,也即一个16 位可控的分频器,给出其VHDL表述,并说明工作原理。设输入频率fi=4MHz,输出频率fo=516.5 1Hz(允许误差 0.1Hz),16 位加载数值是多少?-解:3-9 16 位数控分频器(可进行奇偶数分频)LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEE
20、E.STD_LOGIC_UNSIGNED.ALL;ENTITY DVF16 IS PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC_VECTOR(15 DOWNTO 0);FOUT:OUT STD_LOGIC);END ENTITY DVF16;ARCHITECTURE one OF DVF16 IS SIGNAL FULL:STD_LOGIC;BEGIN P_REG:PROCESS(CLK)VARIABLE CNT8:STD_LOGIC_VECTOR(15 DOWNTO 0);BEGIN IF CLKEVENT AND CLK=1 THEN IF CNT8=00000
21、00000000000 THEN CNT8:=D-1;-当 CNT8 计数归 0 时,预置CNT8=D-1;-计数范围(D=n):n-1n/2 取整(n=10:98765 计数,前后半周期相同)FULL=1;-同时使溢出标志信号FULL 输出为高电平-(n=11:1098765 计数,前比后半周期多一个时钟)ELSIF CNT8=(0&D(15 DOWNTO 1)THEN CNT8:=(0&D(15 DOWNTO 1)-1;-当 CNT8=n/2 取整时,预置 CNT8=D/2 取整-1;-计数范围(D=n):n/2 取整 0(n=10:43210 计数)FULL=1;-同时使溢出标志信号FU
22、LL 输出为高电平(n=11:43210 计数)ELSE CNT8:=CNT8-1;-否则继续作加1 计数FULL=0;-且输出溢出标志信号FULL 为低电平END IF;END IF;END PROCESS P_REG;P_DIV:PROCESS(FULL)VARIABLE CNT2:STD_LOGIC;BEGIN IF FULLEVENT AND FULL=1 THEN CNT2:=NOT CNT2;-如果溢出标志信号FULL 为高电平,D 触发器输出取反IF CNT2=1 THEN FOUT=1;ELSE FOUT 0);-计数器异步复位ELSIF CLKEVENT AND CLK=1
23、THEN-检测时钟上升沿IF EN=1 THEN-检测是否允许计数或加载(同步使能)IF LOAD=0 THEN Q:=DATA;-允许加载ELSE IF Q0);-大于等于9 时,计数值清零END IF;END IF;END IF;END IF;IF Q=9 THEN COUT=1;-计数大于9,输出进位信号ELSE COUT=0;END IF;DOUT 0);-计数器异步复位ELSIF LOAD=1 THEN CQI:=DATA;-LS_LOAD:=0;-计数器异步复位ELSIF CLKEVENT AND CLK=1 THEN-检测时钟上升沿IF ADD_EN=1THEN-检测是否允许计数
24、(同步他能)IF CQI 0);-大于 65535,计数值清零END IF;IF CQI=16#FFFF#THEN COUT=1;-计数大于9,输出进位信号ELSE COUT 0 THEN CQI:=CQI-1;-允许计数,检测是否小于65535 ELSE CQI:=(OTHERS=1);-大于 65535,计数值清零END IF;IF CQI=0 THEN COUT=1;-计数大于9,输出进位信号ELSE COUT=0;END IF;END IF;END IF;CQ=CQI;-将计数值向端口输出END PROCESS;END ARCHITECTURE A_S_16;3-12 分别给出图3-2
25、0 所示的六个RTL 图的 VHDL 描述,注意其中的D 触发器和锁存器的表述。图 3-20 RTL 图图 3-20 RTL 图(a)-解:实现图3-20(a)RTL 图的 VHDL 程序 t3_12_a.vhd LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY t3_12_a IS PORT(CL,CLK0:IN STD_LOGIC;OUT1:OUT STD_LOGIC);END ENTITY t3_12_a;ARCHITECTURE sxdl OF t3_12_a IS-时序电路sxdl SIGNAL Q:STD_LOGIC;BEGIN PRO
26、CESS(CLK0)BEGIN IF CLK0EVENT AND CLK0=1 THEN-检测时钟上升沿Q=NOT(Q OR CL);END IF;END PROCESS;OUT1=NOT Q;END ARCHITECTURE sxdl;图 3-20 RTL 图(b)-解:实现图3-20(b)RTL 图的 VHDL 程序 t3_12_b.vhd LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY t3_12_b IS PORT(A,B,C,D:IN STD_LOGIC;Y:OUT STD_LOGIC);END ENTITY t3_12_b;ARCHI
27、TECTURE sxdl OF t3_12_b IS-时序电路sxdl SIGNAL AB,CD,ABCD:STD_LOGIC;BEGIN PROCESS(A,B,C,D,AB,CD,ABCD)BEGIN AB=A AND B;CD=C OR D;ABCD Y Y NULL;END CASE;END PROCESS;END ARCHITECTURE sxdl;图 3-20 RTL 图(c)-解 1:实现图3-20(c)RTL 图的 VHDL 程序 mux21a.vhd 底层设计描述。-用(WHEN_ELSE)实现 2 选 1 多路选择器程序(mux21a.vhd)。LIBRARY IEEE;U
28、SE IEEE.STD_LOGIC_1164.ALL;ENTITY mux21a IS PORT(a,b:IN STD_LOGIC;s:IN STD_LOGIC;y:OUT STD_LOGIC);END ENTITY mux21a;ARCHITECTURE one OF mux21a IS BEGIN y=a WHEN s=0 ELSE b;END ARCHITECTURE one;-解 2:实现图3-20(c)RTL 图的 VHDL 程序 DFF6.vhd 底层设计描述。-电平触发D 型触发器程序(DFF6.vhd)LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.A
29、LL;ENTITY DFF6 IS PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC;Q:OUT STD_LOGIC);END;ARCHITECTURE bhv OF DFF6 IS BEGIN PROCESS(CLK,D)BEGIN IF CLK=1 THEN Q=D;END IF;END PROCESS;END bhv;-解 3:实现图3-20(c)RTL 图的 VHDL 程序 t3_12_c.vhd 顶层设计描述。LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY t3_12_c IS PORT(D1,D2,CLK:IN
30、 STD_LOGIC;Q:OUT STD_LOGIC);END ENTITY t3_12_c;ARCHITECTURE one OF t3_12_c IS COMPONENT mux21a-调用 2 选 1 多路选择器声明语句PORT(a,b:IN STD_LOGIC;s:IN STD_LOGIC;y:OUT STD_LOGIC);END COMPONENT;COMPONENT DFF6-调用电平型D 触发器声明语句PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC;Q:OUT STD_LOGIC);END COMPONENT;SIGNAL DD:STD_LOGIC;-定
31、义 1 个信号作为内部的连接线。BEGIN u1:mux21a PORT MAP(CLK,D2,D1,DD);u2:DFF6 PORT MAP(CLK,DD,Q);END ARCHITECTURE one;图 3-20 RTL 图(d)-解 1:实现图3-20(d)RTL 图的 VHDL 程序 DFF_PRE.vhd 底层设计描述-带预置、清零和输出使能的D 触发器程序(DFF_PRE.vhd)。LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY DFF_PRE_CLR_ENA IS PORT(CLK:IN STD_LOGIC;D:IN STD_LO
32、GIC;Q:OUT STD_LOGIC;ENA:IN STD_LOGIC;PRE:IN STD_LOGIC;CLR:IN STD_LOGIC);END;ARCHITECTURE bhv OF DFF_PRE_CLR_ENA IS SIGNAL Q1:STD_LOGIC;-类似于在芯片内部定义一个数据的暂存节点BEGIN PROCESS(CLK,D,Q1,ENA,PRE,CLR)BEGIN IF CLR=1 THEN Q1=0;ELSIF PRE=1 THEN Q1=1;ELSIF CLKEVENT AND CLK=1 AND ENA=1 THEN Q1=D;END IF;-IF EN=1 TH
33、EN Q=Q1;-将内部的暂存数据向端口输出-END IF;Q=Q1;-将内部的暂存数据向端口输出END PROCESS;END bhv;-解 2:实现图3-20(d)RTL 图的 VHDL 程序 t3_12_d.vhd 顶层设计描述LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY t3_12_d IS PORT(SET,D,CLK,EN,RESET:IN STD_LOGIC;Q:OUT STD_LOGIC);END ENTITY t3_12_d;ARCHITECTURE one OF t3_12_d IS COMPONENT DFF_PRE_CL
34、R_ENA-调用 D 触发器声明语句PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC;Q:OUT STD_LOGIC;ENA:IN STD_LOGIC;PRE:IN STD_LOGIC;CLR:IN STD_LOGIC);END COMPONENT;SIGNAL SS:STD_LOGIC;-定义 1 个信号作为内部的连接线。BEGIN SS=SET AND(NOT RESET);u1:DFF_PRE_CLR_ENA PORT MAP(CLK,D,Q,EN,SS,RESET);END ARCHITECTURE one;图 3-20 RTL 图(e)-解 1:实现图3-20
35、(e)RTL 图的 VHDL 程序 DFF_PRE_CLR.vhd 底层设计描述-带预置、清零和输出使能的D 触发器程序(DFF_PRE_CLR.vhd)LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY DFF_PRE_CLR_ENA IS PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC;Q:OUT STD_LOGIC;ENA:IN STD_LOGIC;PRE:IN STD_LOGIC;CLR:IN STD_LOGIC);END;ARCHITECTURE bhv OF DFF_PRE_CLR_ENA IS SIGNAL Q
36、1:STD_LOGIC;-类似于在芯片内部定义一个数据的暂存节点BEGIN PROCESS(CLK,D,Q1,ENA,PRE,CLR)BEGIN IF CLR=1 THEN Q1=0;ELSIF PRE=1 THEN Q1=1;ELSIF CLKEVENT AND CLK=1 AND ENA=1 THEN Q1=D;END IF;-IF EN=1 THEN Q=Q1;-将内部的暂存数据向端口输出-END IF;Q=Q1;-将内部的暂存数据向端口输出END PROCESS;END bhv;-解 2:实现图3-20(e)RTL 图的 VHDL 程序 t3_12_d.vhd 顶层设计描述LIBRAR
37、Y IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY t3_12_e IS PORT(D,EN,CLK,RST:IN STD_LOGIC;Q1,Q:OUT STD_LOGIC);END ENTITY t3_12_e;ARCHITECTURE one OF t3_12_e IS COMPONENT DFF_PRE_CLR_ENA-调用 D 触发器声明语句PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC;Q:OUT STD_LOGIC;ENA:IN STD_LOGIC;PRE:IN STD_LOGIC;CLR:IN STD_LOGIC);END
38、 COMPONENT;SIGNAL D_EN:STD_LOGIC;-定义 1 个信号作为内部的连接线。BEGIN D_ENCLK,D=D,Q=Q,ENA=EN,PRE=0,CLR=RST);Q1=(NOT D_EN)OR RST;END ARCHITECTURE one;图 3-20 RTL 图(f)-解 1:实现图3-20(f)RTL 图的 VHDL 程序 mux21a.vhd 底层设计描述-用 WHEN_ELSE 实现 2 选 1 多路选择器程序(mux21a.vhd)LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY mux21a IS POR
39、T(a,b:IN STD_LOGIC;s:IN STD_LOGIC;y:OUT STD_LOGIC);END ENTITY mux21a;ARCHITECTURE one OF mux21a IS BEGIN y=a WHEN s=0 ELSE b;END ARCHITECTURE one;-解 2:实现图3-20(f)RTL 图的 VHDL 程序 DFF_PRE_CLR.vhd 底层设计描述-带预置、清零和输出使能的上升沿D 触发器程序(DFF_PRE_CLR.vhd)LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY DFF_PRE_CLR_EN
40、A IS PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC;Q:OUT STD_LOGIC;ENA:IN STD_LOGIC;PRE:IN STD_LOGIC;CLR:IN STD_LOGIC);END;ARCHITECTURE bhv OF DFF_PRE_CLR_ENA IS SIGNAL Q1:STD_LOGIC;-类似于在芯片内部定义一个数据的暂存节点BEGIN PROCESS(CLK,D,Q1,ENA,PRE,CLR)BEGIN IF CLR=1 THEN Q1=0;ELSIF PRE=1 THEN Q1=1;ELSIF CLKEVENT AND CLK=1
41、AND ENA=1 THEN Q1=D;END IF;-IF EN=1 THEN Q=Q1;-将内部的暂存数据向端口输出-END IF;Q=Q1;-将内部的暂存数据向端口输出END PROCESS;END bhv;-解 3:实现图3-20(f)RTL 图的 VHDL 程序 t3_12_d.vhd 顶层设计描述LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY t3_12_f IS PORT(RST,D,CLK:IN STD_LOGIC;Q,DOUT:OUT STD_LOGIC);END ENTITY t3_12_f;ARCHITECTURE one
42、OF t3_12_f IS COMPONENT DFF_PRE_CLR_ENA-调用 D 触发器声明语句PORT(CLK:IN STD_LOGIC;D:IN STD_LOGIC;Q:OUT STD_LOGIC;ENA:IN STD_LOGIC;PRE:IN STD_LOGIC;CLR:IN STD_LOGIC);END COMPONENT;COMPONENT mux21a-调用 D 触发器声明语句PORT(a,b:IN STD_LOGIC;s:IN STD_LOGIC;y:OUT STD_LOGIC);END COMPONENT;SIGNAL DD,DDD:STD_LOGIC;-定义 1 个信
43、号作为内部的连接线。BEGIN u1:mux21a PORT MAP(D,0,RST,DD);DDD001-011-111-101-100-000)规律工作的六进制同步计数器。4-10 基于原理图输入方式,应用 4 位全加器和74374(8D 触发器)构成 4 位二进制加法计数器。如果使用74299(8 位通用移位寄存器)、74373(8D 锁存器)、D 触发器和非门来完成上述功能,应该有怎样的电路?4-11 用一片 74163(可预置4 位二进制计数器)和两片74138(3 线-8 线译码器)构成一个具有12 路脉冲输出的数据分配器。要求在原理图上标明第1 路到第 12 路输出的位置。若改用
44、一片74195(4 位通用移位寄存器)代替以上的74163(可预置4 位二进制计数器),试完成同样的设计。4-12 用同步时序电路对串行二进制输入进行奇偶校验,每检测 5 位输入,输出一个结果。当 5 位输入中 1 的数目为奇数时,在最后一位的时刻输出1。-解:4-12 用同步时序电路对串行二进制输入进行奇偶校验,每检测5 位输入,输出一个结果。-当 5 位输入中1 的数目为奇数时,在最后一位的时刻输出1。LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY odd_even_p_RXD_
45、5 IS PORT(CLK,RST,S_in:IN STD_LOGIC;-CLK、RST、S_in:时钟、复位、串行输入数据 P_out:OUT STD_LOGIC_VECTOR(4 DOWNTO 0);-P_out:并行输出数据 o_e_out:OUT STD_LOGIC);-o_e_out:奇校验输出位 END ENTITY odd_even_p_RXD_5;ARCHITECTURE one OF odd_even_p_RXD_5 IS BEGIN PROCESS(CLK,RST)VARIABLE shift_Q:STD_LOGIC_VECTOR(4 DOWNTO 0);-shift_Q:
46、移位寄存器 VARIABLE shift_cnt:STD_LOGIC_VECTOR(2 DOWNTO 0);-shift_cnt:移位计数器 BEGIN IF CLKEVENT AND CLK=1 THEN -检测时钟上升沿 IF RST=1 THEN shift_cnt:=100;-移位寄存器和计数器复位 ELSE IF shift_cnt=4 THEN -检测到接收5 位串行输入数据 shift_cnt:=000;-移位计数器清零,为接收下一组数据做准备。P_out=shift_Q;-接收数据并行输出 o_e_out=shift_Q(4)XOR shift_Q(3)XOR shift_Q(
47、2)XOR shift_Q(1)XOR shift_Q(0);-奇校验输出 shift_Q:=S_in&shift_Q(4 DOWNTO 1);-采样移位串行输入 ELSE shift_cnt:=shift_cnt+1;-移位计数 shift_Q:=S_in&shift_Q(4 DOWNTO 1);-采样移位串行输入 END IF;END IF;END IF;END PROCESS;END ARCHITECTURE one;4-13 用 7490(十进制计数器)设计模为872 的计数器,且输出的个位、十位、百位都应符合 8421 码权重。5 习题5-1 什么是固有延时?什么是惯性延时?P150
48、1515-2 是什么?在 VHDL 中,有什么用处?P1525-3 哪些情况下需要用到程序包STD_LOGIC_UNSIGNED?试举一例。答:无符号整数的STD_LOGIC 的数据。(第三版)【例 6-20】数控分频器的设计LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY DVF IS PORT(CLK :IN STD_LOGIC;D :IN STD_LOGIC_VECTOR(7 DOWNTO 0);FOUT:OUT STD_LOGIC);END ENTITY DVF;ARCHITE
49、CTURE one OF DVF IS SIGNAL FULL:STD_LOGIC;BEGIN P_REG:PROCESS(CLK)VARIABLE CNT8:STD_LOGIC_VECTOR(7 DOWNTO 0);BEGIN IF CLKEVENT AND CLK=1 THEN IF CNT8=11111111 THEN CNT8:=D;-当 CNT8计数计满时,输入数据D被同步预置给计数器CNT8 FULL=1;-同时使溢出标志信号FULL输出为高电平 ELSE CNT8:=CNT8+1;-否则继续作加1 计数 FULL=0;-且输出溢出标志信号FULL为低电平 END IF;END I
50、F;END PROCESS P_REG;P_DIV:PROCESS(FULL)VARIABLE CNT2:STD_LOGIC;BEGIN IF FULLEVENT AND FULL=1 THEN CNT2:=NOT CNT2;-如果溢出标志信号FULL为高电平,D触发器输出取反 IF CNT2=1 THEN FOUT=1;ELSE FOUT=0;END IF;END IF;END PROCESS P_DIV;END ARCHITECTURE one;5-4 说明信号和变量的功能特点,以及应用上的异同点。P128P1295-5 什么是重载函数?重载算符有何用处?如何调用重载算符函数?答:(1)什