Verilog赋值问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Verilog赋值问题相关的知识,希望对你有一定的参考价值。
本人刚接触Verilog,想请教一下,赋值的时候,比如:
wire cin,con;
wire [31:0] sum,a,b;
都什么时候用类似[31:0]这种设置位宽呀?原则呢?我可以都省略吗?
还想问一下reg和wire两个类型,书上说always里必须用reg,那么假如always之前定义的
wire a=2; 在always里面也引用到了a,这样的话是不是就出现错误啦?(a不应该定义为wire)。。。
望高手解答、、好疑惑~
2、所说的always必须用reg意思是你里面有赋值语句的被赋值的变量必须为reg型的,而不是说在always语句里面出现的变量都要为reg型。比如我这里写reg b,wire a,然后在always语句里面有b=a,即当always里面的敏感变量变化时把a的值赋值给b,这里面只有b是reg型,a不是被赋值的变量,所以a可以不为reg型的。
reg型为寄存器型,always语句里面被赋值的变量它的值要是寄存型的,因为要保持,只有当always里面的敏感变量有变化时,被赋值的变量的值才会改变。
希望你懂,不懂再追问哈。追问
那是不是假如
reg [8:1] D=5;
那么就相当于赋值D[0]=1, D[1]=0, D[2]=1, D[3]=D[4]=...=D[7]=0
是这样吗?
verilog是不能在定义变量时直接赋值的,这是他和c语言的区别所在。
但是可以用parameter或者用initial语句来赋值,parameter相当于c语言中的define关键字了。
你这里的要赋值的话直接用D=5就可以了,这样就D[0]=1, D[1]=0, D[2]=1, D[3]=D[4]=...=D[7]=0了。
以上是关于Verilog赋值问题的主要内容,如果未能解决你的问题,请参考以下文章