# Sommatore a 3 input (v1)

Stefano Scarcelli & Michele De Fusco $01~{\rm Dic}~2023$ 

## Contents

| 1 | Ana | lisi progettuale       |
|---|-----|------------------------|
|   | 1.1 | Analisi preliminare    |
|   | 1.2 | Struttura del progetto |
| 2 | Imp | lementazione 3         |
|   | 2.1 | Adder n-bit            |
|   |     | 2.1.1 Codice VHDL      |
|   |     | 2.1.2 Sintesi          |
|   | 2.2 | Register n-bit         |
|   |     | 2.2.1 Codice VHDL      |
|   |     | 2.2.2 Sintesi          |
|   | 2.3 | Synched adder          |
|   |     | 2.3.1 Codice VHDL      |
|   |     | 2.3.2 Sintesi          |
|   | 2.4 | Three adder (main)     |
|   |     | 2.4.1 Codice VHDL      |
|   |     | 2.4.2 Sintesi          |
| 3 | Tes | ing 12                 |

## 1 Analisi progettuale

## 1.1 Analisi preliminare

L'obbiettivo è quello di costruire un circuito in grado di sommare 3 numeri a n-bit (2's complements) e restituirne il risultato. Sia gli input che gli output devono essere sincronizzati tramite l'uso di registri.

L'idea di base è quella di usare due **Ripple carry** parametrici in cascata tra di loro per eseguire il calcolo desiderato A + B + C = R.

## 1.2 Struttura del progetto

L'idea alla base dell'implementazione è quella di inserire in pipeline i due moduli **sommatori** per eseguire prima la somma A + B e successivamente (A + B) + C.

Questa implementazione porta all'inserimento di (in totale) di 6 **registri**, 2 in ingresso ad ogni adder, uno in aggiunta all'input C per salvare il risultato per la seconda operazione di somma e uno in uscita per salvare il risultato dell'operazione complessiva (richiesto dalle specifiche del progetto).

Il primo ritardo per riceve un risultato coerente è di 2 colpi di clock mentre il delay per ricevere i risultati successivi al primo è di solo 1 colpo di clock.

## 2 Implementazione

L'implementazione si basa sulla definizione di una struttura gerarchica di componenti, partendo dalla definizione comportamentale dei componenti elementari (Adder n-bit e Register n-bit) per poi andare a comporre (tramite 2 livelli di astrazione, Synched adder e in fine l'elemento principale Three adder (main)) la struttura del progetto.

#### 2.1 Adder n-bit

L'implementazione dell'Adder n-bit segue la descrizione comportamentale tramite Ripple carry parametrico usando i segnali propagate (P) e generate (G).

#### 2.1.1 Codice VHDL

```
-- Company: UNICAL
- Engineer: Michele De Fusco
-- Create Date: 04.12.2023 14:49:19
-- Design Name: -
-- Module Name: Adder - Version1
- Project Name: ThreeNumbersAdder
- Target Devices: xc7z020clg400-2
-- Tool Versions: 2023.2
-- Description: Parametric n-bit ripple carry adder
- Dependencies: None
-- Revision: 2
-- Revision 1.0 - Implementation
- Additional Comments: ---
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity Adder is
    generic (n : integer := 8);
    Port (A, B : in STD_LOGIC_VECTOR (n-1 downto 0);
           R : out STD_LOGIC_VECTOR (n downto 0));
end Adder;
architecture Version1 of Adder is
    signal p, g : STDLOGIC_VECTOR (n downto 0);
    signal carry : STDLOGIC_VECTOR (n+1 downto 0);
begin
    p \le (A(n-1) \text{ xor } B(n-1)) \& (A \text{ xor } B);
    g \le (A(n-1) \text{ and } B(n-1)) \& (A \text{ and } B);
    carry(0) <= '0';
    carry(n+1 \text{ downto } 1) \le g \text{ or } (p \text{ and } carry(n \text{ downto } 0));
    R \le p \text{ xor } carry(n \text{ downto } 0);
end Version1;
```

#### 2.1.2 Sintesi



Figure 1: Circuito di Adder.

## 2.2 Register n-bit

L'implementazione dell'**Register n-bit** segue la descrizione comportamentale classica con memorizzazione a *fronti di salita*.

Il **registro** implementa in più un segnale di *clear* (asincrono) attivo alto.

#### 2.2.1 Codice VHDL

```
-- Company: UNICAL
-- Engineer: Stefano Scarcelli
-- Create Date: 04.12.2023 14:57:11
-- Design Name: --
-- Module Name: Register_n - Version1
-- Project Name: ThreeNumbersAdder
-- Target Devices: xc7z020clg400-2
-- Tool Versions: 2023.2
-- Description: Parametric n-bit register
-- --
-- Dependencies: None
-- Revision: 1
-- Revision: 1 -- Implementation
-- Additional Comments: ---
```

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity Register_n is
    generic (n : integer := 8);
    Port (CLK, Clear : in STD_LOGIC;
          D: in STD_LOGIC_VECTOR (n-1 downto 0);
          Q : out STD_LOGIC_VECTOR (n-1 downto 0));
end Register_n;
architecture Version1 of Register_n is
begin
    process(CLK, Clear) begin
        if (Clear = '1') then
            Q \ll (others \Rightarrow '0');
        elsif rising_edge(CLK) then
            Q \leq D;
        end if;
    end process;
end Version1;
```

### 2.2.2 Sintesi



Figure 2: **Registro** a 8bit.

## 2.3 Synched adder

Questo è un componente intermedio che abbiamo impostato per poi costruire il circuito completo.

Consiste in un Adder n-bit con 2 registri collocati agli input di esso.

#### 2.3.1 Codice VHDL

```
-- Company: UNICAL
— Engineer: Stefano Scarcelli, Michele De Fusco
-- Create Date: 04.12.2023 15:31:55
— Design Name: —
-- Module Name: Synched_adder - Version1
-- Project Name: ThreeNumbersAdder
- Target Devices: xc7z020clq400-2
- Tool Versions: 2023.2
- Description: Adder with input registers
-- Dependencies: Adder.vhd, Register_n.vhd
-- Revision: 1
-- Revision 1.0 - Implementation
- Additional Comments: -
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity Synched_adder is
    generic (n : integer := 8);
    Port (A, B : in STD_LOGIC_VECTOR (n-1 downto 0);
          R : out STDLOGIC_VECTOR (n downto 0);
          CLK, Clear: in STD_LOGIC);
end Synched_adder;
architecture Version1 of Synched_adder is
    component Adder is
        generic (n : integer := 8);
        Port (A, B : in STD_LOGIC_VECTOR (n-1 downto 0);
             R : out STDLOGIC_VECTOR (n downto 0));
```

```
end component;
component Register_n is
    generic (n : integer := 8);
    Port (CLK, Clear : in STDLOGIC;
        D : in STDLOGIC_VECTOR (n-1 downto 0);
        Q : out STDLOGIC_VECTOR (n-1 downto 0));
end component;
signal Ra, Rb: STDLOGIC_VECTOR (n-1 downto 0);
begin
    RegA: Register_n generic map(n) port map(CLK, Clear, A, Ra);
RegB: Register_n generic map(n) port map(CLK, Clear, B, Rb);
Adder1: Adder generic map(n) port map(Ra, Rb, R);
end Version1;
```

#### 2.3.2 Sintesi



Figure 3: Circuito del Synched adder.

## 2.4 Three adder (main)

Il circuito finale comprende invece l'uso di 2 **Synched adder** e 2 **registri** aggiuntivi, uno collocato tra l'input C del circuito e il secondo ingresso del secondo **Synched adder** (usato come buffer per salvare il valore di C nella pipeline) e un'altro tra il risultato dell'operazione e l'output del circuito (come richiesto dalle specifiche del progetto).

#### 2.4.1 Codice VHDL

```
-- Company: UNICAL
-- Engineer: Stefano Scarcelli, Michele De Fusco
-- Create Date: 04.12.2023 15:46:04
-- Design Name: --
-- Module Name: Three_Adder - Version1
- Project Name: ThreeNumbersAdder
- Target Devices: xc7z020clg400-2
— Tool Versions: 2023.2
-- Description: Main file of the project
- Dependencies: Register_n.vhd, Synched_adder.vhd
-- Revision: 1
- Revision 0.01 - File Created
-- Additional Comments: ---
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity Three_Adder is
    generic (n : integer := 8);
    Port (A : in STD_LOGIC_VECTOR (n-1 downto 0);
          B: in STDLOGIC_VECTOR (n-1 \text{ downto } 0);
```

C: in STD\_LOGIC\_VECTOR (n-1 downto 0); R: out STD\_LOGIC\_VECTOR (n+1 downto 0);

CLK : in STD\_LOGIC;
Clear : in STD\_LOGIC);

end Three\_Adder;

```
architecture Version1 of Three_Adder is
    component Synched_adder
        generic (n : integer := 8);
        Port (
              A, B : in STDLOGIC-VECTOR (n-1 \text{ downto } 0);
              R : out STD_LOGIC_VECTOR (n downto 0);
              CLK, Clear : in STD_LOGIC);
    end component;
    component Register_n
        generic (n : integer := 8);
        Port (CLK, Clear : in STD_LOGIC;
              D: in STDLOGIC_VECTOR (n-1 downto 0);
              Q : out STD_LOGIC_VECTOR (n-1 downto 0));
    end component;
    component Adder
        generic (n : integer := 8);
        Port (A, B : in STD_LOGIC_VECTOR (n-1 downto 0);
              R : out STD_LOGIC_VECTOR (n downto 0));
    end component;
    signal Rc: STDLOGIC_VECTOR (n-1 downto 0);
    signal Rs,RCext: STDLOGIC_VECTOR (n downto 0);
    signal RSF: STD_LOGIC_VECTOR (n+1 downto 0);
begin
    RegC: Register_n generic map(n) port map(CLK, Clear, C, Rc);
          Synched_adder generic map(n) port map(A,B,Rs,CLK,Clear);
    SA1:
    RCext \leq Rc(n-1) \& Rc;
          Synched_adder generic map(n+1) port map(Rs, RCext, RSF, CLK, Clear);
    SA2:
    RegSF: Register_n generic map(n+2) port map(CLK, Clear, RSF, R);
end Version1;
```

## 2.4.2 Sintesi



Figure 4: Circuito principale.

# 3 Testing