



#### Lecture #8

In this lecture we will cover the following material:

The standard package, The std\_logic\_1164

- Objects & data Types (Signals, Variables, Constants, Literals, Character)
- Types and Subtypes (Scalar & Composite types).



## Library Clauses





- A library clause declares a name that denotes a library. The name can be any legal identifier.
- A library clause can declare more than one library name by declaring all the library names separated by comma.
- Examples for user defined libraries:
- *library* Designs; -- Declaration for the Designs library <u>use</u> Designs.<u>all</u>; -- Use statement grants visibility of declarations inside the library --Examples for predefined libraries
- Every design assumes the following 2 statement: <u>*library*</u> STD;
- <u>use</u> **STD.STANDARD.***all*; -- *Package STANDARD inside library STD* -Every design assumes " Library WORK" clause







- In VHDL there are no arithmetic operators for types that require bit operation.

- Most VHDL Simulators provide arithmetic packages to perform arithmetic operations using STD\_LOGIC\_1164 types.

Some companies provide many math packages such as floating point.
Some synthesis tool provide special software that maps some functions such as adders, subtractors, multipliers, registers, counters etc. to ASIC library cells.

- Most synthesis companies nowadays provide component packages for a variety of cells such as power and ground pads, I/O buffers, clock driver, 3-state pads etc.

This is usually done by 2 stages first technology-independent codes are generated and then the components are mapped to primitives for technology dependent libraries after synthesis.





## STANDARD PACKAGE

-- the types declared in the standard package are used similar to the way that the reserved words are used package subset STANDARD is type BOOLEAN is (FALSE, TRUE); *type* BIT *is* ( '0', '1'); *type* SEVERITY\_LEVEL *is* (NOTE, WARNING, ERROR, FAILURE); subtype NATURAL is INTEGER range 0 to INTEGER' HIGH; subtype Positive is INTEGER range 1 to INTGER' HIGH; *type* BIT VECTOR *is array* (Natural range <> ) *of* BIT; *type* STRING *is array* (Positive range <>) *of* CHARACTER; subtype DELAY\_LENGTH is TIME range 0 fs to TIME' HIGH; -- A STRING array must have a positive index. -- The type TIME is declared in the STANDARD package as: type TIME is range implementation defined **Units** fs: ps = 1000 fs;ns = 1000 ps;us = 1000 ns;ms = 1000 us;sec = 1000 ms;end units; end subset STANDARD:





# STD\_LOGIC\_1164

- VHDL does not have a in build logic value system. The STANDARD package pre-defines the type **BIT** with two logic values of **'0'** and **'1'**.
- Normally additional values of **'X'** (unknown) and **'Z'** (high impendence) are also needed.
- CMOS circuits require more levels and strengths.
- The STD\_LOGIC\_1164 package includes functions to perform logical, shift, resolution and conversion functions.

To access this package, the following statements have to be included: **library IEEE**;

use IEEE.STD\_LOGIC\_1164.all;

- The STD\_LOGIC\_1164 package contains definitions for a nine-value logic system.
- The STD\_ULOGIC is defined in STD\_LOGIC\_1164.



package subset\_STD\_1164 is -- defines the 9-vlaue logic system type\_STD\_ULOGIC is

('U'

' X '

'Η'

### This type is used in most structural designs

- -- Un-initialized
- -- Forcing unknown
- -- Forcing zero
- -- Forcing one
- -- High Impedance
- -- Weak Impedance
- -- Weak zero
- -- Weak 1
- -- Don't Care

type STD\_ULOGIC\_VECTOR is array (Natural range <> ) of STD\_ULOGIC; function resolved ( S: STD\_ULOGIC\_VECTOR) return STD\_ULOGIC; subtype STD\_LOGIC is resolved STD\_ULOGIC; type STD\_LOGIC\_VECTOR is array(NATURAL range <>) of STD\_LOGIC; function rising\_edge (signal S: STD\_ULOGIC) return BOOLEAN; falling\_edge (signal S: STD\_ULOGIC) return BOOLEAN; falling\_edge (signal S: STD\_ULOGIC) return BOOLEAN; end subset\_STD\_1164;















# Signal Declarations

<u>signal</u> identifier (Label) <u>: subtype</u> (bus/register) [<= expression]

A signal has a history of values. It has a past, present and future value
 The expression specifies the initial value of the signal at simulation time.
 The expression is evaluated at each elaboration of the signal.

Initialized

- The default initial value for a signal of a scalar type T is T' left.
- Signal can be only declared in concurrent descriptions.

```
signal Sig_1: Bit;
signal Address_Bus: BIT_VECTOR (31 downto 0);
signal Bus: tristate;
signal A, B, C : BIT_VECTOR (0 to 2);
signal A: BIT<= '0';</pre>
```







-- to make a signal global, declare it in a package and make the --package visible to the entities that requires it







## Example of Signal assignment

A Concurrent signal assignment assigns a new value to the target signal whenever any of the signals on the right hand side change: Example:

architecture SIG\_ASSIGN of Half\_Adder is
begin
SUM <= A xor B;
CARRY <= A and B;
end SIG\_ASSIGN;</pre>







A signal assignment may have a delay specified:

## architecture DIFFERENT of SIG is constant A\_Delay : time := 20ns;

<u>begin</u>

SUM <= A xor B **<u>after</u>** A-Delay -1 ns; CARRY <= A and B <u>**after**</u> 9 ns;

end DIFFERENT;

NOTE: Synthesis tools usually treat a signal assigned with a concurrent statement as combinational logic. Delays are ignored.

Concordia



University

Variable Declarations

variable identifier (Label): subtype (bus/register) [:= expression]

- A variable has only one value (current).
- The expression specifies the initial value. The expression is evaluated at each elaboration of the variable.
- The default initial value for a scalar type variable T is T' left.
- It is a sequential statement and used inside processes, procedures and functions.
- -The value of the right hand side is copied *immediately*

<u>variable</u> A : BIT := '0'; variable R20 : Integer; <u>variable</u> CHA : character := 'Z'; <u>variable</u> BV: Bit Vector (0 to 3) := "0101"; <u>variable</u> volts : real := 2.67; Variables are synthesizeable if their type is acceptable by the

synthesis tools.







```
Delay can not be assigned to variables
Assignments may be made from signals to
variables and vice-versa, but types have to match:
process (A, B, C, DIFF)
 variable Z : integer range 0 to 7;
begin
 if DIFF = '1' then
  Z := B;
 else
  Z := C;
 end if;
  Y \le A * B + Z; -- Y has been declared as signal
end process;
```



University

**Constant Declarations** Con

constant identifier (Label) : subtype (bus/register) [:= expression]

```
-- Example

<u>constant</u> my_weight: weight := 65 Kg ;
```

```
constant period : TIME := 20ns ;
```

```
constant Pai : real := 3.14 ;
```

```
constant All_Ones: vector_4 := "1111";
```

-- All subtypes are pre-defined. Constants can be synthesized if their type is acceptable by the synthesis tool.







- --Literals are the values given to VHDL objects --Examples of decimal literals
- I1:= 150000; or I2:= 150\_000; 0r I3:= 15 e4; .. All are the same
- R1:=1500.0; or R2:= 1\_500.0; or R3:-1.5e3;
- --examples of based literals
- --The base can be either hexadecimal, octal or binary
- For example Integer literal of value 255 can be expressed as:
- In binary as 2#1111\_1111 or
- In Octal as O#773# or
- In Hexadecimal as 16 # FF#
- --Bit string-literals
- X"FFE" = B"1111-1111-1110"
- O"765" = B"111\_110\_101"
- (Where X is hexadecimal, O is Octal)



# **Character, String literals**

#### **Character literals**

Between two '' (comas) characters: 'B' 'b' '?'

#### String literals

- Text inside two "" (double comas) characters:
- A string must be fitting on a single line.

- Concatenation operation is used to combine strings longer than one line.

"When First line is full then we can continue be placing an "&"

" we have continued on the second line "





## Types, Subtypes





## Types, Subtypes Declarations

- A type is defined by a set of values and a set of actions/operations.

Example: <u>type</u> Nibble\_value <u>is range</u> 0 <u>to</u> 15 ;

A further constraint might be applied to values of a given type.
Then a subtype is a type along with the added constraint.
Example: <u>subtype</u> COUNT <u>is</u> INTEGER <u>range</u> 1 <u>to</u> 255; <u>subtype</u> SEVEN\_BIT <u>is</u> COUNT <u>range</u> 1 <u>to</u> 127;

>Constraint is checked during each simulation.





Predefined Enumeration types

128 ASCII characters

- *BIT* 

('0', '1')

- BOOLEAN

(FALSE, TRUE)

- SEVERITY\_LEVEL

(NOTE, WARNING, ERROR, FAILURE)

--Examples of Enumerations types are:

*type* Transition *is* (H,L,U,Z) ;

*type* STATE *is* (S1,S2,S3);

*type* logic\_strength *is* (W,S,D,) ;

-- Enumeration literals must be characters and in ascending range





## Integer Types

# The only pre-defined integer is INTEGER. Example type WEIGHT is INTEGER range 300 downto 30; subtype HEAVY is WEIGHT range 100 to 250; subtype LIGHT is WEIGHT range 60 downto 40;

#### -- Pre-defined

- -- Integer Range:  $\pm 2^{31}$
- -- Natural Range: 0 to  $2^{31}$
- -- Positive Range: 1 to  $2^{31}$





## Floating Point Types

- --  $\simeq$  (Approx.) Real Numbers
- -- Contains a range constraint

-- Example <u>Type</u> WEIGHT <u>is range</u> 0.5 <u>to</u> 300.0 ; <u>Subtype</u> VERY-LIGHT <u>is WEIGHT range</u> 1.0 <u>to</u> 10.0 ;

#### -- Pre-defined

- -- Real numbers are in Package STANDARD
- -- Guaranteed to include the range
- -- Natural Range:  $1E^{31}$  to +  $1E^{31}$
- -- Real data types supports: =, /=, <=, >, >=, +, -, abs, \*, /







-It is predefined in Package STANDARD

- > Includes the range  $2^{31} + 1$  to +  $2^{31} 1$
- > All delays declared in VHDL must be of the type TIME

*type* TIME *is range* - 1E 18 *to* + 1E 18; units fs;

ps = 1000 fs; ns = 1000 ps; us = 1000 ns; ms = 1000 u; sec = 1000 ms; min = 60 sec;hr = 3600 sec;

#### <u>end</u> units;

- -- fs femto second (10<sup>-15</sup> seconds) is the base unit
- -- Values can be real or integer

## User-defined Physical Types Concordia



University

-- Example: User Defined Capacitance *type* Capacitance *is range* 0 *to* 2\*\* 31 –1 ; Units aF;

fF = 1000 aF; pF = 1000 fF; nF = 1000 pF; uF = 1000 nF;mF = 1000 uF;

<u>end</u> units;

```
-- Example: User Defined Voltage

type Voltage is range 0 to 2** 31 –1 ;

Units pV;

nV = 1000 pV;

uV = 1000 nV;

mV = 1000 uV;

V =1000 mV;

V =1000 mV;

end units;
```



- Array is collection of objects/values of similar type.

Example

*type* array\_1 *is array* (15 *downto* 0) *of* std\_ulogic;

This array declaration defines array\_1 that contains 16 elements. The indexes are decremented from 15 to 0.

An Array can be put under a decrement or increment mode with

 $(y \underline{downto} x)$  or  $(x \underline{to} y)$ .

- Multi-dimensional Array

Arrays can have multiple indices: <u>type</u> Dimension\_2 <u>is array</u> (0 to 7, 10 <u>downto</u> 0) <u>of</u> byte;







Array Type can be declared as **Constrained** or **Unconstrained Constrained Array:** <u>array</u> (discrete range) <u>of</u> element subtype indication

**Unconstrained Array:** 

array (subtype name range) of element subtype indication

-- Example: Array Types

type word is array (7 downto 0) of BIT; type memory is array (natural range <> ) of word; variable ROM: memory (0 to 2 \*\* 10); variable Address: BIT\_VECTOR (0 to N); signal mem1: word;



-- < > is for the range that is not defined at the time.

-- Range can be declared later when using the array, for example:

<u>subtype</u> array\_a <u>is</u> unconstrained (4 <u>downto</u> 0);



Indices (Length) of the array



## Bit Veetor

- Is a single dimensional vector, each element is of type BIT.
- Bit Vector Array is pre-defined in the STANDARD Package.
- Bit Vector is really a template for the elements of an array. Example COEN: <u>out</u> BIT\_VECTOR (7 <u>downto</u> 0);



COEN <= B"10101010";

```
<u>signal</u> destiny : BIT_VECTOR (<u>7 downto</u> 0)
destiny <= B"1110-0011";
```

$$destiny \longrightarrow 1 \qquad 1 \qquad 1 \qquad 0 \qquad 0 \qquad 0 \qquad 1 \qquad 1$$





## **Pre-defined Array Type**

-- Example
subtype NATURAL is INTEGER range 0 to 2\*\* 31;
type BIT\_VECTOR array (NATURAL range <>) of BIT;
type POSITIVE is INTEGER range 1 to 2\*\* 31;

#### **BEHAVIORAL\_Concurrent** verses Algorithm

#### Concurrent entity normally infer logic design

- architecture CONCURRENT of Half\_Adder is
- begin
- SUM<= X XOR Y;</p>
- CARRY<= X <u>AND</u> Y;
- End CONCURRENT;
- <u>architecture</u> BEHAVIORAL of Half\_Adder is
- -- signal X,Y : integer; --X and Yare read as integers
- --<u>signal</u> SUM,CARRY: BIT; in the interface
- <u>begin</u>
- process (X, Y)
- variable Z : integer;
- <u>begin</u>
- SUM<=`0'; CARRY<=`0';
- Z := X+ Y;
- <u>if</u> Z =1 <u>then</u> SUM <= `1';</li>
- <u>elsif</u> Z=2 <u>then</u> CARRY<=`1';</li>
- <u>end if</u>;
- end process;
- end BEHAVIORAL;

- architecture ALGORITHMIC of Half\_Adder is
- begin
- process (X,Y)
- begin
- SUM<= X XOR Y;</p>
- CARRY<= X AND Y;</p>
- end process;
- End ALGORITHMIC;





LIBRARY ieee; USE ieee.std\_logic\_1164.ALL;

**ENTITY** Half\_Adder\_Con\_Tb **IS END** Half\_Adder\_Con\_Tb;

ARCHITECTURE CONCURRENT OF Half\_Adder\_Con\_Tb IS

COMPONENT Half\_Adder\_Con PORT (X,Y : IN std\_logic; SUM,CARRY : OUT std\_logic); END COMPONENT;

signal X : std\_logic := '0'; signal Y : std\_logic := '0';

signal SUM : std\_logic; signal\_CARRY : std\_logic;

#### **BEGIN**

-- Instantiate the Unit Under Test (UUT) uut: Half\_Adder\_Con <u>PORT MAP</u> ( X => X, Y => Y, SUM => SUM, CARRY=>CARRY);

-- Stimulus process

stim\_proc: process

<u>begin</u>

X<='0'; Y<='0'; wait for 10 ns;

X<='0'; Y<='1'; <u>wait for 10 ns</u>;

X<='1'; Y<='0'; <u>wait for</u> 10 ns;

X<='1'; Y<='1';









#### **Simulation of Half Adder**

| POR F |                |         | Layout Help |             |           |            |         |       |       |            |             |       | _ 8    |
|-------|----------------|---------|-------------|-------------|-----------|------------|---------|-------|-------|------------|-------------|-------|--------|
|       | 0000           | 6 D D × | 1 10 CH 10  | € 1 L 265 Ø | 3885      | 1 P K? 1 # | P 8 1 3 | ***   | 1     | 1.00us 💌 🔄 | 🜍 Re-launch |       |        |
| æ     |                |         |             |             | 20.000 ns |            |         |       |       |            |             |       |        |
| 20    | Name           | Value   | 0 ns        | 10 ns       | 20 ns     | 30 ns      | 140 ns  | 50 ns | 60 ns | 70 ns      | 180 ns      | 90 ns | 100 ns |
| 8     | 16 ×           | 1       |             |             |           |            |         |       |       |            |             |       |        |
| 0     | Un y<br>Un sum | 0       |             | _           |           |            |         |       | =     |            |             |       |        |
| õ     | Le carry       | 0       |             |             |           |            |         |       |       |            |             |       |        |
| 12    |                |         |             |             |           |            |         |       |       |            |             |       |        |
| ⇒r    |                |         |             |             |           |            |         |       |       |            |             |       |        |
| Ť     |                |         |             |             |           |            |         |       |       |            |             |       |        |
| 1-5.  |                |         |             |             |           |            |         |       |       |            |             |       |        |
| 100   |                |         |             |             |           |            |         |       |       |            |             |       |        |
| 31    |                |         |             |             |           |            |         |       |       |            |             |       |        |
| 1111  |                |         |             |             |           |            |         |       |       |            |             |       |        |
|       |                |         |             |             |           |            |         |       |       |            |             |       |        |
|       |                |         |             |             |           |            |         |       |       |            |             |       |        |
|       |                |         |             |             |           |            |         |       |       |            |             |       |        |





#### A good site for VHDL Syntax + Examples

#### http://www.ics.uci.edu/~jmoorkan/vhdlref/