- 1、本文档共32页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
专用集成电路教学课件第七章
第七章 硬件描述语言简介 VHDL 语言简介 硬件描述语言:就是可以描述硬件电路的功能、信号的连接关系及定时关系语言。最常用的HDL是VHDL和VerilogHDL。 一、VHDL的发展史 二、VHDL的基本语法 三、VHDL程序的基本结构 四、VHDL的基本描述语句 五、基本逻辑电路设计 一、 VHDL 的发展史 ?VHSIC 计划 美国国防部在上个世纪70年代末和80年代初提出的VHSIC(Very High Speed Integrated Circuit)计划的产物。1981年提出了一种新的硬件描述语言,称为VHSIC Hardware Description Language。简称VHDL。 ?VHDL标准化 1987年12月VHDL被接纳为IEEE std-1076-1987标准,一般称为VHDL’87 。 1993年进一步修订,形成IEEE std-1076-1993标准,称为VHDL’93。 二、 VHDL 的基本语法规则 1、词法规则 2、标识符 3、保留字 4、VHDL的数据类型 5、VHDL的运算操作符 2-1 词法规则 2-1-1 注释 ?由两个短线“--”开始的一行文字,如: --this is a counter 2-1-2 数字 ?十进制整数表示法: 十进制文字::= 整数[整数] [指数] 整数::= 数字或下划线连接的数字 整数举例:089,0,456_78,2e8 实数举例:12.0,3.14159,2.4e+5 2-1 词法规则 2-1-2 数字 ?基表示二、八、十六进制数字的方法: 以基表示的数::=基#基于基的整数[基于基的整数] #指数 基::= 整数 基于基的整数::= 扩展数字{[下划线]扩展数字}扩展数字::=数字/字母 整数举例:2 -二进制表示法 指数举例:2#11.001#E+2 2-1 词法规则 2-1-3 字符和字符串 ?字符:用单引号引起来的ASCII字符,可以是数字,也可以是符号或字母。 字符文字::=‘图形字符’ ?字符串:是一维的字符数组,需放在双引号中。 字符串文字::=“{图形文字}” 如:“FALSE”,B “100” 2-2 标识符 ?短标识符(VHDL’87) VHDL的短标识符必须遵守以下规则: 1、必须以英文字母开头; 2、英文字母、数字(0~9)和下划线都是有效的字符; 3、短标识符不区分大小写; 4、下划线(_)的前后都必须有英文字母或数字; 如:A_1 5、不能和VHDL语言的保留字重名。 2-2 标识符 ?扩展标识符(VHDL’93) VHDL的扩展标识符必须遵守以下规则: 1、用反斜杠来界定。\eda_control\ 2、允许包含图形符号、空格符;\$100\ 3、反斜杠之间的字符可以用保留字;\buffer\ 4、两个反斜杠之间可以用数字开头;\2chip\ 5、扩展标识符中允许多个下划线相连;\Two_computer_sharptor\ 6、扩展标识符区分大小写;\eda\和\EDA\不同 2-3 保留字 ?VHDL内部用的字符串,标识符不能与保留字重名。 如:if else elsif end wait when case entity architecture package component xnor xor 2-4 VHDL 的数据类型 ?客体:凡是可以赋予一个值的对象就称客体。 常数:对某一常数赋予一个固定值。 变量:在进程和子程序中使用,是一个局部量。 信号:是电路内部硬件连接的抽象。 ?数据类型 1、标准数据类型(10种) 2、用户自定义数据类型 3、IEEE 预定义标准 2-4 VHDL 的数据类型 IEEE标准数据类型有两种: “std_logic”和“std_logic_vector” 注意:使用这两种类型,在程序中必须写出库说明语句和使用程序包集合说明语句。若不这样,EDA工具在进行编译、综合时会报告类型错误。 2-5 VHDL 运算操
文档评论(0)