generate生成语句可以动态的生成verilog代码,当对矢量中的多个位进行重复操作时,或者当进行多个模块的实例引用的重复操作时,或者根据参数的定义来确定程序中是否应该包含某段Verilog代码的时候,使用生成语句能大大简化程序的编写过程。
生成语句生成的实例范围,关键字generate-endgenerate用来指定该范围。生成实例可以是以下的一个或多个类型:
(1)模块;(2)用户定义原语;(3)门级语句;(4)连续赋值语句;(5)initial和always块。
generate语句有generate-for,generate-if,generate-case三种语句。
generate-for 语句最近看代码有遇到过,重点介绍一下。
generate-for语句
(1) 必须有genvar关键字定义for语句的变量。
(2)for语句的内容必须加begin:和end(即使就一句)。
(3)for语句必须有个名字。
对矢量中的多个位进行重复操作。
genvar i; //genvar i;i for语句的变量
generate
for(i=0;i<2;i=i+1)
begin:bit // begin : (注意有: bit 是for的名字)
assign bo