在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 3014|回复: 7

[原创] verilog 语法 请大家帮帮忙

[复制链接]
发表于 2010-5-5 21:11:35 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
verilog 语句中,在generate语句中,实例化时,module的名字和实例化名字中间加“#(parameter)” 是怎么回事???  谢谢了!!!例如:
dff #(parameter) unit(.clk(clk),.en(en)....);
发表于 2010-5-5 21:45:47 | 显示全部楼层
是不是修改参数,通常是这么用的,就是在module里定义的参数。在其他的文件里实例这个module是可以通过#(parameters)修改已经定义的参数。
发表于 2010-5-5 21:47:04 | 显示全部楼层
Verilog中generate用法

generate可以用for,case,if。其中,generate实例化多个器件很简洁。

generate

  genvar j ;

  for(j=0;j<=INST_NUM;j=j+1)

    begin : inst

      dff #(PARAMETER) unit(.clk(clk),

                                               .ena(ena),

                                                .in(in),

                                                 .out(out)

                                                ) ;

end

endgenerate

1,genvar后面的for,变量必须是genvar变量;generate+if,不如`ifdef `else `endif

2,for里必须有begin,哪怕只有一句

3,begin必须有名称,原因见4

4,这里例化的模块名称是inst[j].unit

5,generate语句可以看作是标准化为块的综合指令
 楼主| 发表于 2010-5-6 10:45:21 | 显示全部楼层
哦 谢谢了
发表于 2010-5-6 11:39:56 | 显示全部楼层
例化中的参数传递。
发表于 2010-5-7 10:17:42 | 显示全部楼层
同上。最简单的例子就是1个dff拼成n-bit register或者两个半加练成一个全加
发表于 2010-5-21 22:10:59 | 显示全部楼层
GOOD!
发表于 2010-5-21 22:18:14 | 显示全部楼层
修改参数,通常是这么用的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条


小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-1-23 00:56 , Processed in 0.030591 second(s), 23 queries , Gzip On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表