# Set-Reset (SR) Latch

Asynchronous

Level sensitive

cross-coupled Nor gates

active high inputs (only one can be active)



| S | R | Q <sup>+</sup> | Q <sup>+</sup> | Function               |
|---|---|----------------|----------------|------------------------|
| О | О | Q              | ЮI             | Storage State          |
| 0 | 1 | О              | 1              | Reset                  |
| 1 | 0 | 1              | Ο              | Set                    |
| 1 | 1 | 0-?            | 0-?            | Indeterminate<br>State |

cross-coupled Nand gates
active low inputs (only one can be active)



| S | R | Q+  | Q <sup>+</sup> | Function               |
|---|---|-----|----------------|------------------------|
| 0 | 0 | 1-? | 1-?            | Indeterminate<br>State |
| 0 | 1 | 1   | Ο              | Set                    |
| 1 | O | О   | 1              | Reset                  |
| 1 | 1 | Q   | $\overline{Q}$ | Storage State          |

# **Enabled Set-Reset (SR) Latch**

Asynchronous

Level sensitive

cross-coupled Nor gates active high inputs (S & R cannot be active)



| Е | S | R | Q+  | Q+             | Function               |
|---|---|---|-----|----------------|------------------------|
| 0 | X | X | Q   | Q              | Storage State          |
| 1 | 0 | 0 | Q   | $\overline{Q}$ | Storage State          |
| 1 | 0 | 1 | 0   | 1              | Reset                  |
| 1 | 1 | 0 | 1   | 0              | Set                    |
| 1 | 1 | 1 | 0-? | 0-?            | Indeterminate<br>State |

cross-coupled Nand gates active low inputs (S & R cannot be active)



| E | S | R | Q+  | Q+             | Function               |
|---|---|---|-----|----------------|------------------------|
| 0 | 0 | О | 1-? | 1-?            | Indeterminate<br>State |
| 0 | 0 | 1 | 1   | 0              | Set                    |
| О | 1 | 0 | 0   | 1              | Reset                  |
| 0 | 1 | 1 | Q   | $\overline{Q}$ | Storage State          |
| 1 | X | X | Q   | $\overline{Q}$ | Storage State          |

### **Transparent D Latch**

Asynchronous
Level sensitive
cross-coupled Nor gates
active high enable (E)



| E | D | Q <sup>+</sup> | <b>Function</b>  |
|---|---|----------------|------------------|
| 0 | X | Q              | Storage State    |
| 1 | 0 | 0              | Transparent Mode |
| 1 | 1 | 1              | Transparent Mode |

cross-coupled Nand gates active low enable (E)



| Е | D | Q <sup>+</sup> | Function         |
|---|---|----------------|------------------|
| 1 | X | Q              | Storage State    |
| О | 0 | 0              | Transparent Mode |
| О | 1 | 1              | Transparent Mode |

#### D Flip-Flop

Synchronous (also know as Master-Slave FF)

Edge Triggered (data moves on clock transition)

one latch transparent - the other in storage

active low latch followed by active high latch

positive edge triggered (rising edge of CK)



active high latch followed by active low latch negative edge triggered (falling edge of CK)



C. E. Stroud, Dept. of ECE, Auburn Univ.

### **Timing Considerations**

- Set-up time  $(t_{su})$ = minimum time input data must be valid before active edge of clock
- Hold time  $(t_h)$ = minimum time input data must be held valid after active edge of clock
- Clock-to-output delay ( $t_{co}$ )= maximum time before output data is valid with respect to active edge of clock



Set-up <u>or</u> Hold Time violation => metastability (Q & Q go to intermediate voltage values which are <u>eventually</u> resolved to an unknown state)

Set-up & Hold Time violations in a vector set referred to as *clock-data races* 

# **Timing Considerations**

To verify that a sequential logic circuit will work at the specified clock frequency,  $f_{clk}$ , we must consider the clock period,  $T_p$ , the propagation delay,  $P_{del}$ , of the worst case path through the combinational logic, as well as  $t_{su}$  and  $t_{co}$  of the flip-flops such that the following relationship holds:

For paths from flip-flop outputs to flip-flop inputs:

$$1/f_{clk} = T_p \ge P_{del} + t_{co} + t_{su}$$

For paths from primary inputs to flip-flop inputs:

$$1/f_{clk} = T_p \ge P_{del} + t_{su}$$

For paths from flip-flop outputs to primary outputs:

$$1/f_{clk} = T_p \ge P_{del} + t_{co}$$

For paths from primary inputs to primary outputs:

$$1/f_{clk} = T_p \ge P_{del}$$

Timing analysis and timing simulation CAD tools are typically used for this verification.

#### **Good Design Practices**

Use single clock, single edge synchronous design techniques as much as possible

Asynchronous interfaces lead to metastability (minimize the async interface & double clock data to reduce probability of metastability)

Avoid asynchronous presets & clears on FFs (use sync presets & clears whenever possible)

DO NOT construct a FF from two level sensitive latches of the same type with an inverter on the clock input to one latch



DO NOT gate clocks!!!

Create clock enabled FFs via a MUX to feed back current data



Active high clock enable (CEN)