

## ⇒ Modeling Styles

There are three modeling techniques which can be used for describing a circuit:

- 1 Gate level modeling / structural modeling.
- 2 Dataflow modeling
- 3 Behavioral modeling

A circuit can be described in any one of the above techniques or by taking combination of them.

## ⇒ Structure of Dataflow Description

- Dataflow describes how the circuit signals flow from the inputs to the outputs.
- There are some concurrent statements which allow to describe the circuit in terms of operations on signals and flow of signals in the circuit. When such concurrent statements are used in a program, the style is called a 'dataflow design'.
- Concurrent signal assignment statements are used in this type of modeling style.

2

→ Example of VHDL dataflow description

→ ① Implementation of full-adder



entity full\_add is

port (A, B, Cin : in bit;

Sum, Cout : out bit);

end full\_add;

architecture adder of full\_add is

begin

Sum <= A xor B xor Cin;

Cout <= (A and B) or (Cin and A) or (Cin and B);

end adder;

3

2

AND-OR circuit

VHDL code for AND-OR circuit:

```
entity AND_OR is
port (A,B,C,D,E : in bit;
      Y : out bit);
end;
```

```
architecture digital_ckt of AND_OR is
```

```
signal I1,I2;
```

```
begin
```

```
ST1: I1 <= A and B after 10ns; --Time 10ns indicates the propagation
```

```
ST2: I2 <= C and D and E after 10ns; --delay of gate and word after is
```

```
ST3: Y <= I1 or I2 after 20ns; --used to specify propagation delay
```

```
end digital_ckt;
```

3

→ Dataflow description of a half adder.



Logic diagram for half adder.

## VHDL half adder description

entity half\_adder is

port (

A : in bit;

B : in bit;

Sum: out bit;

Cout : out bit);

end half-adder;

architecture adder of half-adder is

begin

Sum <= A xor B; -- signal assignment statement

Cout <= A and B; -- signal assignment statement

end adder;

4

→ Multiplexer with active low enable

### 2x1 Multiplexer

(a) logic diagram



## (b) Logic Symbol



Truth table for a  $2 \times 1$  multiplexer.

|   | Input |                    | Output |
|---|-------|--------------------|--------|
|   | $S$   | $\overline{Enbar}$ | $y$    |
| X |       | 1                  | 0      |
| 0 |       | 0                  | $D_0$  |
| 1 |       | 0                  | $D_1$  |

VHDL code of a  $2 \times 1$  multiplexer

```

library ieee;
use ieee.std_logic_1164.all;
entity mux2x1 is
port (D0, D1, S, Enbar: in std_logic;
      Y : out std_logic);
end mux2x1;
architecture MUX of mux2x1 is
signal I1, I2, I3, I4 : std_logic;
begin
  -- Assume 10 nanoseconds propagation delay
  -- for all and, or, and not
  I1 <= not S after 10ns;
  I2 <= not Enbar after 10ns;
  I3 <= D0 after 10ns;
  I4 <= D1 after 10ns;
  Y <= I1 and I2 and I3 or I4 and not I2;
end;
  
```

$I_3 \leq D_0$  and  $I_1$  and  $I_2$  after 10ns;

$I_4 \leq D_1$  and  $S$  and  $I_2$  after 10ns;

$Y \leq I_3 \text{ or } I_4 \text{ after 10ns;}$

end MUX;

5) → 4x1 multiplexer.

(a) Logic diagram



## (b) Logic symbol



Truth Table

| Input |       |       | Output |
|-------|-------|-------|--------|
| $S_1$ | $S_0$ | Enbar | $y$    |
| X     | X     | 1     | 0      |
| 0     | 0     | 0     | $D_0$  |
| 0     | 1     | 0     | $D_1$  |
| 1     | 0     | 0     | $D_2$  |
| 1     | 1     | 0     | $D_3$  |

VHDL code of a 4x1 multiplexer

library ieee;

use ieee.std\_logic\_1164.all;

entity mux4x1 is

port (D: in std\_logic\_vector(3 downto 0);

S, Enbar: in std\_logic;

Y: out std\_logic);

end mux4x1;

architecture MUX of mux4x1 is

signal I<sub>1</sub>, I<sub>2</sub>, I<sub>3</sub>, I<sub>4</sub>, I<sub>5</sub>, I<sub>6</sub>, I<sub>7</sub>: std\_logic;

begin

-- Assume 10 nanoseconds propagation delay  
-- for all and, or, and not

$I_1 \leq \text{not } S_0 \text{ after } 10\text{ns};$

$I_2 \leq \text{not } S_1 \text{ after } 10\text{ns};$

$I_3 \leq \text{not } E_{\text{bar}} \text{ after } 10\text{ns};$

$I_4 \leq D_0 \text{ and } I_1 \text{ and } I_2 \text{ and } I_3 \text{ after } 10\text{ns};$

$I_5 \leq D_1 \text{ and } S_0 \text{ and } I_2 \text{ and } I_3 \text{ after } 10\text{ns};$

$I_6 \leq D_2 \text{ and } S_1 \text{ and } I_1 \text{ and } I_3 \text{ after } 10\text{ns};$

$I_7 \leq D_3 \text{ and } S_0 \text{ and } S_1 \text{ and } I_3 \text{ after } 10\text{ns};$

\

$Y \leq I_4 \text{ or } I_5 \text{ or } I_6 \text{ or } I_7 \text{ after } 10\text{ns};$

end MUX;

=> Structure of VHDL Behavioral Description

- The keyword in the behavioral description is process.
- Every behavioral description has to include in the process body.
- The process (A, B) is a concurrent statement; so its execution is initiated by the occurrence of an event.
- The ports A and B included in the process (A, B) statement is called sensitivity list.
- Any change in the state of any element of the sensitivity list is treated as an event.
- The process is activated (initiated) only if an event occurs; otherwise, process remains inactive.
- If the process has no sensitivity list, the process is executed continuously.

## VHDL behavioral description of half adder

entity half-adder is

port (A: in bit;

B: in bit;

Sum: out bit;

Cout: out bit);

end half-adder;

architecture adder of half-adder is

begin

process(A, B)

begin

Sum <= A xor B after 10 ns; -- Signal-assignment statement 1

Cout <= A and B after 10 ns; -- Signal-assignment statement 2  
-- with 10 nanoseconds delays.

end process;

end adder;

## ⇒ Gate Level / Structural Description

- In this VHDL description, the entity part is same as that of behavioral description. However, architecture part has two components: declaration and instantiation.
- In declaration part all different components used in the system description are declared. For example, following description declared AND gate component.

Component and2

port (I<sub>1</sub>, I<sub>2</sub>: in std-logic;

O<sub>1</sub>: out std-logic);

end component;

The and2 components has two inputs: I<sub>1</sub> and I<sub>2</sub> and one output O<sub>1</sub>.

- Once the component is declared we can use the same component one or more times in the system description.
- The instantiation part of the code maps the generic inputs/outputs to the actual inputs/outputs of the system.
- For example, the statement `and2 port map (A, B, Cout);` maps A to input  $I_1$  of and2, input B to input  $I_2$  of and2, and output Cout to output  $O_1$  of and2. This mapping means that the logic relationship between A, B and Cout is the same as between  $I_1$ ,  $I_2$  and  $O_1$ .

- VHDL half-adder description

**Ex**

```
library ieee;
```

```
use ieee.std_logic_1164.all;
```

```
entity xor2 is
```

```
port (I1, I2: in std_logic;
      O1 : out std_logic);
```

```
end xor2;
```

```
architecture xor_gate of xor2 is
```

```
begin
```

```
    O1 <= I1 xor I2;
```

```
end xor_gate;
```

```
library ieee;
```

```
use ieee.std_logic_1164.all;
```

```
entity and2 is
```

```
port (I1, I2: in std_logic; O1 : out std_logic);
```

```
end and2;
```

```
architecture and_gate of and2 is
```

```
begin
```

```
    O1 <= I1 and I2;
```

```
end and_gate;
```

library ieee;

use ieee.std\_logic\_1164.all;

entity half\_adder is

port (A, B: in std\_logic;

Sum, cout: out std\_logic);

end half\_adder;

architecture adder of half\_adder is

component xor2 is

port (I<sub>1</sub>, I<sub>2</sub>: in std\_logic;

O<sub>1</sub> : out std\_logic);

end component;

component and2 is

port (I<sub>1</sub>, I<sub>2</sub>: in std\_logic;

O<sub>1</sub> : out std\_logic);

end component;

begin

X<sub>1</sub>: xor2 port map (a, b, s);

A<sub>1</sub>: and2 port map (a, b, c);

end adder;

→ Structural description of 4-Bit Adder

4-Bit Binary Adder



entity Adder4;

architecture Structure of Adder4 is

component FullAdder

port ( $X, Y, Cin$ : in bit; - Inputs

$Cout, Sum$ : out bit); - Outputs

end component;

signal C: bit\_vector(3 downto 1);

begin - Instantiate four copies of the FullAdder

FA0: FullAdder port map (A(0), B(0), Ci, C(1), S(0));

FA1: FullAdder port map (A(1), B(1), C(1), C(2), S(1));

FA2: FullAdder port map (A(2), B(2), C(2), C(3), S(2));

FA3: FullAdder port map (A(3), B(3), C(3), Co, S(3));

end Structure;

add list A B C<sub>0</sub> C<sub>1</sub> S

- put these signals on the output line

force A

- set the A inputs to 1111

force B 0001

- set the B inputs to 0001

force Ci 1

- set Ci to 1

run 50 ns

- run the simulation for 50ns

force Ci 0

force A 0101

force B 1110

run 50ns