

# **CprE 281: Digital Logic**

**Instructor: Alexander Stoytchev** 

http://www.ece.iastate.edu/~alexs/classes/

## D Flip-Flops

CprE 281: Digital Logic Iowa State University, Ames, IA Copyright © Alexander Stoytchev

### **Quick Review**







### **Basic Latch**







### A memory element with NOR gates



#### Two Different Ways to Draw the Same Circuit





#### Circuit and Characteristic Table for the Basic Latch



| S | R | $Q_a$ | $Q_b$ | _           |
|---|---|-------|-------|-------------|
| 0 | 0 | 0/1   | 1/0   | (no change) |
| 0 | 1 | 0     | 1     |             |
| 1 | 0 | 1     | 0     |             |
| 1 | 1 | 0     | 0     |             |

(b) Characteristic table

#### Timing Diagram for the Basic Latch with NOR Gates



(c) Timing diagram

[ Figure 5.4 from the textbook ]

## **Gated SR Latch**

#### **Motivation**

- The basic latch changes its state when the input signals change
- It is hard to control when these input signals will change and thus it is hard to know when the latch may change its state.
- We want to have something like an Enable input
- In this case it is called the "Clock" input because it is desirable for the state changes to be synchronized

#### Circuit Diagram for the Gated SR Latch



#### Circuit Diagram for the Gated SR Latch



This is the "gate" of the gated latch

#### Circuit Diagram for the Gated SR Latch



Notice that these are complements of each other

## Circuit Diagram and Characteristic Table for the Gated SR Latch



| Clk | S | R | Q(t+1)           |
|-----|---|---|------------------|
| 0   | x | x | Q(t) (no change) |
| 1   | 0 | 0 | Q(t) (no change) |
| 1   | 0 | 1 | 0                |
| 1   | 1 | 0 | 1                |
| 1   | 1 | 1 | х                |
|     |   |   |                  |

## Circuit Diagram and Graphical Symbol for the Gated SR Latch



#### Timing Diagram for the Gated SR Latch



[ Figure 5.5c from the textbook ]





In this case the "gate" is constructed using NAND gates! Not AND gates.



Also, notice that the positions of S and R are now swapped.



Finally, notice that when Clk=1 this turns into the basic latch with NAND gates, i.e., the  $\overline{SR}$  Latch.



#### Gated SR latch with NAND gates





#### Gated SR latch with NAND gates





| Clk | S | R | Q(t+1)           |
|-----|---|---|------------------|
| 0   | х | x | Q(t) (no change) |
| 1   | 0 | 0 | Q(t) (no change) |
| 1   | 0 | 1 | 0                |
| 1   | 1 | 0 | 1                |
| 1   | 1 | 1 | x (undesirable)  |
|     |   |   |                  |

#### Gated SR latch with NAND gates



| Clk | S | R | Q(t+1)           |
|-----|---|---|------------------|
| 0   | x | x | Q(t) (no change) |
| 1   | 0 | 0 | Q(t) (no change) |
| 1   | 0 | 1 | 0                |
| 1   | 1 | 0 | 1                |
| 1   | 1 | 1 | x (undesirable)  |
|     |   |   |                  |

Characteristic tables are the same

### **Gated D Latch**

#### **Motivation**

- Dealing with two inputs (S and R) could be messy.
   For example, we may have to reset the latch before some operations in order to store a specific value but the reset may not be necessary depending on the current state of the latch.
- Why not just have one input and call it D.
- The D latch can be constructed using a simple modification of the SR latch.

#### Circuit Diagram for the Gated D Latch



#### Circuit Diagram for the Gated D Latch



This is the only new thing here.

## Circuit Diagram and Characteristic Table for the Gated D Latch



| Clk    | D      | Q(t+1)        |
|--------|--------|---------------|
| 0<br>1 | x<br>0 | Q( <i>t</i> ) |
| 1      | 1      | 1             |

Note that it is now impossible to have S=R=1.

## Circuit Diagram and Characteristic Table for the Gated D Latch



| Clk | D | Q(t+1) |
|-----|---|--------|
| 0   | X | Q(t)   |
| 1   | 0 | 0      |
| 1   | 1 | 1      |

When Clk=1 the output follows the D input. When Clk=0 the output cannot be changed.

## Circuit Diagram and Graphical Symbol for the Gated D Latch



### Timing Diagram for the Gated D Latch





[ Figure 5.7d from the textbook ]

### Setup and hold times



Setup time  $(t_{su})$  – the minimum time that the D signal must be stable prior to the negative edge of the Clock signal

Hold time  $(t_h)$  – the minimum time that the D signal must remain stable after the negative edge of the Clock signal

## **Master-Slave D Flip-Flop**

Master Slave

(Data)

Clk

R

Q

Clk

Q

Clk

Q

Clk

R

R







# Constructing a Master-Slave D Flip-Flop From one D Latch and one Gated SR Latch

(This version uses one less NOT gate)

Master Slave

(Data)

Clk

R

# Constructing a Master-Slave D Flip-Flop From one D Latch and one Gated SR Latch

(This version uses one less NOT gate)



## **Edge-Triggered D Flip-Flops**

### **Motivation**

In some cases we need to use a memory storage device that can change its state no more than once during each clock cycle.

## **Master-Slave D Flip-Flop**



### Timing Diagram for the Master-Slave D Flip-Flop



### **Graphical Symbol for the Master-Slave D Flip-Flop**



### Graphical Symbol for the Master-Slave D Flip-Flop



The > means that this is edge-triggered

The small circle means that is is the negative edge

#### Negative-Edge-Triggered Master-Slave D Flip-Flop



### Positive-Edge-Triggered Master-Slave D Flip-Flop



#### Negative-Edge-Triggered Master-Slave D Flip-Flop



### Positive-Edge-Triggered Master-Slave D Flip-Flop



# Other Types of Edge-Triggered D Flip-Flops



# Comparison of level-sensitive and edge-triggered D storage elements





## Comparison of level-sensitive and edge-triggered D storage elements

Level-sensitive (the output mirrors the D input when Clk=1)





## Comparison of level-sensitive and edge-triggered D storage elements

Positive-edge-triggered





### A positive-edge-triggered D flip-flop



[ Figure 5.11 from the textbook ]

### A positive-edge-triggered D flip-flop



[ Figure 5.11 from the textbook ]

### **Master-slave D flip-flop with Clear and Preset**



(a) Circuit



(b) Graphical symbol

[ Figure 5.12 from the textbook ]

# Positive-edge-triggered D flip-flop with Clear and Preset

## Positive-edge-triggered D flip-flop with Clear and Preset



## Positive-edge-triggered D flip-flop with Clear and Preset



(b) Graphical symbol

(c) Adding a synchronous clear

### Flip-Flop Timing Parameters



(a) D flip-flop with asynchronous clear



[ Figure 5.14 from the textbook ]

(b) Timing diagram

- Basic Latch is a feedback connection of two NOR gates or two NAND gates, which can store one bit of information. It can be set using the S input and reset to 0 using the R input.
- Gated Latch is a basic latch that includes input gating and a control input signal. The latch retains its existing state when the control input is equal to 0. Its state may be changed when the control signal is equal to 1.

- Two types of gated latches (the control input is the clock):
- Gated SR Latch uses the S and R inputs to set the latch to 1 or reset it to 0.
- **Gated D Latch** uses the D input to force the latch into a state that has the same logic value as the D input.

• Flip-Flop – is a storage element that can have its output state changed only on the edge of the controlling clock signal.

- Positive-edge triggered if the state changes when the clock signal goes from 0 to 1.
- Negative-edge triggered if the state changes when the clock signal goes from 1 to 0.

The word *latch* is mainly used for storage elements, while clocked devices are described as *flip-flops*.

A **latch** is level-sensitive, whereas a **flip-flop** is edge-sensitive. That is, when a latch is enabled it becomes transparent, while a flip flop's output only changes on a single type (positive going or negative going) of clock edge.

**Questions?** 

### THE END