



## **Latch sincroni e flip-flop**

Prof. Alberto Borghese  
Dipartimento Informatica  
[borghese@di.unimi.it](mailto:borghese@di.unimi.it)

Università degli Studi di Milano

Riferimento Patterson: sezioni B.7 & B.8.



## **Sommario**



**Latch sincroni SR**

**Latch sincroni D**

**Flip-flop**



## Latch asincrono SC (o SR)



S = set

C = clear (R = reset)

Una coppia di porte NOR retro-azionate può memorizzare un bit.



## Il latch SC sincrono



Latch a-sincrono

Si inserisce tra il clock e gli ingressi un AND che funge da interruttore.

If (CLK = H = 1) then  
 $S' = S; C' = C$



If (CLK = L = 0) then  
 $S' = C' = 0$



Solo quando il clock è alto i "cancelli" rappresentati dagli AND fanno passare gli input (collegano l'altro ingresso dell'AND con l'uscita). Cancelli di «abilitazione» del latch.

Latch asincrono, sincronizzato.



## Il latch sincrono nel tempo: clock basso



## Il latch sincrono SC - set









| T | S | C | Q | Q* |
|---|---|---|---|----|
| 0 | 0 | 0 | 0 | 0  |
| 0 | 0 | 0 | 1 | 0  |
| 0 | 0 | 1 | 0 | 0  |
| 0 | 0 | 1 | 1 | 0  |
| 0 | 1 | 0 | 0 | 1  |
| 0 | 1 | 0 | 1 | 1  |
| 0 | 1 | 1 | 0 | 1  |
| 0 | 1 | 1 | 1 | 1  |
| 1 | 0 | 0 | 0 | 0  |
| 1 | 0 | 0 | 1 | 1  |
| 1 | 0 | 1 | 0 | 0  |
| 1 | 0 | 1 | 1 | 0  |
| 1 | 1 | 0 | 0 | 1  |
| 1 | 1 | 0 | 1 | 1  |
| 1 | 1 | 1 | 0 | X  |
| 1 | 1 | 1 | 1 | X  |

A.A. 2024-2025

## Tabella della verità e tabella di transizione



| TQ | SC = 00 | SC = 01 | SC = 10 | SC = 11 |
|----|---------|---------|---------|---------|
| 00 | 0       | 0       | 0       | 0       |
| 01 | 1       | 1       | 1       | 1       |
| 10 | 0       | 0       | 1       | X       |
| 11 | 1       | 0       | 1       | X       |

$$Q^* = f(S, C, Q, T)$$

Q è l'uscita del latch: **stato presente**.

Q\* è il valore dell'uscita al tempo successivo: **stato prossimo**.

11/51

<http://borghese.di.unimi.it/>



| T | S | C | Q | Q*  |
|---|---|---|---|-----|
| 0 | 0 | 0 | 0 | 0   |
| 0 | 0 | 0 | 1 | 1   |
| 0 | 0 | 1 | 0 | 0   |
| 0 | 0 | 1 | 1 | 1   |
| 0 | 1 | 0 | 0 | 0   |
| 0 | 1 | 0 | 1 | 1   |
| 0 | 1 | 1 | 0 | 0   |
| 0 | 1 | 1 | 1 | 1   |
| 1 | 0 | 0 | 0 | 0   |
| 1 | 0 | 0 | 1 | 1   |
| 1 | 0 | 1 | 0 | 0   |
| 1 | 0 | 1 | 1 | 1   |
| 1 | 1 | 0 | 0 | X=0 |
| 1 | 1 | 0 | 1 | 1   |
| 1 | 1 | 1 | 0 | X=0 |
| 1 | 1 | 1 | 1 | X=0 |

A.A. 2024-2025

## Tabella della verità - I



$$Q^* = f(S, C, Q, T)$$

| TQ | SC = 00 | SC = 01 | SC = 10 | SC = 11 |
|----|---------|---------|---------|---------|
| 00 | 0       | 0       | 0       | 0       |
| 01 | 1       | 1       | 1       | 1       |
| 10 | 0       | 0       | 1       | X=0     |
| 11 | 1       | 0       | 1       | X=0     |

$$Q^* = \overline{TQSC} + \overline{TQSC}$$

$$\overline{TQSC} =$$

$$= \overline{TQC} + \overline{TQSC} + \overline{TQC} + \overline{TSC} =$$

$$= \overline{TQ} + \overline{TQSC} + \overline{TSC} =$$

$$TSC = 1 \rightarrow Q^* = 0$$

$$\begin{array}{l} \text{Status quo} \\ \text{Set} \end{array}$$

<http://borghese.di.unimi.it/>



## Circuito SOP semplificata



| TQ | SC = 00 | SC = 01 | SC = 10 | SC = 11 |
|----|---------|---------|---------|---------|
| 00 | 0       | 0       | 0       | 0       |
| 01 | 1       | 1       | 1       | 1       |
| 10 | 0       | 0       | 1       | X=0     |
| 11 | 1       | 0       | 1       | X=0     |

$$Q^* = \bar{T}Q + T(QSC + SC)$$



CC = 5 CO = 7

Più complesso!



CC = 3 CO = 4

calcoliamo anche  $\bar{Q}$



## Tabella della verità - II



| T | S | C | Q | Q*  |
|---|---|---|---|-----|
| 0 | 0 | 0 | 0 | 0   |
| 0 | 0 | 0 | 1 | 1   |
| 0 | 0 | 1 | 0 | 0   |
| 0 | 0 | 1 | 1 | 1   |
| 0 | 1 | 0 | 0 | 0   |
| 0 | 1 | 0 | 1 | 1   |
| 0 | 1 | 1 | 0 | 0   |
| 0 | 1 | 1 | 1 | 1   |
| 1 | 0 | 0 | 0 | 0   |
| 1 | 0 | 0 | 1 | 1   |
| 1 | 0 | 1 | 0 | 0   |
| 1 | 0 | 1 | 1 | 0   |
| 1 | 1 | 0 | 0 | 1   |
| 1 | 1 | 0 | 1 | 1   |
| 1 | 1 | 1 | 0 | X=1 |
| 1 | 1 | 1 | 1 | X=1 |

$$Q^* = f(S, C, Q, T)$$

| TQ | SC = 00 | SC = 01 | SC = 10 | SC = 11 |
|----|---------|---------|---------|---------|
| 00 | 0       | 0       | 0       | 0       |
| 01 | 1       | 1       | 1       | 1       |
| 10 | 0       | 0       | 1       | X=1     |
| 11 | 1       | 0       | 1       | X=1     |

$$Q^* = \overline{T}QSC + \overline{T}QSC + \overline{T}QSC + \overline{T}QSC + \overline{T}QSC + \overline{T}QSC +$$

$$+ \overline{T}QSC + \overline{T}QSC + \overline{T}QSC =$$

$$= \overline{T}QC + \overline{T}QSC + \overline{T}QC + \overline{T}SC + \overline{T}SC =$$

$$= \overline{T}Q + \overline{T}QSC + TS = \overline{T}Q + T(QSC + S)$$

Status quo  
(Memory)

Cf. Latch  
asincrono



## Latch sincrono



Latch attivo alto (commuta sul periodo alto del clock)



## Sommario



Latch sincroni SR

Latch sincroni D

Flip-flop



## Latch SC sincrono



Memorizza il valore presente all'ingresso dati quando il clock è alto.

if (CLK = 1)  
then  
 $Q^* = D$

If (CLK = 0)  
then  
 $Q^* = Q$



Latch trasparente sincrono

**Latch-D**



## La struttura del latch D (sincrono)



If (CLK==1)  
 $S' = D; C' = !D$   
 $Q^* = D$

If (CLK = 0)  
 $S' = C' = 0$   
 $Q^* = Q$





## Tabella delle transizioni



$$Q^* = f(T, Q, D)$$

| TQ | D = 0 | D = 1 |
|----|-------|-------|
| 00 | 0     | 0     |
| 01 | 1     | 1     |
| 11 | 0     | 1     |
| 10 | 0     | 1     |

Q è l'uscita del latch: **stato presente**.

Q\* è il valore dell'uscita al tempo successivo:  
**stato prossimo**.

**Clock = 0**

La funzione logica corrispondente è:

$$Q^* = TD + \bar{T}Q$$

$$Q^* = D$$

Status quo



$$Q^* = Q$$



## Tabella delle transizioni



$$Q^* = f(T, Q, D)$$

| TQ | D = 0 | D = 1 |
|----|-------|-------|
| 00 | 0     | 0     |
| 01 | 1     | 1     |
| 11 | 0     | 1     |
| 10 | 0     | 1     |

Q è l'uscita del latch: **stato presente**.

Q\* è il valore dell'uscita al tempo successivo:  
**stato prossimo**.

**Clock = 1**

La funzione logica corrispondente è:

$$Q^* = TD + \bar{T}Q$$

$$Q^* = D$$

Status quo



$$Q^* = D$$



## Tabella delle transizioni



$$Q^* = f(T, Q, D)$$

| TQ | D = 0 | D = 1 |
|----|-------|-------|
| 00 | 0     | 0     |
| 01 | 1     | 1     |
| 11 | 0     | 1     |
| 10 | 0     | 1     |

Q è l'uscita del latch: **stato presente**.

Q\* è il valore dell'uscita al tempo successivo:  
**stato prossimo**.

Come mai qui non si verifica la situazione S'=C'=1?

La funzione logica corrispondente è:

$$Q^* = TD + \bar{T}Q$$



## Tabella della verità



$$Q^* = f(T, Q, D)$$



$$Q^* = \bar{T} \bar{D} Q + \bar{T} D \bar{Q} + T D \bar{Q} + T D Q =$$

$$= \bar{T} Q + T D$$

Status  
quo

| T | D | Q | Q* |
|---|---|---|----|
| 0 | 0 | 0 | 0  |
| 0 | 0 | 1 | 1  |
| 0 | 1 | 0 | 0  |
| 0 | 1 | 1 | 1  |
| 1 | 0 | 0 | 0  |
| 1 | 0 | 1 | 0  |
| 1 | 1 | 0 | 1  |
| 1 | 1 | 1 | 1  |



## Ottimizzazione del circuito



Complessità 4  
Cammino critico 3



Clk come interruttore che pilota un mux:

$$Q^* = \bar{T} Q + T D$$



Complessità 3  
Cammino critico 2  
Circuito più semplice ma manca  $\bar{Q}$



## Elemento di memoria



T = segnale di scrittura -> segnale **Write** – attivo alto

$$Q^* = \bar{T} Q + T D$$

$Q^* = Q$   
Status Quo  
(memory)

Se  $W = 1$ , scrivo D  
Se  $W = 0$ , mantiene il dato  
in memoria

$$Q^* = D$$
  
(write)





## Elemento di memoria



Write può essere sincronizzato dal clock

$$Q^* = \overline{W} Q + W D$$

$$Q^* = Q \quad \text{Status Quo (memory)}$$

$$Q^* = D \quad (\text{write})$$



## I latch



Operazioni di Set/Reset



Operazioni di Set/Reset sincronizzate



Elemento di memoria



## Sommario



Latch sincroni SR

Latch sincroni D

**Flip-flop**



## I bistabili



- Elementi di memoria (latch)
  - Sincroni
  - A-sincroni
- “Cancelli” (flip-flop)



## Struttura di un circuito sequenziale



## Shift register



**Registro a scorrimento (shift register o barrel shifter).**

- Un unico ingresso I e un'unica uscita U.
- In presenza di un segnale attivo (clock alto), il contenuto viene spostato verso dx **di una posizione** (e.g. operazione di shift).
- Il valore contenuto nell'elemento più a dx dove va?
- Qual'è il problema con l'utilizzo dei latch sincroni?





## Shift register con i latch (i problemi)



$$U = Q_1$$

$$D_3 = I$$

$$D_2 = Q_3$$

$$D_1 = Q_2$$

Fotografiamo la situazione iniziale:

- Clock basso
- $Q_3 = Q_2 = Q_1 = 0$
- $D_3 = 0$
- $U = 0$
- $I = 0$



## Shift register con i latch (status quo)



$I = D_3$

$Q_3 = 0$

$Q_2 = 0$

$Q_1 = U = 0$





## Shift register con i latch (il problema)



L'ingresso  $I = D_3$  va a 1 – vorrei ottenere  $\{0\ 0\ 0\} \rightarrow \{1\ 0\ 0\}$ . Invece ottengo:  $\{0\ 0\ 0\} \rightarrow \{1\ 1\ 1\}$



## Dispositivo di sincronizzazione



Sistema di “chiuse”



## Flip-flop



Dispositivi attivi sul fronte (di salita o discesa) del clock (edge sensitive): il loro stato (uscita) può commutare solo in corrispondenza della transizione alto->basso o basso->alto del clock.



A.A. 2024-2025



## Flip-flop D



Due latch di tipo D, organizzati in cascata

A.A. 2024-2025

36/51

<http://borgheze.di.unimi.it/>



## Funzionamento del flip-flop D - flip



If (CLK = 1) il primo latch “vede” l’ingresso, D  
 $Q_m^* = D$

If (CLK = 1) il secondo latch è opaco: l’uscita rimane invariata  
 $Q^* = Q_s$



## Funzionamento del flip-flop D - flop



If (CLK = 0) il primo latch è opaco: l’uscita del primo latch rimane invariata  
 $Q_m^* = Q_m$

If (CLK = 0) il secondo latch porta l’uscita del master,  $Q_m$ , in uscita al dispositivo.  
 $Q = Q_s^* = Q_m$









# Configurazione master-slave



- Semi-periodo di clock alto:
  - Il master è trasparente: uscita del latch master = ingresso.
  - Lo slave è “opaco” -> mantiene l’uscita.
  - Lo slave è “disaccoppiato” dal latch master.
    - Master e slave possono avere uscita diversa
- Semi-periodo di clock basso:
  - Il master è opaco: l’uscita del latch master si mantiene.
  - Il master è “disaccoppiato” dall’ingresso esterno.
  - Lo slave è trasparente: uscita del latch slave = uscita del latch master.
    - Master e slave hanno la stessa uscita



# I bistabili



Latch SC asincrono (Set/Reset)



Latch SC sincrono (Set/Reset sincronizzato)



Clk

Latch D sincrono (Elemento di memoria)



Flip-flop di tipo D («cancello»)



## Struttura di un circuito sequenziale



Pone dei problemi di sincronizzazione: la logica combinatoria deve terminare la commutazione in tempo utile.



## Temporizzazione di un circuito sequenziale



- La logica ha tempo sufficiente per completare la commutazione.
- Il periodo di clock è tale, per cui la commutazione del clock avviene dopo che la logica combinatoria ha terminato tutte le commutazioni.
- Il tempo necessario alla logica combinatoria per commutare è  $\leq$  tempo associato al cammino critico.
- Il clock arriva contemporaneamente a tutti i dispositivi sincronizzati.



## Temporizzazione: problemi



L'input D deve essere stabile intorno alla commutazione del clock:

- **Tempo di hold ( $t_h$ ):** è il tempo minimo per cui deve rimanere stabile l'input D prima del fronte di clock (tempo di attraversamento delle porte del master).
- **Tempo di set-up ( $t_s$ ):** è il tempo minimo per cui deve rimanere stabile l'input D dopo il fronte di clock (tempo di attraversamento delle porte dello slave).



A.A. 2024-2025

49/51

**t**

<http://borghese.di.unimi.it/>



## Temporizzazione: Come si dimensiona il clock



**Tempo di propagazione:** è il tempo necessario per propagare il segnale nella logica combinatoria ( $t_p$ ). Il massimo tempo è rappresentato dal cammino critico.

**Tempo di skew:** ritardo massimo del clock ( $t_w$ ).

Tempo logica  
combinatoria ( $t_p$ )



A.A. 2024-2025

50/51

**t**

<http://borghese.di.unimi.it/>



# Sommario



Latch sincroni SR

Latch sincroni D

Flip-flop