|  | 
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  
|  |  | Introduction |  
|  |  | SystemVerilog added lot of new data types and improved the existing data types to improve run time memory utilization of simulators. Highlights of the SystemVerilog datatypes are below |  
|  |  | 
 |  
|  |  | 
    shortint and longint data types.    shortreal (real was already defined in Verilog) data type.    string, chandle and class data types.    logic, bit and byte data type.    User defined types typedef.    struct, union, and class data types.    void data type.    null data type.    arrays, queue, associative array, dynamic array |  
|  |  | 
 |  
|  |  | Next few pages we shall see the basics of this new data types, and then in later chapers we shall see the details of each of this data types. |  
|  |  | 
 |  
|  |  | Note : User define data types defined by typedef should be first defined before they are used. |  
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  
|  |  | Integer data types |  
|  |  | Integer data types can be classified into 2-state types and 4-state types. 2-state types can take only 0, 1, where as 4-state types can take 0,1,X,Z. 2-state types consume less (50%) memory and simulate faster when compared to 4-state types. |  
|  |  | 
 |  
|  |  | 2 state value integer data types are |  
|  |  | 
    shortint : 16-bit signed integer.    int : 32-bit signed integer.    longint : 64-bit signed integer.    byte : 8-bit signed integer, can be used for storing ASCII charater.    bit : User defined vector types. |  
|  |  | 4-state value integers data types are |  
|  |  | 
    logic : User defined vector types.    reg : User defined vector types.    wire : User defined vector types.    integer : 32-bit signed integer.    time : 64-bit unsigned integer. |  
|  |  | 
 |  
|  |  | Integer types can be signed or unsigned, thus can change the result of a arthimetic operation. So care should be taken when declaring the data types that may be have to do arthimetic operation on it. By default byte, shortint, int, integer and longint default to signed and bit, reg, logic, and wire defaults to unsigned. |  
|  |  | 
 |  
|  |  | NoteData type reg and logic are one and same. logic data type was introduced to avoid confusion with reg data type. |  
|  |  | 
 |  
|  |  | Example - Integer Types |  
|  |  | 
 |  
|  |  | 
  1 module data_types();
  2 
  3 bit       data_1bit;
  4 byte      data_8bit;
  5 shortint  data_16bit;
  6 int       data_32bit;
  7 longint   data_64bit;
  8 integer   data_integer;
  9 
 10 bit       unsigned data_1bit_unsigned;
 11 byte      unsigned data_8bit_unsigned;
 12 shortint  unsigned data_16bit_unsigned;
 13 int       unsigned data_32bit_unsigned;
 14 longint   unsigned data_64bit_unsigned;
 15 integer   unsigned data_integer_unsigned;
 16 
 17 initial begin
 18    data_1bit   = {32{4'b1111}};
 19    data_8bit   = {32{4'b1111}};
 20    data_16bit  = {32{4'b1111}};
 21    data_32bit  = {32{4'b1111}};
 22    data_64bit  = {32{4'b1111}};
 23    data_integer= {32{4'b1111}};
 24    $display("data_1bit    = %0d",data_1bit);
 25    $display("data_8bit    = %0d",data_8bit);
 26    $display("data_16bit   = %0d",data_16bit);
 27    $display("data_32bit   = %0d",data_32bit);
 28    $display("data_64bit   = %0d",data_64bit);
 29    $display("data_integer = %0d",data_integer);
 30    data_1bit   = {32{4'bzx01}};
 31    data_8bit   = {32{4'bzx01}};
 32    data_16bit  = {32{4'bzx01}};
 33    data_32bit  = {32{4'bzx01}};
 34    data_64bit  = {32{4'bzx01}};
 35    data_integer= {32{4'bzx01}};
 36    $display("data_1bit    = %b",data_1bit);
 37    $display("data_8bit    = %b",data_8bit);
 38    $display("data_16bit   = %b",data_16bit);
 39    $display("data_32bit   = %b",data_32bit);
 40    $display("data_64bit   = %b",data_64bit);
 41    $display("data_integer = %b",data_integer);
 42    data_1bit_unsigned   = {32{4'b1111}};
 43    data_8bit_unsigned   = {32{4'b1111}};
 44    data_16bit_unsigned  = {32{4'b1111}};
 45    data_32bit_unsigned  = {32{4'b1111}};
 46    data_64bit_unsigned  = {32{4'b1111}};
 47    data_integer_unsigned  = {32{4'b1111}};
 48    $display("data_1bit_unsigned  = %d",data_1bit_unsigned);
 49    $display("data_8bit_unsigned  = %d",data_8bit_unsigned);
 50    $display("data_16bit_unsigned = %d",data_16bit_unsigned);
 51    $display("data_32bit_unsigned = %d",data_32bit_unsigned);
 52    $display("data_64bit_unsigned = %d",data_64bit_unsigned);
 53    $display("data_integer_unsigned = %d",data_integer_unsigned);
 54    data_1bit_unsigned   = {32{4'bzx01}};
 55    data_8bit_unsigned   = {32{4'bzx01}};
 56    data_16bit_unsigned  = {32{4'bzx01}};
 57    data_32bit_unsigned  = {32{4'bzx01}};
 58    data_64bit_unsigned  = {32{4'bzx01}};
 59    data_integer_unsigned  = {32{4'bzx01}};
 60    $display("data_1bit_unsigned  = %b",data_1bit_unsigned);
 61    $display("data_8bit_unsigned  = %b",data_8bit_unsigned);
 62    $display("data_16bit_unsigned = %b",data_16bit_unsigned);
 63    $display("data_32bit_unsigned = %b",data_32bit_unsigned);
 64    $display("data_64bit_unsigned = %b",data_64bit_unsigned);
 65    $display("data_integer_unsigned = %b",data_integer_unsigned);
 66     #1  $finish;
 67 end
 68 
 69 endmodule
You could download file data_types.sv here |  
|  |  | 
 |  
|  |  | Simulation Output - Integer Types |  
|  |  | 
 |  
|  |  |  data_1bit    = 1
 data_8bit    = -1
 data_16bit   = -1
 data_32bit   = -1
 data_64bit   = -1
 data_integer = -1
 data_1bit    = 1
 data_8bit    = 00010001
 data_16bit   = 0001000100010001
 data_32bit   = 00010001000100010001000100010001
 data_64bit   = 0001000100010001000100010001000
    100010001000100010001000100010001
 data_integer = zx01zx01zx01zx01zx01zx01zx01zx01
 data_1bit_unsigned  = 1
 data_8bit_unsigned  = 255
 data_16bit_unsigned = 65535
 data_32bit_unsigned = 4294967295
 data_64bit_unsigned = 18446744073709551615
 data_integer_unsigned = 4294967295
 data_1bit_unsigned  = 1
 data_8bit_unsigned  = 00010001
 data_16bit_unsigned = 0001000100010001
 data_32bit_unsigned = 00010001000100010001000100010001
 data_64bit_unsigned = 0001000100010001000100010001000
   100010001000100010001000100010001
 data_integer_unsigned = zx01zx01zx01zx01zx01zx01zx01zx01
 |  
|  |  | 
 |  
|  |  | 
 |  
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  |  | 
|  
 |  
 |  
 | 
| 
 | 
|    |  
| Copyright © 1998-2025 |  
| Deepak Kumar Tala - All rights reserved |  
| Do you have any Comment? mail me at:deepak@asic-world.com
 |  |