Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

why should I use unpacked vectors in System Verilog?

Following up on this question about the difference between packed and unpacked vectors in SV, why would I ever want to use unpacked vectors?
Packed vectors have these advantages that unpacked vectors don't have:

  • You can perform bit-wise operations on them
  • You can perform arithmetic operations on them
  • You can take slices of them
  • You can copy them as a whole vector
  • You can do anything you can with unpacked vectors (to the best of my knowledge)

What advantage do unpacked vectors have over packed vectors?

like image 689
Nathan Fellman Avatar asked Feb 04 '09 14:02

Nathan Fellman


People also ask

What is the difference between SystemVerilog packed and unpacked array?

SystemVerilog arrays can be either packed or unpacked. Packed array refers to dimensions declared after the type and before the data identifier name. Unpacked array refers to the dimensions declared after the data identifier name.

What is the advantage of using packed array over unpacked arrays?

Packed vectors have these advantages that unpacked vectors don't have: You can perform bit-wise operations on them. You can perform arithmetic operations on them. You can take slices of them.

What is difference between packed and unpacked?

Consequently, a packed array is guaranteed to be represented as a contiguous set of bits. An unpacked array may or may not be so represented. A packed array differs from an unpacked array in that, when a packed array appears as a primary, it is treated as a single vector.

What is an unpacked array in Verilog?

Unpacked Arrays In Verilog, the term unpacked array is used to refer to the dimensions declared after the object name. Unpacked arrays can be made of any data type. Each fixed-size dimension is represented by an address range, such as [0:1023].


2 Answers

There is another reason why I like to use unpacked. With unpacked, there is no temptation (and accidental possibility) of treating the whole array name as a variable, and make an erroneous assignment. There is also no possibility of bit-bleeding from one element to another, when you may be thinking you are accessing B bits of element N, but in reality you may be accessing K bits of element N and B-K bits of element N+-1..

My philosophy is to keep only the things that belong together as a "unit of information" in the packed dimension. Everything else in the unpacked dimension. The default thinking should be unpacked, and pack only what you need to.

For example, if I have 9 ports, each with 21 bits of information, I would like to declare it as :

input logic [20:0] p1 [9];

The 20:0 part constitutes a unit of information, assigned and sampled together (nominally). Splitting those bits apart will destroy the protocol or the character of the port. On the other hand, changing the number of ports from 9 to, say, 16, is not going to affect the nature of the information in each port, so the 9 ports really belong in the unpacked dimension in my mind.

Hope that might give you a paradigm to think along... In this paradigm, you would be surprised how many things start to appear unpacked that you always thought were packed !!

like image 161
Biswajit Khandai Avatar answered Sep 20 '22 15:09

Biswajit Khandai


Unpacked arrays exist for several reasons.

1) Packed arrays are stored in memory as a continuous sequence of bits. Unpacked arrays can have each element stored independently which can yield greater simulation performance.

2) Unpacked arrays can be of types that aren't bit vectors. Arrays of ints, bytes, events, structs, classes, etc. can only be unpacked.

3) Most of the array manipulation methods only work on unpacked arrays.

4) Perhaps, only unpacked arrays can be assigned to using array literals. I'm not sure.

There may be other reasons.

like image 44
Steve K Avatar answered Sep 21 '22 15:09

Steve K