- What is a "Data Type"?
  - This is a classification objects/items/data that defines the possible set of values which the objects/items/data belonging to that type may assume.
  - E.g. (VHDL) integer, bit, std\_logic, std\_logic\_vector
  - Other languages (float, double, int, char etc)

- Predefined Data Types
  - Specified through the IEEE 1076 and IEEE 1164 standards
  - The IEEE Standard 1076 defines the VHSIC Hardware
     Description Language or VHDL
    - Developed by Intermetrics, IBM and Texas Instruments for United States Air Force.
    - 1076-1987 was the first version
    - Revised in 1993, 2000, 2002, and 2008



- Package standard of library std (Included by default ):
  - bit type (0, 1)
  - bit vectors (group of multi-bit signal  $\rightarrow$  bus)
  - Example
    - SIGNAL x: BIT;
    - SIGNAL y: BIT\_VECTOR (3 DOWNTO 0);
    - SIGNAL w: BIT\_VECTOR (0 TO 7);
  - Signal assignment operator <=</li>

- w <= "01110001";

- Package standard of library std (Included by default ):
  - BOOLEAN (TRUE, FALSE)
    - Example
      - variable VAR1: boolean := FALSE;
  - INTEGER (32 bit, -2,147,483,647 to +2,147,483,647
    - Example
      - SIGNAL SUM: integer range 0 to 256 := 16;
  - REAL (from -1.0E38 to +1.0E38)
    - Example
      - constant Pi : real := 3.14159;

- The IEEE Standard 1164
  - Introduce Multivalue Logic (std\_logic\_1164) Packages
  - The primary data type std\_ulogic (standard unresolved logic) consists of nine character literals in the following order:
  - 1. **'U' –** uninitialized (default value)
  - 2. 'X' strong drive, unknown logic value
  - 3. '0' strong drive, logic zero
  - 4. '1' strong drive, logic one
  - 5. 'Z' high impedance (for tri-state logic)

- 6. 'W' weak drive, unknown logic value
- 7. 'L' weak drive, logic zero
- 8. 'H' weak drive, logic one
- 9. '-' don't care

- std\_ulogic and its subtype (std\_logic, std\_logic\_vector, std\_ulogic\_vector) values can be categorized in terms of their state and strength (forcing, weak and high impedance.)
- Weak strength is used for multi-driver inputs catering for pullup/pulldown

• std\_ulogic data type possible values and corresponding strength

| Data Value | State       | Strength       | Comment                                                                                                |
|------------|-------------|----------------|--------------------------------------------------------------------------------------------------------|
| U          | Unitialised | None           | Default value before simulation.                                                                       |
| Х          | Unknown     | Forcing        | Represents driven signals whose value cannot be determined as 1 or 0                                   |
| 0          | 0           | Forcing        | Represents signals from active output                                                                  |
| 1          | 1           | Forcing        | drivers                                                                                                |
| Z          | None        | High Impedance | Represents output of tri-state buffer when not enabled.                                                |
| W          | Unknown     | Weak           | Represents signals from resistive                                                                      |
| L          | 0           | Weak           | drivers e.g. pull-up and pull-down resistors                                                           |
| н          | 1           | Weak           | 163131013                                                                                              |
| -          | Don't care  | None           | Allows synthesiser to decide whether<br>to assign a 0 or a 1 for minimum<br>systhesised logic circuit. |

- std\_ulogic
  - Is an unresolved data type
  - Declared in package STD\_LOGIC\_1164 of library IEEE.
  - All data signals are of unresolved type by default.
  - Unresolved data type signals cannot be driven by more than one driver/sources. (adding multiples sources will result in compiler error).
  - Helps checking that designer has not accidentally assigned two sources to a signal.

- Resolved Data Types
  - Always declared with a resolution function (within its library).
  - Resolution function defines all possible combinations of one or more source values and the correspond resolved value (result).



- std\_logic (this is a resolved data type)
  - A subtype of std\_ulogic
  - Declared in package STD\_LOGIC\_1164 of library IEEE as subtype std\_logic is resolved std\_ulogic;
  - Specified a resolution function called "resolved"

• std\_logic resolution table

|   | Х | 0 | 1 | Z | W | L | Н | - |
|---|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |   |   |
| Х | Х | Х | Х | Х | Χ | Х | Χ | Х |
| 0 | Х | 0 | Х | 0 | 0 | 0 | 0 | Х |
| 1 | Х | Х | 1 | 1 | 1 | 1 | 1 | Χ |
| Ζ | Х | 0 | 1 | Ζ | W | L | Н | Χ |
| W | Х | 0 | 1 | W | W | W | W | Χ |
| L | Х | 0 | 1 | L | W | L | W | Χ |
| н | Х | 0 | 1 | н | W | W | Н | Χ |
| - | Х | Х | Х | Х | Х | Х | Χ | Χ |

- std\_logic declaration examples
  - SIGNAL x: STD\_LOGIC;
  - SIGNAL y: STD\_LOGIC\_VECTOR (3 DOWNTO 0) := "0001";

- Arrays are collections of objects of the same type.
- Can be 1D (1 dimensional) of 2D (2 dimensional) arrays.
- Higher dimensional arrays are not synthesizable



• There are no pre-defined 2D or 1Dx1D arrays; have to be defined by designer.

#### • Defining VHDL Arrays

- First define a new data type
- Second declare a signal, variable or constant of the defined data type.

#### General Format of Array definition

TYPE type\_name IS ARRAY (specification) OF data\_type; SIGNAL signal\_name: type\_name [:= initial\_value];

• Example:

TYPE row IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC;

- Defines a row (1D array) (data type) with of seven STD\_LOGIC values with MSB on left.
- TYPE matrix IS ARRAY (0 TO 3) OF row;
- Defines an 1Dx1D ARRAY (matrix) data type containing 4 row defined in previous line.

SIGNAL x: matrix;

- Defines 1Dx1D signal of type matrix as defined in previous line

- Example:1Dx1D Array (of vectors) --- Alternative method *TYPE matrix IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0);*
- Example:2D Array Data type

TYPE matrix2D IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD\_LOGIC;

- Array construction is not based on vectors, but rather entirely on scalars.
- It is a 2 dimensional array of scalars

#### • Type Definition:

TYPE row IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC;-- 1D arrayTYPE array1 IS ARRAY (0 TO 3) OF row;-- 1Dx1D array

#### • Signal Declaration;

SIGNAL x: row; SIGNAL y: array1;

• Scalar Signal (array) assignment:

#### $x(0) \le y(1)(2);$

• Note the two pairs of parentheses since y is a 1Dx1D array.

#### • Type Definition:

TYPE array2 IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0); -- 1Dx1D

TYPE array3 IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD\_LOGIC;

-- 2D array

• Signal Declarations:

SIGNAL v: array2; SIGNAL w: array3;

• Scalar Signal Assignments:

 $x(1) \le v(2)(3);$  $x(2) \le w(2,1);$ 

• Single pair of parentheses since w is 2D array

TYPE row IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC; TYPE array1 IS ARRAY (0 TO 3) OF row; TYPE array2 IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0); TYPE array3 IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD\_LOGIC;

#### Signal Declaration;

SIGNAL x: row; SIGNAL y: array1; SIGNAL v: array2; SIGNAL w: array3;

•Scalar Signal Assignments:

 $y(1)(1) \le x(6);$   $y(2)(0) \le v(0)(0);$   $y(0)(0) \le w(3,3);$   $w(1,1) \le x(7);$  $w(3,0) \le v(0)(3);$ 

- Vector Signal Assignments *TYPE row IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC; TYPE array1 IS ARRAY (0 TO 3) OF row; TYPE array2 IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0); TYPE array3 IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD\_LOGIC;*
- Signal Declaration;

SIGNAL x: row; SIGNAL y: array1; SIGNAL v: array2; SIGNAL w: array3;

Legal Assignments

x <= y(0); y(1)(7 DOWNTO 3) <= x(4 DOWNTO 0); v(1)(7 DOWNTO 3) <= v(2)(4 DOWNTO 0);

Vector Signal Assignments

TYPE row IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC; TYPE array1 IS ARRAY (0 TO 3) OF row; TYPE array2 IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0); TYPE array3 IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD\_LOGIC;

Signal Declaration;

SIGNAL x: row; SIGNAL y: array1; SIGNAL v: array2; SIGNAL w: array3; 

# **VHDL OPERATORS**

• Logical operators

| Logical operation | Operator | Example          |
|-------------------|----------|------------------|
| AND               | AND      | Z <= (A AND B);  |
| NAND              | NAND     | Z <= (A NAND B); |
| NOR               | NOR      | Z <= (A NOR B);  |
| NOT               | NOT      | Z <= NOT (A);    |
| OR                | OR       | Z <= (A OR B);   |
| XNOR              | XNOR     | Z <= (A XNOR B); |
| XOR               | XOR      | Z <= (A XOR B);  |

# **VHDL OPERATORS**

• Arithmetic operators

| Arithmetic operation | Operator | Example       |
|----------------------|----------|---------------|
| Addition             | +        | Z <= A + B;   |
| Subtraction          | -        | Z <= A - B;   |
| Multiplication       | *        | Z <= A * B;   |
| Division             | /        | Z <= A / B;   |
| Exponentiating       | * *      | Z <= 4 ** 2;  |
| Modulus              | MOD      | Z <= A MOD B; |
| Remainder            | REM      | Z <= A REM B; |
| Absolute value       | ABS      | Z <= ABS A;   |

# **VHDL OPERATORS**

• Relational operators

| Relational operation     | Operator | Example                |  |  |
|--------------------------|----------|------------------------|--|--|
| Equal to                 | =        | If $(A = B)$ Then      |  |  |
| Not equal to             | /=       | If $(A \neq B)$ Then   |  |  |
| Less than                | <        | If $(A < B)$ Then      |  |  |
| Less than or equal to    | <=       | If (A $\leq$ = B) Then |  |  |
| Greater than             | >        | If $(A > B)$ Then      |  |  |
| Greater than or equal to | >=       | If (A $>=$ B) Then     |  |  |

# **VHDL Reserved Words**

• Reserved words cannot be used by designers for identifiers such as variables, signal names, etc.

| 1             |          |         |           |
|---------------|----------|---------|-----------|
| abs           | file     | of      | then      |
| after         | for      | open    | to        |
| all           |          | or      | transport |
| and           | generic  | others  | type      |
| architecture  |          | out     |           |
| array         | if       |         | until     |
|               | in       | package | use       |
| begin         | inertial | port    |           |
|               | inout    | process | variable  |
| case          | is       |         |           |
| component     |          | rem     | wait      |
| configuration | library  | report  | when      |
| constant      | linkage  | rol     | while     |
|               | loop     | ror     | with      |
| downto        | -        |         |           |
|               | mod      | select  | xnor      |
| else          |          | signal  | xor       |
| elsif         | nand     | sla     |           |
| end           | next     | sll     |           |
| entity        | nor      | sra     |           |
|               | not      | srl     |           |

# Data Types: Advanced Topics

- Package std\_logic\_arith of library IEEE:
  - Defines SIGNED and UNSIGNED data types, plus several data conversion functions, like:
    - conv\_integer(p),
    - conv\_unsigned(p, b),
    - conv\_signed(p, b), and
    - conv\_std\_logic\_vector(p, b).
  - Allow arithmetic operations
  - Data conversion to be discussed in later slides

- Packages std\_logic\_signed and std\_logic\_unsigned of library IEEE:
  - Contain functions that allow operations with STD\_LOGIC\_VECTOR data to be performed as if the data were of type SIGNED or UNSIGNED, respectively.

### **User Defined VHDL Data Types**

- User Defined Integer Data Types
  - Subtype of Integer
  - Examples
    - TYPE integer IS RANGE -2147483647 TO +2147483647;
    - TYPE my\_integer IS RANGE -32 TO 32;
    - -- A user-defined subset of integers.
    - TYPE student\_grade IS RANGE 0 TO 100;
    - A user-defined subset of integers or naturals.
       TYPE natural IS PANCE 0 TO +21/7/836/7.
    - TYPE natural IS RANGE 0 TO +2147483647;

### **User Defined VHDL Data Types**

- User Defined ENUMERATED Data Types
  - Data type consisting of a set of named values.
  - Examples
    - **TYPE** bit IS ('0', '1');
    - TYPE my\_logic IS ('0', '1', 'Z');

- This is the pre-defined type BIT

TYPE bit\_vector IS ARRAY (NATURAL RANGE <>) OF BIT;
 This is the pre-defined type BIT\_VECTOR.
 NATURAL RANGE <>, on the other hand, indicates that the only restriction is that the range must fall within the NATURAL range.

### **User Defined VHDL Data Types**

- User Defined ENUMERATED Data Types
  - More Examples
    - TYPE state IS (idle, forward, backward, stop);
      - -- An enumerated data type, typical of finite state machines.
        - Two bits will be used to encode this data type values.
        - Idle will be the default value
    - TYPE color IS (red, green, blue, white, black);
      - -- Another enumerated data type.
      - Three bits will be used for encoding this data type.
      - Red will be the default value

### **VHDL Data Types:Records**

- Like Arrays Arrays records are collections of objects.
- Unlike arrays records can contain objects of different data types.
- Example

TYPE birthday IS RECORD day: INTEGER RANGE 1 TO 31; month: month\_name; – month\_name datatype should be predefined END RECORD;

### VHDL Data Types: Signed and Unsigned Types

- Defined in the **STD\_LOGIC\_ARITH** package of the IEEE library
- For arithmetic operations.
- Signal Declaration Examples SIGNAL x: SIGNED (7 DOWNTO 0); SIGNAL y: UNSIGNED (0 TO 3);
- Syntax is similar to that of STD\_LOGIC\_VECTOR not like integers
- An UNSIGNED value is a number never lower than zero. For example,
  - Unsigned "0101" = the decimal 5
  - Unsigned "1101" signifies 13.
  - Signed "0101" = the decimal 5
  - Signed "1101" signifies -3 (Two's complement)

### VHDL Data Types: Signed and Unsigned Types

Operations Example

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
USE ieee.std_logic_arith.all;
```

```
SIGNAL a: IN SIGNED (7 DOWNTO 0);
SIGNAL b: IN SIGNED (7 DOWNTO 0);
SIGNAL x: OUT SIGNED (7 DOWNTO 0);
SIGNAL u: IN STD_LOGIC_VECTOR (7 DOWNTO 0);
SIGNAL v: IN STD_LOGIC_VECTOR (7 DOWNTO 0);
SIGNAL y: OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
```

x <= a + b; x = a AND b; y = a + b; y = a AND b;

```
- -legal
- - illegal
- - illegal
- - legal
```

### VHDL Data Types: Signed and Unsigned Types

- std\_logic\_signed and std\_logic\_unsigned packages allows both logical and arithmetic operations
- Example:

```
LIBRARY ieee;

USE ieee.std_logic_1164.all;

USE ieee.std_logic_unsigned.all;

...

SIGNAL a: IN STD_LOGIC_VECTOR (7 DOWNTO 0);

SIGNAL b: IN STD_LOGIC_VECTOR (7 DOWNTO 0);

SIGNAL x: OUT STD_LOGIC_VECTOR (7 DOWNTO 0);

...

v \le a + b; -- legal

w \le a AND b; -- legal
```

# **Type Conversion**

- Direct operation between different data types is illegal in VHDL
- Solution!!!! = Data conversion
- Examples:

```
TYPE long IS INTEGER RANGE -100 TO 100;TYPE short IS INTEGER RANGE -10 TO 10;SIGNAL x : short;SIGNAL y : long;...y <= 2^*x + 5;-- error, type mismatchy <= long(2^*x + 5);-- OK, result converted into type long
```

# **Type Conversion**

- Data conversion defined in STD\_LOGIC\_ARITH
- conv\_integer(p) :
  - Converts a parameter p of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to an INTEGER value.
  - Notice that STD\_LOGIC\_VECTOR is not included.
- conv\_unsigned(p, b):

Converts a parameter p of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to an UNSIGNED value with size b bits.

conv\_signed(p, b):

Converts a parameter p of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to a SIGNED value with size b bits.

# **Type Conversion**

- conv\_std\_logic\_vector(p, b):
  - Converts a parameter p of type INTEGER, UN-SIGNED, SIGNED, or STD\_LOGIC to a STD\_LOGIC\_VECTOR value with size b bits.
- Example:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
USE ieee.std_logic_arith.all;
```

```
SIGNAL a: IN UNSIGNED (7 DOWNTO 0);
SIGNAL b: IN UNSIGNED (7 DOWNTO 0);
SIGNAL y: OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
...
y <= CONV STD LOGIC VECTOR ((a+b), 8);
```

 a+b is converted from UNSIGNED to an 8-bit STD\_LOGIC\_VECTOR value, then assigned to y.

### VHDL Data Type:Example

• Four Bit Adder ------ Solution 2: in/out=SIGNED ------

LIBRARY ieee; USE ieee.std\_logic\_1164.all; USE ieee.std\_logic\_arith.all;

ENTITY adder1 IS PORT ( a, b : IN SIGNED (3 DOWNTO 0); sum : OUT SIGNED (4 DOWNTO 0)); END adder1;

ARCHITECTURE adder1 OF adder1 IS BEGIN sum <= a + b; END adder1;

### VHDL Data Type:Example

Four Bit Adder----- Solution 2: out=INTEGER ------

LIBRARY ieee; USE ieee.std\_logic\_1164.all; USE ieee.std\_logic\_arith.all;

ENTITY adder2 IS PORT ( a, b : IN SIGNED (3 DOWNTO 0); sum : OUT INTEGER RANGE -16 TO 15); END adder2;

ARCHITECTURE adder2 OF adder2 IS BEGIN sum <= CONV\_INTEGER(a + b); END adder2;