- 1、本文档共27页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
山东大学 曾繁泰 山东大学 曾繁泰 山东大学 曾繁泰 VHDL程序设计教程(第4版) 第3章 VHDL语言的程序结构 主讲人 :曾繁泰 zft@sdu.edu.cn 3.3 子程序 * 山东大学 曾繁泰 * 子程序(Subprogram)是一个VHDL程序模块,利用顺序语句来定义算法或描述硬件行为。子程序能更有效地完成重复性工作。子程序有两种,即过程语句和函数语句。 3.3.1 过程语句1.过程语句格式 * 山东大学 曾繁泰 * 过程语句的一般格式如下: PROCEDURE 过程名|运算符号 [generic 子句; [generic映射;] ] [[parameter](参数列表)] IS [子程序声明区]; BEGIN [顺序处理语句]; END [PROCEDURE] 过程名|运算符号; [例3-14]用过程语句写的子程序 * 山东大学 曾繁泰 * PROCEDURE V_T_i ( y: IN std_logic_vector; flag: OUT Boolean; g: INOUT integer) IS BEGIN g:=0; flag:=FALSE; FOR: IN y’ range loop g:=g*2; IF (y(i)=1) THEN g:=g+1; ELSEIF (y(i) = 0) THEN flag:=TRUE; END IF; END loop; END v_T_I; 2.过程调用 * 山东大学 曾繁泰 * [例3-15]位矢量到整型数据的转换。 PROCEDURE Bitvector_to_integer (z: IN STD_LOGIC_VECTER; X_flag: OUT BOOLEAN; Q: INOUT INTEGER) IS BEGIN Q := 0; X_falg := TRUE; FOR i IN Z RANGE LOOP Q := q × 2; IF (Z(i) = 1) THEN Q := q + 1; ELSEIF (Z(i) /= 0 ) THEN X_flag := FALSE; END IF; END LOOP; END Bitvector_to_integer; 3.调用规则 * 山东大学 曾繁泰 * 1.过程调用时,先将初始值传递给过程的输入参数。启动过程按顺序自上至下执行过程语句。执行结束后,将输出值复制到调用者的OUT、INOUT所定义的变量或信号中。 2.并发过程调用(Concurrent Procedure Call)语句可以出现在结构体中,也可以在进程中执行过程调用语句。 3.并发过程调用语句是一个完整的语句,具有独立的行为表现形式,在这个语句前面可以加标号。 4.并发过程调用语句应带IN、OUT、INOUT参数,列于过程名后的括号内。并发过程调用可以有多个返回值,这些值通过过程中所定义的输出参数带回。 过程调用进行举例说明 * 山东大学 曾繁泰 * ARCHITECTURE结构体名OF实体名IS BEGIN … Bitvector_to_integer(z,X_ftag,q); --过程名,参数定义 … END 过程调用语句也可以出现在进程中。因此,过程调用语句也可以由过程敏感量的变化而得到启动。 3.3.2 函数语句 * 山东大学 曾繁泰 * 1.函数(function)语句结构 函数是具有某一特定功能的程序段,能够被主程序调用。函数被调用时,首先要初始化,执行处理功能后,将处理结果传递给主程序。函数内部的值不能保持,函数返回后,才能被再次调用,再次初始化。 函数语句格式 * 山东大学 曾繁泰 * FUNCTION 函数名|运算符号 [generic子句; [generic映射;] [[parameter](参数列表)] RETURN 数据类型名 IS [子程序声明区]; BEGIN [顺序处理语句]; RETURN[返回变量名]; END [FUNCTION][函数名|运算符号]; [例3-16]函数的结构及组织方法 * 山东大学 曾繁泰 * LIBRARY IEEE; USE IEEE.STD_logic_1164.ALL; PACKAGE cpld IS --包的名字cpld FUNCTION max( a:std_logic_vector; --包函数m
您可能关注的文档
- 《绩效管理理论与实务》第四章.ppt
- 《江苏移动基站设备安装指导意见》题目.doc
- 《江苏移动数据机房规范实施细则》题目.doc
- 《配送业务处理》《配送业务处理》课程标准.doc
- 《绩效管理理论与实务》第一章 绩效管理概述.ppt
- 《局域网组建与管理》综合布线培训.ppt
- 《配送业务处理》项目1 配送管理岗位认知.ppt
- 《配送业务处理》项目3 配送营运管理.ppt
- 《企业互联网络工程技术课程》00课前预习:IP及子网.ppt
- 《企业互联网络工程技术课程》第1课.docx
- 新部编版二年级上册道德与法治期中测试卷及参考答案【达标题】.docx
- 新部编版二年级上册道德与法治期中测试卷附参考答案【a卷】.docx
- 新部编版二年级上册道德与法治期中测试卷【新题速递】.docx
- 新部编版二年级上册道德与法治期中测试卷精品(突破训练).docx
- 新部编版二年级上册道德与法治期中测试卷【研优卷】.docx
- 新部编版二年级上册道德与法治期中测试卷【历年真题】.docx
- 强化训练-冀教版8年级下册期末试卷(必刷)附答案详解.docx
- 新部编版二年级上册道德与法治期中测试卷【网校专用】.docx
- 强化训练-冀教版8年级下册期末试卷(模拟题)附答案详解.docx
- 教科版科学一年级上册第一单元《植物》测试卷(历年真题).docx
文档评论(0)