1、盛建伦 ,1,习题参考答案,1-14,(1),(2),(3),(4),(5),(6),盛建伦 ,2,习题参考答案,1-16,(1),盛建伦 ,3,习题参考答案,1-16,(2),盛建伦 ,4,习题参考答案,1-16,(3),盛建伦 ,5,习题参考答案,1-16,(4),1-19 输入A、B、C、D是一个十进制数X的8421BCD码,当X为奇数时,输出Y为1,否则Y为0。,习题参考答案,真值表,如果不利用约束项化简,1-19 输入A、B、C、D是一个十进制数X的8421BCD码,当X为奇数时,输出Y为1,否则Y为0。,习题参考答案,真值表,如果利用约束项化简,盛建伦 ,8,数 字 逻 辑,Dig
2、ital Logic,青岛理工大学,广义双语教学课程,211.64.192.58,盛建伦 ,9,硬件描述语言VHDL基础,VHDL(非常高速集成电路硬件描述语言)是由美国国防部支持的一项研究计划,于1983年创建,目的是以文字化方法描述电子电路与系统。1987年,VHDL成为IEEE标准,即IEEE1076标准,1993年修改为IEEE1164标准,1996年,IEEE又将电路合成的标准程序与规格加入到VHDL语言中,称为1076.3标准。之后,又有1076.4标准和1076.6标准。,Very High speed Integrated Circuit Hardware Descriptio
3、n Language,VHDL用语言的方式而非图形等方式描述硬件电路,容易修改,容易保存。特别适合于设计组合逻辑电路和状态机:译码器、编码器、加法器、多路选择器、地址译码器、计数器、 .,附 录 A,盛建伦 ,10,VHDL程序基本结构,VHDL语言通常包含实体(Entity),结构体(Architecture),配置(Configuration),包集合(Package),和库(Library)五部分。,库是专门存放预编译程序包的地方。,其中实体用于描述所设计的系统的外部接口信号;,配置语句安装具体元件到实体结构体对,可以被看作是设计的零件清单;,结构体用于描述系统内部的结构和行为;建立输入
4、和输出之间的关系;,包集合存放各个设计模块共享的数据类型、常数和子程序等;,盛建伦 ,11,VHDL程序设计基本结构,盛建伦 ,12,VHDL主要用于描述设计系统的结构、行为、功能和接口。,器件 或 子系统 ARCHITECTUREProcess Process SequentialProcess CombinationalProcess component Ports,它将一个设计 (元件、电路、系统)分为:,外部( 可视部分、端口), 内部(不可视部分、内部功能、算法)。,Very High speed Integrated Circuit Hardware Description Lan
5、guage,盛建伦 ,13,一、信号(signal)的含义和信号的两种最常用类型:std_logic 和 std_logic_vector,VHDL入门需掌握的基本知识,二、四种常用语句的基本用法赋值语句、if语句、case语句 和 process语句,三、实体(entity)、结构体(architecture)以及一个实体和一个结构体组成的设计实体。,四、层次结构的设计掌握元件(component)语句和端口映射(port map)语句。,五、库(library)和程序包(package)的基本使用。,有了以上入门知识,就能够做一般的设计了。,盛建伦 ,14,库(library)和程序包(p
6、ackage),库(Library)用于存放预先编译好的程序包(Package),,作用:,程序包中定义了数据集合体、逻辑操作和元件等。主要是声明在设计或实体中将用到的常数,数据类型,元件及子程序等。,任何一种设计都要充分利用前人已有的成果,公用的资源要尽可能使用;自己已经设计好的资源也要尽量利用起来,程序包( package )和库(library)就是一些可以公用的资源,是设计实体的一个重要组成部分。,盛建伦 ,15,库(library),设计库对当前设计是可见的,默认的,无需用library子句和use子句说明的库。,VHDL的库分为两种,一种是设计库,一种是资源库。,库是用来放置可编译
7、的设计单元的地方。 VHDL中的常用库有: STD库、WORK库、IEEE库和用户定义库。,Std 和 work 这两个库是设计库。,盛建伦 ,16,VHDL的标准库。库中存放有称为“standard”的标准包集合,其中定义了多种常用的数据类型,均不加说明可直接引用。,库(library),STD库,常用的资源库。IEEE库包含经过IEEE正式认可的STD_LOGIC_1164包集合和某些公司提供的一些包集合,如STD_LOGIC_ARITH(算术运算库)、STD_LOGIC_UNSIGNED等。,WORK库是现行作业库。设计者所描述的VHDL语句不需要任何说明,将都存放在WORK库中。WOR
8、K库对所有设计都是隐含的,因此在使用该库时无需进行任何说明。,IEEE库,WORK库,盛建伦 ,17,库(library),用户定义库,用户定义库简称用户库,是由用户自己创建并定义的库。,除了IEEE标准资源库外,各可编程器件厂家的EDA软件提供自己独特的资源程序包。由于这些程序包是为它们制造的器件服务的,往往更有针对性。 Qartus 中提供了一个LPM库,库中有许多称之为MegaFunctions的功能强大的函数。,设计者可以把自己经常使用的非标准(一般是自己开发的)包集合和实体等汇集在一起定义成一个库,作为对VHDL标准库的补充。,用户定义库在使用时同样要首先进行说明。,盛建伦 ,18,
9、库(library),除了STD库和WORK库之外的其它库均为资源库。,使用资源库中的元件和函数之前,需要使用library子句和use子句予以说明。,没有说明的库中的元件不能使用。,library子句和use子句总是放在设计实体的最前面(可以放在注释之后)。,如果一个设计实体中使用了某个库中的元件和函数,就要使用相应的library子句和use子句。,library子句的作用是使该库在当前文件中“可见”。,盛建伦 ,19,library子句说明使用哪个库,它的格式是library 库名1,库名2,库名n;,库(library),std库和work库是设计库,在任何设计文件中隐含都是“不可见”
10、的,不需要特别说明。也就是说,每一个设计文件中总是隐含下列不可见的行:library std, work;use std.standard.all;,use子句说明使用哪个库中的哪个程序包中的元件或者函数。它的格式是:use 库名.程序包名.all;,这些是不用在程序里写的,盛建伦 ,20,程序包(package),程序包是一种使包体中的类型、常量、元件和函数对其他模块(文件)是可见、可以调用的设计单元。,程序包是公用的存储区,在程序包内说明的数据,可以被其它设计实体使用。程序包由包头和包体两部分组成。,盛建伦 ,21,VHDL语言要素,盛建伦 ,22,VHDL数据对象,数据对象 (Data
11、Objects):,凡是可以被赋予一个值的对象称为数据对象,数据对象用于传递信号。,例 :,数据对象值的类型,数据对象类型,数据对象名,盛建伦 ,23,信号和变量,信号(signal),变量 (variable),是硬件中物理连线的抽象描述,信号在元件的端口连接元件以及在元件内部各部分之间的连接。,在硬件中没有类似的对应关系,它们主要用于保存中间结果。例如作为数组的下标。,常量代表数字电路中的电源、地、恒定逻辑值等常数。,常量( Constant),盛建伦 ,24,信号在逻辑电路设计中最常用的数据类型,在VHDL中有10种数据类型,但是在逻辑电路设计中最常用的是std_logic和std_lo
12、gic_vector提供的数据类型。,std_logic类型分为布尔(boolean)型、位(bit)型、位矢量(bit_vector)型。,std_logic有9种状态,常用的是三种状态:,1 高电平 0 低电平 z 高阻,高阻状态是为了总线的描述,盛建伦 ,25,信号说明,一个信号只有经过说明后才能使用。用VHDL进行设计就是写一系列语句。信号说明形式如下:,一个语句用分号结束。,Signal clock, T1, T2 : std_logic;,Signal 信号名:数据类型 :=设定值;,Signal A : Std_logic_vector(3 Down to 0) := “0000
13、”;,例如:,Signal r0, r1 ,r2, r3 : std_logic_vector(15 downto 0);,Signal r0,r1,r2,r3:std_logic_vector(0 upto 15);,设定值,可选项,盛建伦 ,26,(1)说明位置不同,信号通常在实体、结构体和程序包中说明,变量一般在进程、过程和函数语句中说明;,信号与变量的区别,(2)赋值运算符不同,信号用“ = ”符号进行赋值, 变量用 “ := ”符号赋值;,(3)延迟不同,信号的赋值存在延迟,变量的赋值是直接的,没有任何延迟时间。,从信号说明看不出一个信号是组合逻辑还是时序逻辑(例如寄存器),这与AB
14、EL语言是不同的。,盛建伦 ,27,VHDL 操作符,VHDL操作符:,逻辑操作符,算术操作符,符号操作符,关系操作符,盛建伦 ,28,逻辑运算符,-signal a,b :std_logic;-signal c,d :std_logic_vector(7 downto 0);,有7种逻辑运算符:,NOT、OR、AND、NAND、NOR、XOR 、 XNOR 。,说明:- 是注释开始的标志,这些signal语句的存在只是为了说明这些信号的类型,供阅读方便使用。,两个进行逻辑运算的信号,类型必须相同。例如,a and b a or b not a,正确,c and d c xor d not c
15、,正确,a and c,错误,常用的为前三种。,盛建伦 ,29,不等于 ( a and b) or (c and d),逻辑运算符,例如:,a and b or c and d,等于 (a and b ) or c) and d,这些逻辑运算符, not优先级最高,其他的优先级相同。因此运算时按由左到右的顺序展开。运算时要注意加括号。,NOT、OR、AND、NAND、NOR、XOR 、XNOR 。,能进行逻辑运算的数据类型:bit、 bit_vector、 boolean,std_logic、 std_logic_vector,盛建伦 ,30,Signal a,b,c,d: std_logic
16、_vector(3 downto 0);,Signal e,f,g,h: std_logic_vector(1 downto 0);,d=a and b and c;,d=a or b or c;,d=a xnor b xnor c;,h=e nor f nor g;,h=(e nor f) nor g;,d=(e nor f) nor g;,例,盛建伦 ,31,算术运算符,a + b a + 1,常用的算术运算符有:+ -,-USE ieee.Std_logic_arith.ALL; -signal a,b :std_logic_vector(15 downto 0);,字符串必须用双引号括
17、起来,字符类型通常用单引号引起来,字符类型区分大小写,,a + “01“,求和运算符、求积运算符、符号运算符、混合运算符、移位运算符,VHDL中的求和运算符包括加减运算和并置运算,操作数的数据类型为整型。,例,VHDL语句不区 分大小写,盛建伦 ,32,并置运算符 &,-signal a,b:std_logic_vector(3 downto 0); -signal c,d:std_logic_vector(2 downto 0);a and (1 & c)c & a,并置运算符用于位的连接,形成矢量。也可连接矢量形成更大的矢量。,例如:,盛建伦 ,33,Signal a : std_logi
18、c_vector(4 downto 0);,Signal b : std_logic_vector(2 downto 0);,Signal c : std_logic_vector(1 downto 0);,b c,a = b c,例:,并置运算符 &,并置运算符用于位的连接,形成矢量。也可连接矢量形成更大的矢量。,盛建伦 ,34,关系运算符,= 等于 /= 不等于大于= 大于等于,关系运算符有下列几种:,关系运算的结果为“真”(true)或者“假”(false)。,=、 /= 在实现硬件电路时比其它的关系运算符对芯片的利用率要高,等于、不等于运算符适用于所有的数据类型,其他的运算符适用于整数
19、、位及矢量等。在进行关系运算时,两边的数据类型必须相同,但位长度可以不同。,盛建伦 ,35,VHDL顺序语句,顺序语句的特点是,每一条顺序语句的执行顺序是与它们的书写顺序基本一致的。顺序语句只能出现在进程(Process)和子程序中,子程序包括函数(Function)和过程(Procedure)。,顺序语句的种类:,进程语句 赋值语句流程控制语句等待语句,子程序调用语句返回语句空操作语句,盛建伦 ,36,常用的4种语句,VHDL有许多类型的语句,入门只需掌握4种语句:,赋值语句,if语句,case语句 和 process语句。,盛建伦 ,37,赋值语句,-signal a, b, c: std
20、_logic;-signal d, e, q :std_logic_vector(3 downto 0);,= 是信号赋值符,= 左右两边数据类型必须相同,数据长度必须相同。,1、信号赋值语句,由于信号是物理量,因此赋值有延迟时间。如第二个语句就是一个或门,因此,信号d”或“q后到e有延迟时间。,信号赋值语句的语法格式为: 目标信号名 = 表达式(设定值);,c = not (a and b);e = d or q;,盛建伦 ,38,-variable x,y,z : integer range 0 to 255;x := 0;y := 132;z := x;,赋值语句,2、变量赋值语句,:=
21、是变量赋值符。:=左右两边的数据类型必须相同。由于变量没有相对应的明确的物理量,因此变量赋值没有时间延迟。,盛建伦 ,39,3. 并行赋值语句,(1) 条件赋值语句,格式:,目标信号=表达式1 WHEN 条件1 ELSE,表达式2 WHEN 条件2 ELSE,表达式N-1 WHEN 条件N-1 ELSE,表达式N;,盛建伦 ,40,3. 并行赋值语句,y0 = 1 when a0 = 0 and a1 = 0 else0;,(1) 条件赋值语句,例: 用条件赋值语句描述2 - 4译码器的功能,signal a0, a1: std_logic; -输入 signal y0, y1, y2, y3
22、 : std_logic; -输出,y1 = 1 when a0 = 1 and a1 = 0 else0;,y2 = 1 when a0 = 0 and a1 = 1 else0;,y3 = 1 when a0 = 1 and a1 = 1 else0;,盛建伦 ,41,并行赋值语句,(2) 选择赋值语句,格式:,目标信号 =信号表达式1 WHEN 选择条件1,,信号表达式2 WHEN 选择条件2,,WITH 选择条件表达式 SELECT,信号表达式N WHEN 选择条件N;,盛建伦 ,42,并行赋值语句,(2) 选择赋值语句,signal s: std_logic; -输出signal m
23、: std_logic_vector (1 downto 0); -输入,with m select,例: 用选择赋值语句描述异或门的功能,s =1 when “01“,1 when “10“, 0 when others;,盛建伦 ,43,if 语句,if语句的三种形式:,1、门闩if语句,2、二选一if语句,3、多选一if语句,流程控制语句,语法格式: If expression Thenstatement; Elsif expression Thenstatement; Elsif Thenstatement; elsestatement; End if;,根据条件进行相应赋值操作,注意
24、:不是 Else if,盛建伦 ,44,1、门闩if语句,IF 条件 THEN 若干语句 END IF,例,语句格式,IF ( a b ) THEN out= 1; END IF;,第一种IF语句,这种if语句往往用于产生触发器和锁存器。,盛建伦 ,45,第二种IF语句,IF 条件 THEN 若干语句 ELSE若干语句 END IF,语句格式,IF ( a b ) THEN out= 1; ELSE out=0; END IF;,2、二选一if语句,例,盛建伦 ,46,例: 一个8位二选一数据选择器,用于二选一控制的if语句,-signal sel :std_logic; -signal a,
25、 b,c :std_logic_vector(7 downto 0);,if sel = 1 thenc = a;elsec = b;end if;,盛建伦 ,47,第三种IF语句,If 条件1 Then若干语句; Elsif 条件2 Then若干语句; else 条件n Then若干语句; End if;,语句格式,3、多选一if语句,盛建伦 ,48,例:,Process(A) Begin If A=”00” thenf=D0;elsif A=”01” thenf=D1;elsif A=”10” thenf=D2;else f=D3;end if; end process;,多选一if语句,
26、盛建伦 ,49,process 语句,process语句通常称为进程语句,本质上它描述了一个功能独立的电路块。,在VHDL中,所有的并行执行语句都代表功能独立的电路块,而所有顺序执行语句则是用于描述电路块的功能。,process语句有许多变种,这里只介绍最基本的形式。,流程控制语句,process语句是个并行执行的语句,但是process语句内部的语句要求是顺序执行语句。它是VHDL程序中,描述硬件并行工作的最重要最常用的语句。,50,Process语句的书写格式是:进程名: process(敏感信号1,敏感信号2,敏感信号n)若干变量说明语句begin若干顺序执行语句end process
27、进程名;,process 语句,用方括号括起来的部分是可选的,第一个进程名以冒号结束,和关键字process隔开,它是可选的,可要可不要,对硬件电路没有影响。但建议最好加上进程名,加上进程名等于给这块功能独立的电路加了个标记,增强可读性。,process语句中,begin之前的若干变量说明语句也是可选的。如果该process语句中需要使用变量,则需要在begin之前予以说明。这些被说明的变量只对该进程语句起作用,只能在该process语句中使用。,敏感信号表,盛建伦 ,51,process语句中有个敏感信号表,各敏感信号之间用逗号分开。最后一个敏感信号后面是括号,不需要跟一个逗号。,proce
28、ss 语句,所谓敏感信号就是指当它的状态发生变化时,启动process语句执行。由于process语句代表一块功能独立的电路,它的某些输入信号的状态变化,势必引起电路输出的变化,这些立即引起(当然要经过短暂的时间延迟)输出信号状态变化的信号就是敏感信号。,变量不是真正的物理量,因此不能出现在敏感信号表中。在process语句中只作为输出存在的信号(出现在信号赋值符“=”的左边),不能作为敏感信号。,既出现在信号赋值符“=”的左边,又出现在信号赋值符“=”右边的信号,可以出现在敏感信号表中,这是因为这些信号既作为这块电路的输出,又是电路内部的反馈信号。,盛建伦 ,52,在process语句的书写
29、格式中,在 begin 和 end process 之间的若干顺序执行语句用于描述该process语句所代表的电路块的功能。,process 语句,在前面介绍if语句时,用if语句描述了二选一选择器和多选一选择器。,但是由于if语句是顺序执行语句,因此不能代表一块功能独立的电路,只能成为一块功能独立电路的一部分。需要对前面的if语句进行改造,使之成为一块功能独立的电路(能并行执行)。,改造的方法之一就是将if语句放在process语句中。,盛建伦 ,53,-signal sel: std_logic; -signal a, b, c: std_logic_vector(15 downto 0)
30、; mux2to1: process(sel, a, b)beginif sel = 0 thenc = a;elsec = b;end if;end process;,process 语句,例: 二选一选择器,注意,本例中使用了进程名,不过在end process之后没有书写进程名。,敏感信号表中 有3个输入信号,盛建伦 ,54,case语句,case语句是顺序执行语句,常用来描述总线的行为、编码器和译码器的结构以及状态机等等。case语句可读性好,非常简洁。case语句的书写格式为,流程控制语句,case 条件表达式 iswhen 条件表达式值1 =若干顺序执行语句when 条件表达式n
31、=若干顺序执行语句when others =若干顺序执行语句 end case;,盛建伦 ,55,在case语句中,某一个条件表达式满足时,就执行它后面的顺序执行语句。,case语句,if语句的执行是按顺序执行,各条件有不同的优先级;,case语句各条件表达式值之间不存在不同的优先级,它们是同时执行的,执行的顺序与各条件表达式值的书写顺序无关。,case语句中条件表达式的值须一一列举,不能遗漏;如果不需要一一列举,则用others代替。,case语句和if语句在许多情况下完成的功能是相同的,在这些情况下,用case语句描述比用if语句描述更清晰、更简洁。,盛建伦 ,56,-signal sel
32、 :std_logic_vector(1 downto 0); -signal a, b, c : std_logic; process(a, b, sel) begin sel c c null; end case; end process;,case语句,本例中出现的“null;”是个什么也不做的空语句。,例: 2输入与非门,本例中,首先将与非门输入信号a和b并置,生成一个2位的std_logic_vector信号sel。,信号c是与非门的输出。,第一个when 中的“|”代表或者,即三个条件中的任何一个满足,都执行 c = 1 语句。,实际上与非门一般不这样设计。常用的设计方法是:c =
33、 not (a and b);,盛建伦 ,57,设计实体,在VHDL的设计中,基本设计单元是设计实体。,实体描述了该设计实体对外的接口;结构体描述了设计实体内部的性能;程序包存放各设计实体能共享的数据类型、常数和子程序等等,库中存放已编译好的实体、结构体、程序包和配置。配置描述了实体与构造体之间的连接关系。,一个设计实体最多由5部分构成:实体(entity),一个或者几个结构体(architecture),使用的库(library)和程序包(pachage),配置(configuration)。,这里仅讨论含有一个结构体的设计实体,绝大多数设计实体都是仅含一个结构体的设计实体。一个实体-结构体
34、“对”共同定义一个电路模型。,盛建伦 ,58,设计实体,盛建伦 ,59,实体(entity),实体由实体(entity )语句说明。实体语句又称为实体说明(entity declaration)语句。实体语句的作用是定义设计实体对外的信号。entity语句的书写格式如下:,entity 实体名 is generic (类属参数表);port(端口信号表);实体说明部分;begin实体语句部分;end 实体名;,最常用的形式是:entity 实体名 isport(端口信号表);end 实体名;,盛建伦 ,60,port(端口)语句的书写格式是: port(端口名,端口名:模式 数据类型;端口名,
35、端口名:模式 数据类型;端口名,端口名:模式 数据类型);,实体(entity),实体中的每一个输出/输入被称为一个端口。一个端口实际上是一个信号,因为这些信号负责设计实体与外部的接口,因此称为端口。如果设计实体是一个封装起来的元件,那么端口相当于元件的引脚(pin)。,跟普通信号有两点不同:一是端口一定是信号,因此在说明时省略了关键字signal,二是在说明普通信号的信号说明语句中的信号没有说明方向,端口由于是设计实体与外部的接口,因而是有方向的。,盛建伦 ,61,例:,实体(entity),port(reset, cs: in std_logic;rd, wr: in std_logic;
36、a1, a0: in std_logic;pa, pb: inout std_logic_vector(7 downto 0);pc out std_logic_vector(15 downto 0);,port(端口)语句的书写格式: port(端口名,端口名:模式 数据类型;端口名,端口名:模式 数据类型);,注意:pc信号一行 最后不以分号结束,盛建伦 ,62,端口的模式用来说明信号通过端口的方向和通过方式,这些方向都是相对该设计实体而言的。例如,in模式对设计实体就是输入。有下列几种模式:,实体(entity),in 流入设计实体, 输入,out 从设计实体流出, 输出,inout 双
37、向端口,即可输入,又可输出,buffer 缓存,能用于内部反馈的输出,盛建伦 ,63,out模式和buffer模式的区别在于out端口不能用于设计实体的内部反馈。buffer端口能够用于设计实体的内部反馈。,实体(entity),(a)q1的模式是out,(b)q1的模式是buffer,盛建伦 ,64,结构体 (architecture),结构体描述设计实体内部的特性。结构体的书写格式如下:,architecture 结构体名 of 实体名 is内部信号,常量,数据类型,函数等的定义;begin若干并行执行语句end 结构体名;,实体名一定要与本结构体对应实体的实体名完全一致。architec
38、ture后面的结构体名要与end后的结构体名完全一致,而不是与实体名一致。结构体名可以随便起,因为别的地方很少用到结构体名。,结构体内要求使用并行执行语句。,类似if之类的顺序执行语句,只要将它们放在进程语句process语句之内即可。 process语句是并行执行语句。,盛建伦 ,65,前面已经说明了并行语句和顺序执行语句的区别。,结构体(architecture),并行执行语句代表一个独立的功能电路,因此它一定有明确表示或者隐含表示的输入、输出信号,如process语句中敏感信号表中的信号不是输入信号就是反馈信号。,而顺序执行语句只用于描述电路的功能一般很难判断输入输出信号,因此不能代表一
39、个独立的功能电路,例如从一个if语句中判断输入输出信号就比较难。,盛建伦 ,66,结构体有3种描述方式:行为描述、结构描述和数据流描述。,结构体(architecture),(1) 行为描述 描述该设计实体的功能,即该单元能做什么。,(2) 结构描述 描述该设计实体的硬件结构,即该设计实体的硬件是如何构成的。,(3) 数据流方式 以类似于寄存器传输级的方式描述数据的传输和变换。主要使用并行执行的信号赋值语句,既显式表示了设计实体的行为,也隐式表示了设计实体的结构。,其实初学者不用太钻研各种描述方式的定义,只要能正确描述设计实体的内部特性即可。,盛建伦 ,67,结构体内部要求使用并行执行的语句,
40、这是十分重要的。每个并行执行语句都是一块独立的电路。,结构体(architecture),像与非门这种简单的电路通过信号赋值语句很容易做到,但是像16位寄存器用简单的信号赋值语句就无法实现,因此process语句在结构体内得到了大量的应用。这和电路原理图中是一样的。,在用电路原理图设计的电路中,每块电路也都是并行操作,操作时间也没有先后。所以各process语句之间都是并行执行的。,盛建伦 ,68,在用原理图描述的电路中,各块电路之间使用信号线互相联系。在VHDL语言中,各process语句、各并行执行语句之间同样是通过信号互相联系(或者称之为通信)的。,结构体(architecture),无
41、论用电路原理图的方式设计电路,还是用VHDL语言设计电路,组合逻辑电路中的各个信号,如果不考虑信号传输延迟时间,是没有时间先后的;时序电路中的各信号是通过时钟信号来同步,并且决定时间先后顺序的。,由于结构体中的各并行执行语句都是独立的电路块,因此不允许2个或者2个以上的并行语句对同一个信号赋值。,盛建伦 ,69,例:,设计一个与门电路,逻辑符号,真值表,盛建伦 ,70,Library IEEE; Use std.standard.all; Entity and2 is Port( A: in bit; B: in bit; Y:out bit); End and2;,-首先定义输入输出端口名字
42、,模式(Mode),信号类型,-实体定义:,注意最后语句的 分号在括号外,盛建伦 ,71,Architecture Nb of and2 is Beginy =1 when a=1 and b = 1 else0;End Nb;,结构体的定义可以有不同的形式:,Architecture Na of and2 isBegin y=0 when a=0 and b= 0 else 0 when a=1 and b = 0 else 0 when a=0 and b = 1 else 1;End Na ;,设计一个与门电路,条件赋值语句,行为描述,72,Library IEEE;,USE IEEE.
43、STD_LOGIC_1164.ALL;,ENTITY example IS ;,PORT(a,b,c,d: IN STD_LOGIC;,e : out STD_LOGIC);,END example ;,ACHITECTURE AA1 OF example IS,BEGIN,e=(a and b) or tmp ;,Signal tmp : std_logic;,tmp= c xor d ;,END AA1 ;,例:,并行赋值语句,画逻辑图,Homework,2. 用VHDL设计一个4人表决电路,参加表决者4人,同意为1,不同意为0,同意者过半则表决通过,绿指示灯亮;表决不通过则红指示灯亮。,3. 用VHDL设计一个3线-8线译码器。,1. 用VHDL设计一个8421BCD码优先编码器。,2-1,(a) 当A、B、C中任何一个为0.3V,F1=1V;当A=B=C=3V,F13V, RL(min) 7.5K,(b) 当A=B=C=0.3V,F2=0V;当A、B、C中任何一个为3V,F2=2.3V,习题参考答案,VHDL基本结构框图,