VHDL语言第一讲.ppt_第1页
VHDL语言第一讲.ppt_第2页
VHDL语言第一讲.ppt_第3页
VHDL语言第一讲.ppt_第4页
VHDL语言第一讲.ppt_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、数字电子技术实验教程,第 一讲 VHDL设计初步,江苏科技大学 应电中心,1.1 多路选择器的VHDL描述,1.1.1 2选1多路选择器的VHDL描述,图1-1 mux21a实体,1.1 多路选择器的VHDL描述,1.1.1 2选1多路选择器的VHDL描述,图1-2 mux21a结构体,1.1 多路选择器的VHDL描述,1.1.1 2选1多路选择器的VHDL描述,【例1-1】 ENTITY mux21a IS PORT ( a, b : IN BIT; s : IN BIT; y : OUT BIT ); END ENTITY mux21a; ARCHITECTURE one OF mux21

2、a IS BEGIN y = a WHEN s = 0 ELSE b ; END ARCHITECTURE one ;,1.1 多路选择器的VHDL描述,1.1.1 2选1多路选择器的VHDL描述,【例1-2】 ENTITY mux21a IS PORT ( a, b : IN BIT; s : IN BIT; y : OUT BIT ); END ENTITY mux21a; ARCHITECTURE one OF mux21a IS SIGNAL d,e : BIT; -相当电路内部导线 BEGIN d = a AND (NOT S) ; e = b AND s ; y = d OR e

3、; END ARCHITECTURE one ;,1.1 多路选择器的VHDL描述,1.1.1 2选1多路选择器的VHDL描述,【例1-3】 ENTITY mux21a IS PORT ( a, b, s: IN BIT; y : OUT BIT ); END ENTITY mux21a; ARCHITECTURE one OF mux21a IS BEGIN PROCESS (a,b,s) BEGIN IF s = 0 THEN y = a ; ELSE y = b ; END IF; END PROCESS; END ARCHITECTURE one ;,敏感信号,进程语句,完整 IF语句

4、,1.1 多路选择器的VHDL描述,1.1.1 2选1多路选择器的VHDL描述,图1-3 mux21a功能时序波形,1.1 多路选择器的VHDL描述,1.1.2 相关语句结构和语法说明,【例1-4】 ENTITY e_name IS PORT ( p_name : port_m data_type; . p_namei : port_mi data_type ); END ENTITY e_name;,1. 实体表达,2. 实体名,3. 端口语句和端口信号名,1.1 多路选择器的VHDL描述,1.1.2 相关语句结构和语法说明,4. 端口模式,1.1 多路选择器的VHDL描述,1.1.2 相关

5、语句结构和语法说明,5. 数据类型 BIT (0OR 1),6. 结构体表达,【例1-5】 ARCHITECTURE arch_name OF e_name IS 说明语句 BEGIN (功能描述语句) END ARCHITECTURE arch_name ;,1.1 多路选择器的VHDL描述,1.1.2 相关语句结构和语法说明,7. 赋值符号和数据比较符号,赋值符 “=”,表式中的等号“=”没有赋值的含义,只是一种数据比较符号。,IF a THEN . - 注意,a的数据类型必须是boolean IF (s1=0)AND(s2=1)OR(cb+1) THEN .,1.1 多路选择器的VHDL

6、描述,1.1.2 相关语句结构和语法说明 8. 逻辑操作符 AND、OR、NOT 9. 条件语句 IF 表达式 THEN 表达式; ELSE 表达式 ; END IF ; IF语句必须以语句 “END IF;”结束,1.1 多路选择器的VHDL描述,1.1.2 相关语句结构和语法说明,10. WHEN_ELSE条件信号赋值语句 赋值目标 = 表达式 WHEN 赋值条件 ELSE 表达式 WHEN 赋值条件 ELSE . 表达式 ; EXAMPLE: z = a WHEN p1 = 1 ELSE b WHEN p2 = 1 ELSE c ;,图1-4 半加器h_adder电路图及其真值表,1.2

7、.1 半加器描述,1.2 1位二进制全加器的VHDL描述,图1-5 全加器f_adder电路图及其实体模块,1.2.1 半加器描述,1.2 1位二进制全加器的VHDL描述,1.2.1 半加器描述,1.2 1位二进制全加器的VHDL描述,【例1-8】 LIBRARY IEEE; -半加器描述(1):布尔方程描述方法 USE IEEE.STD_LOGIC_1164.ALL; ENTITY h_adder IS PORT ( a, b : IN STD_LOGIC; co, so : OUT STD_LOGIC); END ENTITY h_adder; ARCHITECTURE fh1 OF h_

8、adder is BEGIN so = NOT(a XOR (NOT b) ; co = a AND b ; END ARCHITECTURE fh1;,KX康芯科技,【例1-9】 LIBRARY IEEE; -半加器描述(2):真值表描述方法 USE IEEE.STD_LOGIC_1164.ALL; ENTITY h_adder IS PORT (a, b : IN STD_LOGIC; co, so : OUT STD_LOGIC); END ENTITY h_adder; ARCHITECTURE fh1 OF h_adder is SIGNAL abc : STD_LOGIC_VECT

9、OR(1 DOWNTO 0) ; -标准逻辑位矢量 BEGIN abc so so so so NULL ;-不可省略 空操作语句 END CASE; END PROCESS; END ARCHITECTURE fh1 ;,1.2.1 半加器描述,1.2 1位二进制全加器的VHDL描述,【例1-10】 或门逻辑描述 LIBRARY IEEE ; USE IEEE.STD_LOGIC_1164.ALL; ENTITY or2a IS PORT (a, b :IN STD_LOGIC; c : OUT STD_LOGIC ); END ENTITY or2a; ARCHITECTURE one O

10、F or2a IS BEGIN c = a OR b ; END ARCHITECTURE one ;,KX康芯科技,【例4-11】 LIBRARY IEEE; -1位二进制全加器顶层设计描述 USE IEEE.STD_LOGIC_1164.ALL; ENTITY f_adder IS PORT ( ain,bin,cin : IN STD_LOGIC; cout,sum : OUT STD_LOGIC ); END ENTITY f_adder; ARCHITECTURE fd1 OF f_adder IS COMPONENT h_adder -调用半加器声明语句 PORT ( a,b :

11、IN STD_LOGIC; co,so : OUT STD_LOGIC); END COMPONENT ; COMPONENT or2a PORT (a,b : IN STD_LOGIC; c : OUT STD_LOGIC); END COMPONENT; SIGNAL d,e,f : STD_LOGIC; -定义3个信号作为内部的连接线 BEGIN u1 : h_adder PORT MAP(a=ain,b=bin,co=d,so=e);-例化语句 u2 : h_adder PORT MAP(a=e, b=cin, co=f,so=sum); u3 : or2a PORT MAP(a=d,

12、 b=f, c=cout); END ARCHITECTURE fd1;,VHDL描述的语言现象说明,1. 设计库和标准程序包 LIBRARY WORK ; LIBRARY STD ; USE STD.STANDARD.ALL ; 使用库和程序包的一般定义表式是: LIBRARY ; USE .ALL ;,VHDL描述的语言现象说明,2.数据类型 BIT数据类型定义: TYPE BIT IS(0,1); -只有两种取值 STD_LOGIC数据类型定义: TYPE STD_LOGIC IS (U,X,0,1,Z,W,L,H,-);,VHDL描述的语言现象说明,标准逻辑矢量数据类型,STD_LOG

13、IC STD_LOGIC_VECTOR,在使用STD_LOGIC_VECTOR中,必须注明其数组宽度,即位宽,如: B : OUT STD_LOGIC_VECTOR(7 DOWNTO 0) ; 或 SIGNAL A :STD_LOGIC_VECTOR(1 TO 4),B = 01100010 ; - B(7)为 0 B(4 DOWNTO 1) = 1101 ; - B(4)为 1 B(7 DOWNTO 4) = A ; - B(6)等于 A(2),3 CASE语句,VHDL描述的语言现象说明,1. CASE语句,CASE IS When = ; . ; ; When = ; . ; ; . W

14、HEN OTHERS = ; END CASE ;,江苏科技大学,VHDL描述的语言现象说明,4. 并置操作符 ,SIGNAL a : STD_LOGIC_VECTOR (3 DOWNTO 0) ; SIGNAL d : STD_LOGIC_VECTOR (1 DOWNTO 0) ; . a = 1 0 d(1) 1 ; - 元素与元素并置,并置后的数组长度为4 . IF a d = 101011 THEN . - 在IF条件句中可以使用并置符,江苏科技大学,5 例化语句,VHDL描述的语言现象说明,COMPONENT 元件名 IS PORT (端口名表) ; END COMPONENT 文件

15、名 ;,COMPONENT h_adder PORT ( c,d : IN STD_LOGIC; e,f : OUT STD_LOGIC);,例化名 : 元件名 PORT MAP( 端口名 = 连接端口名,.);,VHDL描述的语言现象说明,相关语句结构和语法说明,进程语句和顺序语句,在一个结构体中可以包含任意个进程语句结构,所有的进程语句都是并行语句,而由任一进程PROCESS引导的语句(包含在其中的语句)结构属于顺序语句。,应用VHDL设计组合电路实例 BCD转换七段码(共阴极数码管1-亮),BCD转换七段码(共阴极数码管1-亮) (Case语句),LIBRARY IEEE; -真值表描述

16、方法 USE IEEE.STD_LOGIC_1164.ALL; ENTITY segc_1 IS PORT (c: IN STD_LOGIC_vector(3 downto 0); s: OUT STD_LOGIC_vector(6 downto 0); END ENTITY segc_1; ARCHITECTURE one OF segc_1 ; BEGIN PROCESS(c) BEGIN CASE c IS -类似于真值表的CASE语句 WHEN “0000” = s s s s NULL ; END CASE; END PROCESS; END ARCHITECTURE one ;,L

17、IBRARY ieee; -真值表描述方法 USE ieee.std_logic_1164.ALL; ENTITY seg7dec IS PORT(bcdin : IN std_logic_vector(3 DOWNTO 0); segout : OUT std_logic_vector(6 DOWNTO 0); END seg7dec; ARCHITECTURE ver3 OF seg7dec IS BEGIN WITH bcdin SELECT segout = 1000000 WHEN X0, 1100111 WHEN X1, 1101101 WHEN X2, 0000000 WHEN

18、X8, 0000001 WHEN X9, “1111111 WHEN OTHERS; END ver3;,BCD转换7段码(共阳极数码管0-亮) (Select语句),LIBRARY ieee; -真值表描述方法 USE ieee.std_logic_1164.ALL; ENTITY seg7dec IS PORT(bcdin : IN std_logic_vector(3 DOWNTO 0); segout : OUT std_logic_vector(6 DOWNTO 0); END seg7dec; ARCHITECTURE ver3 OF seg7dec IS BEGIN segout = 1000000 WHEN bcdin=X0“ ELSE 1100111 WHEN bcdin=X1“ ELSE 1101101 WHEN bcdin=X2“

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论