

# **CheatSheet Digital Design**

Fs 2025 – Prof. Dr. Paul Zbinden Autoren: Ricca Aaron

V 1.0June 13, 2025

https://github.com/Rin-Ha-n/DigDes

## 1 Introduzione

## 1.1 Scelta/caratteristiche dei componenti





## 1.2 Guida al design

- 1. Design / Entry
- 2. Funktionale Simulation
- 3. Synthese
- 4. Implementierung
  - Logikoptimierung
  - Platzierung
  - Verdrahtung
- 5. Timing Simulation
- 6. Statische Timing Analyse
- 7. Herstellungsdatenerzeugen



# 1.3 Bubble diagram

- Bolle: Ogni bolla rappresenta uno stato
- Freccie: Condizione per passare da uno stato all'altro dev'essere scritta accanto alla freccia.
- Moore: Gli output sono associati agli stati, quindi scritti dentro a quest'ultimi.
- Melay: Gli output sono associati alle transizioni, quindi scritti accanto alle frecce.



# 2 Programmazione VHDL

## 2.1 Library

Una libreria puo contenere componenti e o pachetti. I componenti sono descrizione di circuiti e realizzazione specifiche, vengono memorizzati nella libreria in modo da poter essere riutilizati piu volte e da piu progettisti contemporaneamente.

I blocchi di codice di una libreria sono memorizzati in forma compilata, direttamente eseguibile.

Contenuto di una libreria: Components, Packages, Functions, Procedures, Declarations.

```
library ieee;
use ieee.std_logic_1164.all; -- CPP: using namespace std;
use ieee.numeric_std.all; -- Solo per operazioni aritmetiche per vettori
```

L'entità descrive il componente del progetto. In primo luogo l'entità descrive l'interfaccia (schnittstelle) del componente.

## 2.2 entity

L'architettura descrive il comportamento del componente, come funziona e come è realizzato.

#### 2.3 architecture

```
architecture <architecture_type> of <entity_name> is
[type_declaration]
[subtype_declaration]
[constant_declaration]
[signal_declaration]
[component_declaration]
begin
-- codice di architettura
end <architecture_type>;
```

# 2.4 Port mapping

Il port mapping è utilizzato per collegare le porte dell'entità con i segnali dell'architettura.

architecture structural of half\_adder is

#### 2.4.1 Esempio

```
component xor2
    port (
       in1, in2 : in bit;
       oup
               : out bit
    );
end component;
component and2
    port (
       in1, in2 : in bit;
       quo
end component;
-- instantiation of ocmponents XOR2 and AND2
-- Mappatura esplicita
U1 : xor2
    port map (
       in1 => q,
       in2 \Rightarrow p,
       oup => s
   );
-- Mappatura implicita
    port map (p, q, s) -- L'ordine delle porte segue quello della dichiarazione del

→ componente!
```

#### 2.5 component

I componenti sono utilizzati per definire le porte di un'entità, in modo da poterla utilizzare in altre entità.

#### 2.6 Processi

I processi sono sezioni di codice che vengono eseguite ogni volta che un Segnale sensibile nella lista sensibile cambia di stato.

## **2.7** Tipi

- <architecture type> = Behavioral | Structural | RTL | Dataflow | Tb
- <mode> = in|out|inout
- <type> = bit | bit\_vector | std\_ulogic | std\_ulogic\_vector | integer | boolean

#### 2.7.1 <architecture\_type>

**Behavioral**: si occupa di descrivere il comportamento del circuito, senza preoccuparsi della struttura fisica. Alto livello di astrazione.

**Structural**: si occupa di descrivere la struttura fisica del circuito, utilizzando componenti e connessioni tra di essi. Medio livello di astrazione.

```
1 U1: and_gate port map (A => A, B => B, Y => Y1);
2 U2: or_gate port map (A =1, B => C, Y => Y);
```

**RTL**: si occupa di descrivere il circuito a livello di registro e logica combinatoria, utilizzando registri e porte logiche. Basso livello di astrazione.

```
1 if rising_edge(clk) then
2    reg1 <= A and B;
3    reg2 <= reg1 xor C;
4 end if;</pre>
```

**Dataflow**: si occupa di descrivere il circuito a livello di flusso di dati, utilizzando porte logiche e segnali. Basso livello di astrazione.

```
I Y <= (A and B) or (not C);
```

**Tb**: si occupa di descrivere il circuito a livello di testbench, utilizzando segnali di test e componenti di test.

```
1 A <= '0'; wait for 10 ns;
2 A <= '1'; wait for 10 ns;
3 assert (Y = expected_value) report "Test failed" severity error;
```

## 2.7.2 <type>

- bit: rappresenta un singolo bit, con valori '0' e '1'.
- bit\_vector: rappresenta un vettore di bit, con valori '0' e '1'.

  | signal B : bit\_vector(7 downto 0); -- vettore di 8 bit
- std\_logic: rappresenta un singolo bit con valori '0', '1'.

  | signal C : std\_logic;
- std\_logic\_vector: rappresenta un vettore di std\_logic, con valori '0', '1'.

  | signal D : std\_logic\_vector(7 downto 0);
- std\_ulogic: rappresenta un singolo bit con valori '0', '1', 'Z' (alta impedenza) e 'X' (indeterminato).
   signal E: std\_ulogic;
- std\_ulogic\_vector: rappresenta un vettore di std\_ulogic, con valori '0', '1'
   'Z' e 'X'.
   signal F : std\_ulogic\_vector(7 downto 0);
- integer: rappresenta un numero intero, con valori compresi tra -2<sup>31</sup> e 2<sup>31</sup> -1
   (è necessario definire l'intervallo di utilizzo).
   signal 6: integer range 0 to 255; -- intervallo di utilizzo
- boolean: rappresenta un valore booleano, con valori true e false.

  | signal H : boolean; -- true or false

# 2.8 Nebenläufige Signalzuweisungen

#### 2.8.1 Unbedingte Signalzuweisung

L'assegnazione dei segnali é incondizionale, é sempre ugale alla stessa cosa.

```
1 y <= '0';
2 y <= a and b;
```

## 2.8.2 Bedingte Signalzuweisung

L'assegnazione dei segnali é eseguita in modo sequenziale, si controlla una condizione e se corretta si assegna il valore, sennó si procede con la prossima condizione.

```
1 y <= '0' when a = '1' else
2 '1' when a = '0';
```

#### 2.8.3 Selektive Signalzuweisung

L'assegnazione dei segnali é eseguita in modo selettivo, viene selezionata il valore in base alla condizione.

```
1 with s seelct y <=
2 '0' when "00",
3 '1' when "01",
4 'Z' when "10",
5 'X' when others;</pre>
```

#### 2.8.4 Bedingte Signalzuweisung

L'aggregazione dei segnali permette di aggregare segnali individuali in un unico segnale

#### 2.8.5 concatenate

La concatenazione dei segnali permette di concatenare segnali in un unico segnale.

1 y <= v\_1 & v\_2;

Eingänge

present\_state

#### 3 State machine

Le **Finite State Machine** (FSM) sono macchine a base di circuiti logici sequenzali.

Sono in grado quindi di eseguire operazioni logiche e di poterle memorizzare in modo da consegnare in uscita una funzione che non solo è dipendente dagli Input attuali ma anche (o solo) dallo stato attuale (memorizzato con gli input precedenti).

Le tre alternative proposte di seguito sono delle possibilità di incapsulamento standardizzato della funzione desiderata, qualunque essa sia.

Cit. Alessio Ciceri

## 3.1 Medwedjew

Composta da una un blocco di logica combinatoria(G) che risolve la funzione desiderata e da un blocco di memoria(Z) che memorizza gli stati.

- => Gli Input e lo stato attuale della FSM vengono processati da una logica combinatoria(G)
- => Il risultato della logica viene memorizzato nella Zustandspeicher(Z)
- => L'uscita è esattamente la copia di tutti gli stati memorizzati(s).



Kombina-

torische

Schaltung

Zustands-

speicher

clk rst

Ausgänge

next state

#### 3.2 Moore

Come Medwedjew ma con una logica dedicata sul ramo di output(s).

Tipicamente utile per output più complessi/numerosi rispetto agli stati memorizzati( $k \neq n$ ).

- => logica combinatoria aggiuntiva sul ramo d'uscita (F)
- => Più efficiente di Medwedjew per la memorizzazione degli stati



## 3.3 Mealv

Si tratta della Versione Moore dove la logica sul ramo d'uscita è dipendente anche a segnali provenienti direttamente dagli input della FSM

- => Necessaria se y dipende asincronamente da delle entrate
- => Più complessa, spesso riducibile a Moore



## 3.4 Codice scheletro FSM (G,Z,F)

```
2 G: process(present_state, inputs)
  begin
      next_state <= de fault_state;
         case present state is
              when X state =>
                 next_state <= Y_state;
              when others =>
                 next_state <= R_state;
      end case:
  end process:
13 Z: process(clk)
  begin
      if clk'event and clk = '1' then
          if reset = '1' then
             present_state <= reset_state;
             present_state <= next_state;
          end if;
      end if:
  end process;
24 F: process(present_state, )
25 begin
      oup <= default_value;
      case present_state is
          when X state =>
             oup <= "1001":
          when others =>
             oup <= "1111";
      end case;
  end process;
```

# 3.5 Codifica degli stati

Gli stati di una FSM possono essere codificati in diversi modi, tra cui:

- Codifica binaria: ogni stato è rappresentato da un codice binario unico.
- Codifica Gray: simile alla codifica binaria, ma le transizioni tra stati adiacenti cambiano solo un bit alla volta.

- Codifica one-hot: ogni stato è rappresentato da un bit attivo, con tutti gli altri bit a zero
- Codifica one-cold: simile alla codifica one-hot, ma solo un bit è a zero e tutti gli altri sono attivi.