VHDL并行语句_第1页
VHDL并行语句_第2页
VHDL并行语句_第3页
VHDL并行语句_第4页
VHDL并行语句_第5页
已阅读5页,还剩31页未读 继续免费阅读

下载本文档

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

文档简介

1、六、vhdl语言的并行语句,1、并行信号赋值语句,4、进程语句,3、块语句,2、条件信号赋值语句,5、元件例化语句,6、生成语句,7、并行过程调用语句,结构体,结构体中的并行语句模块,1、并行信号赋值语句,赋值目标 = 表达式,例 architecture curt of bc1 is signal s1, e, f, g, h : std_logic ; begin output1 = a and b ; output2 = c + d ; g = e or f ; h = e xor f ; s1 = g ; end architecture curt,2、条件信号赋值语句,赋值目标 =

2、表达式 when 赋值条件 else 表达式 when 赋值条件 else . 表达式,例 entity mux is port ( a,b,c : in bit ; p1,p2 : in bit ; z : out bit ); end; architecture behv of mux is begin z = a when p1 = 1 else b when p2 = 1 else c ; end,选择信号赋值语句,with 选择表达式 select 赋值目标信号 =表达式 when 选择值, 表达式 when 选择值, ., 表达式 when 选择值,例 . with selt se

3、lect muxout = a when 0|1 , - 0或1 b when 2 to 5 , - 2或3,或4或5 c when 6 , d when 7 , z when others ;,3、块语句,块标号 : block (块保护表达式) 接口说明; 类属说明; begin 并行语句; end block 块标号,与大部分的vhdl语句不同,block语句的应用,包括其中的类属说明和端口定义,都不会影响对原结构体的逻辑功能的仿真结果,例 . b1 : block signal s1: bit ; begin s1 = a and b ; b2 : block signal s2: b

4、it ; begin s2 = c and d ; b3 : block begin z = s2 ; end block b3 ; end block b2 ; y = s1 ; end block b1 ;,4、进程语句,进程标号: process ( 敏感信号参数表 ) is 进程说明部分 begin 顺序描述语句; end process 进程标号,process语句结构的一般表达格式如下,在一个结构体中多个process语句可以同时并发运行,而进程内部语句之间是顺序关系。 process语句在vhdl程序中,是描述硬件并行工作行为的最常用、最基本的语句,process 组成,proc

5、ess语句结构,进程说明,顺序描述语句,敏感信号参数表,信号赋值语句,变量赋值语句,进程启动语句,子程序调用语句,顺序描述语句,进程跳出语句,1) 进程说明部分主要定义一些局部量,可包括数据类型、常数、属性、子程序等。但需注意,在进程说明部分中不允许定义信号和共享变量,2) 顺序描述语句部分可分为赋值语句、进程启动语句、子程序调用语句、顺序描述语句和进程跳出语句等,3)为启动进程,在进程中必须包含有一个显式的敏感信号量表或者包含一个wait语句;敏感信号表应当紧跟在process之后,含有敏感信号表的进程语句中不允许再显式出现wait语句,说明,1. process为一无限循环语句,2. pr

6、ocess语句具有顺序/并行运行双重性,3. 进程必须由敏感信号的变化来启动,4. 信号是多个进程间的通信线,process语句特点,5. 一个进程中只允许描述对应于一个时钟信号的同步时序逻辑,例:entity mul is port (a, b, c, selx, sely : in bit; data_out : out bit ); end mul; architecture ex of mul is signal temp : bit; begin p_a : process (a, b, selx) begin if (selx = 0) then temp = a; else te

7、mp = b; end if; end process p_a; p_b: process(temp, c, sely) begin if (sely = 0) then data_out = temp; else data_out = c; end if; end process p_b; end ex,上例的综合结果,例: library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; entity cnt10 is port(clr: in std_logic; in1:in std_logic_ve

8、ctor(3 downto 0); out1:out std_logic_vector(3 downto 0); end entity cnt10; architecture art of cnt10 is begin process (in1,clr) is begin if (clr= 1 or in1= 1001) then out1=0000; -有清零信号,或计数已达9,out1输出0 else -否则作加1操作 out1=in1+1; -注意,使用了重载算符+,重载算符+是在库 eng if; -std_logic_unsigned中预先声明的 end process; end a

9、rchitecture art,组合电路型十进制加法器cnt10综合后的rtl硬件结构图,一般用于组合电路进程模式,_进程标记: process (_信号名, _信号名, _信号名) variable _变量名 : std_logic; variable _变量名 : std_logic; begin - 指定信号 - 指定变量 - 过程调用 - 如果语句 - case语句 - 循环语句 end process _进程标记,用于时序电路进程模式,_进程标记: process (_信号名, _信号名, _信号名) variable _变量名 : std_logic; variable _变量名

10、: std_logic; begin wait until _时钟信号 = 1; 或 clk event and clk=1 - 指定信号 - 指定变量 - 过程调用 - 如果语句 - case语句 - 循环语句 end process _进程标记,5、元件例化语句,例化名 :元件名 port map( - 元件例化语句 端口名 = 连接端口名,.),元件例化就是将预先设计好的设计实体定义为一个元件,然后利用特定的语句将此元件与当前的设计实体中的指定端口相连接,从而为当前设计实体引入一个新的低一级的设计层次,component 元件名 is generic (类属表); - 元件定义语句 po

11、rt (端口名表); end component 文件名,元件定义(声明)语句,元件例化语句,例:利用元件例化语句设计如下所示电路,library ieee; use ieee.std_logic_1164.all; entity nd2 is port(a,b:in std_logic; c:out std_logic); end entity nd2; architecture artnd2 of nd2 is begin cc1,c=s2,b=d1); -名字关联方式 u3:nd2 port map (s1,s2,c=z1); -混合关联方式 end architecture artor

12、d41,例,6、生成语句,标号: for 循环变量 in 取值范围 generate 说明; begin 并行语句; end generate 标号,表达式 to 表达式 ; - 递增方式,如1 to 5 表达式 downto 表达式 ; - 递减方式,如5 downto 1,标号: if 条件 generate 说明; begin 并行语句; end generate 标号,取值范围,生成语句有一种复制作用,在设计中,只要根据某些条件,设定好某一元件或设计单位,就可以利用生成语句复制一组完全相同的并行元件或设计单元电路结构,生成语句的两种形式,例:利用生成语句产生的八个相同的电路模块,主要的

13、vhdl程序如下: component comp is port (x:in std_logic;y: out std_logic); end component comp; signal a,b:std_logic_vector (0 to 7); gen: for i in arange generate u1:comp port map (x= a(i), y=b(i); end generate gen;,7、并行过程调用语句,procedure 过程名(参数1;参数2;) is 声明语句; begin 顺序处理语句; end 过程名,并行过程调用语句可以作为一个并行语句直接出现在结构

14、体或块语句中。并行过程调用语句的功能等效于包含了同一个过程调用语句的进程。并行过程调用语句的语句调用格式与前面讲的顺序过程调用语句是相同的,过程调用的实质内容要先装入程序包中(package,过程名(关联参数表,并行过程调用,位置关联方式,名字关联方式,参数关联方式,例:设有一过程procedure vect(a,b:in bit; x,y:inout bit); 则调用时: 位置关联方式:vect(in1,in2,out1,out2); 名字关联方式:vect(a=in1,b=in2,x=out1,y=out2,使用说明,1、过程的参数表中可以使用in、out、inout三种;(不能理解为端

15、口) 2、过程可以返回多个变量(通过out、inout 定义的参数返回); 3、参数对象可以为常量(in方式)、信号、变量; 4、在进程外的过程调用为并行过程调用;在进程内的为顺序过程调用,函数调用,function 函数名(参数1;参数2) return 数据类型名 is 定义变量语句; begin 顺序处理语句; return 返回变量名; end 函数名,函数调用的实质内容要先装入程序包中(package,函数名(关联参数表,使用说明,1、函数的参数表中只能为in的信号与常量; 2、函数返回值只有一个(通过return实现,由函数名传给调用者); 3、也可以像过程一样使用位置关联方式和名

16、字关联方式,1、过程可以有多个返回值,函数只有一个; 2、参数传递方式不同: 过程(in out inout) 函数(in,过程(procedure) 函数(function)两者的主要区别,1 库的种类,a. ieee库,b. std库,c. work库,d. vital库,七、vhdl库,2 库的用法,library ieee ; use ieee.std_logic_1164.std_ulogic ; use ieee.std_logic_1164.rising_edge,use语句的使用有两种常用格式: use 库名.程序包名.项目名 ; use 库名.程序包名.all,库的作用范围从

17、一个实体说明开始到它所属的结构体、配置为止,当有两个实体时,第二个实体前要另加库和包的说明,程序包,常数说明,vhdl数据类型说明,元件定义,子程序,定义程序包的一般语句结构如下: package 程序包名 is - 程序包首 程序包首说明部分; end 程序包名; package body 程序包名 is - 程序包体 程序包体说明部分以及包体内顺序语句; end 程序包名,3 vhdl程序包,例: 程序包首,package logic is type three_level_logic is (0,1,z); -数据类型项目 constant unknown_value : three_l

18、evel_logic :=0; - 常数项目 function invert (input: three_level_logic) return three_level_logic; -函数项目 end logic,package body logic is function invert (input: three_level_logic); -函数项目描述 begin case input is when 0 = return 1; when 1 = return 0; when z = return z; end case; end invert; end logic,程序包体,use

19、logic.three_level_logic, logic.invert; -使用数据类型和 函数两个项目 entity inverter is port(x: in three_level_logic ; y: out three_level_logic); end inverter; architecture inverter_body of inverter is begin kk: process begin y=invert(x) after 10ns; wait on x; end process; end inverter_body,该包使用例,package seven is subtype segments is bit_vector(0 to 6) ; type bcd is range 0 to 9 ; end sev

温馨提示

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

评论

0/150

提交评论