

# Design Examples

ELEC 418  
Advanced Digital Systems  
Dr. Ron Hayne

*Images Courtesy of Thomson Engineering*

# BCD to 7-Segment Display



**FIGURE 4-2:**  
**Seven-Segment**  
**Display**



# BCD to 7-Segment Display

```
entity BCD_Seven is
    port(BCD: in std_logic_vector(3 downto 0);
         Seven: out std_logic_vector(7 downto 1));
end BCD_Seven;

architecture Behave of BCD_Seven is
begin
    process(BCD)
    begin
```

# BCD to 7-Segment Display

```
case BCD is
    when "0000" => Seven <= "0111111";
    when "0001" => Seven <= "0000110";
    when "0010" => Seven <= "1011011";
    when "0011" => Seven <= "1001111";
    when "0100" => Seven <= "1100110";
    when "0101" => Seven <= "1101101";
    when "0110" => Seven <= "1111101";
    when "0111" => Seven <= "0000111";
    when "1000" => Seven <= "1111111";
    when "1001" => Seven <= "1101111";
    when others => null;
end case;
end process;
end Behave;
```

# Synchronization & Debouncing

**FIGURE 4-22:**  
**Debouncing**  
**Mechanical**  
**Switches**



(a) Switch bouncing



(b) Debouncing and synchronizing circuit



(a) Switch bouncing



(b) Debouncing and synchronizing circuit

**FIGURE 4-22:**  
**Debouncing**  
**Mechanical**  
**Switches**

# Single Pulser



# Behavioral Model

```
entity PULSE is
    port(SW, CLK: in std_logic;
         SP: out std_logic);
end PULSE;
architecture Behave of PULSE is
    signal Sync: std_logic_vector(2 downto 0) := "000";
begin
    process(CLK)
    begin
        if rising_edge(CLK) then
            Sync <= SW & Sync(2) & Sync(1);
        end if;
    end process;
    SP <= Sync(1) and not Sync(0);
end Behave;
```

# VHDL Test Bench

```
entity Pulse_Test is
end Pulse_Test;

architecture Behave of Pulse_Test is
    component PULSE
        port(SW, CLK: in std_logic;
             SP: out std_logic);
    end component;
    signal SW, CLK: std_logic := '0';
    signal SP: std_logic;
    constant CLK_period: time := 100 ns;
begin
    uut: PULSE port map(SW, CLK, SP);
```

# VHDL Test Bench

```
tb : process
begin
    wait for 48 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0'; wait for 1 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0'; wait for 1 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0'; wait for 1 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0'; wait for 1 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0'; wait for 1 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0'; wait for 1 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0'; wait for 1 ns;
    SW <= '1'; wait for 1 ns;
    SW <= '0';
    wait;
end process;
end;
```

# VHDL Simulation



# VHDL Simulation



# Adders

- ◆ **Ripple-Carry Adder**
  - Concatenation of Full Adders
- ◆ **Carry Look-Ahead Adder**
  - Fast Adder
    - Carry signals calculated in advance
- ◆ **Serial Adder**
  - Single Full Adder
    - Shift and add one bit at a time

# Ripple-Carry Adder



# Carry Look-Ahead Adder



# Carry Look-Ahead (CLA)

$$S_i = A_i \oplus B_i \oplus C_i$$

$$C_{i+1} = A_i B_i + (A_i \oplus B_i) C_i$$

$$G_i = A_i B_i \quad \text{Generate (both 1)}$$

$$P_i = A_i \oplus B_i \quad \text{Propagate (either 1)}$$

$$S_i = P_i \oplus C_i$$

$$C_{i+1} = G_i + P_i C_i$$

# 4-bit CLA Adder

$$C_1 = G_0 + P_0 C_0$$

$$C_2 = G_1 + P_1 C_1 = G_1 + P_1 G_0 + P_1 P_0 C_0$$

$$C_3 = G_2 + P_2 C_2 = G_2 + P_2 G_1 + P_2 P_1 G_0 + P_2 P_1 P_0 C_0$$

$$C_4 = G_3 + P_3 C_3 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 G_0 + P_3 P_2 P_1 P_0 C_0$$

- Limited by fan-in

# 16-bit CLA Adder



# 16-bit CLA Adder

```
entity CLA16 is
    port(A, B: in std_logic_vector(15 downto 0);
         Ci: in std_logic;
         S: out std_logic_vector(15 downto 0);
         Co, PG, GG: out std_logic);
end CLA16;
```

# 16-bit CLA Adder

```
architecture Structure of CLA16 is
component CLA4
    port(A, B: in std_logic_vector(3 downto 0);
        Ci: in std_logic;
        S: out std_logic_vector(3 downto 0);
        Co, PG, GG: out std_logic);
end component;
component CLALogic is
    port(G, P: in std_logic_vector(3 downto 0);
        Ci: in std_logic;
        C: out std_logic_vector(3 downto 1);
        Co, PG, GG: out std_logic);
end component;
```

# 16-bit CLA Adder

```
signal G, P: std_logic_vector(3 downto 0);
signal C: std_logic_vector(3 downto 1);
begin
    CarryLogic: CLALogic port map(G, P, Ci, C, Co, PG,
                                   GG);
    ADD0: CLA4 port map(A(3 downto 0), B(3 downto 0), Ci,
                         S(3 downto 0), open, P(0), G(0));
    ADD1: CLA4 port map(A(7 downto 4), B(7 downto 4),
                         C(1), S(7 downto 4), open, P(1), G(1));
    ADD2: CLA4 port map(A(11 downto 8), B(11 downto 8),
                         C(2), S(11 downto 8), open, P(2), G(2));
    ADD3: CLA4 port map(A(15 downto 12), B(15 downto 12),
                         C(3), S(15 downto 12), open, P(3), G(3));
end Structure;
```

# Behavioral Model

```
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;

entity Adder_Behave16 is
    Port ( A : in  std_logic_vector (15 downto 0);
           B : in  std_logic_vector (15 downto 0);
           Ci : in  std_logic;
           S : out std_logic_vector (15 downto 0);
           Co : out std_logic);
end Adder_Behave16;
```

# Behavioral Model

```
architecture Behave of Adder_Behave16 is
    signal sum17: std_logic_vector(16 downto 0);
begin
    sum17 <= ('0' & A) + ('0' & B) + (x"0000" & Ci);
    S <= sum17(15 downto 0);
    Co <= sum17(16);
end Behave;
```

# FPGA Synthesis Results

| Adder Type                    | Ripple-Carry | CLA  | Behavioral |
|-------------------------------|--------------|------|------------|
| Number of LUTs                | 32           | 65   | 16         |
| Combinational Path Delay (ns) | 22.7         | 12.5 | 7.6        |
| Levels of Logic               | 18           | 9    | 19         |

# Serial Adder



# Adder Comparison

| Adder size | Ripple-Carry<br>Adder Delay | CLA Delay         | Serial Adder<br>Delay |
|------------|-----------------------------|-------------------|-----------------------|
| 4 bit      | $8t_g$                      | $5\text{--}6t_g$  | $16t_g$               |
| 16 bit     | $32t_g$                     | $7\text{--}8t_g$  | $64t_g$               |
| 32 bit     | $64t_g$                     | $9\text{--}10t_g$ | $128t_g$              |
| 64 bit     | $128t_g$                    | $9\text{--}10t_g$ | $256t_g$              |

# Data Path and Controller



# Add-and-Shift Multiplier

- ◆ 4-bit Multiplicand
- ◆ 4-bit Multiplier
- ◆ 8-bit Product
- ◆ 4-bit Adder
- ◆ Controller

# Add-and-Shift Multiplier



# Multiplier Control



# Behavioral Model

```
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;

entity Mult4X4 is
    port(Clk, St: in std_logic;
        Mplier, Mcand: in std_logic_vector(3 downto 0);
        Product: out std_logic_vector(7 downto 0);
        Done: out std_logic);
end Mult4X4;
```

# Behavioral Model

```
architecture Behave of Mult4X4 is
    signal State: integer range 0 to 9;
    signal ACC: std_logic_vector(8 downto 0);
    alias M: std_logic is ACC(0); -- bit 0 of ACC
begin
    process(Clk)
    begin
        if rising_edge(CLK) then
            case State is
                when 0=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 1;
                    end if;
                when 1=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 2;
                    end if;
                when 2=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 3;
                    end if;
                when 3=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 4;
                    end if;
                when 4=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 5;
                    end if;
                when 5=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 6;
                    end if;
                when 6=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 7;
                    end if;
                when 7=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 8;
                    end if;
                when 8=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 9;
                    end if;
                when 9=>
                    if St='1' then -- Load
                        ACC(8 downto 4) <= "00000";
                        ACC(3 downto 0) <= Mplier;
                        State <= 0;
                    end if;
            end case;
        end if;
    end process;
end architecture;
```

# Behavioral Model

```
when 1 | 3 | 5 | 7 =>
    if M = '1' then -- Add
        ACC(8 downto 4) <= '0' & ACC(7 downto 4)
                                + Mcand;
        State <= State + 1;
    else -- Shift
        ACC <= '0' & ACC(8 downto 1);
        State <= State + 2;
    end if;
```

# Behavioral Model

```
when 2 | 4 | 6 | 8 => -- Shift
    ACC <= '0' & ACC(8 downto 1);
    State <= State + 1;
when 9 =>          -- end of cycle
    State <= 0;
end case;
end if;
end process;
Done <= '1' when State = 9 else '0';
Product <= ACC(7 downto 0);
end Behave;
```

# VHDL Simulation



# FPGA Implementation

- ◆ **Xilinx Spartan3e**
  - 250K System Gates
  - 50 MHz Clock
- ◆ **ChipScope Pro**
  - Virtual Input/Output Core (VIO)
  - Integrated Logic Analyzer (ILA)
- ◆ **Real-Time Verification**
  - Captures On-chip Signals
  - Off-chip Analysis via JTAG Programming Cable

# VHDL Test Bench

```
entity testmult4x4 is
    port(CLK: in std_logic);
end testmult4x4;

architecture test1 of testmult4x4 is
component mult4x4
    port(Clk, St: in std_logic;
        Mplier, Mcand: in std_logic_vector(3 downto 0);
        Product: out std_logic_vector(7 downto 0);
        Done: out std_logic);
end component;
```

# VHDL Test Bench

```
component ila
    port(control: in std_logic_vector(35 downto 0);
         clk: in std_logic;
         trig0: in std_logic_vector(17 downto 0));
end component;

component vio
    port(control: in std_logic_vector(35 downto 0);
         clk: in std_logic;
         sync_in: in std_logic_vector(8 downto 0);
         sync_out: out std_logic_vector(8 downto 0));
end component;
```

# VHDL Test Bench

```
signal ...  
signal ...  
  
begin  
    mult1: mult4x4 port map(CLK, St, Mplier, Mcand,  
                            Product, Done);  
    i_ilab: ila port map(control0, clk, trig0);  
    i_vio: vio port map(control1, clk, sync_in,  
                        sync_out);
```

# VHDL Test Bench

```
trig0(17) <= st;
trig0(16 downto 13) <= Mplier;
trig0(12 downto 9) <= Mcand;
trig0(8 downto 1) <= Product;
trig0(0) <= Done;
sync_in(8 downto 1) <= Product;
sync_in(0) <= Done;
St <= sync_out(8);
Mplier <= sync_out(7 downto 4);
Mcand <= sync_out(3 downto 0);

end test1;
```

# ChipScope Pro Analyzer



# Array Multiplier

| $X_3$     | $X_2$     | $X_1$     | $X_0$     | Multiplicand       |
|-----------|-----------|-----------|-----------|--------------------|
| $Y_3$     | $Y_2$     | $Y_1$     | $Y_0$     | Multiplier         |
| $X_3 Y_0$ | $X_2 Y_0$ | $X_1 Y_0$ | $X_0 Y_0$ | Partial product 0  |
| $X_3 Y_1$ | $X_2 Y_1$ | $X_1 Y_1$ | $X_0 Y_1$ | Partial product 1  |
| $C_{12}$  | $C_{11}$  | $C_{10}$  |           | First row carries  |
| $C_{13}$  | $S_{13}$  | $S_{12}$  | $S_{11}$  | First row sums     |
| $X_3 Y_2$ | $X_2 Y_2$ | $X_1 Y_2$ | $X_0 Y_2$ | Partial product 2  |
| $C_{22}$  | $C_{21}$  | $C_{20}$  |           | Second row carries |
| $C_{23}$  | $S_{23}$  | $S_{22}$  | $S_{21}$  | Second row sums    |
| $X_3 Y_3$ | $X_2 Y_3$ | $X_1 Y_3$ | $X_0 Y_3$ | Partial product 3  |
| $C_{32}$  | $C_{31}$  | $C_{30}$  |           | Third row carries  |
| $C_{33}$  | $S_{33}$  | $S_{32}$  | $S_{31}$  | Third row sums     |
| $P_7$     | $P_6$     | $P_5$     | $P_4$     | Final product      |
|           |           |           | $P_3$     | $P_2$              |
|           |           |           |           | $P_1$              |
|           |           |           |           | $P_0$              |

# Array Multiplier



# VHDL Simulation



# Hardware Requirements

- ◆ **n-bit Multiplication (2n-bit Product)**
  - $n^2$  And Gates
  - $(n-1) \times n$ -bit Adders
- ◆ **16-bit Multiplication**
  - 256 And Gates
  - 15 x 16-bit Adders
- ◆ **32-bit Multiplication**
  - 1024 And Gates
  - 31 x 32-bit Adders

# Signed Multiplication

- ◆ **Signed Binary Fractions**
  - 2's Complement
  - S.XXX
    - $\pm . \frac{1}{2} \frac{1}{4} \frac{1}{8}$
- ◆ **Four Cases**
  - + +
  - - +
  - + -
  - - -

# 2's Complement Multiplier



# Multiplier Control



# Faster Multiplier



# Multiplier Control



# Behavioral Model

```
-- This VHDL model explicitly defines control signals

library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;

entity Mult2C is
port(CLK, St: in std_logic;
      Mplier, Mcand: in std_logic_vector(3 downto 0);
      Product: out std_logic_vector (6 downto 0);
      Done: out std_logic);
end Mult2C;
```

# Behavioral Model

```
architecture Behave2 of Mult2C is
    signal State, Nextstate: integer range 0 to 5;
    signal A, B, compout, addout:
        std_logic_vector(3 downto 0);
    signal AdSh, Sh, Load, Cm: std_logic;
    alias M: std_logic is B(0);
begin
    process(State, St, M)
begin
    Load <= '0';
    AdSh <= '0';
    Sh <= '0';
    Cm <= '0';
    Done <= '0';
```

# Behavioral Model

```
case State is
    when 0 =>
        if St = '1' then
            Load <= '1';
            Nextstate <= 1;
        else
            Nextstate <= 0;
        end if;
    when 1 | 2 | 3 => -- "add/shift" State
        if M = '1' then
            AdSh <= '1';
        else
            Sh <= '1';
        end if;
    Nextstate <= State + 1;
```

# Behavioral Model

```
when 4 =>          -- add complement if sign
    if M = '1' then
        Cm <= '1';
        AdSh <= '1';
    else
        Sh <= '1';
    end if;
    Nextstate <= 5;
when 5 =>
    Done <= '1';
    Nextstate <= 0;
end case;
end process;
```

# Behavioral Model

```
compout <= not Mcand when Cm = '1' else Mcand;  
addout <= A + compout + Cm;  
  
process(CLK)  
begin  
    if rising_edge(CLK) then  
        if Load = '1' then  
            A <= "0000";  
            B <= Mplier;  
        end if;  
        if AdSh = '1' then  
            A <= compout(3) & addout(3 downto 1);  
            B <= addout(0) & B(3 downto 1);  
        end if;  
    end if;  
end process;
```

# Behavioral Model

```
if Sh = '1' then
    A <= A(3) & A(3 downto 1);
    B <= A(0) & B(3 downto 1);
end if;
State <= Nextstate;
end if;
end process;
Product <= A(2 downto 0) & B;
end ehave2;
```

# Test Bench



```
constant Mcandarr: arr :=
(  "0100",    "1100",    "1100",    "0010",    "0010" );
constant Mplierarr: arr :=
(  "0110",    "0110",    "1010",    "0101",    "1011" );
constant Productarr: arr2 :=
("0011000", 1101000", "0011000", "0001010", "1110110");
```

# Test Bench

```
stim_proc: process
begin
    for i in 1 to N loop
        Mcand <= Mcandarr(i);
        Mplier <= Mplierarr(i);
        St <= '1';
        wait until rising_edge(CLK);
        St <= '0';
        wait until falling_edge(Done);
        assert Product = Productarr(i)
            report "Incorrect Product"
            severity error;
    end loop;
    report "TEST COMPLETED";
end process;
```

# VHDL Simulation



# FPGA Implementation

- ◆ **Xilinx Spartan3e**
  - 250K System Gates
  - 50 MHz Clock
- ◆ **ChipScope Pro**
  - Virtual Input/Output Core (VIO)
  - Integrated Logic Analyzer (ILA)
- ◆ **Real-Time Verification**
  - Captures On-chip Signals
  - Off-chip Analysis via JTAG Programming Cable

# Summary

- ◆ **Design Examples**
  - BCD to 7-Segment Display
  - Adders
  - Multipliers
- ◆ **VHDL Models**
- ◆ **VHDL Test Benches**
- ◆ **FPGA Implementations**
  - ChipScope Pro