





# Advanced Digital Electronics ألألكترونيات الر قمبةالمتقده (stage 4<sup>TH</sup>BRANCH ELECTRONIC)



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







# 1-Introduction

# 1.1 About VHDL

VHDL is a hardware description language. It describes the behavior of an electronic circuit or system, from which the physical circuit or system can then be attained (implemented).

VHDL stands for VHSIC Hardware Description Language. VHSIC is itself an Abbreviation for Very High Speed Integrated Circuits, an initiative funded by the United States Department of Defense in the 1980s that led to the creation of VHDL.

Its first version was VHDL 87, later upgraded to the so-called VHDL 93. VHDL was the original and first hardware description language to be standardized by the **Institute of Electrical and Electronics Engineers**, through the **IEEE**1076 standard. An additional standard, the IEEE 1164, was later added to introduce a multivalued logic system

VHDL is a standard, technology/vendor independent language, and is there fore Portable and reusable. The two main immediate applications of VHDL are in the field of Programmable Logic Devices (including CPLDs—Complex

Programmable Logic Devices and FPGAs—Field Programmable Gate Arrays) and in the field of ASICs (Application Specific Integrated Circuits). Once the VHDL code

the field of ASICS (Application Specific Integrated Circuits). Once the VHDL code has been written, it can be used either to implement the circuit in a programmable device(from Altera, Xilinx, Atmel, etc.) or can be submitted to a foundry for fabrication of an ASIC chip. Currently, many complex commercial chips (microcontrollers, for example) are designed using such an approach. A final note regarding VHDL is that, contrary to regular computer programs which are sequential, its statements are inherently concurrent (parallel). For that reason, VHDL is usually referred to as a code rather than a program. In VHDL ,only statements placed inside a PROCESS, FUNCTION, or PROCEDURE are executed

#### sequentially 1.2 Design Flow

As mentioned above, one of the major utilities of VHDL is that it allows the synthesis of a circuit or system in a programmable device (PLD or FPGA) or in an ASIC. The steps followed during such a project are summarized in figure 1.1.

We start the design by writing the VHDL code, which is saved in a file with the extension





# **Advanced Digital Electronics**



Eng. K. DAWAH





**VHDL** and the same name as its ENTITY's name. The first step in the synthesis process is compilation. Compilation is the conversion of the high-level VHDL language, which describes the circuit at the Register Transfer Level (RTL), into a net list at the gate level. The second step is optimization, which is performed on the gate-level net list for speed or for area. At this stage, the design can be simulated. Finally, a place and-route (fitter) software will generate the physical layout for a PLD/FPGA chip or will generate the masks for an ASIC.

### 1.3 EDA Tools

There are several EDA (Electronic Design Automation) tools available for circuit synthesis, implementation, and simulation using VHDL. Some tools (place and route, for example) are oered as part of a vendor's design suite

(e.g., Altera's Quartus II, which allows the synthesis of VHDL code onto Altera's CPLD/FPGA chips)

# 1.4 Translation of VHDL Code into a Circuit

A full-adder unit is depicted in figure 1.2. In it, a and b represent the input bits to be added, cin is the carry-in bit, s is the sum bit, and cout the carry-out

bit. As shown in the truth table, Smust be high whenever the number of inputs that are high is odd,

while **cout** must be **high** when **two or more inputs are high**. A VHDL code for the full adder of figure 1.2 is shown in figure 1.3. As can be seen, it consists of an ENTITY, which is a description of the pins (PORTS) of the

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







| a b | cin | S | cout |
|-----|-----|---|------|
| 0 0 | 0   | 0 | 0    |
| 01  | 0   | 1 | 0    |
| 10  | 0   | 1 | 0    |
| 11  | 0   | 0 | 1    |
| 0.0 | 1   | 1 | 0    |
| 01  | 1   | 0 | 1    |
| 10  | 1   | 0 | 1    |
| 11  | 1   | 1 | 1    |

Figure 1.2 Full-adder diagram and truth table.





#### Figure 1.3

Example of VHDL code for the full-adder unit of figure 1.2.

Circuit, and of an ARCHITECTURE, which describes how the circuit should function. We see in the latter that the sum bit is computed as S=aXORbXORcin, while cout is obtained from COUT=a.b+a.cin+b.cin.







# **2-**Code Structure

In this chapter , we describe the **fundamental** sections that comprise a piece of VHDL code: LIBRARY declarations, ENTITY, and ARCHITECTURE.

### 2.1 Fundamental VHDL Units

As depicted in figure 2.1, a standalone piece of VHDL code is composed of at least three fundamental sections:

1-LIBRARY declarations: Contains a list of all libraries to be used in the design. For example: ieee, std, work, etc.

**2- ENTITY**: Specifies the I/O pins of the circuit.

3-ARCHITECTURE: Contains the VHDL code proper, which describes how the circuit should behave (function).

A LIBRARY is a collection of commonly used pieces of code. Placing such pieces inside a library allows them to be reused or shared by other designs.

The typical structure of a library is illustrated in figure 2.2. The code is usually Written in the form of FUNCTIONS, PROCEDURES, or COMPONENTS, which are placed inside PACKAGES, and then compiled into the destination library.

# **2.2 Library Declarations**

To declare a LIBRARY (that is, to make it visible to the design) two lines of codeare needed, one containing the name of the library, and the other a use

clause, as shown in the syntax below. LIBRARY

library\_name;

USE library\_name.package\_name.package\_parts;

At least **three** packages, from three different libraries, are usually needed in a design:

1-ieee.std\_logic\_1164(from the ieeelibrary), 2- standard(from the stdlibrary), 3-work(work library).





# **Advanced Digital Electronics**



MCA. Eng. K. DAWAH



Fundamental sections of a basic VHDL code.

| PA | CKAGE      |
|----|------------|
| ſ  | FUNCTIONS  |
|    | PROCEDURES |
|    | COMPONENTS |
|    | CONSTANTS  |
|    | TYPES      |

Figure 2.2 Fundamental parts of a LIBRARY.

Their **declarations** are as follows:

LIBRARY ieee; -- A semi-colon (;) indicates USE ieee.std\_logic\_1164.all; -- the end of a statement or LIBRARY std;-- declaration, while a double USE std. standard. all; -- dash (--) indicates a comment. LIBRARY work; USE work.all;



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





The libraries **std** and **work** shown above are made visible by default, so there is no need to declare them; only the **ieee** library must be explicitly written. However, the latter is only necessary when the STD\_LOGIC (or STD\_ULOGIC) data type is employed in the design *The purpose of the three packages/libraries* mentioned above is the following: the

std\_logic\_1164package of the ieee library specifies a multi-level logic system; std is are source library (data types, text i/o, etc.) for the VHDL design environment; and the work library is where we save our design (the .vhd file, plus all files created by the compiler, simulator, etc.).Indeed, the ieee library contains several packages, including the following:

*1-std\_logic\_1164:* Specifies the STD\_LOGIC (8 levels) and STD\_ULOGIC (9 levels) multi-valued logic systems.

**2-std\_logic\_arith:** Specifies the SIGNED and UNSIGNED data types and related arithmetic and comparison operations. It also contains several data conversion functions, which allow one type to be converted into another: conv\_integer (p),conv\_unsigned (p, b), conv\_signed(p, b), conv\_std\_logic\_vector(p, b).

*3-std\_logic\_signed:* Contains functions that allow operations with STD\_LOGIC\_VECTOR data to be performed as if the data were of type SIGNED.

**4-std\_logic\_unsigned:** Contains functions that allow operations with STD\_LOGIC\_VECTOR data to be performed as if the data were of type UNSIGNED.

# **2.3 ENTITY**

An ENTITY is a list with specifications of all input and output pins (PORTS) of the circuit. Its **syntax** is shown below.

ENTITY entity\_name IS PORT ( Port\_name : signal\_modesignal\_type; Port\_name : signal\_modesignal\_type; ...); END entity\_name

The mode of the signal can be *IN*, *OUT*, *INOUT*, or *BUFFER*. As illustrated in figure 2.3, IN and OUT are truly unidirectional pins, while INOUT is bidirectional. BUFFER, on the other hand, is employed when the output signal must be used(read)







MCA. Eng. K. DAWAH internally. The type of the signal can be BIT, STD\_LOGIC, INTEGER, etc. Finally, the name of the entity can be basically any name, except VHDL reserved words

**Example**: Let us consider the NAND gate of figure 2.4. Its ENTITY can be

specified as: ENTITY nand\_gate IS PORT (a, b : IN BIT; x : OUT BIT); END nand\_gate;



Figure 2.3 Signal modes.



Figure 2.4 NAND gate.

The meaning of the ENTITY above is the following: the circuit has three I/O pins being two inputs (a and b, mode IN) and one output (x, mode OUT). All three signals are of type BIT. The name chosen for the entity was nand\_gate.

# 2.4 ARCHITECTURE

The ARCHITECTURE is a description of how the circuit should behave (function). Its syntax is the following:

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







ARCHITECTURE architecture\_ name OF entity\_name IS[declarations]

BEGIN(code)

END architecture\_name;

As shown above, an architecture has two parts: a declarative part (optional), where

signals and constants (among others) are declared, and the code part (from BEGIN down). Like in the case of an entity, the name of an architecture can be basically any name (except VHDL reserved words), including the same name as the entity's.

**Example:** Let us consider the NAND gate of figure 2.4 once again. ARCHITECTURE myarch OF nand\_gate IS BEGIN

x <= a NAND b; END myarch

The meaning of the ARCHITECTURE above is the following: the circuit must perform the NAND operation between the two input signals (a, b) and assign ("<=")

the result to the output pin (x). The name chosen for this architecture was myarch. In this example, there is no declarative part, and the code contains just a single assignment

# .Example 2.1: DFF with Asynchronous Reset





# **Advanced Digital Electronics**



MCA. Eng. K. DAWAH

Figure 2.5 shows the diagram of a D-type flip-flop (DFF), triggered at the rising edge of the clock signal (clk), and with an asynchronous reset input (rst). When rst='1', the output must be turned low, regardless of clk. Otherwise, the output must copy the input (that is, q <=d) at the moment when clk changes from '0' to '1' (that is, when an upward event occurs on clk). There are several ways of implementing the DFF of figure 2.5, one being the solution presented below.

One thing to remember, however, is that

VHDL is inherently concurrent (contrary to regular computer programs, which are sequential), so to implement any clocked circuit (flip-flops, for example) we have to "force" VHDL to be sequential. This can be done using a PROCESS, as shown below

1 -----

2 LIBRARY ieee;

3 USE ieee.std\_logic\_1164.all;

4 -----

5 ENTITY dff IS

6 PORT ( d, clk, rst: IN STD\_LOGIC;

7 q: OUT STD\_LOGIC);

8 END dff;

9 -----

10 ARCHITECTURE behavior OF dff IS11 BEGIN12 PROCESS (rst, clk)

13 BEGIN

14 IF (rst='1') THEN

15 q <= '0';

16 ELSIF (clk'EVENT AND clk='1') THEN

17 q <= d;

18 END IF;

19 END PROCESS;

20 END behavior;

21 -----

Comments:

Lines 2–3: Library declaration (library name and library use clause). Recall that the other two indispensable libraries (stdand work) are made visible by default

Lines 5–8: Entity dff.

Lines 10–20: Architecture behavior.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





Line 6: Input ports (input mode can only be IN). In this example, all input signals are of type STD\_LOGIC.

Line 7: Output port (output mode can be OUT, INOUT, or BUFFER). Here, the output is also of type STD\_LOGIC.

Lines 11–19: Code part of the architecture (from word BEGIN on).

Lines 12–19: A PROCESS (inside it the code is executed sequentially).

Line 12: The PROCESS is executed every time a signal declared in its sensitivity list changes. In this example, every time rst or clk changes the PROCESS is run.

Lines 14–15: Every time rst goes to '1' the output is reset, regardless of clk (asynchronous reset).

Lines 16–17: If rst is not active, plus clk has changed (an EVENT occurred on clk),

plus such event was a rising edge (clk='1'), then the input signal (d) is stored in the

flip-flop (q <=d).

Lines 15 and 17: The "<=" operator is used to assign a value to a SIGNAL. In contrast, ":=" would be used for a VARIABLE. All ports in an entity are signals by default.

Lines 1, 4, 9, and 21: Commented out (recall that "--" indicates a comment).Used only to better organize the design.

Note: VHDL is not case sensitive.

### Simulation results:

11

Figure 2.6 presents simulation results regarding example 2.1. The graphs can be easily interpreted. The first column shows the signal names, as defined in the ENTITY. It also shows the mode (direction) of the signals; notice that the arrows associated



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





With rst, d, and clk are inward, and contain the letter I (input) inside, while that of qis outward and has an O (output) marked inside. The second column has the value of each signal in the position where the vertical cursor is placed. In the present case, the cursor is at Ons, where the signals have value 1, 0, 0, 0, respectively. In this example, the values are simply '0' or '1', but when vectors are used, the values can be shown in binary, decimal, or hexadecimal form.

The third column shows the simulation proper. The input signals (rst, d, clk) can be chosen freely, and the simulator will determine the corresponding output (q). Comparing the results of figure 2.6 with those expected from the circuit shown previously, we notice that it works properly.

As mentioned earlier, the designs presented in the book were synthesized onto CPLD/FPGA devices

# Example 2.2: DFF plus NAND Gate

The circuit of figure 2.4 was purely **combinational**, While that of figure 2.5 was purely **sequential**. The circuit of figure 2.7 is a mixture of both (without reset).



Figure 2.8 Simulation results of example 2.2.

solution that follows, we have purposely introduced an unnecessary signal (temp), just to illustrate how a signal should be declared. Simulation results from the circuit synthesized with the code below are shown in figure 2.8.

- 1 -----
- 2 ENTITY example IS
- 3 PORT ( a, b, clk: IN BIT;
- 4 q: OUT BIT);
- 5 END examples;

6 -----

7 ARCHITECTURE example OF example IS 8 SIGNAL temp: BIT;

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرابعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







9 BEGIN

10 temp <= a NAND b;

11 PROCESS (clk)

12 BEGIN

13 IF (clk'EVENT AND clk='1') THEN q<=temp;

14 END IF;

15 END PROCESS;

16 END examples;

17 -----

Comments:

Library declarations are not necessary in this case, because the data is of type BIT, which is specified in the library std (recall that the libraries std and work are made visible by default).

Lines 2–5 : Entity example.

Lines7–16: Architecture example.

Line 3: Input ports (all of type BIT).

Line 4: Output port (also of type BIT).

Line 8:Declarative part of the architecture (optional). The signal temp, of type BIT,

Was declared. Notice that there is no mode declaration (mode is only used in entities).

Lines9–15: Code part of the architecture (from word BEGIN on).

Lines 11–15: A PROCESS (sequential statements executed every time the signal clk

changes).

Lines 10 and 11–15: Though within a process the execution is sequential, the process,

as a whole, is concurrent with the other (external) statements; thus line 10 is executed

Concurrently with the block 11–15.

Line 10: Logical NAND operation. Result is assigned to signal temp.

Lines 13–14: IF statement. At the rising edge of clk the value of temp is assigned to q.

Lines 10 and 13: The "<=" operator is used to assign a value to a SIGNAL. In contrast, ":=" would be used for a VARIABLE.

Lines 8 and 10: Can be eliminated, changing " $q \le a$  NAND b" in line 13. Lines 1, 6, and 17: Commented out. Used only to better organize the design.

# Problem 2.1: Multiplexer

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







MCA. Eng. K. DAWAH The top-level diagram of a multiplexer is shown in figure P2.1. According to the truth table, the output should be equal to one of the inputs if sel= "01" (c = a) or sel= "10" (c = b), but it should be '0' or Z (high impedance) if sel= "00" or sel= "11", respectively.



| sel | с |
|-----|---|
| 00  | 0 |
| 01  | a |
| 10  | b |
| 11  | Z |

Figure P2.1

a) Complete the VHDL code below.

b) Write relevant comments regarding your solution (as in examples 2.1 and 2.2).c) Compile and simulate your solution, checking whether it works as expected.Note: A solution using IF was employed in the code below, because it is more intuitive.

However, as will be seen later, a multiplexer can also be implemented with other statements, like WHEN or CASE.

1 -----2 LIBRARY ieee; 3USE ieee.STD\_LOGIC\_1164.all; 4 -----**5 ENTITY mux IS** 6 PORT (a, b: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0); 7 sel : IN STD\_LOGIC\_VECTOR(1 DOWNTO 0); 8c: OUT STD\_LOGIC\_VECTOR (7 DOWNTO 0)); 9 END mux : 10 -----11 ARCHITECTURE example OF mux IS **12 BEGIN** 13 PROCESS (a, b, sel) 14 BEGIN 15 IF (sel = "00") THEN 16 c <= "00000000"; 17 ELSIF (sel="01") THEN 18 c <= a; 19ELSE (sel = "10") THEN  $20 c \le b;$ **21 ELSE**  $22 c \le (OTHERS => '0');$ 23 END IF; 24 END PROCESS : 25 END mux ; 26 -----

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS



# **Advanced Digital Electronics**



MCA. Eng. K. DAWAH



Figure P2.2

#### Problem 2.2: Logic Gates

a) Write a VHDL code for the circuit of figure P2.2. Notice that it is purely combinational, so a PROCESS is not necessary. Write an expression for d using only logical operators (AND, OR, NAND, NOT, etc.).

b) Synthesize and simulate your circuit. After assuring that it works properly, open the report file and check the actual expression implemented by the compiler. Compare it with your expression.

it with your expression. 1-....; 2-LIBRARY ieee; 3-USE ieee.std\_logic\_1164.all; 4-.... 5-ENTITY P2-3 IS 6-PORT( a,b,c :IN STD\_LOGIC; 7d :OUT STD\_LOGIC); 8-9- END P2-3; 10-.... 11-ARCHITECTURE arc of P2-3 IS 12-BEGIN 13- d<=a NAND((a AND b)OR NOT c); 14-END arc; 15-.... Example - A simple AND gate can be modeled, as follows: ENTITY and 2 IS PORT ( a, b : IN BIT c: OUT BIT ); END and2; ARCHITECTURE and2\_dawah OF and2 IS BEGIN  $c \ll a AND b;$ END and2\_dawah; AND2 INPUT а OUTPUT С b

inst

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS



**Advanced Digital Electronics** 





MCA. Eng. K. DAWAH

# 3Data Types

In order to write VHDL code efficiently, it is essential to know what data types are allowed, and how to specify and use them. In this chapter, all fundamental data types are described, with special emphasis on those that are synthesizable. Discussions on data compatibility and data conversion are also included.

# 3.1 Pre-Defined Data Types

VHDL contains a series of pre-defined data types, specified through the IEEE 1076 and IEEE 1164 standards. More specifically, such data type definitions can be found in the following packages / libraries:

Package\_ standard of library std: Defines BIT, BOOLEAN, INTEGER, and REAL data types.

\_ Package std\_logic\_1164 of library ieee: Defines STD\_LOGIC and STD\_ULOGIC data types.

\_ 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).

\_ 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.

All pre-defined data types (specified in the packages/libraries listed above) are described below.

\_ BIT (and BIT\_VECTOR): 2-level logic ('0', '1').

Examples:

SIGNAL x: BIT;

-- x is declared as a one-digit signal of type BIT.

SIGNAL y: BIT\_VECTOR (3 DOWNTO 0);

-- y is a 4-bit vector, with the leftmost bit being the MSB.

#### SIGNAL w: BIT\_VECTOR (0 TO 7);

-- w is an 8-bit vector, with the rightmost bit being the MSB.

Based on the signals above, the following assignments would be *legal* (to assign a value to a signal, the "<=" operator must be used):

*x* <= '1';

-- x is a single-bit signal (as specified above), whose value is

-- '1'. Notice that single quotes (' ') are used for a single bit.

*y* <= ''0111'';

-- y is a 4-bit signal (as specified above), whose value is "0111"

-- (MSB='0'). Notice that double quotes (" ") are used for

-- vectors.

16

w <= ''01110001'';

-- w is an 8-bit signal, whose value is "01110001" (MSB='1').

\_ STD\_LOGIC (and STD\_LOGIC\_VECTOR):8-valued logic system

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات

#### Department of Computer Engineering and Technology





introduced in the IEEE 1164 standard. 'X' Forcing Unknown (synthesizable unknown) **'0'** Forcing Low (synthesizable logic '1') 'I' Forcing High (synthesizable logic '0') 'Z' High impedance (synthesizable tri-state buffer) 'W' Weak unknown 'L' Weak low 'H' Weak high '-'Don't care **Examples:** SIGNAL x: STD LOGIC; -- x is declared as a one-digit (scalar) signal of type STD LOGIC. SIGNAL y: STD\_LOGIC\_VECTOR (3 DOWNTO 0) := "0001"; -- y is declared as a 4-bit vector, with the leftmost bit being -- the MSB. The initial value (optional) of y is "0001". Notice -- that the ":=" operator is used to establish the initial value. Most of the std\_logic levels are intended for simulation only. However, '0', '1', and 'Z' are synthesizable with no restrictions. With respect to the "weak" values, they are resolved in favor of the "forcing" values in multiply-driven nodes (see table 3.1).Indeed, if any two std\_logic signals are connected to the same node, then conflicting logic levels are automatically resolved according to table 3.1.

Table 3.1 Resolved logic system (STD\_LOGIC).

|   | х | 0 | 1 | z | W | L  | н | ž |  |
|---|---|---|---|---|---|----|---|---|--|
| х | x | х | х | х | х | х  | х | х |  |
| 0 | x | 0 | х | 0 | 0 | 0  | 0 | х |  |
| 1 | x | x | 1 | 1 | 1 | 1  | 1 | X |  |
| z | х | 0 | 1 | z | W | L  | н | Х |  |
| W | х | 0 | 1 | W | W | W  | W | X |  |
| L | x | 0 | 1 | L | W | I. | W | Х |  |
| н | x | 0 | 1 | н | W | W  | н | Х |  |
| 2 | x | х | х | x | х | x  | x | X |  |

STD\_LOGIC system described above is a subtype of STD\_ULOGIC. The latter includes an extra logic value, 'U', which stands for unresolved. Thus, contrary to STD\_LOGIC, conflicting logic levels are not automatically resolved here, so output wires should never be connected together directly. However, if two output wires are never supposed to be connected together, this logic system can be used to detect design errors.

*BOOLEAN:* True, False.

*INTEGER: 32-bit integers* (from \_2,147,483,647 to 2,147,483,647). *NATURAL:* Non-negative integers (from 0 to 2,147,483,647).

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





*REAL:* Real numbers ranging from \_1.0E38 to 1.0E38. Not synthesizable.

\_ Physical literals: Used to inform physical quantities, like time, voltage, etc. Use fouling simulations. Not synthesizable.

\_ Character literals: Single ASCII character or a string of such characters. Not synthesizable

\_SIGNED and UNSIGNED: data types defined in the std\_logic\_arith package of the ieee library. They have the appearance of STD LOGIC VECTOR, but accept arithmetic operations, which are typical of INTEGER data types

### **Examples**:

 $x0 \le 0'$ ;-- bit, std\_logic, or std\_ulogic value '0' *x1*<= ''000111111'';-- bit\_vector, std\_logic\_vector, -- std\_ulogic\_vector, signed, or unsigned  $x2 \le "0001\_1111";$ -- underscore allowed to ease visualization  $x3 \le "1011111"$ -- binary representation of decimal 47  $x4 \le B''1011111''$  -- binary representation of decimal 47  $x5 \le O''57''$ -- octal representation of decimal 47 x6 <= X''2F''-- hexadecimal representation of decimal 47 *n* <= *1200*;-- integer  $m \leq 1_{200}$ ;-- integer, underscore allowed IF ready THEN...- Boolean, executed if ready=TRUE y <= 1.2E-5;-- real, not synthesizable q <= d after 10 ns;-- physical, not synthesizable **Example:** Legal and illegal operations between data of different types. SIGNAL a: BIT; SIGNAL b: BIT VECTOR(7 DOWNTO 0); SIGNAL c: STD\_LOGIC; SIGNAL d: STD\_LOGIC\_VECTOR(7 DOWNTO 0); SIGNAL e: INTEGER RANGE 0 TO 255; SOLUTION:

a <= b(5); -- *legal* (same scalar type: BIT)

 $b(0) \le a; -- legal$  (same scalar type: BIT)

c <= d(5); -- *legal* (same scalar type: STD\_LOGIC)

d(0) <= c; -- *legal* (same scalar type: STD\_LOGIC)

a <= c; -- *illegal* (type mismatch: BIT x STD\_LOGIC)

- b <= d;--*illegal* (type mismatch: BIT\_VECTOR x-- STD\_LOGIC\_VECTOR)
- e <= b; -- *illegal* (type mismatch: INTEGER x BIT\_VECTOR)
- e <= d; -- *illegal* (type mismatch: INTEGER x-- STD\_LOGIC\_VECTOR)





# 3.2 User-Defined Data Types

VHDL also allows the user to define own data types. Two categories of user defined data types are shown below: *integer* and *enumerated*.

User-defined *integer* types:

1-TYPE integer IS RANGE -2147483647 TO +2147483647;

-- This is indeed the pre-defined type INTEGER.

2-TYPE natural IS RANGE 0 TO +2147483647;

-- This is indeed the pre-defined type NATURAL.

3-TYPE my\_integer IS RANGE -32 TO 32;

-- A user-defined subset of integers.

4-TYPE student\_grade IS RANGE 0 TO 100;

-- A user-defined subset of integers or naturals.

User-defined *enumerated*types:

1-TYPE bit IS ('0', '1');

-- This is indeed the pre-defined type BIT

2-TYPE my\_logic IS ('0', '1', 'Z');

-- A user-defined subset of std\_logic.

3-TYPE bit\_vector IS ARRAY (NATURAL RANGE <>) OF BIT;

-- This is indeed the pre-defined type BIT\_VECTOR.

-- RANGE <> is used to indicate that the range is unconstrained.

-- NATURAL RANGE <>, on the other hand, indicates that the only

-- Restriction is that the range must fall within the NATURAL

-- range.

4-TYPE state IS (idle, forward, backward, stop);

-- An enumerated data type, typical of finite state machines.

5-TYPE color IS (red, green, blue, white);

-- Another enumerated data type.

The encoding of enumerated types is done sequentially and automatically (unless specified otherwise by a user-defined attribute, as will be shown in chapter 4). For example, for the type color above, two bits are necessary (there are four states), being "00" assigned to the first state (*red*), "01" to the second (*green*), "10" to the next

(blue), and finally "11" to the last state (white)

### 3.3 Subtypes

A SUBTYPE is a TYPE with a constraint. The main reason for using a sub type rather than specifying a new type is that, though operations between data of different types are not allowed, they are allowed between a subtype and its corresponding base type.

Examples: The subtypes below were derived from the types presented in the previous examples.

SUBTYPE natural IS INTEGER RANGE 0 TO INTEGER'HIGH; -- As expected, NATURAL is a subtype (subset) of INTEGER. SUBTYPE my\_logic IS STD\_LOGIC RANGE '0' TO 'Z'; -- Recall that STD\_LOGIC=('X','0','1','Z','W','L','H','-'). -- Therefore, my\_logic=('0','1','Z').

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرابعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







SUBTYPE my\_color IS color RANGE red TO blue; -- Since color=(red, green, blue, white), then -- my\_color=(red, green, blue). SUBTYPE small\_integer IS INTEGER RANGE -32 TO 32; -- A subtype of INTEGER. Example: Legal and illegal operations between types and subtypes. SUBTYPE my\_logic IS STD\_LOGIC RANGE '0' TO '1'; SIGNAL a: BIT; SIGNAL b: STD\_LOGIC; SIGNAL c: my\_logic; SOLUION: b <= a; --illegal (type mismatch: BIT versus STD\_LOGIC) b <= c;--legal (same "base" type: STD\_LOGIC)</pre>

### 3.4 –Arrays--

Arrays are *collections* of *objects* of the *same type*. They can be one-dimensional (1D), two-dimensional (2D), or one-dimensional-by-one-

Dimensional(**1Dx1D**). They can also be of higher dimensions, but then they are generally not synthesizable Figure 3.1 illustrates the construction of data arrays. A single value (scalar) is shown in (a), a vector (1D array) in (b), an array of vectors (1Dx1D array) in (c), and an array of scalars (2D array) in (d).

Indeed, the pre-defined VHDL data types (seen in section 3.1) include only thescalar (single bit) and vector (one-dimensional array of bits) categories.

The predefined synthesizable types in each of these categories are the following: 1-Scalars: BIT, STD\_LOGIC, STD\_ULOGIC, and BOOLEAN.

2-Vectors: BIT\_VECTOR, STD\_LOGIC\_VECTOR, STD\_ULOGIC\_VECTOR, INTEGER, SIGNED, and UNSIGNED.



Figure 3.1

Illustration of (a) scalar, (b) 1D, (c) 1Dx1D, and (d) 2D data arrays.

As can be seen, there are no pre-defined 2D or 1Dx1D arrays, which, when necessary must be specified by the user. To do so, the new TYPE must first be defined ,then the new SIGNAL, VARIABLE, or CONSTANT can be declared using that data type. The syntax below should be used. *To specify a new array type:* 

TYPE type\_name IS ARRAY (specification) OF data\_type;

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





#### To make use of the new array type:

SIGNAL signal\_name: type\_name [:= initial\_value];

In the syntax above, a SIGNAL was declared. However, it could also be a CONSTANT or a VARIABLE. Notice that the initial value is optional (for simulation only).

#### Example: 1Dx1D array.

Say that we want to build an array containing *four vectors*, each of size **eight** bits .This is then an 1Dx1D array (see figure 3.1). Let us call each vector by row, and the Complete array by matrix. Additionally, say that we want the leftmost bit of each vector to be its MSB (most significant bit), and that we want the top row to be row 0.Then the array implementation would be the following (notice that a signal, called x, of type matrix, was declared as an example):

#### Example

TYPE row IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC;-- 1D array TYPE matrix IS ARRAY (0 TO 3) OF row; -- 1Dx1D array SIGNAL x: matrix; -- 1Dx1D signal

#### Example: 1Dx1D array.

Another way of constructing the 1Dx1D array above would be the following: **TYPE matrix IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0);** From a data-compatibility point of view, the latter might be advantageous over that in the previous example (see example 3.1).

#### Example: 2D array.

The array below is truly two-dimensional. Notice that its construction is not basedon vectors, but rather entirely on scalars.

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

-- 2D array

#### **Example:** Array initialization.

As shown in the syntax above, the initial value of a SIGNAL or VARIABLE is optional .However, when initialization is required, it can be done as in the **examples** below.

.....:="0001";-- for 1D array

... :=('0','0','1')-- for 1D array

...:=(('0','1','1','1'), ('1','1','1','0')); -- for 1Dx1D or-- 2D array

#### Example: Legal and illegal array assignments.

The assignments in this example are based on the following type definitions and signal declarations:

TYPE row IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC;-- 1D array TYPE array1 IS ARRAY (0 TO 3) OF row;-- 1Dx1D array 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

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







SIGNAL x: row: SIGNAL y: array1; SIGNAL v: array2; SIGNAL w: array3; ------ Legal scalar assignments: -------- The scalar (single bit) assignments below are all legal, -- because the "base" (scalar) type is STD\_LOGIC for all signals-- (x,y,v,w).  $x(0) \le y(1)(2)$ ; -- notice two pairs of parenthesis-- (y is 1Dx1D)  $x(1) \le v(2)(3)$ ; -- two pairs of parenthesis (v is 1Dx1D)  $x(2) \le w(2,1);$  -- a single pair of parenthesis (w is 2D)  $y(1)(1) \le x(6);$  $v(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 assignments: ----- $x \le y(0)$ ;------ *legal* (same data types: ROW) x <= v(1);.....- *illegal* (type mismatch: ROW x-- STD\_LOGIC\_VECTOR)  $x \le w(2);\dots, -- illegal$  (w must have 2D index)  $x \le w(2, 2 \text{ DOWNTO } 0);...-illegal (type mismatch: ROW x-- STD LOGIC)$ v(0) <= w(2, 2 DOWNTO 0);-- *illegal* (mismatch: STD\_LOGIC\_VECTOR-x STD\_LOGIC)  $v(0) \le w(2);\dots$  -- *illegal* (w must have 2D index) y(1) <= v(3);.....- *illegal* (type mismatch: ROW x-- STD\_LOGIC\_VECTOR)  $y(1)(7 \text{ DOWNTO } 3) \le x(4 \text{ DOWNTO } 0); -- legal (same type, -- same size)$  $v(1)(7 \text{ DOWNTO } 3) \le v(2)(4 \text{ DOWNTO } 0);$ -- *legal* (same type,-- same size)  $w(1, 5 \text{ DOWNTO } 1) \le v(2)(4 \text{ DOWNTO } 0);$ -- *illegal* (type mismatch) 3.5 Port Array As we have seen, there are no pre-defined data types of more than one dimension .However, in the specification of the input or output pins (PORTS) of a circuit (which is made in the ENTITY), we might need to specify the ports as arrays of vectors .Since User-defined data types in a PACKAGE, which will then be visible to the whole design (thus including the ENTITY). An example is shown below. ----- Package: -----LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

-----

PACKAGE my\_data\_types IS TYPE vector\_array IS ARRAY (NATURAL RANGE <>) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0); END my\_data\_types;

-----

------ Main code: ------LIBRARY ieee; USE ieee.std\_logic\_1164.all;

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







USE work.my\_data\_types.all; -- user-defined package

# ENTITY mux IS PORT (inp: IN VECTOR\_ARRAY (0 TO 3); ... ); END mux;

As can be seen in the example above, a user-defined data type, called vector array, was created, which can contain an indefinite number of vectors of size eight bits each (NATURAL RANGE <> signifies that the range is not fixed, with the only restriction that it must fall within the NATURAL range, which goes from 0 to 2,147,483,647). The data type was saved in a PACKAGE called my \_data\_ types, and later used in an ENTITY to specify a PORT called inp. Notice in the main code the inclusion of an additional USE clause to make the user-defined package my \_data \_types visible to the design Another option for the PACKAGE above would be that shown below, Where a CONSTANT declaration is included (a detailed study of PACKAGES will be presented in chapter 10).

------ Package: ------LIBRARY ieee; USE ieee.std\_logic\_1164.all;

-----

PACKAGE my\_data\_types IS CONSTANT b: INTEGER:= 7; TYPE vector\_array IS ARRAY (NATURAL RANGE <>) OF STD\_LOGIC\_VECTOR(b DOWNTO 0); END my\_data\_types;

#### <mark>3.6 Records</mark>

Records are similar to arrays, with the only difference that they contain objects of different types

Example: TYPE birthday IS RECORD day: INTEGER RANGE 1 TO 31; month: month\_ name; END RECORD;

#### **3.7 Signed and Unsigned Data Types**

As mentioned earlier, these types are defined in the std \_logic \_arith package of the ieee library. Their syntax is illustrated in the examples below.

#### Examples:

SIGNAL x: SIGNED (7 DOWNTO 0); SIGNAL y: UNSIGNED (0 TO 3); Notice that their syntax is similar to that of STD\_LOGIC\_VECTOR, not like thatof an INTEGER, as one might have expected. An UNSIGNED value is a number never lower than zero. For example,

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرابعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







MCA. Eng. K. DAWAH "0101" represents the decimal 5, while "1101" signifies 13. If type SIGNED is used instead, the value can be positive or negative (in two's complement format). Therefore, "0101" would represent the decimal 5, while "1101" would mean(-3). To use SIGNED or UNSIGNED data types, the std\_logic\_arith package, of The ieee library, must be declared. Despite their syntax, SIGNED and UNSIGNED data types are intended mainly for arithmetic operations, that is, contrary to STD\_LOGIC\_VECTOR, they accept arithmetic operations. On the other hand ,logical operations are not allowed. With respect to relational (comparison) operations ,there are no restrictions.

**Example**: Legal and illegal operations with signed/unsigned data types. LIBRARY ieee:

USE ieee.std logic 1164.all;

USE ieee.std\_logic\_arith.all; -- extra package necessary

... SIGNAL a: IN SIGNED (7 DOWNTO 0); SIGNAL b: IN SIGNED (7 DOWNTO 0); SIGNAL x: OUT SIGNED (7 DOWNTO 0); SOLUTION

v <= a + b; -- legal (arithmetic operation OK)

w <= a AND b; -- illegal (logical operation not OK)

**Example:** *Legal* and *illegal* operations with std\_logic\_vector. LIBRARY ieee;

USE ieee.std\_logic\_1164.all; -- no extra package required

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); SOLUTION:

v <= a + b; -- illegal (arithmetic operation not OK)

w <= a AND b; -- legal (logical operation OK)

Despite the constraint mentioned above, there is a simple way of allowing data of type STD\_LOGIC\_VECTOR to participate directly in arithmetic operations. For that, the ieee library provides two packages, std\_logic\_signed and

std\_logic\_unsigned, which allow operations with STD\_LOGIC\_VECTOR data to be performed as if the data were of type SIGNED or UNSIGNED, respectively. Example: Arithmetic operations with std\_logic\_vector.

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.std\_logic\_unsigned.all; -- extra package included

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); SOLUTION:

v <= a + b; -- legal (arithmetic operation OK), unsigned w <= a AND b; -- legal (logical operation OK)

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرابعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







# 3.8 Data Conversion

VHDL does not allow direct operations (arithmetic, logical, etc.) between data of different types. Therefore, it is often necessary to convert data from one type to another .This can be done in basically two ways: or we write a piece of VHDL code for that, or we invoke a FUNCTION from a pre-defined PACKAGE which is capable of doing it for us. If the data are closely related (that is, both operands have the same base type ,despite being declared as belonging to two different type classes), then thestd\_logic\_1164 of the ieee library provides straightforward conversion functions. An example is shown below

### **Example: Legal and illegal** operations with subsets.

TYPE long IS INTEGER RANGE -100 TO 100; TYPE short IS INTEGER RANGE -10 TO 10; SIGNAL x : short; SIGNAL y : long; SOLUTION:  $y \le 2^*x + 5$ ; -- error, type mismatch  $y \le \log(2^*x + 5)$ ; -- OK, result converted into type long Several data conversion functions can be found in the std\_logic\_arith package of the ieee library. They are: -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.

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

#### Example: Data conversion.

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);

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

Another alternative was already mentioned in the previous section. It consists of using the std\_logic\_signedor the std\_logic\_unsigned package from the ieee library Such packages allow operations with STD\_LOGIC\_VECTOR data to be performed as if the data were of type SIGNED or UNSIGNED, respectively .Besides the data

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





conversion functions described above, several others are often offered by synthesis tool vendors.

#### 3.9 Summary

The fundamental synthesizable VHDL data types are summarized in table 3.2. 3.10 Additional Examples We close this chapter with the presentation of additional examples illustrating the specification and use of data types. The development of actual designs from scratch will only be possible after we conclude laying out the basic foundations of VHDL(chapters 1 to 4).

#### Example 3.1: Dealing with Data Types

The legal and illegal assignments presented next are based on the following type definitions and signal declarations:

TYPE byte IS ARRAY (7 DOWNTO 0) OF STD\_LOGIC; -- 1D-- array TYPE mem1 IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD\_LOGIC;--2D-- array TYPE mem2 IS ARRAY (0 TO 3) OF byte; -- 1Dx1D-- array TYPE mem3IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(0 TO 7); -- 1Dx1Darray SIGNAL a: STD\_LOGIC; -- scalar signal SIGNAL b: BIT; -- scalar signal SIGNAL x: byte; -- 1D signal SIGNAL y: STD\_LOGIC\_VECTOR (7 DOWNTO 0); -- 1D signal SIGNAL v: BIT\_VECTOR (3 DOWNTO 0); -- 1D signal SIGNAL z: STD LOGIC VECTOR (x'HIGH DOWNTO 0); -- 1D signal SIGNAL w1: mem1; -- 2D signal SIGNAL w2: mem2; -- 1Dx1D signal SIGNAL w3: mem3; -- 1Dx1D signal ------ Legal scalar assignments: ----- $x(2) \le a;$  -- same types (STD\_LOGIC), correct indexing  $y(0) \le x(0)$ ; -- same types (STD\_LOGIC), correct indexing  $z(7) \le x(5)$ ; -- same types (STD\_LOGIC), correct indexing  $b \le v(3)$ ; -- same types (BIT), correct indexing  $w1(0,0) \le x(3)$ ; -- same types (STD\_LOGIC), correct indexing  $w1(2,5) \le y(7)$ ; -- same types (STD\_LOGIC), correct indexing  $w_2(0)(0) \le x(2)$ ; -- same types (STD\_LOGIC), correct indexing  $w_2(2)(5) \le y(7)$ ; -- same types (STD\_LOGIC), correct indexing  $w1(2,5) \le w2(3)(7)$ ; -- same types (STD\_LOGIC), correct indexing ------ Illegal scalar assignments: -----b <= a; -- type mismatch (BIT x STD\_LOGIC)  $w1(0)(2) \le x(2); --$  index of w1 must be 2D  $w_2(2,0) \le a$ ; -- index of w2 must be 1Dx1D ------ Legal vector assignments: -----x <= "111111110"; y <= ('1','1','1','1','1','0','Z'); z <= "11111" & "000";  $x \ll (OTHERS \Rightarrow '1');$ y <= (7 =>'0', 1 =>'0', OTHERS => '1');  $z \leq v$ ;  $y(2 \text{ DOWNTO } 0) \le z(6 \text{ DOWNTO } 4);$ كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology

BY:K.DAWAH .ABBAS





------ Illegal array assignments: -----  $x \le y$ ; -- type mismatch  $y(5 \text{ TO } 7) \le z(6 \text{ DOWNTO } 0)$ ; -- wrong direction of y  $w1 \le (\text{OTHERS} => '1')$ ; -- w1 is a 2D array  $w1(0, 7 \text{ DOWNTO } 0) \le "11111111"$ ; -- w1 is a 2D array  $w2 \le (\text{OTHERS} => 'Z')$ ; -- w2 is a 1Dx1D array  $w2(0, 7 \text{ DOWNTO } 0) \le "11110000"$ ; -- index should be 1Dx1D

```
-- Example of data type independent array initialization:

FOR i IN 0 TO 3 LOOP

FOR j IN 7 DOWNTO 0 LOOP

x(j) \le 0';

y(j) \le 0';

x(i,j) \le 0';

w1(i,j) \le 0';

w2(i)(j) \le 0';

END LOOP;
```

#### Example 3.2: Single Bit Versus Bit Vector

This example illustrates the difference between a single bit assignment and a bit vector assignment (that is, BIT versus BIT\_VECTOR, STD\_LOGIC versus STD\_LOGIC\_VECTOR, or STD\_ULOGIC versus STD\_ULOGIC\_VECTOR). Two VHDL codes are presented below. Both perform the AND operation between the input signals and assign the result to the output signal. The only difference between them is the number of bits in the input and output ports (one bit in the first, four bits in the second).

The circuits inferred from these codes are shown in figure 3.2.

ENTITY and IS PORT (a, b: IN BIT; x: OUT BIT); END and2;

\_\_\_\_\_

ENTITY and IS PORT (a, b: IN BIT\_VECTOR (0 TO 3); كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







x: OUT BIT\_VECTOR (0 TO 3)); END and2;

ARCHITECTURE and 2 OF and 2 IS BEGIN x <= a AND b; END and 2;

ARCHITECTURE and 2 OF and 2 IS BEGIN x <= a AND b; END and 2;

### Example 3.3: Adder

Figure 3.3 shows the top-level diagram of a 4-bit adder. The circuit has two inputs(a, b) and one output (sum). Two solutions are presented. In the first, all signals are of type SIGNED, while in the second the output is of type INTEGER. Notice in solution 2 that a conversion function was used in line 13, for the type of a b does not match that of sum. Notice also the inclusion of the std\_logic\_arith package (line4 of each solution), which specifies the SIGNED data type. Recall that a SIGNED value is represented like a vector; that is, similar to STD\_LOGIC\_VECTOR, not like an INTEGER.

1 ----- Solution 1: in/out=SIGNED -----2 LIBRARY ieee;
3 USE ieee.std\_logic\_1164.all;
4 USE ieee.std\_logic\_arith.all;
5 -----6 ENTITY adder1 IS
7 PORT ( a, b : IN SIGNED (3 DOWNTO 0);
8 sum : OUT SIGNED (4 DOWNTO 0));
9 END adder1;
10 -----11 ARCHITECTURE adder1 OF adder1 IS
12 BEGIN
13 sum <= a + b;
14 END adder1;
15 ------</pre>





# **Advanced Digital Electronics**













|         |      |    | 100.0 | Ons  | 200,0    | Ons | 300.0 | Ins  | 400,0 | Ins  |
|---------|------|----|-------|------|----------|-----|-------|------|-------|------|
| a 🏹     | но   | 0) | 2)    | 4    | 6)       | 8 X | A)    | c )  | EX    | 0)   |
| 🗊 b     | но   | 0) | (4)(  | 8)   | <u> </u> | ο χ | 4)    | 8 )  | c )   | 0)   |
| sum sum | н оо | 00 | χ 06  | ( 1C | χ 02     | 18  | χ 1E  | X 14 | χ 1A  | χ οο |

Figure 3.4 Simulation results of example 3.3.







12 BEGIN 13 sum <= CONV\_INTEGER(a + b); 14 END adder2; 15 -----

Simulation results (for either solution) are presented in figure 3.4. Notice that the numbers are represented in hexadecimal 2's complement form. Since the input range is from(- 8 to 7), its representation is( $7 \rightarrow 7$ ),  $6 \rightarrow 6$ , ...,  $0 \rightarrow 0$ ,  $-1 \rightarrow 15$ ,  $-2 \rightarrow 14$ , ...,  $-8 \rightarrow 8$ . Likewise, the output range is from -16 to 15, so its representation is $15 \rightarrow 15$ , ...,  $0 \rightarrow 0$ ,  $-1 \rightarrow 31$ , ...,  $-16 \rightarrow 16$ . Therefore, 2H 4H =06H (that is, 2 + 4 = 6), 4H +8H = 1CH (that is, 4 + (-8) = -4), etc., where H = Hexadecimal







# **4 -Operators and Attributes**

The purpose of this chapter, along with the preceding chapters, is to lay the basic foundations of VHDL, so in the next chapter we can start dealing with actual circuit designs.

It is indeed impossible—or little productive, at least—to write any code efficiently without undertaking first the sacrifice of understanding data types, operators, and attributes well.

Operators and attributes constitute a relatively long list of general VHDL constructs, which are often examined only sparsely. We have collected them together in

# 4.1-Operators

VHDL provides several kinds of pre-defined operators:

- 1- Assignment operators
- 2- Logical operators
- 3- Arithmetic operators
- 4- Relational operators
- 5- Shift operators
- 6- Concatenation operators

Each of these categories is described below.

# **1-Assignment Operators**

Are used to assign values to signals, variables, and constants. They are: <= Used to assign a value to a SIGNAL.

**:=**Used to assign a value to a VARIABLE, CONSTANT, or GENERIC. Usedalso for establishing initial values.

=>Used to assign values to individual vector elements or with OTHERS.

**Example:** Consider the following signal and variable declarations: SIGNAL **x** : STD\_LOGIC;

VARIABLE **y** : STD\_LOGIC\_VECTOR(3 DOWNTO 0); -- Leftmost bit is MSB

SIGNAL w: STD\_LOGIC\_VECTOR(0 TO 7); -- Rightmost bit is -- MSB

Then the following assignments are **legal:** 

x <= '1'; -- '1' is assigned to SIGNAL x using "<=" y := "0000"; -- "0000" is assigned to VARIABLE y using ":=" w <= "10000000"; -- LSB is '1', the others are '0' w <= (0 =>'1', OTHERS =>'0'); -- LSB is '1', the others are '0'







# Logical Operators

Used to perform logical operations. The data must be of type BIT, STD\_LOGIC,

or STD\_ULOGIC (or, obviously, their respective extensions, BIT\_VECTOR,

STD\_LOGIC\_VECTOR, or STD\_ULOGIC\_VECTOR). The logical operators are:

\_NOT

OR

\_NAND

\_NOR

\_XNOR

Notes: The NOT operator has precedence over the others. The XNOR operator was

introduced in VHDL93.

### Examples:

 $\overline{y} \le \overline{NOT}$  a AND b; -- (a'.b)

y <= NOT (a AND b); -- (a.b)'

y <= a NAND b; -- (a.b)'

# **2-Arithmetic Operators**

Used to perform arithmetic operations. The data can be of type INTEGER,

SIGNED, UNSIGNED, or REAL (recall that the last cannot be synthesized directly).

Also, if the std\_logic\_signed or the std\_logic\_unsigned package of the ieeelibrary is used, then STD\_LOGIC\_VECTOR can also be employed directly in addition

# +Addition

-Subtraction \* Multiplication / Division \*\* Exponentiation MOD Modulus REM Remainder ABS Absolute value







There are no synthesis restrictions regarding addition and subtraction, and the same is generally true for multiplication. For division, only power of two dividers are allowed. For exponentiation, only static values of base and exponent are accepted. Regarding the mod and rem operators, y mod x returns the remainder of y/x with the signal of x,

while y rem x returns the remainder of y/x with the signal of y. Finally, abs returns the absolute value. With respect to the last three operators (mod, rem, abs), there generally is little or no synthesis support.

# **Comparison Operators**

Used for making comparisons. The data can be of any of the types listed above. The relational (comparison) operators are:

=Equal to

 $\neq$ Not equal to

<Less than

>Greater than

<=Less than or equal to

>=Greater than or equal to

# Shift Operators

Used for shifting data. They were introduced in VHDL93. Their syntax is the following:

(left operand)(shift operation)(right operand). The left operand must be of type BIT\_VECTOR, while the right operand must be an INTEGER (+or -infront of it is accepted).

The shift operators are:

1-sll Shift left logic-positions on the right are filled with '0's

2-srl Shift right logic – positions on the left are filled with '0's

# Data Attributes

The pre-defined, synthesizable data attributes are the following:

1-d'LOW: Returns lower array index

2-d'HIGH: Returns upper array index

3-d'LEFT: Returns leftmost array index

4-d'RIGHT: Returns rightmost array index

5-d'LENGTH: Returns vector size

6-d'RANGE: Returns vector range

7d'REVERSE\_RANGE: Returns vector range in reverse order







*Example:* Consider the following signal: SIGNAL d : STD\_LOGIC\_VECTOR (7 DOWNTO 0); Then: d'LOW=0, d'HIGH=7, d'LEFT=7, d'RIGHT=0, d'LENGTH=8, d'RANGE=(7 downto 0), d'REVERSE\_RANGE=(0 to 7).

*Example:* Consider the following signal: SIGNAL x: STD\_LOGIC\_VECTOR (0 TO 7); Then all four LOOP statements below are synthesizable and equivalent. FOR i IN RANGE (0 TO 7) LOOP ... FOR i IN RANGE LOOP ... FOR i IN RANGE (x'LOW TO x'HIGH) LOOP... FOR i IN RANGE (0 TO x'LENGTH-1) LOOP... If the signal is of enumerated type, then: -d'VAL(pos): Returns value in the position specified -d'POS(value): Returns position of the value specified -d'LEFTOF(value): Returns value in the position to the left of the value specified -d'VAL(row, column): Returns value in the position specified; etc. There is little or no synthesis support for enumerated data type attributes.

# Signal Attributes

Let us consider a signal s. Then: -s'EVENT: Returns true when an event occurs on s -s'STABLE: Returns true if no event has occurred on s -s'ACTIVE: Returns true if **S**='1' -'QUIET (time): Returns true if no event has occurred during the time specified -s'LAST\_EVENT: Returns the time elapsed since last event -s'LAST ACTIVE: Returns the time elapsed since last **S**='1' -s'LAST\_VALUE: Returns the value of s before the last event; etc. Though most signal attributes are for simulation purposes only, the first two in the list above are synthesizable, s'EVENT being the most often used of them all. Example: All four assignments shown below are synthesizable and equivalent. They return TRUE when an event (a change) occurs on clk, AND if such event is upward (in other words, when a rising edge occurs on clk). IF (clk'EVENT AND clk='1')... -- EVENT attribute used-- with IF IF (NOT clk'STABLE AND clk='1') ... -- STABLE attribute used-- with IF WAIT UNTIL (clk'EVENT AND clk='1'); -- EVENT attribute used-- with WAIT IF RISING EDGE(clk)... -- call to a function





# 4.3 User-Defined Attributes

We saw above attributes of the type HIGH, RANGE, EVENT, etc. Those are all pre-defined in VHDL87. However, VHDL also allows the construction of user defined attributes To employ a user-defined attribute, it must be declared and specified. The syntax is the following

### Attribute declaration:

**ATTRIBUTE** attribute\_name: attribute\_type;

### Attribute specification:

# ATTRIBUTE attribute\_name OF target\_name: class IS value;

where:

attribute\_type:any data type (BIT, INTEGER, STD\_LOGIC\_VECTOR, etc.) class: TYPE, SIGNAL, FUNCTION, etc. value: '0', 27, ''00 11 10 01'', etc.

# 4.4 GENERIC

As the name suggests, GENERIC is a way of specifying a generic parameter (that is, a static parameter that can be easily modified and adapted to different applications). The purpose is to confer the code more flexibility and reusability.

A GENERIC statement, when employed, must be declared in the ENTITY. The specified parameter will then be truly global (that is, visible to the whole design, including the ENTITY itself). Its syntax is shown below.

### **GENERIC** (parameter\_name : parameter\_type := parameter\_value);

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







# 4.5 Examples

We show now a few complete design examples, with the purpose of further

illustrating the use of operators, attributes and GENERIC

. Recall, however, that so far we have just worked on establishing the basic foundations of VHDL, with the formal discussion

#### the student must return and reexamine later

### **Example 4.1: Generic Decoder**

Figure 4.1 shows the top-level diagram of a generic m-by-n decoder. The circuit has two inputs, sel (m bits) and ena (single bit), and one output, x (n bits). We assume that n is a power of two, so  $m = \log 2n$ . If ena ='0', then all bits of x should be high;



Figure 4.1 Decoder of example 4.1.

otherwise, the output bit selected by *sel* should be *low*, as illustrated in the truth table of figure 4.1. The ARCHITECTURE below is totally generic, for the only changes needed to operate with different values of **m** and **n** are in the ENTITY (through sel, line 7, and x, line 8, respectively). In this example, we have used m = 3 and n = 8. However, though this works fine, the use of GENERIC would have made it clearer that m andn are indeed generic parameters. That is indeed the procedure that we will adopt in the other examples that follow (please refer to problem 4.4).

Notice in the code below the use of the following operators:"+" (line 22), "\*" (lines 22 and 24), ":=" (lines 17, 18, 22, 24, and 27), "<=" (line 29), and "=>" (line 17). Notice also the use of the following attributes: HIGH (lines 14–15) and RANGE (line 20).

1 ----- 2 LIBRARY ieee;
 3 USE ieee.std\_logic\_1164.all;
 4 ----- 5 ENTITY decoder IS
 6 PORT ( ena : IN STD\_LOGIC;
 7 sel : IN STD\_LOGIC\_VECTOR (2 DOWNTO 0);
 8 x : OUT STD\_LOGIC\_VECTOR (7 DOWNTO 0));
 9 END decoder;
 10 ----- 11 ARCHITECTURE generic\_decoder OF decoder IS
 12 BEGIN
 13 PROCESS (ena, sel)

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







MCA. Eng. K. DAWAH 14 VARIABLE temp1 : STD\_LOGIC\_VECTOR (x'HIGH DOWNTO 0); 15 VARIABLE temp2 : INTEGER RANGE 0 TO x'HIGH; 16 BEGIN 17 temp1 := (OTHERS => '1');18 temp2 := 0;19 IF (ena='1') THEN 20 FOR i IN sel'RANGE LOOP -- sel range is 2 downto 0 21 IF (sel(i)='1') THEN -- Bin-to-Integer conversion 22 temp2:=2\*temp2+1; 23 ELSE 24 temp2 := 2\* temp2;25 END IF; 26 END LOOP; 27 temp1(temp2):='0'; 28 END IF; 29 x <= temp1; 30 END PROCESS; 31 END generic\_decoder; 32 -----

The functionality of the encoder above can be verified in the simulation results of figure 4.2. As can be seen, all outputs are high, that is, x = "111111111" (decimal 255), when ena ='0'. After ena has been asserted, only one output bit (that selected by sel) is turned low. For example, when sel ="000" (decimal 0), x = "1111110" (decimal 254); when sel ="001" (decimal 1), x = "1111101" (decimal 253); when sel ="010" (decimal 2), x = "1111101" (decimal 251); and so on.



Figure 4.2 Simulation results of example 4.1.

### **Example 4.2: Generic Parity Detector**

Figure 4.3 shows the top-level diagram of a parity detector. The circuit must provide output ='0' when the number of '1's in the input vector is even, or output ='1' otherwise. Notice in the VHDL code below that the ENTITY contains a GENERIC statement (line 3), which defines n as 7. This code would work for any other vector

size, being only necessary to change the value of n in that line. You are invited to highlight the operators and attributes that appear in this design.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







#### Figure 4.3

Generic parity detector of example 4.2.



Figure 4.4

Simulation results of example 4.2.

1 -----2 ENTITY parity\_det IS 3 GENERIC (n : INTEGER := 7); 4 PORT (input: IN BIT\_VECTOR (n DOWNTO 0); 5 output: OUT BIT); 6 END parity\_det; 7 -----8 ARCHITECTURE parity OF parity\_det IS 9 BEGIN 10 PROCESS (input) 11 VARIABLE temp: BIT; 12 BEGIN 13 temp := '0'; 14 FOR i IN input'RANGE LOOP 15 temp := temp XOR input(i); 16 END LOOP; *17 output <= temp;* 18 END PROCESS; 19 END parity; 20 -----

Simulation results from the circuit synthesized with the code above are shown in figure 4.4. Notice that when input ="00000000" (decimal 0), the output is '0', because the number of '1's is even; when input ="00000001" (decimal 1), the output is'1', because the number of '1's is odd; and so on.

#### **Example 4.3: Generic Parity Generator**

The circuit of figure 4.5 must add one bit to the input vector (on its left). Such bit must be a '0' if the number of '1's in the input vector is even, or a '1' if it is odd, such that the resulting vector will always contain an even number of '1's (even parity).

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





A VHDL code for the parity generator is shown below. Once again, you

are invited to highlight the operators and attributes used in the design.

1 -----2 ENTITY parity\_gen IS 3 GENERIC (n : INTEGER := 7); 4 PORT (input: IN BIT\_VECTOR (n-1 DOWNTO 0); 5 output: OUT BIT\_VECTOR (n DOWNTO 0)); 6 END parity\_gen; 7 -----8 ARCHITECTURE parity OF parity\_gen IS 9 BEGIN 10 PROCESS (input) 11 VARIABLE temp1: BIT; 12 VARIABLE temp2: BIT\_VECTOR (output' RANGE); 13 BEGIN 14 temp1 := '0';15 FOR i IN input' RANGE LOOP 16 temp1 := temp1 XOR input(i); 17 temp2(i) := input(i); 18 END LOOP; 19 temp2(output' HIGH) := temp1; 20 output  $\leq$  temp2; 21 END PROCESS; 22 END parity; 23 -----



#### Figure 4.6

Simulation results of example 4.3.



#### Figure 4.5

Generic parity generator of example 4.3.

#### *input* (n-1:0) PARITY GENERATOR *output* (n:0)







Simulation results are presented in figure 4.6. As can be seen, when input = "0000000" (decimal 0, with seven bits), output ="0000000" (decimal 0, with eight bits); when input ="0000001" (decimal 1, with seven bits), output ="10000001" (decimal 129, with eight bits); and so on. **Operators.** 

| Operator type      | Operators                    | Data types                          |
|--------------------|------------------------------|-------------------------------------|
|                    |                              |                                     |
| A                  |                              |                                     |
| Assignment         | <=, :=, =>Any                |                                     |
| Logical            | NOT, AND, NAND,              | BIT, BIT_VECTOR,                    |
|                    |                              |                                     |
| OR, NOR, XOR, XI   | NOR STD LOGIC, S             | STD LOGIC VECTOR,                   |
| STD ULOGIC, STI    | D ULOGIC VECTOR              |                                     |
| Arithmetic *. /. * | * INTEGER, SIGNED, UNS       | SIGNED                              |
| (mod, rem, abs))   | ,,,,,                        |                                     |
|                    |                              |                                     |
|                    |                              |                                     |
| Comparison         | =, ≠, <, >, <=, >=           | All above                           |
| Shift              | sll, srl, sla, sra, rol, ror | BIT VECTOR                          |
| Concatenation      | &, ( , , , )                 | Same as for logical operators, plus |
| SIGNED and UNS     |                              | Same as for region operators, pras  |
| BIGITED and UIIS   |                              |                                     |
|                    |                              |                                     |







### **5**-Concurrent Code

The concurrent statements in VHDL are **WHEN** and **GENERATE**. Besides them, assignments using only operators (AND, NOT,+, \*, sll, etc.) can also be used to construct concurrent code. Finally, a special kind of assignment, called BLOCK, can also be employed in this kind of code.

#### 5.1 Concurrent versus Sequential

We start this chapter by reviewing the fundamental differences between **combinational logic** and **sequential logic**, and by contrasting them with the differences between concurrent code and sequential code.

#### **Combinational versus Sequential Logic**

By definition, combinational logic is that in which the output of the circuit depends only on the current inputs

(figure 5.1(a))., *the system requires no memory* and can be implemented using conventional logic gates.

# sequential logic is defined as that in which the output does depend on previous inputs (figure 5.1(b)).*Therefore, storage elements are required*,

the output of the circuit. a common mistake is to think that any circuit that possesses storage elements(flip-flops) is sequential

A RAM (Random Access Memory) can be modeled as in figure 5.2. Notice that the storage elements appear in a forward path rather than in a feedback loop.

The memory-read operation depends only on the address vector presently applied to the RAM input, with the retrieved value

#### **Concurrent versus Sequential Code**

VHDL code is inherently **concurrent (parallel).** Only statements placed inside a PROCESS, FUNCTION, or PROCEDURE are **sequential.** Still, though within these blocks the execution is sequential, the block, as a whole, is concurrent with any other (external) statements. Concurrent code is also called dataflow code.

**Example,** let us consider a code with three concurrent statements (stat1,

stat2, stat3). Then any of the alternatives below will render the same physical circuit: stat1 stat3 stat1

stat2  $\equiv$  stat2  $\equiv$  stat3  $\equiv$  etc.

stat3stat1 stat2

It is then clear that, since the order does not matter, purely concurrent code can not be used to implement synchronous circuits (the only exception is when a







MCA. Eng. K. DAWAH





RAM model.

**Example,** let us consider a code with three concurrent statements (stat1,

stat2, stat3). Then any of the alternatives below will render the same physical circuit: stat1 stat3 stat1

stat2  $\equiv$  stat2  $\equiv$  stat3  $\equiv$  etc.

stat3stat1 stat2

In general we can only build combinational logic circuits with concurrent code. obtain We will discuss concurrent code, that is, we will study the statements

That can only be used outside PROCESSES, FUNCTIONS, or PROCEDURES. They are the **WHEN** statement and the **GENERATE** statement. Besides

them, assignments using only operators (logical, arithmetic, etc) can obviously also be used to create combinational circuits. Finally, a special kind of statement, called **BLOCK**, can also be employed In summary, in concurrent code the following can be used:

```
used:

1-Operators;

2-The WHEN statement (WHEN/ELSE or WITH/SELECT/WHEN);

3-The GENERATE statement;

4-The BLOCK statement.

Each of these cases is described below.
```







#### **5.2 Using Operators**

This is the **most basic** way of **creating concurrent code.** Operators (AND, OR, , \_. \*, sll, sra, etc.) were discussed in section 4.1, being a summary repeated in table 5.1 below.

# **Operators can be used to implement any combinational circuit.** However, as will become apparent later, **complex circuits are usually easier to write using sequential code**,

even if the circuit does not contain sequential logic. In the example that follows, a design using only logical operators is presented.

Table 5.1 Operators.

| <b>Operator type</b>                                           | Operators                   | Data types                                              |
|----------------------------------------------------------------|-----------------------------|---------------------------------------------------------|
| Logical NOT, AND, NAND, OR, NOR, XOR, XNOR                     | BIT, BIT<br>STD_LOGIC,STD_L | _VECTOR,<br>OGIC_VECTOR<br>STD_ULOGIC,STD_ULOGIC_VECTOR |
| <b>Arithmetic</b> , _, *, /, **                                | INTEGER,<br>(mod, rem, abs) | SIGNED, UNSIGNED                                        |
| <b>Comparison</b> =, ≠, <, >, <=                               | , >=All above               |                                                         |
| Shiftsll, srl, sla, sra, rol, ror BI<br>Concatenation &, (,,,) |                             | rs, plus SIGNED and UNSIGNED                            |



**Figure 5.3** Multiplexer of example 5.1.







#### Example 5.1: Multiplexer #1

#### Write the VHDL code for the circuit in the figure(5-3)by using the logic ?

Figure 5.3 shows a 4-input, one bit per input multiplexer. The output must be equal to the input selected by the selection bits, s1-s0. Its implementation, using only logical operators, can be done as follows:

1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 ----5 ENTITY mux IS 6 PORT (a, b, c, d, s0, s1: IN STD\_LOGIC; 7 y: OUT STD\_LOGIC); 8 END mux; 9 ---10 ARCHITECTURE pure\_logic OF mux IS 11 BEGIN 12 y <= (a AND NOT s1 AND NOT s0) OR 13 (b AND NOT s1 AND s0) OR 14 (c AND s1 AND NOT s0) OR 15 (d AND s1 AND s0); 16 END pure\_logic; 17 -----

Simulation results, confirming the functionality of the circuit, are shown in figure 5.4



Figure 5.4

Simulation results of example 5.1.

#### 5.3 WHEN (Simple and Selected)

As mentioned above, WHEN is one of the **fundamental concurrent state**ments (along with operators and GENERATE). It appears in two forms: WHEN / ELSE (simple WHEN) and WITH / SELECT / WHEN (selected WHEN). Its syntax is shown below.

#### WHEN / ELSE:

assignment WHEN condition ELSE assignment WHEN condition ELSE







#### WITH / SELECT / WHEN:

WITH identifier SELECT assignment WHEN value, assignment WHEN value, ...;

Whenever **WITH/ SELECT/WHEN** is used, all permutations must be tested, so the keyword OTHERS is often useful. Another important keyword is UNAFFECTED, which should be used when no action is to take place.

#### Example

. ------ With WHEN/ELSE -----outp <= "000" WHEN (inp='0' OR reset='1') ELSE "001" WHEN ctl='1' ELSE "010"; ----- With WITH/SELECT/WHEN ------WITH control SELECT output <= "000" WHEN reset, "111" WHEN set, UNAFFECTED WHEN OTHERS; ------

Another important aspect related to the WHEN statement is that the "WHEN value" shown in the syntax above can indeed take up three forms: 1-WHEN value -- single value 2-WHEN value1 to value2 -- range, for enumerated data types-- only 3-WHEN value1 | value2 |... -- value1 or value2 or ...

#### Example 5.2: Multiplexer #2

This example shows the implementation of the same multiplexer of example 5.1, but with a slightly different representation for the sel input (figure 5.5). However, in it WHEN was employed instead of logical operators. Two solutions are presented: one using WHEN/ELSE (simple WHEN) and the other with WITH/SELECT/WHEN (selected WHEN). The experimental results are obviously similar to those obtained in example 5.1.



Figure 5.5 Multiplexer of example 5.2.





46



MCA. Eng. K. DAWAH

1 ------ Solution 1: with WHEN/ELSE------2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; 4 -----5 ENTITY mux IS 6 PORT (a, b, c, d: IN STD\_LOGIC; 7 sel: IN STD\_LOGIC\_VECTOR (1 DOWNTO 0); 8 y: OUT STD\_LOGIC); 9 END mux; 10 -----11 ARCHITECTURE mux1 OF mux IS 12 BEGIN 13 y  $\leq$  a WHEN sel="00" ELSE 14 b WHEN sel="01" ELSE 15 c WHEN sel="10" ELSE 16 d; 17 END mux1; 18 -----1 --- Solution 2: with WITH/SELECT/WHEN-----2 LIBRARY ieee: 3 USE ieee.std logic 1164.all; 4 -----**5 ENTITY mux IS** 6 PORT (a, b, c, d: IN STD\_LOGIC; 7 sel: IN STD\_LOGIC\_VECTOR (1 DOWNTO 0); 8 y: OUT STD\_LOGIC); 9 END mux; 10 -----11 ARCHITECTURE mux2 OF mux IS 12 BEGIN 13 WITH sel SELECT 14 y <= a WHEN "00", -- notice "," instead of ";" 15 b WHEN "01", 16 c WHEN "10", 17 d WHEN OTHERS; -- cannot be "d WHEN "11" " 18 END mux2: 19 -----In the solutions above, sel could have been declared as an INTEGER, in which case the code would be the following: 1 ------2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----**5 ENTITY mux IS** 6 PORT (a, b, c, d: IN STD\_LOGIC; 7 sel: IN INTEGER RANGE 0 TO 3; كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology **BY:K.DAWAH** .ABBAS





MCA. Eng. K. DAWAH

8 y: OUT STD\_LOGIC); 9 END mux; 10 ---- Solution 1: with WHEN/ELSE ------11 ARCHITECTURE mux1 OF mux IS 12 BEGIN 13 y <= a WHEN sel=0 ELSE 14 b WHEN sel=1 ELSE 15 c WHEN sel=2 ELSE 16 d; 17 END mux1;

18 -- Solution 2: with WITH/SELECT/WHEN -----19 ARCHITECTURE mux2 OF mux IS
20 BEGIN
21 WITH sel SELECT
22 y <= a WHEN 0,</li>
23 b WHEN 1,
24 c WHEN 2,
25 d WHEN 3; -- here, 3 or OTHERS are equivalent,
26 END mux2; -- for all options are tested anyway
27 -------

Note: Only one ARCHITECTURE can be synthesized at a time. Therefore, whenever we show more than one solution within the same overall code (like above), it is implicit that all solutions but one must be commented out (with "--"), or a synthesis script must be used, in order to synthesize the remaining solution. In simulations, the CONFIGURATION statement can be used to select a specific architecture. Note: For a generic mux, please refer to problem 5.1.



Figure 5.6 Tri-state buffer of example 5.3.

#### Example 5.3: Tri-state Buffer

This is another example that illustrates the use of WHEN. The 3-state buffer of figure 5.6 must provide output =input when ena (enable) is low, or output = "ZZZZZZZZZZ"(high impedance) otherwise.

1 LIBRARY ieee;

2 USE ieee.std\_logic\_1164.all;

3 -----

4 ENTITY tri\_state IS

5 PORT ( ena: IN STD\_LOGIC;

6 input: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0);







7 output: OUT STD\_LOGIC\_VECTOR (7 DOWNTO 0)); 8 END tri\_state; 9 ------10 ARCHITECTURE tri\_state OF tri\_state IS 11 BEGIN 12 output <= input WHEN (ena='0') ELSE 13 (OTHERS => 'Z'); 14 END tri\_state; 15 ------

Simulation results from the circuit synthesized with the code above are shown in figure 5.7. As expected, the output stays in the high-impedance state while ena is high, being a copy of the input when ena is turned low.

#### Example 5.4: Encoder

The top-level diagram of an n-by-m encoder is shown in figure 5.8. We assume that n is a power of two, so m =log2n. One and only one input bit is expected to be high at a time, whose address must be encoded at the output. Two solutions are presented, one using WHEN / ELSE, and the other with WITH / SELECT / WHEN.











13 "001" WHEN x="00000010" ELSE 14 "010" WHEN x="00000100" ELSE 15 "011" WHEN x="00001000" ELSE 16 "100" WHEN x="00010000" ELSE 17 "101" WHEN x="00100000" ELSE 18 "110" WHEN x="01000000" ELSE 19 "111" WHEN x="10000000" ELSE 20 "ZZZ"; 21 END encoder1; 22 -----1 ---- Solution 2: with WITH/SELECT/WHEN------2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; 4 -----5 ENTITY encoder IS 6 PORT (x: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0); 7 y: OUT STD\_LOGIC\_VECTOR (2 DOWNTO 0)); 8 END encoder: 9 -----10 ARCHITECTURE encoder2 OF encoder IS 11 BEGIN 12 WITH x SELECT 13 y <= "000" WHEN "00000001", 14 "001" WHEN "00000010", 15 "010" WHEN "00000100". 16 "011" WHEN "00001000", 17 "100" WHEN "00010000". 18 "101" WHEN "00100000", 19 "110" WHEN "01000000". 20 "111" WHEN "10000000", 21 "ZZZ" WHEN OTHERS; 22 END encoder2; 23 -----

Simulation results (from either solution) are shown in figure 5.9

### Example 5.5: ALU

An **ALU** (Arithmetic Logic Unit) is shown in figure 5.10. As the name says, it is a circuit capable of executing both kinds of operations, arithmetic as well as logical. Its operation is described in the truth table of figure 5.10. The output (arithmetic or logical) is selected by the MSB of sel, while the specific operation is selected by sel's other three bits.









Figure 5.9

Simulation results of example 5.4.



| sel  | Operation Function |                        | Unit       |  |
|------|--------------------|------------------------|------------|--|
| 0000 | y <= a             | Transfer a             | 2          |  |
| 0001 | y <= a+1           | Increment a            |            |  |
| 0010 | y <= a-1           | Decrement a            |            |  |
| 0011 | y <= b             | Transfer b             | Arithmetic |  |
| 0100 | y <= b+1           | Increment b            |            |  |
| 0101 | y <= b-1           | Decrement b            |            |  |
| 0110 | y <= a+b           | Add a and b            |            |  |
| 0111 | y <= a+b+cin       | Add a and b with carry |            |  |
| 1000 | y <= NOT a         | Complement a           |            |  |
| 1001 | y <= NOT b         | Complement b           |            |  |
| 1010 | y <= a AND b       | AND                    |            |  |
| 1011 | y <= a OR b        | OR                     | Logic      |  |
| 1100 | y <= a NAND b      | NAND                   |            |  |
| 1101 | y <= a NOR b       | NOR                    |            |  |
| 1110 | y <= a XOR b       | XOR                    |            |  |
| 1111 | y <= a XNOR b      | XNOR                   |            |  |

Figure 5.10 ALU of example 5.5.



Figure 5.11 Simulation results of example 5.5.







MCA. Eng. K. DAWAH The solution presented below, besides using **only concurrent code**, also illustrates the use of the same data type to perform both arithmetic and logical operations. That is possible due to the presence of the std\_logic\_unsigned package of the ieee library Two signals, arith and logic, are used to hold the results from the arithmetic and logic units, respectively, being the value passed to the output selected by the multiplexer. Simulation results are shown in figure 5.11. 1 -----2 LIBRARY ieee; 3USE ieee.std\_logic\_1164.all; 4 USE ieee.std\_logic\_unsigned.all; 5 -----**6 ENTITY ALU IS** 7 PORT (a, b: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0); 8 sel: IN STD\_LOGIC\_VECTOR (3 DOWNTO 0); 9 cin: IN STD\_LOGIC; 10 y: OUT STD\_LOGIC\_VECTOR (7 DOWNTO 0)); 11 END ALU: 12 -----13 ARCHITECTURE dataflow OF ALU IS 14 SIGNAL arith, logic: STD\_LOGIC\_VECTOR (7 DOWNTO 0); 15 BEGIN 16 ----- Arithmetic unit: ------17 WITH sel(2 DOWNTO 0) SELECT 18 arith <= a WHEN "000", 19 a+1 WHEN "001", 20 a-1 WHEN "010", 21 b WHEN "011", 22 b+1 WHEN "100", 23 b-1 WHEN "101", 24 a+b WHEN "110", 25 a+b+cin WHEN OTHERS; 26 ----- *Logic unit:* ------27 WITH sel(2 DOWNTO 0) SELECT 28 logic <= NOT a WHEN "000", 29 NOT b WHEN "001", 30 a AND b WHEN "010", 31 a OR b WHEN "011", 32 a NAND b WHEN "100", 33 a NOR b WHEN "101", 34 a XOR b WHEN "110", 35 NOT (a XOR b) WHEN OTHERS; 36 ------ **Mux:** ------37 WITH sel(3) SELECT 38 y  $\leq$  arith WHEN '0', 39 logic WHEN OTHERS; 40 END dataflow; 41 -----







### 5.4 GENERATE

GENERATE is another **concurrent** statement (along with operators and WHEN). It is equivalent to the **sequential** statement LOOP

the same assignments. Its regular form is the FOR / GENERATE construct, with the syntax shown below. Notice that GENERATE must be labeled.

#### FOR / GENERATE:

#### label: FOR identifier IN range GENERATE(concurrent assignments)

#### END GENERATE;

An irregular form is also available, which uses IF/GENERATE (with an IF equivalent; recall that originally IF is a sequential statement). Here ELSE is not allowed. In the same way that IF/GENERATE can be nested inside FOR/GENERATE (syntax below), the opposite can also be done. IF / GENERATE nested inside FOR / GENERATE:

label1: FOR identifier IN range GENERATE

....

label2: IF condition GENERATE (concurrent assignments) END GENERATE;

END GENERATE;

#### **Example:**

SIGNAL x: BIT\_VECTOR (7 DOWNTO 0); SIGNAL y: BIT\_VECTOR (15 DOWNTO 0); SIGNAL z: BIT\_VECTOR (7 DOWNTO 0);

... G1: FOR i IN x'RANGE GENERATE z(i) <= x(i) AND y(i+8); END GENERATE:

One important remark about GENERATE (and the same is true for LOOP, which will be seen in chapter 6) is that both limits of the range must be static. As an example, let us consider the code below, where choice is an input (non-static) parameter. This kind of code is generally not synthesizable. NotOK: FOR i IN 0 TO choice GENERATE(concurrent statements)

END GENERATE;

We also must to be aware of multiply-driven (unresolved) signals. For example, OK: FOR i IN 0 TO 7 GENERATE output(i) <='1' WHEN (a(i) AND b(i))='1' ELSE '0';

END GENERATE;







MCA. Eng. K. DAWAH is fine. However, the compiler will complain that accum is multiply driven (and stop compilation) in either of the following two cases: Not OK: FOR i IN 0 TO 7 GENERATE accum <="11111111" WHEN (a(i) AND b(i))='1' ELSE "00000000"; END GENERATE; Not OK: For i IN 0 to 7 GENERATE accum <= accum + 1 WHEN x(i)='1'; END GENERATE;

#### **Example 5.6: Vector Shifter**

This example illustrates the use of GENERATE. In it, the output vector must be a shifted version of the input vector, with twice its width and an amount of shift specified by another input. For example, if the input bus has width 4, and the present value is "1111", then the output should be one of the lines of the following matrix (the original vector is underscored):

row(0): 0 0 0 0 1 1 1 1 row(1): 0 0 0 1 1 1 1 1 row(2): 0 0 1 1 1 1 0 row(2): 0 1 1 1 1 0 0 row(3): 0 1 1 1 1 0 0 0 row(4): 1 1 1 1 0 0 0 0

The **first** row corresponds to the input itself, with **no shift** and the most significant bits filled with '0's. Each successive row is equal to the previous row shifted one position to the left.

The solution below has **input** *inp*, **output** *outp*, and shift selection sel. Each row of the array above (called matrix, line 14) is defined as subtype vector (line 12).

1 -----

2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all;

4 -----

5 ENTITY shifter IS

6 PORT (inp: IN STD\_LOGIC\_VECTOR (3 DOWNTO 0);

7 sel: IN INTEGER RANGE 0 TO 4;

8 outp: OUT STD\_LOGIC\_VECTOR (7 DOWNTO 0));

9 END shifter;

10 -----

11 ARCHITECTURE shifter OF shifter IS

12 SUBTYPE vector IS STD\_LOGIC\_VECTOR (7 DOWNTO 0);

13 TYPE matrix IS ARRAY (4 DOWNTO 0) OF vector;

14 SIGNAL row: matrix;

15 BEGIN

16 row(0) <= "0000" & inp;

17 G1: FOR i IN 1 TO 4 GENERATE

18 row(i) <= row(i-1)(6 DOWNTO 0) & '0';

- 19 END GENERATE;
- 20 outp <= row(sel);
- 21 END shifter;

22 -----







Simulation results are presented in figure 5.12. As can be seen, inp ="0011" (decimal 3) was applied to the circuit. The result was outp ="0000011" (decimal 3) When sel =0 (no shift), outp="00000110" (decimal 6) when sel =1 (one shift to the left), outp ="00001100" (decimal 12) when sel =2 (two shifts to the left), and so on.

#### 5.5 BLOCK

There are **two** kinds of BLOCK statements: **Simple** and **Guarded**. **Simple BLOCK** 

The BLOCK statement, in its simple form, represents only a way of locally partitioning

the code. It allows a set of concurrent statements to be clustered into a BLOCK, with the purpose of turning the overall code more readable and more manageable Its syntax is shown below.

label: BLOCK [declarative part] BEGIN (concurrent statements) END BLOCK label;

#### **Example:**

b1: BLOCK SIGNAL a: STD\_LOGIC; BEGIN a <= input\_sig WHEN ena='1' ELSE 'Z'; END BLOCK b1; A BLOCK (simple or guarded) can be nested inside another BLOCK. The corresponding syntax is shown below.

label1: BLOCK [declarative part of top block] BEGIN [concurrent statements of top block] label2: BLOCK [declarative part nested block] BEGIN (concurrent statements of nested block) END BLOCK label2; [more concurrent statements of top block] END BLOCK label1;

#### **Guarded BLOCK**

A guarded BLOCK is a special kind of BLOCK, which includes an additional expression, called guard expression.

A guarded statement in a guarded BLOCK is executedonly when the guard expression is TRUE.







#### Guarded BLOCK:

#### label: BLOCK (guard expression) [declarative part]

#### **BEGIN**(concurrent guarded and unguarded statements)

#### END BLOCK label;

As the examples below illustrate, even though only concurrent statements can be written within a BLOCK, with a guarded BLOCK even sequential circuits can be constructed. This, however, is not a usual design approach.

#### **Example 5.7: Latch Implemented with a Guarded BLOCK**

The example presented below implements a transparent latch. In it, clk='1' (line 12) is the guard expression, while q<=GUARDED d (line 14) is a guarded statement. Therefore, q<=d will only occur if clk='1'.

1 -----2 LIBRARY ieee:

3 USE ieee.std\_logic\_1164.all;

4 -----

5 ENTITY latch IS

6 PORT (d, clk: IN STD\_LOGIC;

7 q: OUT STD\_LOGIC);

8 END latch;

10 ARCHITECTURE latch OF latch IS

11 BEGIN

12 b1: BLOCK (clk='1')

13 BEGIN

14 q <= GUARDED d;

15 END BLOCK b1;

16 END latch;

17 -----

#### **Example 5.8: DFF Implemented with a Guarded BLOCK**

Here, a positive-edge sensitive D-type flip-flop, with synchronous reset, is designed. The interpretation of the code is similar to that in the example above. In it, clk'EVENT AND clk='1' (line 12) is the guard expression, while  $q \le GUARDED$  '0' WHEN rst='1' (line 14) is a guarded statement. Therefore, q<='0' will occur when the guard expression is true and rst is '1'.

1 -----

2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all;

4 ------

5 ENTITY dff IS

6 PORT (d, clk, rst: IN STD\_LOGIC;

7 q: OUT STD\_LOGIC);

8 END dff;

9 -----







10 ARCHITECTURE dff OF dff IS 11 BEGIN 12 b1: BLOCK (clk'EVENT AND clk='1') 13 BEGIN 14 q <= GUARDED '0' WHEN rst='1' ELSE d; 15 END BLOCK b1; 16 END dff; 17 ------







## **6**-Sequential Code

As mentioned in chapter 5, VHDL code is inherently concurrent .PROCESSES, FUNCTIONS, and PROCEDURES are the only sections of code that are executed sequentially.

One **important aspect of sequential** code is that it is not limited to sequential logic. Indeed, with it we can build sequential circuits as well as combinational circuits. Sequential code is also called behavioral code.

The statements discussed are all sequential, that is, allowed only inside PROCESSES, FUNCTIONS, or PROCEDURES. They are: **IF**, **WAIT**, **CASE**, and **LOOP**.

VARIABLES are also restricted to be used in sequential code only (that is, inside a PROCESS, FUNCTION, or PROCEDURE). Thus, contrary to a SIGNAL, a VARIABLE can never be global, so its value can not be passed out directly. We will concentration PROCESSES here. FUNCTIONS and PROCEDURES

#### 6.1 PROCESS

A PROCESS is a sequential section of VHDL code. It is characterized by the presence of IF, WAIT, CASE, or LOOP, and by a sensitivity list (except when WAIT is used).

A PROCESS must be installed in the main code, Itssyntax is shown below.

[label:] PROCESS (sensitivity list)
[VARIABLE name type [range] [:= initial\_value;]]
BEGIN
(sequential code)
END PROCESS [label];

VARIABLES are optional. If used, they must be declared in the declarative part of the PROCESS (before the word BEGIN, as indicated in the syntax above). The initial value is not synthesizable, being only taken into consideration in simulations. The use of a label is also optional. Its purpose is to improve code readability. The label can be any word, except VHDL reserved words .



**Figure 6.1** DFF with asynchronous reset of example 6.1.







MCA. Eng. K. DAWAH



Figure 6.2

Simulation results of example 6.1.

To construct a synchronous circuit, monitoring a signal (clock, for example) is necessary. A common way of detecting a signal change is by means of the EVENT attribute For instance, if clk is a signal to be monitored, then

clk'EVENT returns TRUE when a change on clk occurs (rising or falling edge).

#### Example 6.1: DFF with Asynchronous Reset #1

A D-type flip-flop (DFF, figure 6.1) is the most basic building block in **sequential** logic circuits. In it, **the output** must **copy** the **input** at either the positive or negative transition of the clock signal (rising or falling edge).

In the code presented below, we make use of the **IF** statement to design a DFF with asynchronous reset.

If rst = '1', then the output must be q = '0' (lines 14–15), regardless of the status of

**clk** Otherwise, the output must copy the input (that is,  $\mathbf{q} = \mathbf{d}$ ) at the positive edge of clk (lines 16–17).

The EVENT attribute is used in line 16 to detect a clock transition.

The PROCESS (lines 12–19) is run every time any of the signals that appear in its sensitivity list (clk and rst, line 12)changes.

Simulation results, confirming the functionality of the synthesized circuit, are presented in figure 6.2

```
1 ------
2 LIBRARY ieee;
3 USE ieee.std_logic_1164.all;
4 ------
5 ENTITY dff IS
6 PORT (d, clk, rst: IN STD LOGIC;
7 q: OUT STD_LOGIC);
8 END dff;
9 -----
10 ARCHITECTURE behavior OF dff IS
11 BEGIN
12 PROCESS (clk, rst)
13 BEGIN
14 IF (rst='1') THEN
15 q <= '0';
16 ELSIF (clk'EVENT AND clk='1') THEN
17 q \ll d;
```







```
18 END IF;19 END PROCESS;20 END behavior;21 ------
```

### 6.2 Signals and Variables

VHDL provides two objects for dealing with non-static data values: SIGNAL and VARIABLE. It also provides means for establishing default (static) values: CONSTANT and GENERIC.

CONSTANT and SIGNAL can be global (that is, seen by the whole code), and can be used in either type of code, concurrent or sequential. A VARIABLE, on the other hand, is local, for it can only be used inside a piece of sequential code (that is, in a PROCESS, FUNCTION, or PROCEDURE) and its value can never be passed out directly.

#### Constant

CONSTANT serves to establish default values. Its syntax is shown below.

CONSTANT name : type := value;

Examples:

```
CONSTANT set_bit : BIT := '1';
CONSTANT datamemory : memory := (('0','0','0','0'),
('0','0','0','1'),
('0','0','1','1'));
```

A CONSTANT can be declared in a PACKAGE, ENTITY, or ARCHITECTURE. When declared in a package, it is truly global, for the package can be used by several entities. When declared in an entity (after PORT), it is global to all architectures that follow that entity. Finally, when declared in an architecture (in its declarative part), it is global only to that architecture's code. The most common places to find a CONSTANT declaration is in an ARCHITECTURE or in a PACKAGE.

### **Signal**

SIGNAL serves to pass values in and out the circuit, as well as between its internal units. In other words, a signal represents circuit interconnects (wires). For instance, all PORTS of an ENTITY are signals by default. Its syntax is the following:

```
SIGNAL name : type [range] [:= initial_value];
```







MCA. Eng. K. DAWAH

Examples:

```
SIGNAL control: BIT := '0';
SIGNAL count: INTEGER RANGE 0 TO 100;
SIGNAL y: STD_LOGIC_VECTOR (7 DOWNTO 0);
```

The declaration of a SIGNAL can be made in the same places as the declaration of a CONSTANT.

A very important aspect of a SIGNAL, when used inside a section of sequential code (PROCESS, for example), is that its update is not immediate. In other words, its new value should not be expected to be ready before the conclusion of the corresponding

PROCESS, FUNCTION or PROCEDURE.

Recall that the assignment operator for a SIGNAL is ''<='' (Ex.: count <= 35;).

#### Example 9.1: Count Ones #1 (not OK)

Design a circuit that counts the number of '1's in a binary vector.

```
1
  _____
2 LIBRARY ieee;
3 USE ieee.std logic 1164.all;
4
 ------
5 ENTITY count ones IS
6
    PORT ( din: IN STD LOGIC VECTOR (7 DOWNTO 0);
7
          ones: OUT INTEGER RANGE 0 TO 8);
8
 END count ones;
9
  _____
10 ARCHITECTURE not ok OF count ones IS
11
     SIGNAL temp: INTEGER RANGE 0 TO 8;
12 BEGIN
13
    PROCESS (din)
14
    BEGIN
15
       temp \leq 0;
       FOR i IN 0 TO 7 LOOP
16
17
          IF (din(i)='1') THEN
18
            temp <= temp + 1;</pre>
19
         END IF;
20
       END LOOP;
21
       ones <= temp;
22
    END PROCESS;
23 END not ok;
24 ------
```

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





### **VARIABLE**

Contrary to CONSTANT and SIGNAL, a VARIABLE represents only local information.

It can only be used inside a PROCESS, FUNCTION, or PROCEDURE (that is, in sequential code), and its value cannot be passed out directly. On the other hand, its update is immediate, so the new value can be promptly used in the next line of code.

To declare a VARIABLE, the following syntax should be used:

```
VARIABLE name : type [range] [:= init_value];
```

Examples:

```
VARIABLE control: BIT := '0';
VARIABLE count: INTEGER RANGE 0 TO 100;
VARIABLE y: STD_LOGIC_VECTOR (7 DOWNTO 0) := "10001000";
```

Since a VARIABLE can only be used in sequential code, its declaration can only be done in the declarative part of a PROCESS, FUNCTION, or PROCEDURE.

```
Recall that the assignment operator for a VARIABLE is `` := `' (Ex.: count:=35; ).
```

#### Example 9.2: Count Ones #2 (OK)

Design a circuit that counts the number of '1's in a binary vector

```
1 -----
2 LIBRARY ieee;
3 USE ieee.std_logic_1164.all;
4 ------
5 ENTITY count_ones IS
6 PORT ( din: IN STD_LOGIC_VECTOR (7 DOWNTO 0);
7 ones: OUT INTEGER RANGE 0 TO 8);
```







MCA. Eng. K. DAWAH

```
8
  END count ones;
9
    10 ARCHITECTURE ok OF count ones IS
11 BEGIN
12
     PROCESS (din)
13
       VARIABLE temp: INTEGER RANGE 0 TO 8;
14
    BEGIN
       temp := 0;
15
       FOR i IN 0 TO 7 LOOP
16
          IF (din(i)='1') THEN
17
18
            temp := temp + 1;
19
          END IF;
20
       END LOOP;
21
       ones <= temp;
22
    END PROCESS;
23 END ok;
24 -----
             _____
```

#### SIGNAL versus VARIABLE

choosing between a SIGNAL or a VARIABLE is not always straightforward. Their main differences are summarized in table 9.1.

 Table 9.1

 Comparison between SIGNAL and VARIABLE.

|                                                                                                   | SIGNAL                                                                                                                                            | VARIABLE                                                                            |  |  |
|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--|--|
| Assignment                                                                                        | <=                                                                                                                                                |                                                                                     |  |  |
| Utility                                                                                           | Represents circuit interconnects (wires)                                                                                                          | Represents local information                                                        |  |  |
| Scope Can be global (seen by entire code)                                                         |                                                                                                                                                   | Local (visible only inside the<br>corresponding PROCESS, FUNCTION,<br>or PROCEDURE) |  |  |
| Behavior                                                                                          | Update is not immediate in sequential<br>code (new value generally only available<br>at the conclusion of the PROCESS,<br>FUNCTION, or PROCEDURE) | Updated immediately (new value can be<br>used in the next line of code)             |  |  |
| Usage In a PACKAGE, ENTITY, or<br>ARCHITECTURE. In an ENTITY, all<br>PORTS are SIGNALS by default |                                                                                                                                                   | Only in sequential code, that is, in a<br>PROCESS, FUNCTION, or<br>PROCEDURE        |  |  |

#### Example 9.3: Bad versus Good Multiplexer



sel (1:0)

#### Figure 9.1: Multiplexer of example 9.3.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH -- Solution 1: using a SIGNAL (not ok) --1 LIBRARY ieee; 2 USE ieee.std\_logic\_1164.all; 3 -----4 5 ENTITY mux IS PORT ( a, b, c, d, s0, s1: IN STD\_LOGIC; 6 7 y: OUT STD LOGIC); 8 END mux; 9 ------10 ARCHITECTURE not ok OF mux IS SIGNAL sel : INTEGER RANGE 0 TO 3; 11 12 BEGIN PROCESS (a, b, c, d, s0, s1) 13 14 BEGIN 15 sel <= 0; IF (s0='1') THEN sel <= sel + 1; 16 17 END IF; 18 IF (s1='1') THEN sel <= sel + 2; END IF; 19 20 CASE sel IS 21 WHEN  $0 \Rightarrow y <= a;$ 22 WHEN 1 =>  $y \le b$ ; 23 WHEN 2 =>  $y \leq c$ ; 24 WHEN 3 =>  $y \le d$ ; 25 END CASE; END PROCESS; 26 27 END not ok; 28 -----1 -- Solution 2: using a VARIABLE (ok) ----2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; 4 5 ENTITY mux IS 6 PORT ( a, b, c, d, s0, s1: IN STD LOGIC; 7 y: OUT STD LOGIC); 8 END mux; 9 

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH 10 ARCHITECTURE ok OF mux IS 11 BEGIN 12 PROCESS (a, b, c, d, s0, s1) 13 VARIABLE sel : INTEGER RANGE 0 TO 3; 14 BEGIN 15 sel := 0; 16 IF (s0='1') THEN sel := sel + 1; 17 END IF; 18 IF (s1='1') THEN sel := sel + 2; 19 END IF; 20 CASE sel IS 21 WHEN  $0 \Rightarrow y <= a;$ 22 WHEN 1 =>  $y \le b$ ; 23 WHEN 2 =>  $y \leq c$ ; 24 WHEN 3 =>  $y \le d;$ 25 END CASE; 26 END PROCESS; 27 END ok; 28 ----500.0ns 100.0ns 200.0ns 300.0ns 400.0ns 0 - s0 = s1 0 - a U 0 b b 0 C Π in - di 0 0 0 0 -100 Y 100.0ns 200.0ns 300.0ns 400.0ns 500.0ns 0 🗩 s0 0 U - a 0 - b 0 C - C Π min-d 0 - V

Figure 9.2: Simulation results of example 9.3.

#### Example 9.4: DFF with q and qbar #1

Implementing the DFF of figure 9.3.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرابعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH









MCA. Eng. K. DAWAH

```
11 ARCHITECTURE ok OF dff IS
12 BEGIN
13
       PROCESS (clk)
14
       BEGIN
15
           IF (clk'EVENT AND clk='1') THEN
16
               q <= d;
17
           END IF;
18
       END PROCESS;
19
       qbar <= NOT q;
20 END ok;
21
   ----
                                                                    600.0ns
                        100.0ns
                                 200.0ns
                                          300.0ns
                                                   400.0ns
                                                           500.0ns
d 🚽
              0
              0
Clk
              0
-0 q
              0
- qbar
                        100.0ns
                                 200.0ns
                                          300.0ns
                                                   400.0ns
                                                           500.0ns
                                                                    600.0ns
d -
              Х
Clk
              Х
              Х
- 🐨 q
🗝 qbar
              Х
```

Figure 9.4: Simulation results of example 9.4. Example 9.5: Frequency Divider

This example implements a circuit that divides the clock frequency by 6.



Figure 9.5: Frequency divider of example 9.5.







MCA. Eng. K. DAWAH

```
1
  -------
2
  LIBRARY ieee;
3
  USE ieee.std logic 1164.all;
  _____
4
5
  ENTITY freq divider IS
     PORT ( clk : IN STD LOGIC;
6
7
           out1, out2 : BUFFER STD LOGIC);
8
  END freq divider;
9
  10 ARCHITECTURE example OF freq_divider IS
     SIGNAL count1 : INTEGER RANGE 0 TO 7;
11
12 BEGIN
13
     PROCESS (clk)
14
        VARIABLE count2 : INTEGER RANGE 0 TO 7;
15
      BEGIN
         IF (clk'EVENT AND clk='1') THEN
16
17
           count1 \le count1 + 1;
           count2 := count2 + 1;
18
            IF (count1 = ? ) THEN
19
20
               out1 <= NOT out1;
               count1 <= 0;
21
22
           END IF;
23
           IF (count2 = ?) THEN
               out2 <= NOT out2;
24
25
               count2 := 0;
26
           END IF;
27
        END IF;
28
     END PROCESS;
29 END example;
30 -----
                  125.0ns
                           250.0ns
                                             500.0ns
                                                      625.0r
                                    375.0ns
- clk
        1
-@ out1
        0
        0
-ov out2
```

Figure 9.6: Simulation results of example 9.5.

#### 6.3 IF statement

As mentioned earlier, **IF**, **WAIT**, **CASE**, and **LOOP** are the statements intended for

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH sequential code. Therefore, they can only be used inside a PROCESS, FUNCTION, or PROCEDURE. The syntax of IF isshown below.

IF conditions THEN assignments; ELSIF conditions THEN assignments;

ELSE assignments; END IF;

Example: IF (x<y) THEN temp:="11111111"; ELSIF (x=y AND w='0') THEN temp:="11110000"; ELSE temp:=(OTHERS =>'0');

Example 6.2: One-digit Counter #1

The code below implements a progressive 1-digit decimal counter  $(0 \rightarrow 9 \rightarrow 0)$ . A top-level diagram of the circuit is shown in figure 6.3. It contains a single-bit input (clk) and a 4-bit output (digit). The IF statement is used in this example. A variable, temp, was employed to create the four flip-flops necessary to store the 4-bit output signal. Simulation results, confirming the correct operation of the synthesized circuit, are shown in figure 6.4.



Figure 6.3 Counter of example 6.2.

|                  |          | 1 | 100.0ns | 200.0ns | 300.0ns | 400.0ns |
|------------------|----------|---|---------|---------|---------|---------|
| iii clk<br>iigit | 0<br>H 0 |   | )(2)(3) |         |         |         |

Figure 6.4 Simulation results of example 6.2.

BY:K.DAWAH .ABBAS







8 END counter;

9 ------10 ARCHITECTURE counter OF counter IS 11 BEGIN 12 count: PROCESS (clk) 13 VARIABLE temp : INTEGER RANGE 0 TO 10; 14 BEGIN 15 IF (clk' EVENT AND clk ='1') THEN 16 temp := temp + 1; 17 IF (temp=10) THEN temp := 0; 18 END IF; 19 END IF; 20 digit <= temp; 21 END PROCESS count; 22 END counter; 23 ------

temp in the physical circuit can be any 4-bit value. If such value is below 10 (see line 17), the circuit will count correctly from there. On the other hand, if the value is above 10, a number of clock cycles will be used until temp reaches full count (that is, 15, or "1111"), being thus automatically reset to zero, from where the correct operation

then starts. The possibility of wasting a few clock cycles in the beginning is generally not a problem. Still, if one does want to avoid that, temp =10, in line 17, can be changed to temp =>10, but this will increase the hardware. However, if starting exactly from 0 is always necessary, then a reset input should be included (as in example 6.7).Notice in the code above that we increment temp and compare it to 10, with the

purpose of resetting temp once 10 is reached. This is a typical approach used in counters. Notice that 10 is a constant, so a comparator to a constant is inferred by the compiler, which is a relatively simple circuit to construct. However, if instead of a constant we were using a programmable parameter, then a full comparator would need to be implemented, which requires substantially more logic than a comparator to a constant. In this case, a better solution would be to load temp with such a parameter, and then decrement it, reloading temp when the 0 value is reached. In this case, our comparator would compare temp to 0 (a constant), thus avoiding the generation of a full comparator.

#### **Example 6.3: Shift Register**

Figure 6.5 shows a 4-bit shift register. The output bit (q) must be four positive clock edges behind the input bit (d). It also contains an asynchronous reset, which must force all flip-flop outputs to '0' when asserted. In this example, the **IF** statement is again employed.

3 USE ieee.std\_logic\_1164.all;

4 -----

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS

<sup>2</sup> LIBRARY ieee;











Simulation results of example 6.3.

used, the PROCESS cannot have a sensitivity list when **WAIT** is employed. Its syntax(there are three forms of WAIT) is shown below.

WAIT UNTIL signal\_condition;

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





WAIT ON signal1 [, signal2, ... ];

#### WAIT FOR time;

**The WAIT UNTIL statement accepts** only **one signal**, thus being more appropriate for synchronous code than asynchronous. Since the PROCESS has no sensitivity list in this case, WAIT UNTIL must be the first statement in the PROCESS.

#### Example: 8-bit register with synchronous reset.

PROCESS -- no sensitivity list BEGIN WAIT UNTIL (clk'EVENT AND clk='1'); IF (rst='1') THEN output <= "00000000"; ELSIF (clk'EVENT AND clk='1') THEN output <= input; END IF; END PROCESS; WAIT ON, on the other hand, accepts multiple signals. The PROCESS is put on hold until any of the signals listed changes. In the example below, the PROCESS will continue execution whenever a change in rst or clk occurs.

#### Example: 8-bit register with asynchronous reset.

#### PROCESS

BEGIN WAIT ON clk, rst; IF (rst='1') THEN output <= "00000000"; ELSIF (clk'EVENT AND clk='1') THEN output <= input; END IF; END PROCESS;

Finally, WAIT FOR is intended for simulation only (waveform generation for testbenches). Example: **WAIT FOR** 5ns;

#### Example 6.4: DFF with Asynchronous Reset #2

The code below implements the same DFF of example 6.1 (figures 6.1 and 6.2). However, here WAIT ON is used instead of IF only.

- 1 -----2 LIBRARY ieee;
- 3 USE ieee.std\_logic\_1164.all;
- 4 -----
- 5 ENTITY dff IS
- 6 PORT (d, clk, rst: IN STD\_LOGIC; 7 q: OUT STD\_LOGIC);







8 END dff; 9 ------10 ARCHITECTURE dff OF dff IS 11 BEGIN 12 PROCESS 13 BEGIN 14 WAIT ON rst, clk; 15 IF (rst='1') THEN 16 q <= '0'; 17 ELSIF (clk'EVENT AND clk='1') THEN 18 q <= d; 19 END IF; 20 END PROCESS; 21 END dff; 22 ------

#### Example 6.5: One-digit Counter #2

The code below implements the same progressive 1-digit decimal counter of example 6.2 (figures 6.3 and 6.4). However, **WAIT UNTIL** was used **instead** of **IF** only. 1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----**5 ENTITY counter IS** 6 PORT (clk : IN STD\_LOGIC; 7 digit : OUT INTEGER RANGE 0 TO 9); 8 END counter; 9 \_\_\_\_\_ 10 ARCHITECTURE counter OF counter IS 11 BEGIN 12 PROCESS -- no sensitivity list 13 VARIABLE temp : INTEGER RANGE 0 TO 10; 14 BEGIN 15 WAIT UNTIL (clk'EVENT AND clk='1'); 16 temp := temp + 1;17 IF (temp=10) THEN temp := 0; 18 END IF; 19 digit <= temp; 20 END PROCESS; 21 END counter; 22 -----\_\_\_\_\_





## 6.5 CASE

CASE is another statement intended exclusively for sequential code (along with IF, LOOP, and WAIT). Its syntax is shown below.

CASE identifier IS WHEN value => assignments; WHEN value => assignments;

END CASE;

#### Example:

CASE control IS WHEN "00" => x<=a; y<=b; WHEN "01" => x<=b; y<=c; WHEN OTHERS => x<="0000"; y<="ZZZZ"; END CASE;

The CASE statement (sequential) is very similar to WHEN (combinational). should be used when no action is to take place. For example, WHEN OTHERS => NULL;. However, CASE allows multiple assignments for each test condition (as shown in the example above), while WHEN allows only one.

Like in the case of WHEN (section 5.3), here too "WHEN value" can take up three forms:

1-WHEN value -- single value

2-WHEN value1 to value2 -- range, for enumerated data types only

3-WHEN value1 | value2 |... -- value1 or value2 or .

#### ••

#### Example 6.6: DFF with Asynchronous Reset #3

The code below implements the same DFF of example 6.1 (figures 6.1 and 6.2). However, here CASE was used instead of IF only. Notice that a few unnecessary declarations were intentionally included in the code to illustrate their usage.

1 -----

2 LIBRARY ieee; -- Unnecessary declaration,

3 -- because

4 USE ieee.std\_logic\_1164.all; -- BIT was used instead of

5 -- STD\_LOGIC

6 -----

7 ENTITY dff IS

8 PORT (d, clk, rst: IN BIT;

9 q: OUT BIT);

10 END dff;

11 -----12 ARCHITECTURE dff3 OF dff IS

14 PROCESS (clk, rst)



<sup>13</sup> BEGIN





15 BEGIN
16 CASE rst IS
17 WHEN '1' => q<='0';</li>
18 WHEN '0' =>
19 IF (clk'EVENT AND clk='1') THEN
20 q <= d;</li>
21 END IF;
22 WHEN OTHERS => NULL; -- Unnecessary, rst is of type
23 -- BIT
24 END CASE;
25 END PROCESS;
26 END dff3;
27 ------

#### Example 6.7: Two-digit Counter with SSD Output

The code below implements a progressive 2-digit decimal counter  $(0 \rightarrow 99 \rightarrow 0)$ , with external asynchronous reset plus binary-coded decimal (**BCD**) to seven-segment display

(SSD) conversion. Diagrams of the circuit and SSD are shown in figure 6.7. The CASE statement (lines 31–56) was employed to determine the output signals that will feed the SSDs. Notice that we have chosen the following connection between the circuit and the SSD: **xabcdefg** (that is, the **MSB** feeds the decimal point, while the **LSB** feeds segment g).

As can be seen, this circuit is a straight extension of that presented in example 6.2, with the differences that now two digits are necessary rather than one, and that the outputs must be connected to SSD displays. The operation of the circuit can be verified in the simulation results of figure 6.8.



Figure 6.7 2-digit counter of example 6.7.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ĩ                          | 125.0ns                 | 250.0ns                                  | 375.0ns        | 500.0ns          | 625.0ns            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-------------------------|------------------------------------------|----------------|------------------|--------------------|
| m- reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                          |                         | 1                                        | 1              | 1                |                    |
| 🕬 clk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                          |                         |                                          |                |                  | ппп                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Н5                         | 0 (1)(2                 | $\left(3 \left(4 \right) \left(5\right)$ | (6)(7)         | 8 ( 9 ( 0        | (1)(2)(0           |
| temp2     tetmp2     temp2     temp3     temp3 | но                         |                         | 0                                        |                | X                | 1 χ Ο              |
| aigit1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | H 5B                       | 7E 🖁 30 🖁 6D            | (79) (33) (5                             | B ( 5F ( 70 )  | (7F)(7B)(7E      | 30 <b>¥</b> - 🖁 7E |
| digit2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | H7E                        |                         | 7E                                       |                | ¥.               | 30 🚆 7E            |
| <b>Figure 6.8</b><br>Simulation resu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                            |                         |                                          |                |                  |                    |
| 2 LIBRARY ieee<br>3 USE ieee.std_lo<br>4<br>5 ENTITY counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ;<br>ogic_116<br><br>er IS |                         |                                          |                |                  |                    |
| 6 PORT (clk, rese<br>7 digit1, digit2 : 0<br>8 END counter;<br>9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                            |                         | CTOR (6 D                                | OWNTO 0        | ));              |                    |
| 10 ARCHITECT<br>11 BEGIN<br>12 PROCESS(clk<br>13 VARIABLE te<br>14 VARIABLE te<br>15 BEGIN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | , reset)<br>emp1: IN       | TEGER RAN               | GE 0 TO 10                               |                |                  |                    |
| 15 BEGIN<br>16 <b>counter:</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                            |                         |                                          |                |                  |                    |
| 17 IF (reset='1') T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                            |                         |                                          |                |                  |                    |
| 18  temp1 := 0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                            |                         |                                          |                |                  |                    |
| 19  temp 1 := 0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                            |                         |                                          |                |                  |                    |
| 20 ELSIF (clk'EV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ENT AN                     | ND clk='1') TH          | IEN                                      |                |                  |                    |
| 21 temp1 := temp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                            | ,                       |                                          |                |                  |                    |
| 22 IF (temp1=10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | THEN                       |                         |                                          |                |                  |                    |
| 23 temp1 := 0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                            |                         |                                          |                |                  |                    |
| 24  temp 2 := temp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                            |                         |                                          |                |                  |                    |
| 25 IF (temp2=10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | THEN                       |                         |                                          |                |                  |                    |
| 26  temp2 := 0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                            |                         |                                          |                |                  |                    |
| 27 END IF;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                            |                         |                                          |                |                  |                    |
| 28 END IF;<br>29 END IF;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                            |                         |                                          |                |                  |                    |
| 29  END II,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                            |                         |                                          |                |                  |                    |
| 30 <b>BCD to </b><br>31 CASE temp1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                            | nversion:               |                                          |                |                  |                    |
| 32 WHEN <b>0</b> => d<br>33 WHEN <b>1</b> => d<br>34 WHEN <b>2</b> => d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | igit1 <=<br>igit1 <=       | "0110000";              | <mark>30</mark>                          |                |                  |                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                          | ,<br>ب - المرحلةالرا بع |                                          | حامعة-قسم هندس | الية المعار ف ال | 5                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | -                          | ent of Compute          |                                          | g and Techn    |                  |                    |







```
35 WHEN 3 => digit1 <= "1111001"; --79
36 WHEN 4 => digit1 <= "0110011"; --33
37 WHEN 5 => digit1 <= "1011011"; --5B
38 WHEN 6 => digit1 <= "1011111"; --5F
39 WHEN 7 => digit1 <= "1110000"; --70
40 WHEN 8 => digit1 <= "11111111"; --7F
41 WHEN 9 => digit1 <= "1111011"; --7B
42 WHEN OTHERS => NULL;
43 END CASE;
44 CASE temp2 IS
45 WHEN 0 => digit2 <= "1111110"; --7E
46 WHEN 1 => digit2 <= "0110000"; --30
47 WHEN 2 => digit2 <= "1101101"; --6D
48 WHEN 3 => digit2 <= "1111001"; --79
49 WHEN 4 => digit2 <= "0110011"; --33
50 WHEN 5 => digit2 <= "1011011"; --5B
51 WHEN 6 => digit2 <= "10111111"; --5F
52 WHEN 7 => digit2 <= "1110000"; --70
53 WHEN 8 => digit2 <= "11111111"; --7F
54 WHEN 9 => digit2 <= "1111011"; --7B
55 WHEN OTHERS => NULL;
56 END CASE;
57 END PROCESS;
58 END counter:
59 -----
```

Comment: Notice above that the same routine was repeated twice (using CASE statements).

### **6.6** LOOP

LOOP is useful when a piece of code must be instantiated several times. Like IF, WAIT, and CASE, LOOP is intended exclusively for sequential *code*, so it too can only be used inside a PROCESS, FUNCTION, or PROCEDURE. **Example of WHILE / LOOP:** In this example, LOOP will keep repeating while i <10. WHILE (i < 10) LOOP WAIT UNTIL clk'EVENT AND clk='1'; (other statements) END LOOP; **Example with EXIT:** FOR i IN data'RANGE LOOP CASE data(i) IS WHEN '0'  $\Rightarrow$  count:=count+1; WHEN OTHERS => EXIT: END CASE; END LOOP;







#### **Example with NEXT**:

when i =skip. FOR i IN 0 TO 15 LOOP NEXT WHEN i=skip; -- jumps to next iteration (...) END LOOP;

#### **Example 6.8: Carry Ripple Adder**

Figure 6.9 shows an 8-bit unsigned carry ripple adder. The top-level diagram shows the inputs and outputs of the circuit:  $\mathbf{a}$  and  $\mathbf{b}$  are the input vectors to be added, cin is the carry-in bit, s is the sum vector, and cout is the carry-out bit. top diagram shows how the carry bits propagate (ripple).



Figure 6.9 8-bit carry ripple adder of example 6.8

|      |                      |                            | Ons                                 | 200                                          | l.Ons                                                    | 500.                                                                              | Ons                                                                                                                                                                                                                                     | 400.                                                                                                                                                                                                                                                                    | Ons                                                                                                                                                                                                                                                                                                                                                                                            |
|------|----------------------|----------------------------|-------------------------------------|----------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    |                      |                            | 1                                   |                                              |                                                          |                                                                                   |                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                |
| HOE  | 00                   | ( 02 )                     | 04                                  | 06                                           | ( 08 )                                                   | ( 0A )                                                                            | ( OC )                                                                                                                                                                                                                                  | ( 0E )                                                                                                                                                                                                                                                                  | (10)                                                                                                                                                                                                                                                                                                                                                                                           |
| H 08 | FF                   | (FD)                       | FC                                  | χ οο                                         | ( 02 )                                                   | (04)                                                                              | (06)                                                                                                                                                                                                                                    | ( 08 )                                                                                                                                                                                                                                                                  | ( 0A )                                                                                                                                                                                                                                                                                                                                                                                         |
| H 12 |                      | 00                         |                                     | )() 06                                       | ) 0A                                                     | ) OE                                                                              | χ 12                                                                                                                                                                                                                                    | ) 16                                                                                                                                                                                                                                                                    | ))( 1A                                                                                                                                                                                                                                                                                                                                                                                         |
| 0    |                      |                            |                                     |                                              |                                                          |                                                                                   |                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                |
|      | H 0E<br>H 08<br>H 12 | H 0E 00<br>H 08 FF<br>H 12 | H 0E 00 02<br>H 08 FF FD<br>H 12 00 | H 0E 00 02 04<br>H 08 FF FD FD FC<br>H 12 00 | H 0E 00 02 04 06<br>H 08 FF FD FD FC 00<br>H 12 00 00 00 | H 0E 00 ( 02 ) 04 ( 06 ) 08<br>H 08 FF ( FD ) FC ( 00 ) 02<br>H 12 00 ) ( 06 ) 0A | H 0E         00         02         04         06         08         0A           H 08         FF         FD         FC         00         02         04           H 12         00         X         06         0A         0A         0E | H 0E         00         02         04         06         08         0A         0C           H 08         FF         FD         FC         00         02         04         06           H 12         00         X         06         0A         X         0E         12 | H 0E         00         02         04         06         08         0A         0C         0E           H 08         FF         FD         FC         00         02         04         06         08         0A         0C         0E         12         16 |

**Figure 6.10** Simulation results of example 6.8.

Each section of the latter diagram is a full-adder unit Thus its outputs can be computed by means of:

#### sj =aj XOR bj XOR cj

#### cj1 =(aj AND bj) OR (aj AND cj) OR (bj AND cj)

Two solutions are presented, being one generic and the other specific for 8-bit numbers.

Simulation results from either solution are shown in figure 6.10.

1 ----- Solution 1: Generic, with VECTORS------

- 2 LIBRARY ieee;
- 3 USE ieee.std\_logic\_1164.all;

4 -----









5 ENTITY adder IS 6 GENERIC (length : INTEGER := 8); 7 PORT (a, b: IN STD\_LOGIC\_VECTOR (length-1 DOWNTO 0); 8 cin: IN STD\_LOGIC; 9 s: OUT STD\_LOGIC\_VECTOR (length-1 DOWNTO 0); 10 cout: OUT STD LOGIC); 11 END adder; 12 -----13 ARCHITECTURE adder OF adder IS 14 BEGIN 15 PROCESS (a, b, cin) 16 VARIABLE carry : STD\_LOGIC\_VECTOR (length DOWNTO 0); 17 BEGIN  $18 \operatorname{carry}(0) := \operatorname{cin};$ 19 FOR i IN 0 TO length-1 LOOP  $20 s(i) \le a(i) XOR b(i) XOR carry(i);$ 21 carry(i+1) := (a(i) AND b(i)) OR (a(i) AND 22 carry(i)) OR (b(i) AND carry(i)); 23 END LOOP; 24 cout <= carry(length); 25 END PROCESS; 26 END adder: 27 -----1 ---- Solution 2: non-generic, with INTEGERS----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY adder IS 6 PORT (a, b: IN INTEGER RANGE 0 TO 255; 7 c0: IN STD\_LOGIC; 8 s: OUT INTEGER RANGE 0 TO 255; 9 c8: OUT STD\_LOGIC); 10 END adder; 11 -----12 ARCHITECTURE adder OF adder IS 13 BEGIN 14 PROCESS (a, b, c0) 15 VARIABLE temp : INTEGER RANGE 0 TO 511; **16 BEGIN** 17 IF (c0='1') THEN temp:=1; 18 ELSE temp:=0; 19 END IF; 20 temp := a + b + temp;21 IF (temp > 255) THEN 22 c8 <= '1'; 23 temp := temp---256; 24 ELSE c8 <= '0'; 25 END IF: كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology

**BY:K.DAWAH** .ABBAS





26 s <= temp; 27 END PROCESS; 28 END adder; 29 ------

### **Example 6.9: Simple Barrel Shifter**

26 -----

Figure 6.11 shows the diagram of a very simple barrel shifter. In this case, the circuit must shift the input vector (of size 8) either 0 or 1 position to the left. When actually shifted (shift =1), the LSB bit must be filled with '0' (shown in the bottom left corner of the diagram). If shift =0, then outp =inp; if shift =1, then outp(0) ='0' and  $outp(i) = inp(i-1), \text{ for } 1 \le i \le 7.$ A complete VHDL code is presented below, which illustrates the use of FOR/ LOOP. Simulation results appear in figure 6.12. 1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----**5 ENTITY barrel IS** 6 GENERIC (n: INTEGER := 8); 7 PORT (inp: IN STD\_LOGIC\_VECTOR (n-1 DOWNTO 0); 8 shift: IN INTEGER RANGE 0 TO 1; 9 outp: OUT STD\_LOGIC\_VECTOR (n-1 DOWNTO 0)); 10 END barrel; 11 -----12 ARCHITECTURE RTL OF barrel IS 13 BEGIN 14 PROCESS (inp, shift) 15 BEGIN 16 IF (shift=0) THEN 17 outp  $\leq$  inp; **18 ELSE**  $19 \text{ outp}(0) \le 0';$ 20 FOR i IN 1 TO inp'HIGH LOOP 21 outp(i)  $\leq inp(i-1);$ 22 END LOOP; 23 END IF: 24 END PROCESS; 25 END RTL;









Figure 6-11- simple barrel shifter

### **Example 6.10: Leading Zeros**

The design below counts the number of leading zeros in a binary vector, starting from the left end. The solution illustrates the use of **LOOP / EXIT**. Recall that EXIT implies not a escape from the current iteration of the loop, but rather a definite exit from it (that is, even if i is still within the specified range, the LOOP statement will be considered as concluded). In this example, the loop will end as soon as a '1' is found in the data vector. Therefore, it is appropriate for counting the number of zeros that precedes the first one.

1 -----

2 LIBRARY ieee;

3 USE ieee.std\_logic\_1164.all;

4 -----

5 ENTITY Leading Zeros IS

6 PORT ( data: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0); كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





7 zeros: OUT INTEGER RANGE 0 TO 8); 8 END LeadingZeros; 9 -----10 ARCHITECTURE behavior OF Leading Zeros IS 11 BEGIN 12 PROCESS (data) 13 VARIABLE count: INTEGER RANGE 0 TO 8; 14 BEGIN 15 count := 0;16 FOR i IN data 'RANGE LOOP 17 CASE data(i) IS 18 WHEN '0' => count := count + 1; 19 WHEN OTHERS => EXIT: 20 END CASE; 21 END LOOP; 22 zeros  $\leq$  count; 23 END PROCESS; 24 END behavior; 25 -----

Simulation results, verifying the functionality of the circuit, are shown in figure 6.13. With data ="00000000" (decimal 0), eight zeros are detected; when data = "00000001" (decimal 1), seven zeros are encountered; etc.

|        |    |    | 100 | .Ons | 200 | ).Ons | 300 | l.Ons | 400 | .Ons | 500 | ).Ons | 600 | 1.Ons |
|--------|----|----|-----|------|-----|-------|-----|-------|-----|------|-----|-------|-----|-------|
| 💕 data | DO | 0) | (1) | 2    | ) 3 | ) 4   | ( 5 | 6     | )(7 | 8    | 9   | ) 10  | 11  | 12    |
| zeros  | D8 | 8  | X 7 | γ    | 6   | X     |     | 5     |     | γ    |     | 4     |     |       |

Figure 6.13

Simulation results of example 6.10.

### Example 6.11: RAM

Below is another example using **sequential code**, particularly the IF statement. We show the implementation of a RAM (random access memory).

As can be seen in figure 6.14(a), the circuit has a data input bus (data\_in), a data output bus (data\_out), an address bus (addr), plus clock (clk) and write enable







MCA. Eng. K. DAWAH



Figure 6.14 RAM circuit of example 6.11.

wr\_ena) pins. When wr\_ena is asserted, at the next rising edge of clk the vector present at data\_in must be stored in the position specified by addr. The output, data\_out, on the other hand, must constantly display the data selected by addr. From the register point-of-view, the circuit can be summarized as in figure 6.14(b). When wr\_ena is low, q is connected to the input of the flip-flop, and terminal d is open, so no new data will be written into the memory. However, when wr\_ena is turned high, d is connected to the input of the register, so at the next rising edge of clk d will overwrite its previous value.

A VHDL code that implements the circuit of figure 6.14 is shown below. The capacity chosen for the RAM is 16 words of length 8 bits each. Notice that the code is totally generic.

Note: Other memory implementations will be presented in section 9.10 of chapter 9.

2 LIBRARY ieee;

1 -----

3 USE ieee.std\_logic\_1164.all;

4 -----

5 ENTITY ram IS 6 GENERIC ( bits: INTEGER := 8; -- # of bits per word

7 words: INTEGER := 16); -- # of words in the memory

8 PORT ( wr\_ena, clk: IN STD\_LOGIC;

9 addr: IN INTEGER RANGE 0 TO words-1;

10 data\_in: IN STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0);

\_\_\_\_\_

11 data\_out: OUT STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0));

12 END ram;

13 -----

14 ARCHITECTURE ram OF ram IS

15 TYPE vector\_array IS ARRAY (0 TO words-1) OF

16 STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0);

- 17 SIGNAL memory: vector\_array;
- **18 BEGIN**

19 PROCESS (clk, wr\_ena)

20 BEGIN

21 IF (wr\_ena='1') THEN

22 IF (clk'EVENT AND clk='1') THEN







23 memory(addr) <= data\_in; 24 END IF; 25 END IF; 26 END PROCESS; 27 data\_out <= memory(addr); 28 END ram; 29 ------

Simulation results from the circuit synthesized with the code above are shown in figure 6.15.

| 产 wr_ena   | 1    | 100   | .0ns 200 | .Ons 300  | 0ns 400 | .Ons 500  | ).Ons 600<br>' | Uns /UL | 1.0ns 80<br>1 |
|------------|------|-------|----------|-----------|---------|-----------|----------------|---------|---------------|
| ir clk     | 0    |       |          | 1         |         | 1         | ]              |         | 1             |
| 🎤 addr     | Dз   | 3     | 4        | χ 5       | 2       | <u>(з</u> | $\sqrt{4}$     | ( 5     | 6             |
| F data_in  | D 50 | 50    | 51       | (52)      | 53      | 54        | ( 55 )         | 56      | X 57          |
| 🔊 data_out | DoF  | 0 \ 5 |          | 1 χ 0 χ 5 | 2 0     | χ 50      | XX 51          | χ 52    | N O           |

Figure 6.15

Simulation results of example 6.11.

#### 6.10 Using Sequential Code to Design Combinational Circuits

We have already seen that sequential code can be used to implement either sequential or combinational circuits.

In order to satisfy the criteria above, the following rules should be observed:

**Rule 1**: Make sure that all input signals used (read) in the PROCESS appear in its sensitivity list.

**Rule 2:** Make sure that all combinations of the input/output signals are included in the code;



Circuit of example 6.12: (a) top-level diagram, (b) specifications provided, (c) implemented truth-table, and (d) the right approach.

With respect to rule 2, however, the consequences can be more serious because incomplete specifications of the output signals might cause the synthesizer to infer latches in order to hold their previous values. This fact is illustrated in the example below.

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





### Example 6.12: Bad Combinational Design

Let us consider the circuit of figure 6.16, for which the following specifications have been provided: x should behave as a multiplexer; that is, should be equal to the input selected by sel; y, on the other hand, should be equal to '0' when sel ="00", or '1' if sel ="01". These specifications are summarized in the truth-table of figure 6.16(b). Notice that this is a combinational circuit. However, the specifications provided for y are incomplete, as can be observed in the truth-table of figure 6.16(b). Using just these specifications, the code could be the following:

```
1 -----
2 LIBRARY ieee;
3 USE ieee.std_logic_1164.all;
4 -----
5 ENTITY example IS
6 PORT (a, b, c, d: IN STD_LOGIC;
7 sel: IN INTEGER RANGE 0 TO 3;
8 x, y: OUT STD_LOGIC);
9 END example;
10 -----
11 ARCHITECTURE example OF example IS
12 BEGIN
13 PROCESS (a, b, c, d, sel)
14 BEGIN
15 IF (sel=0) THEN
16 x<=a;
17 y<='0';
18 ELSIF (sel=1) THEN
19 x<=b;
20 y<='1';
21 ELSIF (sel=2) THEN
22 x <= c;
23 ELSE
24 x <= d;
25 END IF;
26 END PROCESS;
27 END example;
28 -----
               _____
```

After compiling this code, the report files show that no flip-flops were inferred (as expected). However, when we look at the simulation results (figure 6.17), we notice something peculiar about y. Observe that, for the same value of the input (sel =3 ="11"), two different results are obtained for y (when sel =3 is preceded by sel =0, y ='0' results, while y ='1' is obtained when sel =3 is preceded by sel =1). This signifies that some sort of memory was indeed implemented by the compiler.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





#### MCA. Eng. K. DAWAH









## **8**-State Machines

**F**inite **s**tate **m**achines (**FSM**) constitute a special modeling technique **for sequential logic circuits**. Such a model can be very helpful in the design of certain types of systems, particularly those whose tasks form a well-defined sequence (digital controllers,

#### 8.1 Introduction

Figure 8.1 shows the block diagram of a **single-phase state machine**. the *lower section* contains the *sequential logic (flip-flops)*, the *upper section* contains the *combinational logic*.

The **combinational (upper) section** has two inputs, being one pr\_*state (present state)* and the other the external input proper. It has also two outputs, *nx\_state (next state)* and the external output proper.

The **sequential (lower) section** has **three inputs (clock, reset, and nx\_state)**, and *one output (pr\_state)*. Since all flip-flops are in this part of the system, clock and reset must be connected to it.

*If the output of the machine depends not only on the present state but also on the current input*, then it is **called a Mealy machine.** Otherwise, **if it depends only on the current state**, it is **called a Moore machine**.

The separation of the circuit into two sections (figure 8.1) allows the part, being sequential, will require a PROCESS, while the upper part, being combinational,



#### Figure 8.1 Mealy (Moore) state machine diagram.







### 8.2 Design Style #1

Several approaches can be conceived to design a FSM. We will describe in detail one style that is well structured and easily applicable. In it, **the design of the lower section** of the state machine (figure 8.1) is completely separated from that of the upper section.

storage perspective, in order to further understand and refine its construction, which will lead to design style #2.

#### Design of the Lower (Sequential) Section

In figure 8.1, the **flip-flops** are in the lower section, so **clock** and **reset** are connected to it. The other lower section's **input** is **nx\_state** (next state), while **pr\_state** (present state) is its only **output.** Being the circuit of the lower section sequential, a PROCESS is required, in which any of the sequential statements (IF, WAIT, CASE, or LOOP, ) can be employed. A typical design template for the lower section is the following:

#### PROCESS (reset, clock) BEGIN IF (reset='1') THEN pr\_state <= state0; ELSIF (clock'EVENT AND clock='1') THEN pr\_state <= nx\_state; END IF;

#### **END PROCESS;**

The code shown above is very simple. It consists of an **asynchronous reset**, which Determines the initial state of the system (state0), followed by the synchronous storage of nx\_state (at the positive transition of clock), which will produce pr\_state at the

#### design of the lower section is basically standard.

Another advantage of this design style is that the **number of registers is minimum**. we know that the number of flip-flops inferred from the code above is simply equal to the number of bits needed to encode all states of the FSM (because the only signal to which a value is assigned at the transition of another signal is pr\_state). Therefore, if the default (binary) encoding style (section8.4) is used, just [log2n]flip-flops will then be needed, where n is the number of states.

### Design of the Upper (Combinational) Section

In figure 8.1, the upper section is fully combinational, so its code does not need to be sequential; concurrent code can be used as well.

PROCESS (input, pr\_state) BEGIN CASE pr\_state IS WHEN state0 => IF (input = ...) THEN output <= <value>; nx\_state <= state1; ELSE ... END IF; WHEN state1 =>







IF (input = ...) THEN output <= <value>; nx\_state <= state2; ELSE ... END IF; WHEN state2 => IF (input = ...) THEN output <= <value>; nx\_state <= state2; ELSE ... END IF;

... END CASE; END PROCESS;

As can be seen, **this code is also very simple**, and does two things: (a) it assigns the output value and (b) it establishes the next state. the design of combinational circuits using sequential statements ,for all input signals are present in the sensitivity list and all input/output combinations are specified. Finally, observe that no signal assignment is made at the transition of another signal, so no flip-flops will be inferred

#### State Machine Template for Design Style #1

A complete template is shown below. Notice that, in addition to the two processes presented above, it also contains a user-defined enumerated data type (here called state), which lists all possible states of the machine. LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

-----

ENTITY <entity\_name> IS PORT ( input: IN <data\_type>; reset, clock: IN STD\_LOGIC; output: OUT <data\_type>); END <entity\_name>;

-----

ARCHITECTURE <arch\_name> OF <entity\_name> IS TYPE state IS (state0, state1, state2, state3, ...); SIGNAL pr\_state, nx\_state: state; BEGIN

----- Lower section: -----

PROCESS (reset, clock) BEGIN IF (reset='1') THEN pr\_state <= state0; ELSIF (clock'EVENT AND clock='1') THEN pr\_state <= nx\_state; END IF; END PROCESS; -------Upper section: ------







PROCESS (input, pr\_state) **BEGIN** CASE pr\_state IS WHEN state0 => IF (input = ...) THEN output <= <value>; nx\_state <= state1;</pre> ELSE ... END IF: WHEN state1 =>IF (input = ...) THEN output <= <value>; nx state <= state2; ELSE ... END IF: WHEN state2 =>IF (input = ...) THEN output <= <value>; nx\_state <= state3; ELSE ... END IF: ••• END CASE; END PROCESS:

## END <arch\_name>;

## **Example 8.1: BCD Counter**

A **counter** is an example of **Moore machine**, for the *output depends* only on the stored (*present*) *state*. As a simple registered circuit and as a sequencer, it can be easily implemented in either approach: The problem with the latter is that when the number of states is large it becomes cumbersome to enumerate them all, a problem easily avoided using the LOOP statement in a conventional approach. The state diagram of a **0-to-9 circular counter** is shown in figure 8.2. The states were called **zero**, **one**, ..., **nine**, each name corresponding to the decimal value of the output.

A VHDL code, directly resembling the design style #1 template, is presented below. An enumerated data type (state) appears in lines 11–12. The design of the lower (clocked) section is presented in lines 16–23, and that of the upper (combinational) section, in lines 25–59. In this example, the number of registers is [log210]=4. Simulation results are shown in figure 8.3. As can be seen, the output (count) grows from 0 to 9, and then restarts from 0 again.







MCA. Eng. K. DAWAH









29 count <= "0000"; 30 nx\_state <= one; 31 WHEN one =>32 count <= "0001"; 33 nx\_state <= two; 34 WHEN two => 35 count <= "0010"; 36 nx state <= three; 37 WHEN three =>38 count <= "0011"; 39 nx\_state <= four; 40 WHEN four =>41 count <= "0100"; 42 nx state  $\leq$  five; 43 WHEN five => 44 count <= "0101"; 45 nx\_state  $\leq$  six; 46 WHEN six => 47 count <= "0110"; 48 nx\_state <= seven; 49 WHEN seven => 50 count <= "0111"; 51 nx\_state <= eight; 52 WHEN eight =>53 count <= "1000"; 54 nx state <= nine; 55 WHEN nine => 56 count <= "1001"; 57 nx\_state <= zero; 58 END CASE; 59 END PROCESS; 60 END state\_machine; 61 -----



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





### Example 8.2: Simple FSM #1

Figure 8.4 shows the states diagram of a very simple FSM. The system has two states (state A and state B), and must change from one to the other every time d = '1' is received. The desired output is x = a when the machine is in state A, or x = b when in state B. The initial (reset) state is state A.

A VHDL code for this circuit, employing design style #1, is shown below.

1 -----

2 ENTITY simple\_fsm IS

3 PORT ( a, b, d, clk, rst: IN BIT;

4 x: OUT BIT);

5 END simple\_fsm; 6 ------

7 ARCHITECTURE simple\_fsm OF simple\_fsm IS

8 TYPEstate IS (stateA, stateB);

9 SIGNAL pr\_state, nx\_state: state;

10 BEGIN

11 ----- Lower section: ------

12 PROCESS (rst, clk)

<mark>13 BEGIN</mark>

14 IF (rst='1') THEN

15 pr\_state <= stateA;</pre>

16 ELSIF (clk'EVENT AND clk='1') THEN

17 pr\_state <= nx\_state;

18 END IF;

**19 END PROCESS;** 

20 ----- Upper section: -----

21 PROCESS (a, b, d, pr\_state) 22 BEGIN 23 CASE pr state IS 24 WHEN stateA => $25 \text{ x} \le a$ : 26 IF (d='1') THEN nx state  $\leq$  stateB; 27 ELSE nx\_state <= stateA; 28 END IF; 29 WHEN stateB =>  $30 x \le b$ : 31 IF (d='1') THEN nx\_state <= stateA; 32 ELSE nx\_state <= stateB; 33 END IF; 34 END CASE: 35 END PROCESS; 36 END simple\_fsm; 37 -----







MCA. Eng. K. DAWAH



Simulation results relative to the code above are shown in figure 8.5. Notice that the circuit works as expected. Indeed, looking at the report files, one will verify that, as expected, only one flip-flop was required to implement this circuit because there are only two states to be encoded. Notice also that the upper section is indeed combinational for the output (x), which in this case does depend on the inputs (a or b, depending on which state the machine is in), varies when a or b vary, regardless of clk. If a synchronous output were required, then design style #2 should be employed.

### 8.3 Design Style #2 (Stored Output)

As we have seen, in design style #1 only pr-state is stored. Therefore, the overall circuit can be summarized as in figure 8.6(a). Notice that in this case, if it is a **Mealy** machine (**one whose output is dependent on the current input**), the output might change when the input changes (asynchronous output). In many applications, the signals are required to be synchronous, so the output should be updated only when the proper clock edge occurs. To make Mealy machines synchronous, the output must be stored as well, as shown in figure 8.6(b).

This structure is the object of design style #2.

To implement this new structure, very few modifications are needed. For example, we can use an additional signal (say, temp) to compute the output value (upper section), but only pass its value to the actual output signal when a clock event occurs (lower section). These modifications can be observed in the template shown below.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH



Circuit diagrams for (a) Design Style #1 and (b) Design Style #2.

#### **State Machine Template for Design Style #2**

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

SIGNAL pr\_state, nx\_state: states; SIGNAL temp: <data\_type>; BEGIN

----- Lower section: -----

PROCESS (reset, clock) BEGIN IF (reset='1') THEN pr\_state <= state0; ELSIF (clock'EVENT AND clock='1') THEN output <= temp; pr\_state <= nx\_state; END IF; END PROCESS; ------ **Upper section:** ------

PROCESS (pr\_state) BEGIN CASE pr\_state IS WHEN state0 => temp <= <value>; IF (condition) THEN nx\_state <= state1; کلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





...



MCA. Eng. K. DAWAH

END IF; WHEN state1 => temp <= <value>; IF (condition) THEN nx\_state <= state2;

END IF; WHEN state2 => temp <= <value>; IF (condition) THEN nx\_state <= state3;

END IF;

...

... END CASE; END PROCESS; END <arch\_name>; Comparing the template of design style #2 with that of design style #1, we verify that the only differences are those related to the introduction of the internal signal temp. This signal will cause the output of the state machine to be stored, for its value is passed to the output only when clk'EVENT occurs.

### Example 8.3: Simple FSM #2

Let us consider the design of example 8.2 once again. However, let us say that now we want the output to be **synchronous** (to **change** only when **clock rises**). Since this isa **Mealy machine**, design style #2 is required.

1 -----2 ENTITY simple\_fsm IS 3 PORT (a, b, d, clk, rst: IN BIT; 4 x: OUT BIT); 5 END simple\_fsm; 6 -----7 ARCHITECTURE simple\_fsm OF simple\_fsm IS 8 TYPE state IS (stateA, stateB); 9 SIGNAL pr\_state, nx\_state: state; 10 SIGNAL temp: BIT; 11 BEGIN 12 ----- Lower section: ------13 PROCESS (rst, clk) 14 BEGIN 15 IF (rst='1') THEN 16 pr\_state <= stateA; 17 ELSIF (clk'EVENT AND clk='1') THEN  $18 \text{ x} \leq \text{temp};$ 19 pr\_state <= nx\_state; 20 END IF;







21 END PROCESS: 22 ------ Upper section: ------23 PROCESS (a, b, d, pr\_state) 24 BEGIN 25 CASE pr\_state IS 26 WHEN stateA => 27 temp  $\leq a$ ; 28 IF (d='1') THEN nx state <= stateB; 29 ELSE nx state <= stateA; 30 END IF: 31 WHEN stateB =>32 temp <= b; 33 IF (d='1') THEN nx\_state <= stateA; 34 ELSE nx state <= stateB; 35 END IF; 36 END CASE: 37 END PROCESS: 38 END simple fsm; 39 -----

Looking at the report files produced by the compiler, we observe that two flip-flops were now inferred, one to encode the states of the machine, and the other to store the output.

Simulation results are shown in figure 8.7. Recall that when a signal is stored, its value will necessarily remain static between two consecutive clock edges. Therefore, if the input (a or b in the example above) changes during this interval, the change might not be observed by the circuit; moreover, when observed, it will be delayed with respect to the input (which is proper of synchronous circuits).









### **Example 8.4: String Detector**

We want to design a circuit that takes as input a **serial bit stream and outputs a '1' whenever the sequence "111" occurs.** Overlaps must also be considered, that is, if . . 0111110...occurs, than the output should remain active for three consecutive clock cycles. The state diagram of our machine is shown in figure 8.8. There are four states, which we called zero, one, two, and three, with the name corresponding to the number of consecutive '1's detected. The solution shown below utilizes design style#1.







14 ----- Lower section: ------15 PROCESS (rst, clk) **16 BEGIN** 17 IF (rst='1') THEN 18 pr\_state <= zero; 19 ELSIF (clk'EVENT AND clk='1') THEN 20 pr\_state <= nx\_state; 21 END IF; 22 END PROCESS: 23 ------ Upper section: ------24 PROCESS (d, pr state) 25 BEGIN 26 CASE pr\_state IS 27 WHEN zero => 28 q <= '0'; 29 IF (d='1') THEN nx state <= one; 30 ELSE nx\_state <= zero; 31 END IF; 32 WHEN one =>33 q <= '0'; 34 IF (d='1') THEN nx\_state <= two; 35 ELSE nx\_state <= zero; 36 END IF; 37 WHEN two =>38 q <= '0': 39 IF (d='1') THEN nx state <= three; 40 ELSE nx\_state <= zero; 41 END IF: 42 WHEN three => 43 q <= '1'; 44 IF (d='0') THEN nx state <= zero; 45 ELSE nx\_state <= three; 46 END IF; 47 END CASE: 48 END PROCESS: 49 END my arch; 50 -----

Notice that in this example the output does not depend on the current input. This fact can be observed in lines 28, 33, 38, and 43 of the code above, which show that all assignments to **q** are unconditional (that is, do not depend on **d**). Therefore, the output is automatically synchronous (a **Moore** machine), so the use of design style #2 is unnecessary. The circuit requires two flip-flops, which encode the four states of the state machine, from which q is computed.

Simulation results are shown in figure 8.9. As can be seen, the data sequence d = "011101100" was applied to the circuit, resulting the response q = "000100000" at the output.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





### Example 8.5: Traffic Light Controller (TLC)

As mentioned earlier, digital controllers are good examples of circuits that can be efficiently implemented when modeled as state machines. In the present example, we want to design a **TLC** with the characteristics summarized in the table of figure 8.10, that is:

1-Three modes of operation: Regular, Test, and Standby.

2-Regular mode: four states, each with an independent, programmable time, passed to the circuit by means of a CONSTANT.

3-Test mode: allows all pre-programmed times to be overwritten (by a manual switch) with a small value, such that the system can be easily tested during maintenance

(1 second per state). This value should also be programmable and passed to the circuit using a CONSTANT.

4-Standby mode: if set (by a sensor accusing malfunctioning, for example, or a manual switch) the system should activate the yellow lights in both directions and remain so while the standby signal is active

5-Assume that a 60 Hz clock (obtained from the power line itself ) is available.







MCA. Eng. K. DAWAH



Here, design style #1 can be employed, as shown in the code below.

2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -------5 ENTITY tlc IS 6 PORT ( clk, stby, test: IN STD\_LOGIC; 7 r1, r2, y1, y2, g1, g2: OUT STD\_LOGIC); كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الإلكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS



1 -----



101

8 END tlc:





MCA. Eng. K. DAWAH

9 -----10 ARCHITECTURE behavior OF tlc IS 11 CONSTANT timeMAX : INTEGER := 2700; 12 CONSTANT timeRG : INTEGER := 1800; 13 CONSTANT timeRY : INTEGER := 300; 14 CONSTANT timeGR : INTEGER := 2700; 15 CONSTANT timeYR : INTEGER := 300; 16 CONSTANT timeTEST : INTEGER := 60; 17 TYPE state IS (RG, RY, GR, YR, YY); 18 SIGNAL pr\_state, nx\_state: state; 19 SIGNAL time : INTEGER RANGE 0 TO timeMAX; 20 BEGIN 21 ----- Lower section of state machine: ----22 PROCESS (clk, stby) 23 VARIABLE count : INTEGER RANGE 0 TO timeMAX; 24 BEGIN 25 IF (stby='1') THEN 26 pr\_state <= YY; 27 count := 0; 28 ELSIF (clk'EVENT AND clk='1') THEN 29 count := count + 1;30 IF (count = time) THEN31 pr\_state <= nx\_state; 32 count := 0;33 END IF; 34 END IF; 35 END PROCESS; 36 ----- Upper section of state machine: ----37 PROCESS (pr\_state, test) **38 BEGIN** 39 CASE pr\_state IS 40 WHEN RG => 41 r1<='1'; r2<='0'; y1<='0'; y2<='0'; g1<='0'; g2<='1'; 42 nx state  $\leq RY$ ; 43 IF (test='0') THEN time <= timeRG; 44 ELSE time <= timeTEST; 45 END IF: 46 WHEN RY => 47 r1<='1'; r2<='0'; y1<='0'; y2<='1'; g1<='0'; g2<='0'; 48 nx\_state <= GR; 49 IF (test='0') THEN time <= timeRY; 50 ELSE time <= timeTEST; 51 END IF; 52 WHEN GR => 53 r1<='0'; r2<='1'; y1<='0'; y2<='0'; g1<='1'; g2<='0'; 54 nx state  $\leq$  YR; كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology **BY:K.DAWAH** .ABBAS





MCA. Eng. K. DAWAH

55 IF (test='0') THEN time <= timeGR; 56 ELSE time <= timeTEST; 57 END IF; 58 WHEN YR => 59 r1<='0'; r2<='1'; y1<='1'; y2<='0'; g1<='0'; g2<='0'; 60 nx state  $\leq RG$ ; 61 IF (test='0') THEN time <= timeYR; 62 ELSE time <= timeTEST; 63 END IF: 64 WHEN YY =>65 r1<='0'; r2<='0'; y1<='1'; y2<='1'; g1<='0'; g2<='0'; 66 nx state  $\leq RY$ ; 67 END CASE; 68 END PROCESS; 69 END behavior; 70 -----

The expected number of flip-flops required to implement this circuit is 15; three to store pr\_state (the machine has five states, so three bits are needed to encode them ), plus twelve for the counter (it is a 12-bit counter, for it must count up to time MAX =2700).

Simulation results are shown in figure 8.11. In order for the results to fit properly in the graphs, we adopted small time values, with all CONSTANTS equal to 3 except time TEST, which was made equal to 1. Therefore, the system is expected to change state every three clock cycles when in Regular operation, or every clock cycle if in Test mode. These two cases can be observed in the first two graphs of figure 8.11, respectively. The third graph shows the Standby mode being activated. As expected, stby is asynchronous and has higher priority than test, causing the system to stay in state YY (state 4) while st by is active. The test signal, on the other hand, is synchronous,

but does not need to wait for the current state timing to finish to be activated, as can be observed in the second graph.

#### **Example 8.6: Signal Generator**

We want to design a circuit that, from a clock signal clk, gives origin to the signal outp shown in figure 8.12(a). Notice that the circuit must operate at both edges (rising and falling) of clk.

To circumvent the two-edge aspect (section 6.9), one alternative is to implement two machines, one that operates exclusively at the positive transition of clk and another

that operates exclusively at the negative edge, thus generating the intermediate signals out1 and out2 presented in figure 8.12(b). These signals can then be ANDed to give origin to the desired signal outp. Notice that this circuit has no external inputs (except for clk, of course), so the output can only change when clk changes (synchronous output).

1 -----

2 ENTITY signal\_gen IS 3 PORT ( clk: IN BIT;

4 outp: OUT BIT);







5 END signal gen; 6 -----7 ARCHITECTURE fsm OF signal gen IS 8 TYPE state IS (one, two, three); 9 SIGNAL pr\_state1, nx\_state1: state; 10 SIGNAL pr\_state2, nx\_state2: state; 11 SIGNAL out1, out2: BIT; 12 BEGIN 13 ----- Lower section of machine #1: ---14 PROCESS(clk) **15 BEGIN** 16 IF (clk'EVENT AND clk='1') THEN 17 pr\_state1 <= nx\_state1; 18 END IF; 19 END PROCESS; 20 ----- Lower section of machine #2: ---21 PROCESS(clk) 22 BEGIN 23 IF (clk'EVENT AND clk='0') THEN 24 pr\_state2 <= nx\_state2; 25 END IF; 26 END PROCESS; 27 ---- Upper section of machine #1: -----28 PROCESS (pr\_state1) 29 BEGIN 30 CASE pr\_state1 IS 31 WHEN one => 32 out1 <= '0'; 33 nx\_state1 <= two; 34 WHEN two => 35 out1 <= '1'; 36 nx\_state1 <= three; 37 WHEN three =>38 out1 <= '1'; 39 nx\_state1 <= one; 40 END CASE; 41 END PROCESS; 42 ---- Upper section of machine #2: -----43 PROCESS (pr\_state2) 44 BEGIN 45 CASE pr\_state2 IS 46 WHEN one => 47 out2 <= '1';  $48 \text{ nx}_{\text{state2}} \ll \text{two};$ 49 WHEN two => 50 out2 <= '0'; 51 nx\_state2 <= three; 52 WHEN three =>







53 out2 <= '1'; 54 nx\_state2 <= one; 55 END CASE; 56 END PROCESS; 57 outp <= out1 AND out2; 58 END fsm; 59 ------

Simulation results from the circuit synthesized with the code above are shown in figure 8.13.







MCA. Eng. K. DAWAH



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH



#### Figure 8.12

Waveforms of example 8.6: (a) signal outp to be generated from clk and (b) intermediate signals out1 and out2 (outp = out1 AND out2).

| - clk             | 0  |     |            | 1 |            |          |     |            |     |     |       |
|-------------------|----|-----|------------|---|------------|----------|-----|------------|-----|-----|-------|
| pr_state1         | DO | 0 ) | 1 (        | 2 | ) <u> </u> | $\chi$ 1 | ) 2 | χ <u>ο</u> | χ_1 | 2   |       |
| pr_state2         | DO | 0   | ) 1        | X | 2 )        | ο χ      | 1)  | 2 )(       | ο χ | 1)( | 2 )(0 |
| r_state2<br>≥outp | 0  | 0   | <u>) 1</u> |   | 2 1        |          |     | 2 ) 1      |     |     | 2     |

#### Figure 8.13 Simulation results of example 8.6.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





# 9-AdditionalCircuit Designs

In the preceding chapters, we saw a series of complete design examples utilizing VHDL code. Each design included: 1-Top-level diagram of the circuit, with description; 2-Review of basic concepts whenever necessary; 3-Complete VHDL code; 4-Simulation results: and 5-Additional comments when needed. The designs presented in this chapter are the following: 1-Barrel shifter (section 9.1) 2-Signed and unsigned comparators (section 9.2) 3-Carry ripple and carry look ahead adders (section 9.3) 4-Fixed-point division (section 9.4) 5-Vending machine controller (section 9.5) 6-Serial data receiver (section 9.6) 7-Parallel-to-serial converter (section 9.7) 8-Playing with a SSD (section 9.8) 9-Signal generators (section 9.9) 10-Memories (section 9.10) 9.1 Barrel Shifter

The diagram of a barrel shifter is shown in figure 9.1. The input is an 8-bit vector. The output is a shifted version of the input, with the amount of shift defined by the "shift" input (from 0 to 7). The circuit consists of three individual barrel shifters, each similar to that seen in example 6.9. Notice that the first barrel has only one '0' connected to one of the multiplexers (bottom left corner), while the second has two, and the third has four. For larger vectors, we would just keep doubling the number of '0' inputs. If shift ="001", for example, then only the first barrel should cause a shift; on the other hand, if shift ="111", then all barrels should cause a shift. A VHDL code for the circuit of figure 9.1 is presented below. Simulation results, verifying the functionality of the circuit, are shown in figure 9.2. As can be seen in the latter, the output is equal to the input when shift =0 (that is, shift ="000"). It can also be seen that, as long as no bit of value '1' is shifted out of the barrel, the output is equal to the input multiplied by 2 (1 shift) when shift =1 ("001"), multiplied by 4 (2 shifts) when shift =2 ("010"), multiplied by 8 (3 shifts) when shift =3 ("011"), and so on.







MCA. Eng. K. DAWAH



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY barrel IS 6 PORT (inp: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0); 7 shift: IN STD\_LOGIC\_VECTOR (2 DOWNTO 0); 8 outp: OUT STD\_LOGIC\_VECTOR (7 DOWNTO 0)); 9 END barrel: 10 -----11 ARCHITECTURE behavior OF barrel IS 12 BEGIN 13 PROCESS (inp, shift) 14 VARIABLE temp1: STD\_LOGIC\_VECTOR (7 DOWNTO 0); 15 VARIABLE temp2: STD\_LOGIC\_VECTOR (7 DOWNTO 0); 16 BEGIN 17 ---- 1st shifter -----18 IF (shift(0)='0') THEN 19 temp1 := inp; 20 ELSE 21 temp1(0) := '0';22 FOR i IN 1 TO inp'HIGH LOOP 23 temp1(i) := inp(i-1); 24 END LOOP: 25 END IF; 26 ---- 2nd shifter -----27 IF (shift(1)='0') THEN 28 temp2 := temp1;**29 ELSE** 30 FOR i IN 0 TO 1 LOOP 31 temp2(i) := '0';32 END LOOP; 33 FOR i IN 2 TO inp'HIGH LOOP 34 temp2(i) := temp1(i-2);35 END LOOP; 36 END IF; 37 ---- 3rd shifter -----38 IF (shift(2)='0') THEN 39 outp <= temp2; 40 ELSE 41 FOR i IN 0 TO 3 LOOP 42 outp(i)  $\leq 0'$ ; 43 END LOOP; 44 FOR i IN 4 TO inp'HIGH LOOP  $45 \text{ outp}(i) \le \text{temp2}(i-4);$ 46 END LOOP; 47 END IF;

> كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





48 END PROCESS; 49 END behavior; 50 ------

## 9.2 Signed and Unsigned Comparators

Figure 9.3 shows the top-level diagram of a comparator. The size of the vectors to be compared is generic (n + 1). Three outputs must be provided: one corresponding to a >b, another to a =b, and finally one relative to a <b. Three solutions are presented: the first considers a and b as signed numbers, while the other two consider them as unsigned values. Simulation results are also included.

### 9.2-1 Signed Comparator

Notice the presence of the **std\_logic\_arith package** in the code below (line 4), which is necessary to operate with SIGNED (or UNSIGNED) data types (a and b were declared as SIGNED numbers in line 8).

1 ---- Signed Comparator: ------2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 USE ieee.std\_logic\_arith.all; -- necessary! 5 -----**6 ENTITY comparator IS** 7 GENERIC (n: INTEGER := 7); 8 PORT (a, b: IN SIGNED (n DOWNTO 0); 9 x1, x2, x3: OUT STD LOGIC); 10 END comparator; 11 -----12 ARCHITECTURE signed OF comparator IS 13 BEGIN  $14 \text{ x1} \le 1' \text{ WHEN } a > b \text{ ELSE '0'};$ 15 x2 <= '1' WHEN a = b ELSE '0'; 16 x3 <= '1' WHEN a < b ELSE '0'; 17 END signed; 18 -----









Comparator.

Simulation results are shown in figure 9.4. As can be seen, 127 >0, but 128 <0 and also 255 <0 (because in 2's complement notation 127 is the decimal 127 itself, but 128 is the decimal \_128, and 255 is indeed -1).

## 9.2-2 Unsigned Comparator #1

The VHDL code below is the counterpart of the code just presented (signed comparator).

Notice again the presence of the std\_logic\_arith package (line 4), which is necessary to operate with UNSIGNED (or SIGNED) data types (a and b were declared as UNSIGNED numbers in line 8).

1 ---- Unsigned Comparator #1: -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 USE ieee.std\_logic\_arith.all; -- necessary! 5 -----**6 ENTITY comparator IS** 7 GENERIC (n: INTEGER := 7); 8 PORT (a, b: IN UNSIGNED (n DOWNTO 0); 9 x1, x2, x3: OUT STD\_LOGIC); 10 END comparator; 11 -----12 ARCHITECTURE unsigned OF comparator IS 13 BEGIN 14 x1 <= '1' WHEN a > b ELSE '0'; 15 x2 <= '1' WHEN a = b ELSE '0': 16 x3 <= '1' WHEN a < b ELSE '0'; 17 END unsigned;

18 -----







MCA. Eng. K. DAWAH



### 9.3Carry Ripple and Carry Look Ahead Adders

Carry ripple and carry look ahead are two classical approaches to the design of Adders . The former has the advantage of requiring less hardware, while the latter is Faster . Both approaches are discussed below.

#### **Carry Ripple Adder**

Figure 9.6 shows a 4-bit unsigned carry ripple adder. For each bit, a full adder unit (FAU, section 1.4) is employed. The truth table of the FAU is also shown. In it, a and b represent the **input** bits, **cin** is the **carry-in** bit, **s** is the **sum** bit, and **cout** is the **carry-out** bit. **s** must be **high** whenever the number of **inputs** that are **high** is **odd** (parity function), while **cout** must be **high** when **two** or more **inputs** are **high** (majority function).

#### s = a XOR b XOR cin

#### cout = (a AND b) OR (a AND cin) OR (b AND cin)

Therefore, a VHDL implementation of the carry ripple adder is straightforward. The solution shown below works for any number (n) of input bits, defined by means of a GENERIC statement in line 5. Simulation results from the circuit synthesized with the code below are shown in figure 9.7.











100.0ns 300.0ns 400.0ns 500.0ns 600.0ns 700.0ns 200.0ns 🗩 a DO 0 3 5 6 7 1 2 4 DO 0 8 12 2 4 6 10 14 De b 0 - cin DO 0 3 6 9 12 15 . 6 s s 0 3 0 cout Figure 9.7 Simulation results from the carry ripple adder of figure 9.6. 1 LIBRARY ieee: 2 USE ieee.std\_logic\_1164.all; 3 -----4 ENTITY adder\_cripple IS 5 GENERIC (n: INTEGER := 4); 6 PORT (a, b: IN STD\_LOGIC\_VECTOR (n-1 DOWNTO 0); 7 cin: IN STD\_LOGIC; 8 s: OUT STD\_LOGIC\_VECTOR (n-1 DOWNTO 0); 9 cout: OUT STD\_LOGIC); 10 END adder\_cripple; 11 -----12 ARCHITECTURE adder OF adder\_cripple IS 13 SIGNAL c: STD LOGIC VECTOR (n DOWNTO 0); 14 BEGIN  $15 c(0) \le cin;$ 16 G1: FOR i IN 0 TO n-1 GENERATE  $17 \text{ s(i)} \leq a(i) \text{ XOR b(i) XOR c(i);}$  $18 c(i+1) \le (a(i) AND b(i)) OR$ 19 (a(i) AND c(i)) OR 20 (b(i) AND c(i)); 21 END GENERATE; 22 cout  $\leq c(n)$ ; 23 END adder; 24 -----\_\_\_\_\_

### **Carry Look Ahead Adder**

A diagram of a 4-bit carry look ahead adder is shown in figure 9.8. Its implementation is based on the generate and propagate concept, which gives the circuit higher speed than its carry ripple adder counterpart (at the expense of more silicon area). Consider two input bits, a and b. The generate (g) and propagate (p) signals are defined as:

g = a AND b

 $\mathbf{p} = \mathbf{a} \mathbf{XOR} \mathbf{b}$ 

Notice that such signals can be computed in advance, because neither depends on the carry bit.







MCA. Eng. K. DAWAH **If we consider now two input vectors, a =a(n -1) ... a(1)a(0) and b =b(n -1)** ... b(1)b(0), then the corresponding generate and propagate vectors are g =g(n -1) ... g(1)g(0) and p =p(n -1) ... p(1)p(0), where g(j) =a(j) AND b(j) p(j) =a(j) XOR b(j) Let us consider now the carry vector, c =c(n -1) ... c(1)c(0). The carry bits can be computed from g and p: c(0)=cin c(1) =c(0)p(0) +g(0) c(2) = c(0)p(0)p(1) +g(0)p(1) +g(1) c(3) = c(0)p(0)p(1)p(2) +g(0)p(1)p(2) +g(1)p(2) +g(2), etc.

Independently; that is, none of the expressions above depends on preceding carry Computations, and that is the reason why this circuit is faster. On the other hand, the Hardware complexity grows very fast, limiting this approach to just a few bits (typically four). Larger carry look ahead adders can be implemented by associating such4-bit-or-so units.

The implementation of the adder of figure 9.8 is now straightforward. The **PGU** (**P**ropagate—**G**enerate Unit) computes p and g (four units are required), plus the Actual sum (s), while the **CLAU** (**C**arry Look Ahead Unit) computes the carry bits. Note: In order to construct bigger carry look ahead adders, the CLAU block of figure 9.8 must posses Group Propagate (GP) and Group Generate (GG) outputs, Which were omitted in the figure because this implementation is intended for four bits Only.

1 -----\_\_\_\_\_ 2 LIBRARY ieee: 3 USE ieee.std logic 1164.all; 4 -----5 ENTITY CLA Adder IS 6 PORT (a, b: IN STD\_LOGIC\_VECTOR (3 DOWNTO 0); 7 cin: IN STD LOGIC: 8 s: OUT STD\_LOGIC\_VECTOR (3 DOWNTO 0); 9 cout: OUT STD LOGIC); 10 END CLA Adder; 11 -----12 ARCHITECTURE CLA Adder OF CLA Adder IS 13 SIGNAL c: STD\_LOGIC\_VECTOR (4 DOWNTO 0); 14 SIGNAL p: STD\_LOGIC\_VECTOR (3 DOWNTO 0); 15 SIGNAL g: STD\_LOGIC\_VECTOR (3 DOWNTO 0); 16 BEGIN 17 ---- **PGU:** -----18 G1: FOR i IN 0 TO 3 GENERATE  $19 p(i) \le a(i) \text{ XOR } b(i);$  $20 g(i) \le a(i) AND b(i);$ 21 s(i)  $\leq p(i) \text{ XOR } c(i)$ : 22 END GENERATE; كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكتر ونيات Department of Computer Engineering and Technology

tment of Computer Engineering and Technolo

BY:K.DAWAH .ABBAS







MCA. Eng. K. DAWAH

```
23 ---- CLAU: -----
24 c(0) \le c(0)
25 c(1) \le (cin AND p(0)) OR
26 g(0);
27 c(2) \le (cin AND p(0) AND p(1)) OR
28 (g(0) AND p(1)) OR
29 g(1);
30 c(3) \le (cin AND p(0) AND p(1) AND p(2)) OR
31 (g(0) AND p(1) AND p(2)) OR
32 (g(1) AND p(2)) OR
33 g(2);
34 c(4) \le (cin AND p(0) AND p(1) AND p(2) AND p(3)) OR
35 (g(0) AND p(1) AND p(2) AND p(3)) OR
36 (g(1) AND p(2) AND p(3)) OR
37 (g(2) AND p(3)) OR
38 g(3);
39 cout \leq c(4);
40 END CLA Adder;
41 -----
```

Qualitatively, the simulation results obtained from the circuit synthesized with the code above are similar to those from the carry ripple adder presented in figure 9.7.

### 9.4 Fixed-Point Division

We saw in chapter 4 that the pre-defined "/" (division) operator accepts only power of two divisors, that is, it is indeed a "shift" operator. In this section, we will discuss the implementation of **generic division**, in which the dividend and divisor can be any integer. We start by describing the division algorithm, then we present two VHDL solutions followed by simulation results.

### **Division Algorithm**

Say that we want to calculate y = a/b, where a, b, and y have the same number (n + 1) of bits. The algorithm is illustrated in figure 9.9, for a ="1011" (decimal 11) and b ="0011" (decimal 3), from which we expect y = "0011" (decimal 3) and remainder"0010" (decimal 2). We first create a shifted version of b, whose length is 2n + 1 bits (shown in the b-related column in figure 9.9). b\_inp (i) is simply b shifted to the left by **i** positions (notice the underscored characters in the b-related column).

| Index<br>(i) | a-related<br>input (a_inp) | Comparison | b-related<br>input (b_inp) | y (quotient) | Operation on 1st column |
|--------------|----------------------------|------------|----------------------------|--------------|-------------------------|
| 3            | 1011                       | <          | 0011000                    | 0            | none                    |
| 2            | 1011                       | <          | 0001100                    | 0            | none                    |
| 1            | 1011                       | >          | 0000110                    | 1            | a_inp(i)-               |
| 0            | 0101                       | >          | 0000011                    | 1            | b_inp(i)                |
|              |                            |            |                            |              | a_inp(i)-               |
|              |                            |            |                            |              | b_inp(i)                |

#### 0010(rem)

The computation of the quotient is performed as follows. Starting from the top of

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





MCA. Eng. K. DAWAH the table, we compare(a-inp(i)) with (b-inp(i).) If the former is **bigger** than or **equal** to the latter, than  $\mathbf{y}(\mathbf{i}) = \mathbf{'1'}$  and **b-inp(i)** is **subtracted** from **a-inp(i)**; otherwise,  $\mathbf{y}(\mathbf{i}) = \mathbf{'0'}$  and we simply proceed to the next line. After  $\mathbf{n} + \mathbf{1}$  iterations, the computation is completed and the value left in a-inp is the remainder. Note: It is obvious that, to subtract b-inp from a-inp, the number of bits of a-inp cannot be **less** than that of b-inp, so the actual length of a-inp must be increased, which is attained by simply filling a-inp with n '0's on its left-hand side ('0's not shown in figure 9.9). Another way of presenting the division algorithm is the following. We multiply b by  $2^{**n}$ , where  $\mathbf{n} + \mathbf{1}$  is the number of bits. This, of course, corresponds to shifting  $\mathbf{b}$  $\mathbf{n}$  positions to the left, but without throwing out any of its bits (so the new b-vector must be n bits longer than the original vector). If a is **bigger** than the new  $\mathbf{b}$ , then  $\mathbf{y}(\mathbf{n}) = \mathbf{'1'}$ , and  $\mathbf{b}$  (the new value) must be **subtracted** from  $\mathbf{a}$ ; otherwise,  $\mathbf{y}(\mathbf{n}) = \mathbf{'0'}$ . Now we move to the next iteration. We multiply b (the original value) by  $2^{**}(\mathbf{n} - 1)$ ,

which is equivalent to shifting the original vector n - 1 positions to the left, or shifting the value of b just used in the previous computation back one position to the right. Then we compare it to a, as we did before, to decide whether y(n - 1) should be '1' or '0', and so on.

## VHDL Dividers

Below are two solutions for the division problem. Both use **sequential code**: IF is used in the first, while LOOP plus IF are employed in the second. The first solution is a step-by-step code, so the division algorithm described above can be clearly observed. The second is more compact and is also generic (notice that n was defined



Figure 9.10

Simulation results of divider (for 4-bit operands).

by means of a GENERIC statement in line 6). The solutions include also a b = 0 check routine. Simulation results are shown in figure 9.10.

Department of Computer Engineering and Technology

BY:K.DAWAH .ABBAS







6 PORT (a, b: IN INTEGER RANGE 0 TO 15; 7 y: OUT STD\_LOGIC\_VECTOR (3 DOWNTO 0); 8 rest: OUT INTEGER RANGE 0 TO 15; 9 err : OUT STD\_LOGIC); 10 END divider; 11 -----12 ARCHITECTURE rtl OF divider IS 13 BEGIN 14 PROCESS (a, b) 15 VARIABLE temp1: INTEGER RANGE 0 TO 15; 16 VARIABLE temp2: INTEGER RANGE 0 TO 15; 17 BEGIN 18 ----- Error and initialization: ------19 temp1 := a; 20 temp2 := b;21 IF (b=0) THEN err <= '1'; 22 ELSE err <= '0'; 23 END IF; 24 ----- y(3): -----25 IF (temp1 >= temp2 \* 8) THEN 26 y(3) <= '1'; 27 temp1 := temp1 - temp2\*8;28 ELSE y(3) <= '0'; 29 END IF: 30 ----- y(2): -----31 IF (temp1 >= temp2 \* 4) THEN 32 y(2) <= '1'; 33 temp1 := temp1 - temp2 \* 4;34 ELSE y(2) <= '0'; 35 END IF; 36 ----- y(1): -----37 IF (temp1  $\geq$  temp2 \* 2) THEN 38 y(1) <= '1'; 39 temp1 := temp1 - temp2 \* 2;40 ELSE y(1) <= '0'; 41 END IF; 42 ----- y(0): -----43 IF (temp1  $\geq$  temp2) THEN 44 y(0) <= '1'; 45 temp1 := temp1 - temp2;46 ELSE y(0) <= '0'; 47 END IF; 48 ----- Remainder: -----49 rest  $\leq$  temp1; 50 END PROCESS; 51 END rtl; 52 -----







1 ----- Solution 2: compact and generic------2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY divider IS 6 GENERIC(n: INTEGER := 3); 7 PORT (a, b: IN INTEGER RANGE 0 TO 15; 8 y: OUT STD\_LOGIC\_VECTOR (3 DOWNTO 0); 9 rest: OUT INTEGER RANGE 0 TO 15; 10 err : OUT STD LOGIC); 11 END divider: 12 -----13 ARCHITECTURE rtl OF divider IS 14 BEGIN 15 PROCESS (a, b) 16 VARIABLE temp1: INTEGER RANGE 0 TO 15; 17 VARIABLE temp2: INTEGER RANGE 0 TO 15; 18 BEGIN 19 ----- Error and initialization: ------20 temp1 := a; 21 temp2 := b; 22 IF (b=0) THEN err <= '1'; 23 ELSE err  $\leq 0'$ ; 24 END IF; 25 ----- y: -----26 FOR i IN n DOWNTO 0 LOOP 27 IF(temp1 >= temp2 \*  $2^{**i}$ ) THEN  $28 y(i) \le 1';$ 29 temp1 := temp1 - temp2 \*  $2^{**I}$ ;  $30 \text{ ELSE } y(i) \le 0';$ 31 END IF; 32 END LOOP; 33 ----- Remainder: ------34 rest  $\leq$  temp1; 35 END PROCESS; 36 END rtl; 37 -----

### 9.5 Vending-Machine Controller

The inputs and outputs of the controller are shown in figure 9.11. The input signals nickel-in, dime-in, and quarter-in indicate that a corresponding coin has been deposited. Two additional inputs, clk (clock) and rst (reset), are also necessary. The controller responds with three outputs: candy-out, to dispense a candy bar, plus nickel-out and dime-out, asserted when change is due.

Figure 9.11 also shows the states of the corresponding FSM. The numbers inside the circles represent the total amount deposited by the customer (only nickels, dimes,





119

## **Advanced Digital Electronics**



MCA. Eng. K. DAWAH

and quarters are accepted). State 0 is the idle state. From it, if a nickel is deposited, the machine moves to state 5; if a dime, to state 10; or if a quarter, to state 25. Similar situations are repeated for all states, up to state 20. If state 25 is reached, then a candy bar is dispensed, with no change. However, if state 40 is reached, for example, then a nickel is delivered, passing therefore the system to state 35, from which a dime is delivered and a candy bar is delivered and the machine returns to state 0. This problem will be divided into two parts: in the first, the fundamental aspects related to the design of the vending machine controller (figure 9.11) are treated; in the second, additional (and indispensable) features are added. The first part is studied in this section, while the second is proposed as a problem (problem 9.3). The introduction of such additional features is necessary for safety reasons; since we are dealing with money, we must assure that none of the parts (machine or customer) will be hurt in the transaction

A VHDL code, treating only the basic features of the problem depicted in figure 9.11, is presented below. We have assumed that the additional features proposed in problem 9.3 will indeed be implemented, in which case glitches are acceptable in the first part of the solution. Therefore, design style #1 (section 8.2) can be employed. The enumerated type state (line 12) contains a list of all states shown in the FSM diagram of figure 9.11. There are ten states, so four bits are necessary to encode them (so four flip-flops will be inferred). Recall that the compiler encodes such states in the order that they are listed, so st0 = "0000" (decimal 0), st5 = "0001" (decimal 1), ..., st45 = "1001" (decimal 9). Therefore, in the simulations, such numbers are shown instead of the state names.

1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY vending\_machine IS 6 PORT ( clk, rst: IN STD\_LOGIC; 7 nickel\_in, dime\_in, quarter\_in: IN BOOLEAN; 8 candy\_out, nickel\_out, dime\_out: OUT STD\_LOGIC); 9 END vending machine; 10 -----11 ARCHITECTURE fsm OF vending machine IS 12 TYPE state IS (st0, st5, st10, st15, st20, st25, 13 st30, st35, st40, st45); 14 SIGNAL present\_state, next\_state: STATE; 15 BEGIN 16 ---- Lower section of the FSM (Sec. 8.2): ------17 PROCESS (rst, clk) 18 BEGIN 19 IF (rst='1') THEN 20 present\_state <= st0; 21 ELSIF (clk'EVENT AND clk='1') THEN 22 present\_state <= next\_state; 23 END IF; 24 END PROCESS; كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالر ا بعة- فرع الالكتر ونيات Department of Computer Engineering and Technology





```
MCA. Eng. K. DAWAH
```

```
25 ---- Upper section of the FSM (Sec. 8.2): ------
26 PROCESS (present_state, nickel_in, dime_in, quarter_in)
27 BEGIN
28 CASE present_state IS
29 WHEN st0 =>
30 candy_out <= '0';
31 nickel_out <= '0';
32 dime out \leq 0';
33 IF (nickel_in) THEN next_state <= st5;
34 ELSIF (dime_in) THEN next_state <= st10;
35 ELSIF (quarter_in) THEN next_state <= st25;
36 ELSE next state <= st0;
37 END IF;
38 WHEN st5 =>
39 candy_out <= '0';
40 nickel out \leq 0';
41 dime_out <= '0';
42 IF (nickel_in) THEN next_state <= st10;
43 ELSIF (dime_in) THEN next_state <= st15;
44 ELSIF (quarter_in) THEN next_state <= st30;
45 ELSE next state <= st5;
46 END IF;
47 WHEN st10 =>
48 candy_out <= '0';
49 nickel_out <= '0';
50 dime out \leq 0';
51 IF (nickel_in) THEN next_state <= st15;
52 ELSIF (dime in) THEN next state <= st20;
53 ELSIF (quarter_in) THEN next_state <= st35;
54 ELSE next_state <= st10;
55 END IF;
56 WHEN st15 =>
57 candy_out <= '0';
58 nickel_out <= '0';
59 dime_out <= '0';
60 IF (nickel_in) THEN next_state <= st20;
61 ELSIF (dime_in) THEN next_state <= st25;
62 ELSIF (quarter_in) THEN next_state <= st40;
63 ELSE next state <= st15;
64 END IF;
65 WHEN st20 =>
66 candy_out <= '0';
67 nickel out \leq 0';
68 dime_out <= '0';
69 IF (nickel_in) THEN next_state <= st25;
70 ELSIF (dime_in) THEN next_state <= st30;
71 ELSIF (quarter_in) THEN next_state <= st45;
72 ELSE next_state <= st20;
          كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات
                 Department of Computer Engineering and Technology
```

**BY:K.DAWAH** .ABBAS





73 END IF: 74 WHEN st25 => 75 candy out  $\leq 1'$ ; 76 nickel\_out <= '0'; 77 dime\_out <= '0'; 78 next\_state <= st0; 79 WHEN st30 => 80 candy out  $\leq 1'$ ; 81 nickel\_out <= '1'; 82 dime\_out <= '0'; 83 next\_state <= st0; 84 WHEN st35 => 85 candy\_out <= '1'; 86 nickel\_out <= '0'; 87 dime\_out <= '1'; 88 next state  $\leq$  st0; 89 WHEN st40 => 90 candy\_out <= '0'; 91 nickel\_out <= '1'; 92 dime\_out <= '0'; 93 next\_state <= st35; 94 WHEN st45 => 95 candy\_out <= '0'; 96 nickel out  $\leq 0'$ ; 97 dime\_out <= '1'; 98 next\_state <= st35; 99 END CASE; 100 END PROCESS; 101 102 END fsm; 103 -----

Simulation results are presented in figure 9.12. As can be seen, three nickels and one quarter were deposited. Notice that, at the first positive clock edge after the first nickel was deposited, the FSM moves from state st0 (decimal 0) to st5 (decimal 1);



Figure 9.12 Simulation results from the vending-machine controller.







MCA. Eng. K. DAWAH



after de second nickel, to state st10 (decimal 2); after de third, to state st15 (decimal 3); and, after de quarter has been deposited, to state st40 (decimal 8). After that, a nickel is returned to the customer (nickel-out ='1'), causing the FSM to move to state st35 (decimal 7), at which a dime is delivered (dime-out ='1') and a candy bar is dispensed (candy-out ='1'). The system returns then to its idle state (st0). As mentioned above, additional features (like handshake) are necessary to increase the security of the transactions. Please refer to problem 9.3 for a continuation of this design.

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





### **9.6**Serial Data Receiver

The diagram of a serial data receiver is shown in figure 9.13. It contains a serial data input, din, and a parallel data output, data(6:0). A clock signal is also needed at the input. Two supervision signals are generated by the circuit: err (error) and data-valid. The input train consists of ten bits. The first bit is a start bit, which, when high, must cause the circuit to start receiving data. The next seven are the actual data bits. The ninth bit is a parity bit, whose status must be '0' if the number of ones in data is even, or '1' otherwise. Finally, the tenth is a stop bit, which must be high if the transmission is correct. An error is detected when either the parity does not check or the stop bit is not a '1'. When reception is concluded and if no error has been detected, then the data stored in the internal registers (reg) is transferred to data(6:0) and the data\_valid output is asserted.

A VHDL code for this circuit is presented below. A few variables were used: count, to determine the number of bits received; reg, which stores the data; and temp, to compute the error. Notice in line 37 that reg(0) = din was used instead of  $reg(0) = 0^{\circ}$ , because we want the time slot immediately after the stop bit to be considered as possibly containing a start bit for the next input train.











```
16 VARIABLE temp : BIT;
17 BEGIN
18 IF (rst='1') THEN
19 count:=0;
20 \text{ reg} := (\text{reg'RANGE} => '0');
21 temp := '0';
22 err <= '0';
23 data valid \leq 0';
24 ELSIF (clk'EVENT AND clk='1') THEN
25 IF (reg(0)='0' AND din='1') THEN
26 \operatorname{reg}(0) := '1';
27 ELSIF (reg(0)='1') THEN
28 \operatorname{count} := \operatorname{count} + 1;
29 IF (count < 10) THEN
30 \operatorname{reg(count)} := \operatorname{din};
31 ELSIF (count = 10) THEN
32 \text{ temp} := (\text{reg}(1) \text{ XOR } \text{reg}(2) \text{ XOR } \text{reg}(3) \text{ XOR}
33 reg(4) XOR reg(5) XOR reg(6) XOR
34 reg(7) XOR reg(8)) OR NOT reg(9);
35 err \leq temp;
36 \text{ count} := 0;
37 \operatorname{reg}(0) := \operatorname{din};
38 IF (temp = '0') THEN
39 data valid \leq 1';
40 \text{ data} \leq \text{reg}(7 \text{ DOWNTO } 1);
41 END IF;
42 END IF;
43 END IF;
44 END IF:
45 END PROCESS;
46 END rtl;
47 -----
```

Simulation results are presented in figure 9.14. The input sequence is din =  $\{\text{start} = 1, \text{din} = 0111001, \text{parity} = 0, \text{stop} = 1\}$ . As can be seen in the upper graph, no error was detected in this case, because the parity and stop bits are correct. Hence, after count reaches 9, the data is made available, that is, data = 0111001, from data(0) to data(6), which corresponds to the decimal 78, and the data-valid bit is Figure







### 9.7 PARALLEL-TO-SERIAL CONVERTER

A parallel-to-serial converter is a typical application of shift registers. It consists of sending out a block of data serially. The need for such converters arises, for example, in ASIC chips when there are not enough pins available to output all data bits simultaneously.

A diagram of a parallel-to-serial converter is presented in figure 9.15. d(7:0) is the data vector to be sent out, while dout is the actual output. There are also two other inputs: clk and load. When load is asserted, d is synchronously stored in the shift register reg. While load stays high, the MSB, d(7), remains available at the output. Once load is returned to '0', the subsequent bits are presented at the output at each positive edge of clk. After all eight bits have been sent out, the output remains low until the next transmission.

1 -----

2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY serial converter IS 6 PORT (d: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0); 7 clk, load: IN STD LOGIC; 8 dout: OUT STD\_LOGIC); 9 END serial\_converter; 10 -----11 ARCHITECTURE serial\_converter OF serial\_converter IS 12 SIGNAL reg: STD\_LOGIC\_VECTOR (7 DOWNTO 0); **13 BEGIN** 14 PROCESS (clk) **15 BEGIN** 16 IF (clk'EVENT AND clk='1') THEN 17 IF (load='1') THEN reg  $\leq d$ ; 18 ELSE reg <= reg(6 DOWNTO 0) & '0'; 19 END IF: 20 END IF: 21 END PROCESS;  $22 \text{ dout} \le \text{reg}(7);$ 23 END serial\_converter; 24 -----

Simulation results from the circuit synthesized with the code above are shown in figure 9.16. d ="11011011" (decimal 219) was chosen. As can be seen, d(7) = 1 is presented at the output at the first rising edge of clk after load has been asserted, staying there while load remains high (to illustrate this fact, load was kept high during two clock cycles). The other bits follow as soon as load returns to '0'. Notice that after all bits have been transmitted, the output stays low.

### 9.8 Playing with a Seven-Segment Display

We want to design a little game with an SSD (seven-segment display). The top-level diagram of the circuit is shown in figure 9.17. It contains two inputs, clk and stop, and one output, dout(6:0), which feeds the SSD. Assume that fclk =1 kHz. Our circuit should cause a continuous clockwise movement of the SSD segments. Also, in order to make the circulatory movement more realistic, we want to momentarily كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الإلكترونيات

Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS







MCA. Eng. K. DAWAH

overlap neighboring segments. Consequently, the sequence should be  $a \rightarrow ab \rightarrow bc \rightarrow c \rightarrow cd \rightarrow dd \rightarrow ed \rightarrow ef \rightarrow fd \rightarrow a$ , with the combined states (ab, bc, etc.) lasting only a few milliseconds. If stop is asserted, then the circuit should return to state a and remain so until stop is turned low again. From chapter 8, it is clear that this is a circuit for which the FSM approach is appropriate. The states diagram is presented in figure 9.18. We want the system to remain in states a, b, c, etc. for time1 =80 ms, and in the combined states, ab, bc, etc., for time 2 = 30 ms. Therefore, a counter counting up to 80 (the clock period is 1 ms) or up to 30 can be employed to determine when to move to the next state. A VHDL solution is shown below. Notice that it is a straight implementation of the FSM template seen in section 8.2. In lines 11–12, time1 and time2 were declared as two constants. Small values (4 and 2, respectively) were here used in order for the simulation results to fit well in one plot, but 80 and 30, respectively, were used in the actual physical implementation. A signal called flip was used to switch from time1 to time2, and vice-versa. Notice that the corresponding decimals are marked beside each value of dout, so they can be easily verified in the simulation results.









MCA. Eng. K. DAWAH

1 2 LIBRARY ieee: 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY ssd\_game2 IS 6 PORT ( clk, stop: IN BIT; 7 dout: OUT BIT\_VECTOR (6 DOWNTO 0)); 8 END ssd game2; 9 -----10 ARCHITECTURE fsm OF ssd\_game2 IS 11 CONSTANT time1: INTEGER := 4; -- actual value is 80 12 CONSTANT time2: INTEGER := 2; -- actual value is 30 13 TYPE states IS (a, ab, b, bc, c, cd, d, de, e, ef, f, fa); 14 SIGNAL present\_state, next\_state: STATES; 15 SIGNAL count: INTEGER RANGE 0 TO 5; 16 SIGNAL flip: BIT; **17 BEGIN** 18 ------ Lower section of FSM (Sec. 8.2): ------19 PROCESS (clk, stop) 20 BEGIN 21 IF (stop='1') THEN 22 present\_state <= a; 23 ELSIF (clk'EVENT AND clk='1') THEN 24 IF ((flip='1' AND count=time1) OR 25 (flip='0' AND count=time2)) THEN 26 count <= 0;27 present\_state <= next\_state; 28 ELSE count  $\leq$  count + 1; 29 END IF; 30 END IF; 31 END PROCESS; 32 ------ Upper section of FSM (Sec. 8.2): ------33 PROCESS (present\_state) 34 BEGIN 35 CASE present\_state IS 36 WHEN a => 37 dout <= "1000000"; -- Decimal 64 38 flip<='1'; 39 next state  $\leq ab$ : 40 WHEN  $ab \Rightarrow$ 41 dout <= "1100000"; -- Decimal 96 42 flip<='0'; 43 next state  $\leq b$ ; 44 WHEN b => 45 dout <= "0100000"; -- Decimal 32 46 flip<='1'; 47 next\_state <= bc; 48 WHEN bc =>كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology

**BY:K.DAWAH** .ABBAS







49 dout <= "0110000"; -- Decimal 48 50 flip<='0'; 51 next state  $\leq c$ ; 52 WHEN c => 53 dout <= "0010000"; -- Decimal 16 54 flip<='1'; 55 next\_state <= cd; 56 WHEN cd =>57 dout <= "0011000"; -- Decimal 24 58 flip<='0'; 59 next\_state <= d;  $60 \text{ WHEN } d \Rightarrow$ 61 dout <= "0001000"; -- Decimal 8 62 flip<='1'; 63 next\_state <= de; 64 WHEN de =>65 dout <= "0001100"; -- Decimal 12 66 flip<='0'; 67 next\_state <= e; 68 WHEN e => 69 dout <= "0000100"; -- Decimal 4 70 flip<='1'; 71 next\_state <= ef; 72 WHEN ef =>73 dout <= "0000110"; -- Decimal 6 74 flip<='0'; 75 next\_state <= f; 76 WHEN  $f \Rightarrow$ 77 dout <= "0000010"; -- Decimal 2 78 flip<='1'; 79 next state  $\leq$  fa; 80 WHEN fa =>81 dout <= "1000010"; -- Decimal 66 82 flip<='0'; 83 next\_state <= a; 84 END CASE; 85 END PROCESS; 86 END fsm; 87 -----

Simulation results are presented in figure 9.19. As can be seen, the system stays in the single states, a, b, etc., for four clock cycles (time1 = 4 here) and in the combined states, ab, bc, etc., for two clock cycles (time2 = 2). Observe also that the decimals detected by the simulator match the decimals listed in the VHDL code.







## 9.9-Signal Generators

The signal of figure 9.20 can be modeled as an 8-state FSM. Using a counter from 0 to 7, we can establish that wave  $\frac{1}{4}$ '0' (1st pulse) when count  $\frac{1}{4}$ 0, wave  $\frac{1}{4}$ '1' (2nd pulse) when count  $\frac{1}{4}$ 1, and so on, thus creating the signal shown in the figure. This implementation requires a total of four flip-flops: three to store count (three bits), plus one to store wave (one bit). Recall from chapter 8, sections 8.2–8.3, that the output of a FSM will only be registered if design style #2 is employed, which is necessaryhere, because glitches are not acceptable in a signal generator.





The corresponding VHDL code, using design style #2 (section 8.3), is shown below. Simulation results appear in figure 9.21. Checking the report file created by the synthesis tool, we verify that a total of four flip-flops were indeed inferred from this code.

1 ------2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY signal\_gen IS 6 PORT (clk: IN STD\_LOGIC; 7 wave: OUT STD LOGIC); 8 END signal\_gen; 9 -----10 ARCHITECTURE fsm OF signal\_gen IS 11 TYPE states IS (zero, one, two, three, four, five, six, 12 seven); 13 SIGNAL present\_state, next\_state: STATES; 14 SIGNAL temp: STD\_LOGIC; 15 BEGIN كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات

Department of Computer Engineering and Technology

BY:K.DAWAH .ABBAS







16 17 --- Lower section of FSM (Sec. 8.3): ---18 PROCESS (clk) **19 BEGIN** 20 IF (clk'EVENT AND clk='1') THEN 21 present\_state <= next\_state; 22 wave  $\leq$  temp; 23 END IF; 24 END PROCESS; 25 26 --- Upper section of FSM (Sec. 8.3): ---27 PROCESS (present\_state) 28 BEGIN 29 CASE present\_state IS 30 WHEN zero => temp<='0'; next\_state <= one; 31 WHEN one => temp<='1'; next\_state <= two; 32 WHEN two => temp<='0'; next\_state <= three; 33 WHEN three => temp<='1'; next state <= four; 34 WHEN four => temp<='1'; next\_state <= five; 35 WHEN five => temp<='1'; next\_state <= six; 36 WHEN six => temp<='0'; next\_state <= seven; 37 WHEN seven => temp<='0'; next\_state <= zero; 38 END CASE; 39 END PROCESS; 40 END fsm; 41 -----

### **Conventional Approach**

A conventional design, with the IF statement, is shown next. Notice that count and wave are both assigned at the transition of another signal (clk). Therefore, according to what you saw in section 7.5, both will be stored (that is, four flip-flops will be inferred, three for count and one for wave).

Simulation results are shown in figure 9.22.



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





1 ------2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY signal\_gen1 IS 6 PORT (clk: IN BIT; 7 wave: OUT BIT); 8 END signal\_gen1; 9 -----10 ARCHITECTURE arch1 OF signal\_gen1 IS 11 BEGIN **12 PROCESS** 13 VARIABLE count: INTEGER RANGE 0 TO 7; 14 BEGIN 15 WAIT UNTIL (clk'EVENT AND clk='1'); 16 CASE count IS 17 WHEN  $0 \Rightarrow wave \iff 0'$ ; 18 WHEN 1 => wave <= '1'; 19 WHEN 2 => wave  $\leq 0'$ ; 20 WHEN 3 => wave <= '1': 21 WHEN 4 => wave <= '1'; 22 WHEN 5 => wave <= '1'; 23 WHEN 6  $\Rightarrow$  wave  $\leq$  '0': 24 WHEN 7 => wave  $\leq 0'$ ; 25 END CASE;  $26 \operatorname{count} := \operatorname{count} + 1;$ 27 END PROCESS; 28 END arch1; 29 -----

## 9.10 Memory Design

In this section, the design of the following memory circuits is presented: **-ROM** 

- -RAM with separate in/out data buses
- RAM with bidirectional in/out data bus

#### **ROM (Read Only Memory)**

Figure 9.23 shows the diagram of a ROM. Since it is a read-only memory, no clock signal or write-enable pin is necessary. As can be seen, the circuit contains a pile of pre-stored words, being the one selected by the address input (addr) presented at the output (data). In the code shown below, words (line 7) represents the number of words stored in the memory,

while bits (line 6) represents the size of each word. To create a ROM, an array of CONSTANT values can be used (lines 15–22). First, a new TYPE, called

كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلة الرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS





vector\_array, was defined (lines 13–14), which was then used in the declaration of a CONSTANT named memory (line 15). An 8 \*8 ROM is illustrated in this example, with the following (decimal) values stored in addresses 0 to 7: 0, 2, 4, 8, 16, 32, 64, and 128 (lines 15–22). Line 24 shows an example of call to the memory; the output (data) is equal to the word stored at address addr. When implementing a ROM, no data registers are inferred, because no signal assignment occurs at the transition of another signal. Logical gates forming an LUT (lookup table), are used instead.

1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY rom IS 6 GENERIC (bits: INTEGER := 8; -- # of bits per word 7 words: INTEGER := 8); -- # of words in the memory 8 PORT (addr: IN INTEGER RANGE 0 TO words-1; 9 data: OUT STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0)); 10 END rom: 11 -----12 ARCHITECTURE rom OF rom IS 13 TYPE vector array IS ARRAY (0 TO words-1) OF 14 STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0); 15 CONSTANT memory: vector\_array := ( "00000000", 16 "00000010", 17 "00000100". 18 "00001000", 19 "00010000", 20 "00100000". 21 "01000000", 22 "10000000"); 23 BEGIN 24 data <= memory(addr); 25 END rom; 26 -----

Simulation results are shown in figure 9.24. As can be seen, the address changes from 0 to 7, then restarts from 0, with the outputs matching the values listed in the code above.

### **RAM with Separate Input and Output Data Buses**

A RAM (Random Access Memory), with separate input and output data buses, is illustrated in figure 9.25.



كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات Department of Computer Engineering and Technology BY:K.DAWAH .ABBAS



As can be seen in figure 9.25(a), the circuit has a data input bus (data\_in), a data



MCA. Eng. K. DAWAH

output bus (data out), an address bus (addr), plus clock (clk) and write enable (wr\_ena) pins. When wr\_enable is asserted, at the next rising edge of clk the vector present at data\_in must be stored in the position specified by addr. data\_out, on the other hand, must constantly display the data selected by addr. From the register point-of-view, the circuit can be summarized as in figure 9.25(b). When wr ena is low, q is connected to the input of the flip-flop, and terminal d is open, so no new data will be written into the memory. However, when wr\_ena is turned high, d is connected to the input of the register, so at the next rising edge of clk d will be stored. A VHDL code that implements the circuit of figure 9.25 is shown below. The chosen capacity was 16 words of length eight bits each. Notice that the code is totally generic. Simulation results are shown in figure 9.26. 1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----**5 ENTITY ram IS** 6 GENERIC (bits: INTEGER := 8; -- # of bits per word 7 words: INTEGER := 16); -- # of words in the 8 -- memory 9 PORT ( wr\_ena, clk: IN STD\_LOGIC; 10 addr: IN INTEGER RANGE 0 TO words-1; 11 data\_in: IN STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0); 12 data out: OUT STD LOGIC VECTOR (bits-1 DOWNTO 0)); 13 END ram; 14 -----15 ARCHITECTURE ram OF ram IS 16 TYPE vector\_array IS ARRAY (0 TO words-1) OF 17 STD LOGIC VECTOR (bits-1 DOWNTO 0); 18 SIGNAL memory: vector\_array; **19 BEGIN** 20 PROCESS (clk, wr\_ena) 21 BEGIN 22 IF (wr ena='1') THEN 23 IF (clk'EVENT AND clk='1') THEN 24 memory(addr) <= data\_in; 25 END IF: 26 END IF: 27 END PROCESS; 28 data\_out <= memory(addr);</pre> 29 END ram: 30 -----







# RAM with Bidirectional In/Out Data Bus

A RAM with bidirectional in/out data bus is illustrated in figure 9.27. The overall structure is similar to that of figure 9.25, except for the fact that now the same bus (bidir) is used to write data into the memory as well to read data from it. From the register point-of-view, the circuit can be summarized as in figure 9.27(b). When wr-ena is low, the output of the register is connected to its input, so no change on the store data will occur. On the other hand, when wr-ena is asserted, q is connected to d, allowing new data to be stored at the next rising edge of clk. A VHDL code that implements the circuit of figure 9.27 is shown below. The chosen capacity was 16 words of length eight bits each. Notice that this code is also totally generic. Simulation results are shown in figure 9.28.

1 -----2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 -----5 ENTITY ram4 IS 6 GENERIC (bits: INTEGER := 8; -- # of bits per word 7 words: INTEGER := 16); -- # of words in the 8 -- memory 9 PORT ( clk, wr\_ena: IN STD\_LOGIC; 10 addr: IN INTEGER RANGE 0 TO words-1; 11 bidir: INOUT STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0)); 12 END ram4; 13 -----14 ARCHITECTURE ram OF ram4 IS 15 TYPE vector\_array IS ARRAY (0 TO words-1) OF 16 STD\_LOGIC\_VECTOR (bits-1 DOWNTO 0); 17 SIGNAL memory: vector\_array; 18 BEGIN 19 PROCESS (clk, wr\_ena) 20 BEGIN 21 IF (wr\_ena='0') THEN 22 bidir <= memory(addr); 23 ELSE 24 bidir  $\leq$  (OTHERS = 'Z'); 25 IF (clk'EVENT AND clk='1') THEN 26 memory(addr) <= bidir; 27 END IF; 28 END IF; 29 END PROCESS;







30 END ram; 31 -----

## **10-Packages and Components**

Packages and Components Introduction we will simply add new building blocks to the material already presented. These new building blocks are intended mainly for library allocation, being shown on the right-hand side of figure 10.1. They are: "h Packages "h Components "h Functions "h Procedures



Figure 10.1: Fundamental units of VHDL code.

### PACKAGE

frequently used pieces of VHDL code are usually written in the form of COMPONENTS, FUNCTIONS, or PROCEDURES. Such codes are then placed inside a PACKAGE and compiled into the destination LIBRARY. The importance of this technique is that it allows code partitioning, code sharing, and code reuse.

Packages syntax is presented below. the syntax is composed of two parts: PACKAGE and PACKAGE BODY. The first part is mandatory and contains all declarations, while the second part is necessary only when one or more subprograms (FUNCTION or PROCEDURE) are declared in the upper part, in which case it must contain the descriptions (bodies) of the subprograms. PACKAGE and PACKAGE BODY must have the same name.







```
PACKAGE package_name IS
    (declarations)
END package_name;
[PACKAGE BODY package_name IS
    (FUNCTION and PROCEDURE descriptions)
END package_name;]
```

The declarations list can contain the following: COMPONENT, FUNCTION, PROCEDURE, TYPE, CONSTANT, etc.

### **Example 10.1: Simple Package**

The example below shows a PACKAGE called my\_package. It contains only TYPE and CONSTANT declarations, so a PACKAGE BODY is not necessary

```
1
 2 LIBRARY ieee;
3 USE ieee.std logic 1164.all;
4
 5 PACKAGE my package IS
   TYPE state IS (st1, st2, st3, st4);
6
   TYPE color IS (red, green, blue);
7
   CONSTANT vec: STD LOGIC VECTOR(7 DOWNTO 0) := "11111111";
8
9 END my package;
10 -----
          _____
```

### Example 10.2: Package with a Function

This example contains, besides TYPE and CONSTANT declarations, a FUNCTION. Therefore, a PACKAGE BODY is now needed. This function returns TRUE when a positive edge occurs on clk.

```
1 _____
2 LIBRARY ieee;
3 USE ieee.std logic 1164.all;
4 -----
5 PACKAGE my package IS
     TYPE state IS (st1, st2, st3, st4);
6
     TYPE color IS (red, green, blue);
7
     CONSTANT vec: STD LOGIC VECTOR(7 DOWNTO 0) := "11111111";
8
     FUNCTION positive edge(SIGNAL s: STD LOGIC) RETURN BOOLEAN;
9
10 END my package;
      كلية المعارف الجامعة-قسم هندسة تقنيات الحاسوب - المرحلةالرا بعة- فرع الالكترونيات
           Department of Computer Engineering and Technology
                      BY:K.DAWAH .ABBAS
```



Any of the PACKAGES above (example 10.1 or example 10.2) can now be compiled, becoming then part of our work LIBRARY (or any other). To make use of it in a VHDL code, we have to add a new USE clause to the main code (USE work .my\_ package .all), as shown below.

#### COMPONENT

A COMPONENT is simply a piece of conventional code (that is, LIBRARY

declarations + ENTITY + ARCHITECTURE). However, by declaring such code as being a COMPONENT, it can then be used within another circuit, thus allowing the construction of hierarchical designs A COMPONENT is also another way of partitioning a code and providing code sharing and code reuse. For example, commonly used circuits, like flip-flops, multiplexers ,adders, basic gates, etc., can be placed in a LIBRARY, so any project can make use of them without having to explicitly rewrite such codes. To use (instantiate) a COMPONENT, it must first be declared. The corresponding syntaxes are shown below COMPONENT declaration:







```
COMPONENT component_name IS
    PORT (
        port_name : signal_mode signal_type;
        port_name : signal_mode signal_type;
        ...);
END COMPONENT;
```

COMPONENT instantiation:

label: component\_name PORT MAP (port\_list);

Example 10.3: Components Declared in the Main Code We want to implement the circuit of figure 10.3 employing only COMPONENTS (inverter, nand\_2, and nand\_3), but without creating a specific PACKAGE to declare them thus as in figure 10.2(a).









MCA. Eng. K. DAWAH



Figure 10.2: Basic ways of declaring COMPONENTS: (a) declarations in the main code itself, (b) declarations in a PACKAGE



Figure 10.3: Circuit of example 10.3.







MCA. Eng. K. DAWAH 1 ----- File inverter.vhd: ------2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; \_\_\_\_\_ 4 5 ENTITY inverter IS PORT (a: IN STD LOGIC; b: OUT STD LOGIC); 6 7 END inverter; 8 9 ARCHITECTURE inverter OF inverter IS 10 BEGIN 11 b <= NOT a; 12 END inverter; 1 ----- File nand 2.vhd: ------2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; 4 5 ENTITY nand 2 IS 6 PORT (a, b: IN STD LOGIC; c: OUT STD LOGIC); 7 END nand 2; 8 ARCHITECTURE nand 2 OF nand 2 IS 9 10 BEGIN 11 c <= NOT (a AND b);</pre> 12 END nand 2; 13 -----







MCA. Eng. K. DAWAH

```
1
 ----- File nand 3.vhd: ------
 LIBRARY ieee;
2
3
 USE ieee.std logic 1164.all;
4
  5
 ENTITY nand 3 IS
6
    PORT (a, b, c: IN STD LOGIC; d: OUT STD LOGIC);
7
 END nand 3;
8
 9 ARCHITECTURE nand 3 OF nand 3 IS
10 BEGIN
   d <= NOT (a AND b AND c);
11
12 END nand 3;
13 ------
1 ----- File project.vhd: ------
2 LIBRARY ieee;
3 USE ieee.std logic 1164.all;
4 ------
5
 ENTITY project IS
6
    PORT (a, b, c, d: IN STD LOGIC;
7
        x, y: OUT STD LOGIC);
8
  END project;
9
```







```
10 ARCHITECTURE structural OF project IS
11
      ____
12
      COMPONENT inverter IS
13
         PORT (a: IN STD LOGIC; b: OUT STD LOGIC);
14
      END COMPONENT;
15
      -----
16
      COMPONENT nand 2 IS
17
         PORT (a, b: IN STD LOGIC; c: OUT STD LOGIC);
18
      END COMPONENT;
19
      _____
20
      COMPONENT nand 3 IS
21
         PORT (a, b, c: IN STD LOGIC; d: OUT STD LOGIC);
22
      END COMPONENT;
23
      ____<mark>___</mark>____
24
       SIGNAL w: STD LOGIC;
25 BEGIN
       U1: inverter PORT MAP (b, w);
26
27
       U2: nand 2 PORT MAP (a, b, x);
28
       U3: nand 3 PORT MAP (w, c, d, y);
29 END structural;
30
                   100.0ns
                          200.0ns
                                  300.0ns
                                         400.0ns
                                                 500.0ns
                                                        60
           0
           0
h h
           0
           0
           1
           1
- V
```

.Figure 10.4: Experimental results of example 10.3

**Example 10.4**: Components Declared in a Package We want to implement the same project of the previous example (figure 10.3) However, we will now create a PACKAGE where all the COMPONENTS (inverter ,nand\_2, and nand\_3) will be declared, like in figure 10.2(b).





```
ENTITY inverter IS
5
6
    PORT (a: IN STD LOGIC; b: OUT STD LOGIC);
7
  END inverter;
  _____
8
9
  ARCHITECTURE inverter OF inverter IS
10 BEGIN
  b <= NOT a;
11
12 END inverter;
13 ------
1 ----- File nand 2.vhd: ------
2 LIBRARY ieee;
3 USE ieee.std logic 1164.all;
4 ------
5 ENTITY nand 2 IS
    PORT (a, b: IN STD LOGIC; c: OUT STD LOGIC);
6
7
 END nand 2;
8
 9
 ARCHITECTURE nand 2 OF nand 2 IS
10 BEGIN
   c <= NOT (a AND b);
11
12 END nand 2;
13 -----
1 ----- File nand 3.vhd: ------
2 LIBRARY ieee;
3 USE ieee.std logic 1164.all;
  _____
4
```







```
5
  ENTITY nand 3 IS
6
     PORT (a, b, c: IN STD LOGIC; d: OUT STD LOGIC);
7
  END nand 3;
8
  9
  ARCHITECTURE nand 3 OF nand 3 IS
10 BEGIN
11
     d <= NOT (a AND b AND c);</pre>
12 END nand 3;
13 -----
1 ----- File my components.vhd: ------
2 LIBRARY ieee;
3 USE ieee.std logic_1164.all;
4 ------
5 PACKAGE my components IS
     ----- inverter: ------
6
7
     COMPONENT inverter IS
8
       PORT (a: IN STD LOGIC; b: OUT STD LOGIC);
9
     END COMPONENT;
10
     ----- 2-input nand: ---
11
     COMPONENT nand 2 IS
12
       PORT (a, b: IN STD LOGIC; c: OUT STD LOGIC);
13
    END COMPONENT;
14
    ----- 3-input nand: ---
15
     COMPONENT nand 3 IS
16
       PORT (a, b, c: IN STD LOGIC; d: OUT STD LOGIC);
17
     END COMPONENT;
18
     ------
19 END my components;
20 -----
```







MCA. Eng. K. DAWAH ----- File project.vhd: ------1 2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; 4 USE work.my components.all; 5 \_\_\_\_\_\_ 6 ENTITY project IS PORT ( a, b, c, d: IN STD LOGIC; 7 8 x, y: OUT STD LOGIC); 9 END project; 10 ------11 ARCHITECTURE structural OF project IS 12 SIGNAL W: STD LOGIC; 13 BEGIN 14 Ul: inverter PORT MAP (b, w); 15 U2: nand 2 PORT MAP (a, b, x); 16 U3: nand 3 PORT MAP (w, c, d, y); 17 END structural; 18 ------

**Example 10.5:** ALU Made of COMPONENTS In the present example, however, we will assume that our library contains the three components (logic\_unit, arith\_unit, and mux) with which the ALU can be constructed







MCA. Eng. K. DAWAH ----- COMPONENT arith unit: -----1 2 LIBRARY ieee; USE ieee.std logic 1164.all; 3 4 USE ieee.std logic unsigned.all; 5 6 ENTITY arith unit IS PORT ( a, b: IN STD\_LOGIC\_VECTOR (7 DOWNTO 0); 7 sel: IN STD LOGIC VECTOR (2 DOWNTO 0); 8 9 cin: IN STD LOGIC; x: OUT STD LOGIC VECTOR (7 DOWNTO 0)); 10 11 END arith\_unit;









MCA. Eng. K. DAWAH

| sel  | Operation     | Function               | Unit       |  |
|------|---------------|------------------------|------------|--|
| 0000 | y <= a        | Transfer a             |            |  |
| 0001 | y <= a+1      | Increment a            |            |  |
| 0010 | y <= a-1      | Decrement a            |            |  |
| 0011 | y <= b        | Transfer b             | Arithmetic |  |
| 0100 | y <= b+1      | Increment b            |            |  |
| 0101 | y <= b-1      | Decrement b            |            |  |
| 0110 | y <= a+b      | Add a and b            |            |  |
| 0111 | y <= a+b+cin  | Add a and b with carry |            |  |
| 1000 | y <= NOT a    | Complement a           |            |  |
| 1001 | y <= NOT b    | Complement b           |            |  |
| 1010 | y <= a AND b  | AND                    | -          |  |
| 1011 | y <= a OR b   | OR                     | Logic      |  |
| 1100 | y <= a NAND b | NAND                   |            |  |
| 1101 | y <= a NOR b  | NOR                    |            |  |
| 1110 | y <= a XOR b  | XOR                    |            |  |
| 1111 | y <= a XNOR b | XNOR                   |            |  |

11

### Figure 10.5: ALU constructed from three COMPONENTS.

12 -----13 ARCHITECTURE arith unit OF arith unit IS SIGNAL arith, logic: STD\_LOGIC\_VECTOR (7 DOWNTO 0); 14 15 BEGIN 16 WITH sel SELECT x <= a WHEN "000", 17 18 a+1 WHEN "001", a-1 WHEN "010", 19 20 b WHEN "011", 21 b+1 WHEN "100", 22 b-1 WHEN "101", a+b WHEN "110", 23 a+b+cin WHEN OTHERS; 24 25 END arith\_unit; 26 -----







MCA. Eng. K. DAWAH ----- COMPONENT logic unit: -----1 2 LIBRARY ieee; 3 USE ieee.std\_logic\_1164.all; 4 5 ENTITY logic unit IS 6 PORT ( a, b: IN STD LOGIC VECTOR (7 DOWNTO 0); 7 sel: IN STD\_LOGIC\_VECTOR (2 DOWNTO 0); 8 x: OUT STD LOGIC VECTOR (7 DOWNTO 0)); 9 END logic unit; 10 ------11 ARCHITECTURE logic unit OF logic unit IS 12 BEGIN 13 WITH sel SELECT  $x \le NOT a WHEN "000",$ 14 NOT b WHEN "001", 15 a AND b WHEN "010", 16 17 a OR b WHEN "011", a NAND b WHEN "100", 18 19 a NOR b WHEN "101", a XOR b WHEN "110", 20 21 NOT (a XOR b) WHEN OTHERS; 22 END logic\_unit; 23 -----







MCA. Eng. K. DAWAH ----- COMPONENT mux: -----1 2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; 4 ------5 ENTITY mux IS 6 PORT ( a, b: IN STD LOGIC VECTOR (7 DOWNTO 0); 7 sel: IN STD LOGIC; x: OUT STD LOGIC VECTOR (7 DOWNTO 0)); 8 9 END mux; 10 ------11 ARCHITECTURE mux OF mux IS 12 BEGIN 13 WITH sel SELECT 14  $x \leq a$  WHEN '0', 15 b WHEN OTHERS; 16 END mux; 17 -----1 ----- Project ALU (main code): ------2 LIBRARY ieee; 3 USE ieee.std logic 1164.all; 4 5 ENTITY alu IS PORT ( a, b: IN STD\_LOGIC\_VECTOR(7 DOWNTO 0); 6 7 cin: IN STD LOGIC; 8 sel: IN STD LOGIC VECTOR(3 DOWNTO 0); y: OUT STD LOGIC VECTOR(7 DOWNTO 0)); 9 10 END alu; 11 ------







MCA. Eng. K. DAWAH

```
11 ------
12 ARCHITECTURE alu OF alu IS
13 -----
14
     COMPONENT arith unit IS
15
     PORT ( a, b: IN STD LOGIC VECTOR(7 DOWNTO 0);
           cin: IN STD LOGIC;
16
17
           sel: IN STD LOGIC VECTOR(2 DOWNTO 0);
           x: OUT STD_LOGIC_VECTOR(7 DOWNTO 0));
18
19
    END COMPONENT;
20
     ------
21
    COMPONENT logic unit IS
22
    PORT ( a, b: IN STD_LOGIC_VECTOR(7 DOWNTO 0);
           sel: IN STD LOGIC VECTOR(2 DOWNTO 0);
23
           x: OUT STD LOGIC VECTOR(7 DOWNTO 0));
24
    END COMPONENT;
25
26
    -----
27
     COMPONENT mux IS
28
     PORT ( a, b: IN STD LOGIC VECTOR(7 DOWNTO 0);
29
           sel: IN STD LOGIC;
           x: OUT STD_LOGIC_VECTOR(7 DOWNTO 0));
30
31
     END COMPONENT;
32
     -----
33
     SIGNAL x1, x2: STD LOGIC VECTOR(7 DOWNTO 0);
34 ------
35 BEGIN
36
     Ul: arith unit PORT MAP (a, b, cin, sel(2 DOWNTO 0), x1);
     U2: logic unit PORT MAP (a, b, sel(2 DOWNTO 0), x2);
37
     U3: mux PORT MAP (x1, x2, sel(3), y);
38
39 END alu;
```

Simulation results are shown in figure 10.6.

|       |       | 100. | Ons 20(    | ).Ons 300 | ).Ons 400.(  | Ons 50 | 0.0ns 600 | .Ons 700. | Ons 800 | Ons 9 | 00.0ns |
|-------|-------|------|------------|-----------|--------------|--------|-----------|-----------|---------|-------|--------|
| 产 cin | 0     |      |            | A97.      | 12 (K)       |        |           |           |         |       |        |
| 💕 a   | D 250 | 250  | 252        | 254       | X o X        | 2      | ) 4       | (6)       | 8)      | (10   | (12    |
| 🍞 b   | DO    | ο )  | 1          | χ 2       | χ <u>з</u> χ | 4      | χ 5       | (6)       | 7       | 8     | ) 9    |
| 泽 sel | DO    | 0    | χ          | 2         | χ 4          | χ      | 6         | 8         | χ       | 10    | ) 12   |
| 🔊 y   | D 250 | 250  | X 252 X 25 | 1 253     | 4            | X 5 X  | 6 🖁 9     | 249       | 247 0   | χ 8   | X      |

Figure 10.6: Simulation results of example 10.6.







MCA. Eng. K. DAWAH

# Reference :Circuit Design with VHDL

Volnei A. Pedroni(Massachusetts Institute of Technology)

