在做芯片验证过程中一种参数传递的简单方法,使用define宏定义!
1.使用目的:为了防止同一个文件在编译时被重复编译,引发多重定义的问题。
2.在文件开头和结尾定义,用法如下:
`ifndef xxx
`define xxx
class xxx extends xxx;
...
endclass
`endif
例如:
3.作用
ifndef 的含义:即 “if not defined”,也就是说,当文件编译到这一行,如果这个文件还没有被编译过,也就是首次编译,就会执行后续的 `define xxx这句话,把后续的代码定义一次。反之,则不会再重复编译。
ifdef 的含义:即"if defined",与 ifndef 的作用相反,如果已经编译过,那么则继续执行后面的代码。
enif 的含义:出现 ifndef 或者 ifdef 作为开头,程序块的末尾就需要有 endif 作为结束的标识。
- 特点
(1)文本代替的宏
(2)不会被其他机制覆盖值
(3)一旦声明,作用空间就是全局的
5.进行参数传递形式
例如:在sim_top中建立时钟,参数化定义时钟周期
在testcase中设置参数,传递到sim_top中