Integer寄存器类型
发布时间:2008/6/5 0:00:00 访问次数:847
整数寄存器包含整数值。整数寄存器可以作为普通寄存器使用,典型应用为高层次行为建模。使用整数型说明形式如下:
integer integer1, integer2,. . . intergern [msb:1sb] ;
msb和lsb是定义整数数组界限的常量表达式,数组界限的定义是可选的。注意容许无位界限的情况。一个整数最少容纳32位。但是具体实现可提供更多的位。下面是整数说明的实例。
integer a, b, c; //三个整数型寄存器。
integer hist [3:6]; //一组四个寄存器。
一个整数型寄存器可存储有符号数,并且算术操作符提供2的补码运算结果。
整数不能作为位向量访问。例如,对于上面的整数b的说明,b[6]和b[20:10]是非法的。一种截取位值的方法是将整数赋值给一般的reg类型变量,然后从中选取相应的位,如下所示:
reg [31:0] breg;
integer bint;
. . .
//bint[6]和bint[20:10]是不允许的。
. . .
breg = bint;
/*现在,breg[6]和breg[20:10]是允许的,并且从整数bint获取相应的位值。*/
上例说明了如何通过简单的赋值将整数转换为位向量。类型转换自动完成,不必使用特定的函数。从位向量到整数的转换也可以通过赋值完成。例如:
integer j;
reg [3:0] bcq;
j = 6; //j的值为32'b0000...00110。
bcq = j; // bcq的值为4'b0110。
bcq = 4'b0101.
j = bcq; //j的值为32'b0000...00101。
j = -6; //j 的值为 32'b1111...11010。
bcq = j; //bcq的值为4'b1010。
注意赋值总是从最右端的位向最左边的位进行;任何多余的位被截断。如果你能够回忆起整数是作为2的补码位向量表示的,就很容易理解类型转换。
integer integer1, integer2,. . . intergern [msb:1sb] ;
msb和lsb是定义整数数组界限的常量表达式,数组界限的定义是可选的。注意容许无位界限的情况。一个整数最少容纳32位。但是具体实现可提供更多的位。下面是整数说明的实例。
integer a, b, c; //三个整数型寄存器。
integer hist [3:6]; //一组四个寄存器。
一个整数型寄存器可存储有符号数,并且算术操作符提供2的补码运算结果。
整数不能作为位向量访问。例如,对于上面的整数b的说明,b[6]和b[20:10]是非法的。一种截取位值的方法是将整数赋值给一般的reg类型变量,然后从中选取相应的位,如下所示:
reg [31:0] breg;
integer bint;
. . .
//bint[6]和bint[20:10]是不允许的。
. . .
breg = bint;
/*现在,breg[6]和breg[20:10]是允许的,并且从整数bint获取相应的位值。*/
上例说明了如何通过简单的赋值将整数转换为位向量。类型转换自动完成,不必使用特定的函数。从位向量到整数的转换也可以通过赋值完成。例如:
integer j;
reg [3:0] bcq;
j = 6; //j的值为32'b0000...00110。
bcq = j; // bcq的值为4'b0110。
bcq = 4'b0101.
j = bcq; //j的值为32'b0000...00101。
j = -6; //j 的值为 32'b1111...11010。
bcq = j; //bcq的值为4'b1010。
注意赋值总是从最右端的位向最左边的位进行;任何多余的位被截断。如果你能够回忆起整数是作为2的补码位向量表示的,就很容易理解类型转换。
整数寄存器包含整数值。整数寄存器可以作为普通寄存器使用,典型应用为高层次行为建模。使用整数型说明形式如下:
integer integer1, integer2,. . . intergern [msb:1sb] ;
msb和lsb是定义整数数组界限的常量表达式,数组界限的定义是可选的。注意容许无位界限的情况。一个整数最少容纳32位。但是具体实现可提供更多的位。下面是整数说明的实例。
integer a, b, c; //三个整数型寄存器。
integer hist [3:6]; //一组四个寄存器。
一个整数型寄存器可存储有符号数,并且算术操作符提供2的补码运算结果。
整数不能作为位向量访问。例如,对于上面的整数b的说明,b[6]和b[20:10]是非法的。一种截取位值的方法是将整数赋值给一般的reg类型变量,然后从中选取相应的位,如下所示:
reg [31:0] breg;
integer bint;
. . .
//bint[6]和bint[20:10]是不允许的。
. . .
breg = bint;
/*现在,breg[6]和breg[20:10]是允许的,并且从整数bint获取相应的位值。*/
上例说明了如何通过简单的赋值将整数转换为位向量。类型转换自动完成,不必使用特定的函数。从位向量到整数的转换也可以通过赋值完成。例如:
integer j;
reg [3:0] bcq;
j = 6; //j的值为32'b0000...00110。
bcq = j; // bcq的值为4'b0110。
bcq = 4'b0101.
j = bcq; //j的值为32'b0000...00101。
j = -6; //j 的值为 32'b1111...11010。
bcq = j; //bcq的值为4'b1010。
注意赋值总是从最右端的位向最左边的位进行;任何多余的位被截断。如果你能够回忆起整数是作为2的补码位向量表示的,就很容易理解类型转换。
integer integer1, integer2,. . . intergern [msb:1sb] ;
msb和lsb是定义整数数组界限的常量表达式,数组界限的定义是可选的。注意容许无位界限的情况。一个整数最少容纳32位。但是具体实现可提供更多的位。下面是整数说明的实例。
integer a, b, c; //三个整数型寄存器。
integer hist [3:6]; //一组四个寄存器。
一个整数型寄存器可存储有符号数,并且算术操作符提供2的补码运算结果。
整数不能作为位向量访问。例如,对于上面的整数b的说明,b[6]和b[20:10]是非法的。一种截取位值的方法是将整数赋值给一般的reg类型变量,然后从中选取相应的位,如下所示:
reg [31:0] breg;
integer bint;
. . .
//bint[6]和bint[20:10]是不允许的。
. . .
breg = bint;
/*现在,breg[6]和breg[20:10]是允许的,并且从整数bint获取相应的位值。*/
上例说明了如何通过简单的赋值将整数转换为位向量。类型转换自动完成,不必使用特定的函数。从位向量到整数的转换也可以通过赋值完成。例如:
integer j;
reg [3:0] bcq;
j = 6; //j的值为32'b0000...00110。
bcq = j; // bcq的值为4'b0110。
bcq = 4'b0101.
j = bcq; //j的值为32'b0000...00101。
j = -6; //j 的值为 32'b1111...11010。
bcq = j; //bcq的值为4'b1010。
注意赋值总是从最右端的位向最左边的位进行;任何多余的位被截断。如果你能够回忆起整数是作为2的补码位向量表示的,就很容易理解类型转换。
上一篇:Verilog HDL操作数