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)。。。
望高手解答、、好疑惑~

参考技术A 1、【31:0】D,这样设置是为了简洁易懂,比如总线有32位,即D0~D31,这样就把它们一次性赋值,但是可以一位一位地取出来用,比如a=D[0].。
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赋值问题的主要内容,如果未能解决你的问题,请参考以下文章

verilog如何给数组赋值

verilog数组赋值

verilog中为啥非阻塞赋值要用绝对时延

verilog中有哪几种类型的赋值语句,说明它们的区别,并举例

verilog HDL状态机 赋初值问题

verilog reg 数组类型赋值后,仿真总是高阻