付费下载
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
浅析VerilogHDL编译系统的预处理编译预处理语句编译预处理是VerilogHDL编译系统的一个组成部分,指编译系统会对一些特殊命令进行预处理,然后将预处理结果和源程序一起在进行通常的编译处理。以”`”(反引号)开始的某些标识符是编译预处理语句。在VerilogHDL语言编译时,特定的编译指令在整个编译过程中有效(编译过程可跨越多个文件),直到遇到其他不同的编译程序指令。常用的编译预处理语句如下:(1)`define,`undef(2)`include(3)`timescale(4)`ifdef,`else.`endif(5)`default_nettype;(6)`resetall(7)`unconnect_drive,`nounconnected-drive;(8)`celldefine,`endcelldefine宏定义`define指令是一个宏定义命令,通过一个指定的标识符来代表一个字符串,可以增加VeirlogHDL代码的可读性和可维护性,找出参数或函数不正确或不允许的地方。`define指令类似C语言中的#define指令,可以在模块的内部或外部定义,编译器在编译过程中遇到该语句将把宏文本替换为宏的名字。`define的声明语法格式如下:`define,《macro_name》《Text》对于已声明的语句,在代码中的应用格式如下(不要漏掉宏前面的”`”):`macro-name例如:defineMAX-BUS-SIZE32。..Reg[`MAX-BUS-SIZE-1:0]AddReg;一旦`define指令被编译,其在整个编译过程中都有效。例如,通过另一个文件中的`define指令,MAX-BUS-SIZE能被多个文件使用。`undef指令用于取消前面定义的宏。例如:`undefWORD16。..Wire[`WORD:1]Bus;。..`undefWORD宏定义指令的注意事项:(1)宏定义的名称可以是大写,也可以是小写,但要注意不要和变量名重复。(2)和所有编译器伪指令一样,宏定义在超过单个文件边界时仍有效(对工程的其他源文件),除非被后面的`define、`undef或`resetall伪指令覆盖,否则`define不收范围限制。(3)当用变量定义宏时,变量可以在宏正文中使用,并且在使用宏的时候可以用实际的变量表达式代替。(4)通过用反斜杠”\”转义中间换行符,宏定义可以跨越几行,新的行是宏正文的一部分。(5)宏定义行末不需要添加分号表示结束。(6)宏正文不能分离的语言记号包括注释、数字、字符串、保留的关键字、运算符。(7)编译器伪指令不允许作为宏的名字。(8)宏定义中的文本也可以是一个表达式,并不仅仅用于变量名称的替换。define和parameter`define和parameter是有区别的。`define和parameter都可以用于完成文本替换,但其存在本质上的不同,前者是编译之前就预处理,而后者是在正常编译过程中完成替换的。此外,`define和parameter存在下列两点不同之处:(1)作用域不同。Parameter作用于声明的那个文件;`define从编译器读到这条指令开始到编译结束都有效,除非遇到`undef命令使之失效,可以应用于整个工程。如果要让parameter作用于整个项目,可以将声明语句写于单独文件中,并用)`include让每个文件都包含声明文件。`define可以写在代码的任何位置,而Parameter则必须在应用之前定义。通常编译器都可以定义编译顺序,或者从最底层模块开始编译,因此写在最底层就可以了。(2)传递功能不同。P
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 安防工程造价高级工程师考试试卷及答案
- 2026高级经济师《金融》必会知识点速记
- 2025年黑龙江事业单位招聘考试(植物生产与农业技术)历年参考题库含答案详解
- 专题07 静电场(学生版)
- 慢性病并发症数据的统计可视化预警
- T∕AOPA 0107-2026 中小学生无人驾驶航空器技能等级认证使用器材与评定要求
- 专题十三:力学实验(解析版)
- 餐厅承包合同
- 医学26年:慢性肾功能不全合并心衰管理 心内科查房
- 2025~2026学年河北省石家庄市第81中学度七年级上学期英语期末考试试卷
- 智能汽车组合驾驶辅助系统技术规范
- 专案改善报告
- GB/T 41850.1-2024机械振动机器振动的测量和评价第1部分:总则
- 【MOOC】《思想道德与法治》(东南大学)章节中国大学慕课答案
- T-CERS 0026-2024 能源企业可持续发展(ESG)披露指标体系和评价导则
- 樊昌信通信原理课后答案
- FMEA手册新中文版(第五版)
- 《中国大学介绍》课件
- 超星网课《国际学术论文写作与发表》答案
- 中国海洋石油集团有限公司招聘笔试题库2024
- (高清版)AQ 6210-2007 煤矿井下作业人员管理系统通 用技术条件
评论
0/150
提交评论