# <span id="page-0-0"></span>Chapter 1 Basic Building Blocks

Digital circuits are no longer defined by logical schemes but by Hardware Description Language programs [[1\]](#page-21-0). The translation of this kind of definition to an actual implementation is realized by Electronic Automation Design tools ([Chap. 5\)](http://dx.doi.org/10.1007/978-94-007-2987-2_5). All along this book the chosen language is VHDL. In this chapter the most useful constructions are presented. For all of the proposed examples, the complete source code is available at the Authors' web page.

# 1.1 Combinational Components

## 1.1.1 Boolean Equations

Among the predefined operations of any Hardware Description Language are the basic Boolean operations. Boolean functions can easily be defined. Obviously, all the classical logic gates can be defined. Some of them are considered in the following example.

#### Example 1.1

The following VHDL instructions define the logic gates NOT, AND2, OR2, NAND2, NOR2, XOR2, XNOR2, NAND3, NOR3, XOR3, XNOR3 (Fig. [1.1](#page-1-0)).

 $b \leq NOT(a)$ ;  $c \leq a$  AND b;  $c \leq a$  OR  $b$ ;  $c \leq a$  NAND b;

<span id="page-1-0"></span>

Fig. 1.1 Logic gates

```
c \leq a NOR b;
c \leq a \text{ XOR } b;
c \leq a XNOR b;
d \leq NOT(a AND b AND c);
d \leq NOT(a \ OR \ b \ OR \ c);
d \le a XOR b XOR c;
d \leq NOT(a XOR b XOR c);
```
The same basic Boolean operations can be used to define sets of logic gates working in parallel. As an example, assume that signals  $a = (a_{n-1}, a_{n-2}, \ldots, a_0)$  and  $b = (b_{n-1}, b_{n-2}, \ldots, b_0)$  are *n*-bit vectors. The following assignation defines a set of *n* AND2 gates that compute  $c = (a_{n-1} \cdot b_{n-1}, a_{n-2} \cdot b_{n-2}, \dots, a_0 \cdot b_0)$ :

 $c \leq a$  AND b;

More complex Boolean functions can also be defined. It is worthwhile to indicate that within most Field Programmable Gate Arrays (FPGA) the basic combinational components are not 2-input logic gates but Look Up Tables (LUT) allowing the implementation of any Boolean function of a few numbers (4, 5, 6) of variables [\(Chap. 5](http://dx.doi.org/10.1007/978-94-007-2987-2_5)). Hence, it makes sense to consider the possibility of defining small combinational components by the set of Boolean functions they implement.

#### Example 1.2

The following VHDL instruction defines an ANDORI gate (a 4-input 1-output component implementing the complement of  $a \cdot b \vee c \cdot d$ , Fig. [1.2\)](#page-2-0)

 $e \leq NOT((a AND b) OR (c AND d));$ 

and the two following instructions define a 1-bit full adder (a 3-input 2-output component implementing  $a+b+c_{in} \mod 2$  and  $a \cdot b \lor a \cdot c_{in} \lor b \cdot c_{in}$ , Fig. [1.3](#page-2-0)).

 $s \leq a$  XOR b XOR cin;  $\text{cout} \leq (\text{a AND b}) \text{ OR } (\text{a AND cin}) \text{ OR } (\text{b AND cin});$  <span id="page-2-0"></span>Fig. 1.2 ANDORI gate

Fig. 1.3 One-bit full adder



*s*

## 1.1.2 Tables

Combinational components can also be defined by their truth tables, without the necessity to translate their definition to Boolean equations. As a first example, consider a 1-digit to 7-segment decoder, that is a 4-input 7-output combinational circuit.

#### Example 1.3

The behavior of a 4-to-7 decoder (Fig. [1.4\)](#page-3-0) can be described by a conditional assignment instruction

```
WITH digit SELECT segments <=
  "1110111" WHEN "0000",
  "0010010" WHEN "0001",
  "1011101" WHEN "0010",
  "1011011" WHEN "0011",
  "0111010" WHEN "0100",
  "1101011" WHEN "0101",
  "1101111" WHEN "0110",
  "1010010" WHEN "0111",
  "1111111" WHEN "1000",
  "1111011" WHEN "1001",
  "1111110" WHEN "1010",
  "0101111" WHEN "1011",
  "1100101" WHEN "1100",
  "0011111" WHEN "1101",
  "1101101" WHEN "1110",
  "1101100" WHEN OTHERS;
```
The last choice of a WITH… SELECT construction must be WHEN OTHERS in order to avoid the inference of an additional latch, and it is the same for other multiple choice instructions such as CASE.

As mentioned above, small Look Up Tables are basic components of most FPGA families. The following example is a generic 4-input 1-output LUT.

<span id="page-3-0"></span>

Fig. 1.4 Four-digit to seven-segment decoder





## Example 1.4

The following entity defines a 4-input Boolean function whose truth vector is stored within a generic parameter (Fig. 1.5). Library declarations are omitted.

```
ENTITY lut4 IS
  GENERIC (truth vector: STD LOGIC VECTOR (0 to 15));
PORT (
  a: IN STD LOGIC VECTOR (3 DOWNTO 0);
  b: OUT STD LOGIC
);
END lut4;ARCHITECTURE behavior OF lut4 IS
BEGIN
  PROCESS (a)
    VARIABLE c: NATURAL;
  BEGIN
    \text{c} := CONV INTEGER(a);
    b \leq truth vector(c);
  END PROCESS;
END behavior;
```
Then the following component instantiation defines a 4-input XOR function.

```
xor4: lut4
GENERIC MAP (truth vector => "0110100110010110")
PORT MAP(a => a, b => b);
```
#### <span id="page-4-0"></span>Fig. 1.6 Multiplexers



#### Comment 1.1

The VHDL model of the preceding Example 1.4 can be used for simulation purposes, independently of the chosen FPGA vendor. Nevertheless, in order to implement an actual circuit, the corresponding vendor's primitive component should be used instead [\(Chap. 5](http://dx.doi.org/10.1007/978-94-007-2987-2_5)).

# 1.1.3 Controllable Connections

Multiplexers are the basic components for implementing controllable connections. Conditional assignments are used for defining them. Some of them are considered in the following example.

#### Example 1.5

The following conditional assignments define a 2-to-1 and a 4-to-1 multiplexer (Fig. 1.6). The signal types must be compatible with the conditional assignments:  $a, b, c, d$  and e are assumed to be *n*-bit vectors for some constant value *n*.

```
WITH sel SELECT c \le a when '0', b when OTHERS;
WITH sel SELECT e <=
  a WHEN "00",
 b WHEN "01",
  c WHEN "10",
  d WHEN OTHERS;
```
Demultiplexers, address decoders and tri-state buffers are other components frequently used for implementing controllable connections such as buses.

## Example 1.6

The following equations define a 1-bit 1-to-2 demultiplexer (Fig. [1.7](#page-5-0)a)

```
b \leq NOT(sel) AND a;
c \le sel AND a;
```
and the following conditional assignments a 1-to-4 demultiplexer (Fig. [1.7b](#page-5-0))

<span id="page-5-0"></span>*b c* DEMUX1-2  $\overline{0}$ 1 *a sel*  $\frac{n}{b}$ *b sel n n n* 2 DEMUX1-4 00 01 10 11  $a \rightarrow 0$ <sup>1</sup> *c d* Fig. 1.7 Demultiplexers (a) (b)

```
WITH sel SELECT b \leqa WHEN "00", (OTHERS => '0') WHEN OTHERS;
WITH sel SELECT c \leqa WHEN "01", (OTHERS => '0') WHEN OTHERS;
WITH sel SELECT d \leqa WHEN "10", (OTHERS => '0') WHEN OTHERS;
WITH sel SELECT e \leqa WHEN "11", (OTHERS => '0') WHEN OTHERS;
```
In the second case the signal types must be compatible with the conditional assignments:  $a, b, c, d$  and  $e$  are assumed to be *n*-bit vectors for some constant value n.

An address decoder is a particular case of 1-bit demultiplexer whose input is 1.

## Example 1.7

The following equations define a 3-input address decoder (Fig. [1.8\)](#page-6-0).

```
rows (0) \leqNOT(address(2)) AND NOT(address(1)) AND NOT(address(0));
rows (1) <=
  NOT (address (2)) AND NOT (address (1)) AND address (0);
rows(2) \leqNOT(address(2)) AND address(1) AND NOT(address(0));
rows (3) <=
  NOT (address (2)) AND address (1)
                                     AND address (0);
rows (4) <=
  address(2)
               AND NOT(address(1)) AND NOT(address(0));
rows (5) < =address(2)AND NOT (address(1)) AND address(0);
rows (6) \leqaddress(2)
                 AND address(1)
                                      AND NOT (address(0));
rows (7) \leqAND address(1)
  address(2)
                                      AND address (0) ;
```
Three-state buffers implement controllable switches.

#### <span id="page-6-0"></span>Fig. 1.8 Address decoder



Fig. 1.9 Three-state buffer



Fig. 1.10 Example of a data bus



#### Example 1.8

The following conditional assignment defines a tri-state buffer (Fig. 1.9): when the enable signal is equal to 1, output  $b$  is equal to input  $a$ , and when the enable signal is equal to 0, output  $b$  is disconnected (high impedance state). The signal types must be compatible with the conditional assignments: a and b are assumed to be  $n$ bit vectors for some constant value n.

```
WITH enable SELECT b <=
  a WHEN '1',
  (OTHERS =>'Z') WHEN OTHERS;
```
An example of the use of demultiplexers and tri-state buffers, namely a data bus, is shown in Fig. 1.10.

## Example 1.9

The circuit of Fig. 1.10, made up of demultiplexers and three-state buffers, can be described by Boolean equations (the multiplexers) and conditional assignments (the three-sate buffers).

<span id="page-7-0"></span>



```
enable a \le y(2)AND V(1);
enable b \le y(2)AND NOT(y(1));
enable c \leq NOT(y(2)) AND y(1);
enable d \leq NOT(y(2)) AND NOT(y(1)) AND y(0);
enable e \leq NOT(y(2)) AND NOT(y(1)) AND NOT(y(0));
WITH enable a SELECT data bus <=
  a WHEN '1', (OTHERS =>'Z') WHEN OTHERS;
WITH enable b SELECT data bus <=
 b WHEN '1', (OTHERS =>'Z') WHEN OTHERS;
WITH enable c SELECT data bus <=
  c WHEN '1', (OTHERS =>'Z') WHEN OTHERS;
WITH enable d SELECT data bus <=
 d WHEN '1', (OTHERS =>'Z') WHEN OTHERS;
WITH enable e SELECT data bus <=
  e WHEN '1', (OTHERS =>'Z') WHEN OTHERS;
```
Nevertheless, the same functionality can be implemented by an 8-bit 5-to-1 multiplexer (Fig. 1.11).

```
WITH y SELECT data bus <=
  a WHEN "111" | "110",
 b WHEN "101" | "100",
  c WHEN "011" | "010",
  d WHEN "001",
  e WHEN OTHERS:
```
Generally, this second implementation is considered safer than the first one. In fact, tri-state buffers should not be used within the circuit core. They should only be used within I/O-port components [\(Sect. 1.4\)](#page-18-0).

# 1.1.4 Arithmetic Circuits

Among the predefined operations of any Hardware Description Language there are also the basic arithmetic operations. The translation of this kind of description to

Fig.  $1.12$  *n*-bit adders



actual implementations, using special purpose FPGA resources (carry logic, multiplier blocks), is realized by Electronic Automation Design tools ([Chap. 5\)](http://dx.doi.org/10.1007/978-94-007-2987-2_5).

### Example 1.10

The following arithmetic equation defines an adder mod  $2^n$ , being a, b and s n-bit vectors and  $c_{IN}$  an input carry (Fig. 1.12a).

 $s \leq a + b + c$  in;

By adding a most significant bit 0 to one (or both) of the *n*-bit operands  $a$  and  $b$ , an *n*-bit adder with output carry  $c_{OUT}$  can be defined (Fig. 1.12b). The internal signal sum is an  $(n+1)$ -bit vector.

sum  $\leq$  ('0'&a) + b + c in;  $s \leq sum(n-1)$  DOWNTO 0); c out  $\leq$  sum(n);

The following arithmetic equation defines an *n*-bit by *m*-bit multiplier where  $a$  is an *n*-bit vector, *b* an *m*-bit vector and *product* an  $(n+m)$ -bit vector (Fig. 1.13).

product  $\leq$  a \* b;

#### Comment 1.2

In most VHDL models available at the Authors' web page, the type *unsigned* has been used, so that bit-vectors can be treated as natural numbers. In some cases, it could be better to use the signed type, for example when bit-vectors are interpreted as 2's complement integers, and when magnitude comparisons or sign-bit extensions are performed.



<span id="page-9-0"></span>Fig. 1.14 D flip-flops



# 1.2 Sequential Components

# 1.2.1 Flip-Flops

The basic sequential component is the D-flip-flop. In fact, several types of D-flipflop can be considered: positive edge triggered, negative edge triggered, with asynchronous input(s) and with complemented output.

## Example 1.11

The following component is a D-flip-flop triggered by the positive edge of  $clk$ (Fig. 1.14a),

```
PROCESS (clk)
BEGIN
  IF Clk'EVENT AND Clk = '1' THEN q \leq d; END IF;
END PROCESS:
```
while the following, which is controlled by the negative edge of *clkb*, has two asynchronous inputs clearb (active at low level) and preset (active at high level), having *clearb* priority, and has two complementary outputs q and  $q\bar{b}$ (Fig. 1.14b).

```
PROCESS(clkb, preset, clearb)
BEGIN
  IF clearb = '0' THEN q <= '0'; qb <= '1';
  ELSIF preset = '1' THEN q \leq '1'; qb \leq '0';
 ELSIF clkb'EVENT AND clkb = '0' THEN q \leq d; qb \leq not(d);
 END IF;
END PROCESS;
```
## Comment 1.3

The use of level-controlled, instead of edge-controlled, components is not recommendable. Nevertheless, if it were necessary, a D-latch could be modeled as follows:

IF en = '1' THEN  $q \leq d$ ; END IF;

where  $en$  is the enable signal and  $d$  the data input.

#### <span id="page-10-0"></span>Fig. 1.15 Parallel register



# 1.2.2 Registers

Registers are sets of D-flip-flops controlled by the same synchronization and control signals, and connected according to some regular scheme (parallel, left or right shift, bidirectional shift).

## Example 1.12

The following component is a parallel register with ce (clock enable) input, triggered by the positive edge of  $clk$  (Fig. 1.15).

```
PROCESS (clk)
BEGIN
  IF Clk'EVENT AND Clk = '1' THEN
    IF ce = '1' THEN q \leq d; END IF;
  END IF;
END PROCESS;
```
As a second example (Fig. [1.16](#page-11-0)), the next component is a right shift register with parallel input (controlled by *load*) and serial input (controlled by *shift*).

```
PROCESS (clk)
BEGIN
  IF Clk'EVENT AND Clk = '1' THEN
    IF load = '1' THEN q \leq parallel in;
    ELSIF shift = '1' THEN
      q \le serial_in & q(n-1 downto 1);
    END IF;
  END IF;
END PROCESS;
```
# 1.2.3 Counters

A combination of registers and arithmetic operations permits the definition of counters.

#### <span id="page-11-0"></span>Fig. 1.16 Right shift register

Fig. 1.17 Up/down counter



This defines an up/down counter (Fig.  $1.17$ ) with control signals *load* (input parallel\_in), count (update the state of the counter) and  $upb_down$  (0: count up, 1: count down).

```
PROCESS (clk)
BEGIN
  IF clk' EVENT AND clk = '1' THEN
    IF load = '1' THEN q \leq parallel in;
    ELSIF count = '1' AND upb down = '0' THEN
      q \leq q + 1;ELSIF count = '1' AND upb down = '1' THEN
      q \leq q - 1;
    END IF;
  END IF;
END PROCESS;
```
The following component is a down counter (Fig. [1.18\)](#page-12-0) with control signals *load* (input parallel\_in) and count (update the state of the counter). An additional binary output equal\_zero is raised when the state of the counter is zero (all 0's vector).

```
PROCESS (clk)
BEGIN
  IF Clk'EVENT AND Clk = '1' THEN
    IF load = '1' THEN q \leq parallel in;
    ELSIF count = '1' THEN q \leq q - 1;
    END IF;
  END IF;
END PROCESS;
equal zero \le '1' WHEN q = zero ELSE '0';
```


#### <span id="page-12-0"></span>Fig. 1.18 Down counter



Fig. 1.19 Moore machine

# 1.2.4 Finite State Machines

Hardware Description Languages allow us to define finite state machines at an input/output behavioral level. The translation to an actual implementation including registers and combinational circuits—a classical problem of traditional switching theory—is realized by Electronic Automation Design tools ([Chap. 5](http://dx.doi.org/10.1007/978-94-007-2987-2_5)).

In a Moore machine, the output state only depends on the current internal state (Fig. 1.19) while in a Mealy machine the output state depends on both the input state and the current internal state (Fig. [1.20](#page-13-0)). Let  $t_{SUinput}$  be the maximum set up time of the input state with respect to the positive clock edge,  $t_1$  the maximum delay of the combinational block that computes the next internal state, and  $t_2$  the maximum delay of the combinational block that computes the output state. Then, in the case of a Moore machine, the following conditions must hold

$$
t_{SUinput} + t_1 < T_{CLK} \text{ and } t_2 < T_{CLK}, \tag{1.1}
$$

and in the case of a Mealy machine

$$
t_{SUnput} + t_1 < T_{CLK} \text{ and } t_{SUnput} + t_2 < T_{CLK}. \tag{1.2}
$$

<span id="page-13-0"></span>

Fig. 1.20 Mealy machine

The set up and hold times of the register ([Chap. 6\)](http://dx.doi.org/10.1007/978-94-007-2987-2_6) have not been taken into account.

## Example 1.14

A Moore machine is shown in Fig. [1.21.](#page-14-0) It is the control unit of a programmable timer (Exercise 2.6.2). It has seven internal states, three binary input signals *start*, zero and reference, and two output signals *operation* (2 bits) and *done*. It can be described by the following processes.

```
next state: PROCESS (reset, clk)
BEGIN
  IF reset = '1' THEN current state \leq 0;
  ELSIF clk' EVENT AND clk = '1' THEN
    CASE current state IS
      WHEN 0 => IF start = '0'
                  THEN current state \leq 1;
                  END IF;
      WHEN 1 \Rightarrow IF start = '1'THEN current state \leq 2;
                  END IF;
      WHEN 2 \Rightarrow current state \leq 3;
      WHEN 3 \Rightarrow IF zero = '1'
                  THEN current state \leq 0;
                  ELSE current state \leq 4;
                  END IF;
      WHEN 4 \Rightarrow IF reference = '0'THEN current state \leq 5;
                  END IF;
      WHEN 5 => IF reference = '1'
                  THEN current state \leq 6;
```
<span id="page-14-0"></span>

Fig. 1.21 An example of a Moore machine

```
END IF;
      WHEN 6 \Rightarrow current state \leq 3;
    END CASE;
  END IF;
END PROCESS next state;
output state: PROCESS (current state)
BEGIN
  CASE current_state IS
    WHEN 0 TO 1 => operation <= "00"; done <= '1';
                   operation <= "11"; done <= '0';
    WHEN 2 =>
    WHEN 3 TO 5 => operation <= "00"; done <= '0';
    WHEN 6 =>
                   operation <= "01"; done <= '0';END CASE;
END PROCESS output state;
```
## Example 1.15

Consider the Mealy machine of Table [1.1](#page-15-0). It has four internal states, two binary inputs  $x_1$  and  $x_0$ , and one binary output z. Assume that  $x_0$  and  $x_1$  are

<span id="page-15-0"></span>

periodic, but out of phase, signals. Then the machine detects if  $x_0$  changes before  $x_1$  or if  $x_1$  changes before  $x_0$ . In the first case the sequence of internal states is A B C D A B... and  $z = 0$ . In the second case the sequence is D C B A D C... and  $z = 1$ .

It can be described by the following processes.

```
input state \leq x16x0;next state: PROCESS (reset, clk)
BEGIN
  IF reset = '1' THEN current state \leq A;
  ELSIF c1k' EVENT AND c1k = '1' THEN
    CASE current state IS
      WHEN A \Rightarrow IF input state = "01" THENcurrent state \leq B;
                 ELSIF input state = "11" THEN
                    current state \leq D;
                 END IF;
      WHEN B \Rightarrow IF input state = "10" THEN
                    current state \leq A;
                 ELSIF input state = "11" THEN
                    current state \leq C;
                 END IF;
      WHEN C \implies IF input state = "00" THEN
                    current state \leq B;
                 ELSIF input state = "10" THEN
                    current state \leq D;
                 END IF;
      WHEN D \implies IF input state = "00" THEN
                   current state \leq A;
                 ELSIF input state = "01" THEN
                    current state \leq C;
                 END IF;
    END CASE;
  END IF;
END PROCESS;
```

```
output state: PROCESS (current state, input state)
BEGIN
  CASE current state IS
    WHEN A => z <= x1;
    WHEN B \Rightarrow z \le not (x0);
    WHEN C \Rightarrow z \le not(x1);
    WHEN D \implies z \leq x0;END CASE:
END PROCESS output state;
```
# 1.3 Memory Blocks

With regards to memory blocks, a previous comment similar to Comment 1.1 must be outlined: VHDL models can be generated for simulation purposes; nevertheless, in order to implement an actual circuit, the corresponding vendor's primitive component should be used instead [\(Chap. 5\)](http://dx.doi.org/10.1007/978-94-007-2987-2_5).

## Example 1.16

The following entity defines a Read Only Memory storing  $2^n$  m-bit words. The stored data is defined by a generic parameter (Fig. [1.22\)](#page-17-0). Library declarations are omitted.

```
ENTITY rom IS
  GENERIC (n, m: NATURAL; stored data: STD LOGIC VECTOR);
PORT (
  address: IN STD LOGIC VECTOR (n-1 DOWNTO 0);
  word: OUT STD LOGIC VECTOR (m-1 DOWNTO 0)
\rightarrowEND rom;
ARCHITECTURE behavior OF rom IS
BEGIN
  PROCESS (address)
    VARIABLE c: NATURAL;
  BEGIN
    c := CONV_INTEGER(address) * m;word \leq stored data(c to c + m -1);
  END PROCESS;
END behavior;
```
<span id="page-17-0"></span>

Then the following component instantiation defines a ROM storing 16 4-bit words, namely

0100,1010,1011,1100,0111,1000,1001,0010,0001,1101,1101,1110,1111,0101,010 0,0001

(from address 0000 to address 1111).

```
DUT: rom
GENERIC MAP (n => 4, m => 4, stored data =>
X"4abc78921ddef541")
PORT MAP(address => address, word => word);
```
## Example 1.17

The following entity defines a synchronous Random Access Memory storing  $2<sup>n</sup>$ m-bit words (Fig. 1.23). A *write* input enables the writing operation. Functionally, it is equivalent to a Register File made up of  $2<sup>n</sup>$  m-bit registers whose *clock enable* inputs are connected to write, plus an address decoder. Library declarations are omitted.

```
ENTITY ram IS
  GENERIC (n, m: NATURAL) ;
PORT (
  address: IN STD LOGIC VECTOR (n-1 DOWNTO 0);
  data in: IN STD LOGIC VECTOR (m-1 DOWNTO 0);
  clk, write: IN STD LOGIC;
  data out: OUT STD LOGIC VECTOR (m-1 DOWNTO 0)
);
END ram:
ARCHITECTURE behavior OF ram IS
  TYPE memory IS ARRAY (0 TO 2 ** n-1) of
    STD LOGIC VECTOR (m-1 DOWNTO 0);
  SIGNAL stored data: memory;
BEGIN
  PROCESS (clk)
  BEGIN
    IF Clk'EVENT AND CLK = '1' THEN
      IF write = '1' THEN
      stored data (CONV INTEGER (address)) <= data in;
    END IF;
  END IF:
END PROCESS;
  data out <= stored data (CONV INTEGER (address)) ;
END behavior:
```
The following component instantiation defines a synchronous RAM storing 16 4-bit words.

```
DUT: ram
GENERIC MAP (n \Rightarrow 4, m \Rightarrow 4)PORT MAP (address => address, data in => data in,
  clk => clk, write => write, data out => data out);
```
# 1.4 IO-Port Components

Once again, a previous comment similar to Comment 1.1 must be outlined: VHDL models can be generated for simulating input and output amplifiers; nevertheless, in order to implement an actual circuit, the corresponding vendor's I/O component should be used instead [\(Chap. 5](http://dx.doi.org/10.1007/978-94-007-2987-2_5)).

<span id="page-19-0"></span>

Fig. 1.24 I/O ports

In order to generate VHDL models of I/O amplifiers, it is convenient to understand the meaning of the STD\_LOGIC type elements, that is

```
'X': forcing unknown, '0' : forcing 0, '1' : forcing 1,
'W': weak unknown, 'L' : weak 0, 'H' : weak 1,
'Z': high impedance
```
(''uninitialized'' and ''don't care'' states have no sense in the case of I/O amplifiers).

An amplifier generates low-impedance (forcing) signals when enabled and high impedance signals when disabled. Thus the possible outputs generated by an amplifier are 'X', '0', '1' and 'Z'. In the following example several types of input, output and bidirectional amplifiers are defined.

#### Example 1.18

The following conditional assignment defines an input buffer (Fig. 1.24a):

```
WITH a SELECT b \leq'0' WHEN '0' | 'L',
'1' WHEN '1' | 'H',
'X' WHEN OTHERS;
```
An input buffer with a pull-up resistor can be defined as follows (Fig. 1.24b).

WITH a SELECT  $b \leq$ '0' WHEN '0' | 'L', '1' WHEN '1' | 'H' | 'Z', 'X' WHEN OTHERS;

The definition of a tri-state output buffer (Fig. [1.24c](#page-19-0)) is the same as in example 1.8, that is

WITH en SELECT  $b \le a$  WHEN '1', 'Z' WHEN OTHERS;

An open-drain output can be defined as follows (Fig. [1.24](#page-19-0)d).

WITH a SELECT  $b \leq v_0$ ' WHEN '1' | 'H', 'Z' WHEN OTHERS;

As an example of hierarchical description, a bidirectional I/O buffer can be defined by instantiating an input buffer and a tri-state output buffer (Fig. [1.24](#page-19-0)e).

```
an input buffer: input buffer
PORT MAP(a => b, b => c);
an output buffer: tri state output
PORT MAP(a => a, en => en, b => b) ;
```
# 1.5 VHDL Models

The following complete VHDL models are available at the Authors' web page [www.arithmetic-circuits.org](http://www.arithmetic-circuits.org):

```
Sects. 1.1.1,1.1.21.1.3),
(Sects. 1.1.41.2.11.2.2),
(Sects. 1.2.11.2.21.2.3),
Sect. 1.2.4),
(Sect. 1.3),
input output.vhd Sect. 1.4).
```
## 1.6 Exercises

- 1. Generate the VHDL model of a circuit that computes  $y = a \cdot x$  where a is a bit, and x and y are *n*-bit vectors, so that  $y = (a \cdot x_{n-1}, a \cdot x_{n-2}, \dots, a \cdot x_0)$ .
- 2. Generate several models of a 1-bit full subtractor (Boolean equations, table, LUT instantiation).
- 3. Generate a generic model of an n-bit 8-to-1 multiplexer.
- <span id="page-21-0"></span>4. Generate a generic model of an n-input address decoder.
- 5. Design an *n*-bit magnitude comparator: given two *n*-bit naturals  $a$  and  $b$ , it generates a 1-bit output gt equal to 1 if  $a \ge b$  and equal to 0 if  $a < b$ .
- 6. Design a 60-state up counter with reset and count control inputs.
- 7. Design a finite state machine with two binary inputs  $x$  and  $y$  and a binary output z defined as follows: if the input sequence is  $(x, t) = 00011110000111...$  then  $z = 0$ , and if the input sequence is  $(x, y) = 00 10 11 01 00 10 11...$  then  $z = 1$ .

## Reference

1. Hamblen JO, Hall TS, Furman MD (2008) Rapid prototyping of digital systems. Springer, New York