- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《在系统可编程技术应用设计SOPC技术及应用》 许钢 * 《在系统可编程技术应用设计SOPC技术及应用》 * 第7讲 VHDL子程序 子程序和进程(Process)一样,采用顺序描述来定义算法。和进程不同的是,子程序不可以直接从结构体的其他部分对信号进行读写操作,所有的通信都必须通过子程序的接口完成。由于可以在结构体的不同部分调用子程序完成重复的计算,因此子程序显得非常的实用。和元件例化语句不同的是,当子程序被实体或者其他子程序调用的时候,并不会产生新的设计层次,但是可以通过手工定义的方法增加设计层次。 子程序由过程(PROCEDURE)和函数(FUNCTION)组成。函数只能用以计算数值,而不能用以改变与函数形参相关的对象的值。因此,函数的参量只能是方式为IN的信号与常量;而过程的参量可以为IN, OUT, INOUT方式(注意:不能为BUFFER方式)。过程没有返回值,但是可以通过改变过程参数值的方法向过程的调用者传递信息。 函数和过程常见于面向逻辑综合的设计中,主要进行高层次的数值运算或类型转换、运算符重载,也可用来元件例化。 许钢 * 《在系统可编程技术应用设计SOPC技术及应用》 * 第7讲 VHDL子程序 7.1 函数(Function) 函数的语法格式: 函数首(一般放在程序包的说明部分): FUNCTION 函数名 (输入参数表) RETURN 数据类型 ; 函数体: FUNCTION 函数名 (输入参数表) RETURN 数据类型 IS [说明语句]; BEGIN 顺序处理语句; RETURN 返回变量名; END FUNCTION 函数名 ; 其中输入参数表中的每个参数均应表示为:参数名:数据类型; 许钢 * 《在系统可编程技术应用设计SOPC技术及应用》 * 第7讲 VHDL子程序 例1:函数举例。此函数完成取反功能。(declare.vhd) PACKAGE declare IS --程序包首 TYPE three_level_logic IS (0,1,Z); FUNCTION invert(s :three_level_logic) RETURN three_level_logic ; --函数首 END PACKAGE declare; PACKAGE BODY declare IS --程序包体 FUNCTION invert(s :three_level_logic) RETURN three_level_logic IS –-函数体 VARIABLE temp: three_level_logic ; BEGIN CASE s IS --顺序语句 WHEN 0=temp:=1; WHEN 1=temp:=0; WHEN Z=temp:=Z; END CASE; RETURN temp; END FUNCTION invert; END PACKAGE BODY declare; 7.1 函数(Function) 许钢 * 《在系统可编程技术应用设计SOPC技术及应用》 * 第7讲 VHDL子程序 例1:函数举例。此函数完成取反功能。(declare.vhd) USE WORK.declare.ALL; ENTITY fun_example IS PORT(x: IN three_level_logic; y: OUT three_level_logic); END ENTITY fun_example; ARCHITECTURE a OF fun_example IS BEGIN y=invert(x); --函数的调用! x为in类型 END a; 7.1 函数(Function) 许钢 * 《在系统可编程技术应用设计SOPC技术及应用》 * 第7讲 VHDL子程序 过程的语法格式: 过程首: PROCEDURE 过程名 (参数表); 过程体: PROCEDURE 过程名(参数表)IS [说明语句]; BEGIN 顺序处理语句; END PROCEDURE 过程名; 7.2 过程 (Procedure) 许钢 * 《在系统可编程技术应用设计SOPC技术及应用》 * 第7讲 VHDL子程序 例2:过程举例。此过程返回两数中的
您可能关注的文档
- 模拟电子技术基础:第26讲 信号的转换.ppt
- 模拟电子技术基础:第27讲 功率放大电路.ppt
- 模拟电子技术基础:第30讲 复习与考试.ppt
- 模拟电子技术基础:第一章 常用半导体器件.ppt
- 逆变电路动态模型第六章 逆变电路动态模型.ppt
- 配电自动化系统:第七章 自动抄表及电能计费系统.ppt
- 配电自动化系统:第三章 配电网数据采集与监控系统.ppt
- 配电自动化系统:第五章 馈线自动化.ppt
- 汽车构造课件:第2章-曲柄连杆机构4节-曲轴飞轮组.ppt
- 汽车构造课件:第4章-供给系-2.ppt
- 《在系统可编程技术应用设计&SOPC技术及应用》——第8讲 常用逻辑单元的VHDL语言描述.ppt
- 《在系统可编程技术应用设计&SOPC技术及应用》——第9讲 Altera公司EDA开发环境的高级应用.ppt
- 《自动控制原理》(第六版)课件:01-01自动控制的基本原理与方式.ppt
- 《自动控制原理》(第六版)课件:02-02控制系统的复数域数学模型.ppt
- 《自动控制原理》(第六版)课件:第3章 线性系统的时域分析法1.ppt
- 《自动控制原理》(第六版)课件:第3章 线性系统的时域分析法3.ppt
- 《自动控制原理》(第六版)课件:第4章 线性系统的根轨迹法2.ppt
- 《自动控制原理》(第六版)课件:第4章 线性系统的根轨迹法3.ppt
- 《自动控制原理》(第六版)课件:第5章 线性系统的频域分析法2.ppt
- 《自动控制原理》(第六版)课件:第5章 线性系统的频域分析法3.ppt
原创力文档


文档评论(0)