# Design of Digital Circuits Lecture 7: Sequential Logic Design 

Prof. Onur Mutlu

ETH Zurich
Spring 2018
15 March 2018

## Readings

- Please study Slides 102-120 from Lecture 6 on your own
- This week
- Sequential Logic
- P\&P Chapter 3.4 until end $+\quad$ H\&H Chapter 3 in full
- Hardware Description Languages and Verilog
- H\&H Chapter 4 in full
- Timing and Verification
- H\&H Chapters 2.9 and $3.5+$ Chapter 5
- Next week
- Von Neumann Model, LC3, and MIPS
- P\&P Chapter 4-5 + H\&H Chapter 6
- Digital Building Blocks
- H\&H Chapter 5


## What We Will Learn Today

- Circuits that can store information
- R-S Latch
- Gated D Latch
- D Flip-Flop
- Register
- Finite State Machines (FSM)
- Moore Machine
- Mealy Machine
- Verilog implementations of sequential circuits

Circuits that Can
Store Information

## Introduction

- Combinational circuit output depends only on current input
- We want circuits that produce output depending on current and past input values - circuits with memory
- How can we design a circuit that stores information?


Basic Storage Element: The R-S Latch

## The R-S (Reset-Set) Latch

- The simplest implementation of the R-S Latch
- Two NAND gates with outputs feeding into each other's input
- Data is stored at $\mathbf{Q}$ (inverse at $\mathbf{Q}^{\prime}$ )
- $\mathbf{S}$ and $\mathbf{R}$ inputs are held at 1 in quiescent (idle) state
- $\mathbf{S}$ (set): drive $\mathbf{S}$ to 0 (keeping $\mathbf{R}$ at 1) to change $\mathbf{Q}$ to 1
- $\mathbf{R}$ (reset): drive $\mathbf{R}$ to 0 (keeping $\mathbf{S}$ at 1) to change $\mathbf{Q}$ to 0
$\mathbf{S}$ and $\mathbf{R}$ should never both be 0 at the same time


| Input |  | Output |
| :---: | :---: | :---: |
| R | S | Q |
| 1 | 1 | $\mathrm{Q}_{\text {prev }}$ |
| 1 | 0 | 1 |
| 0 | 1 | 0 |
| 0 | 0 | Invalid |

## Why not $\mathrm{R}=\mathrm{S}=0$ ?



| Input |  | Output |
| :---: | :---: | :---: |
| R | S | Q |
| 1 | 1 | $\mathrm{Q}_{\text {prev }}$ |
| 1 | 0 | 1 |
| 0 | 1 | 0 |
| 0 | 0 | Invalid |

1. If $\mathbf{R}=\mathbf{S}=\mathbf{0}, \mathbf{Q}$ and $\mathbf{Q}^{\mathbf{\prime}}$ will both settle to 1 , which breaks our invariant that $\mathbf{Q}=!\mathbf{Q}^{\prime}$
2. If $\mathbf{S}$ and $\mathbf{R}$ transition back to 1 at the same time, $\mathbf{Q}$ and $\mathbf{Q}^{\prime}$ begin to oscillate between 1 and 0 because their final values depend on each other (metastability)

- This eventually settles depending on variation in the circuits (more metastability to come in Lecture 8)


## The Gated D Latch

## The Gated D Latch

- How do we guarantee correct operation of an R-S Latch?



## The Gated D Latch

- How do we guarantee correct operation of an R-S Latch?
- Add two more NAND gates!

- $\mathbf{Q}$ takes the value of $\mathbf{D}$, when write enable (WE) is set to 1
- $\mathbf{S}$ and $\mathbf{R}$ can never be 0 at the same time!


## The Gated D Latch



## The Register

## The Register

How can we use D latches to store more data?

- Use more D latches!
- A single WE signal for all latches for simultaneous writes


Here we have a register, or a structure that stores more than one bit and can be read from and written to

This register holds 4 bits, and its data is referenced as Q[3:0]

## The Register

How can we use D latches to store more data?

- Use more D latches!
- A single WE signal for all latches for simultaneous writes


Here we have a register, or a structure that stores more than one bit and can be read from and written to

This register holds 4 bits, and its data is referenced as Q[3:0]

Memory

## Memory

- Memory is comprised of locations that can be written to or read from. An example memory array with 4 locations:

| Addr(00): | 0100 | 1001 | Addr(01): | 0100 | 1011 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $\boldsymbol{A d d r}(10):$ | 0010 | 0010 | Addr(11): | 1100 | 1001 |

- Every unique location in memory is indexed with a unique address. 4 locations require 2 address bits (log[\#locations]).
- Addressability: the number of bits of information stored in each location. This example: addressability is 8 bits.
- The full set of unique locations in memory is referred to as the address space.
- Typical memory is MUCH larger (billions of locations)


## Addressing Memory

Let's implement a simple memory array with:

- 3-bit addressability \& address space size of 2 (total of 6 bits) 1 Bit


6-Bit Memory Array

| $\boldsymbol{A d d r}(\mathbf{0})$ | $\mathrm{Bit}_{2}$ | $\mathrm{Bit}_{1}$ | $\mathrm{Bit}_{0}$ |
| :---: | :---: | :---: | :---: |
| $\boldsymbol{A d d r}(\mathbf{1})$ | $\mathrm{Bit}_{2}$ | $\mathrm{Bit}_{1}$ | $\mathrm{Bit}_{0}$ |
|  |  |  |  |

## Reading from Memory

## How can we select the address to read?

- Because there are 2 addresses, address size is $\log (2)=1$ bit



## Reading from Memory

## How can we select the address to read?

- Because there are 2 addresses, address size is $\log (2)=1$ bit

Addr[0]


## Reading from Memory

## How can we select the address to read?

- Because there are 2 addresses, address size is $\log (2)=1$ bit

Addr[0]


## Reading from Memory

## How can we select the address to read?

- Because there are 2 addresses, address size is $\log (2)=1$ bit

Addr[0]


## Writing to Memory

How can we select the address and write to it?


## Writing to Memory

## How can we select the address and write to it?

- Input is indicated with $D_{i}$



## Putting it all Together

## Enable reading and writing to a memory array



## A Bigger Memory Array



## A Bigger Memory Array



## Sequential Logic Circuits

## Sequential Logic Circuits

- We have looked at designs of circuit elements that can store information
- Now, we will use these elements to build circuits that remember past inputs


Combinational
Only depends on current inputs


Sequential
Opens depending on past inputs

## State

- In order for this lock to work, it has to keep track (remember) of the past events!
- If passcode is R13-L22-R3, sequence of states to unlock:
A. The lock is not open (locked), and no relevant operations have been performed
B. Locked but user has completed R13
C. Locked but user has completed L22
D. Locked but user has completed R3
E. The lock can now be opened
- The state of a system is a snapshot of all relevant elements of the system at the moment of the snapshot
- To open the lock, states A-E must be completed in order
- If anything else happens (e.g., L5), lock returns to state A


## Another Simple Example of State

- A standard Swiss traffic light has 4 states
A. Green
B. Yellow
C. Red
D. Red and Yellow

- The sequence of these states are always as follows



## Changing State: The Notion of Clock (I)



- When should the light change from one state to another?
- We need a clock to dictate when to change state
- Clock signal alternates between 0 \& 1

CLK: ${ }_{0}^{1} \sqcap \square \square \square \square \square \square \square \square \square \square \square$

- At the start of a clock cycle ( $\square \square$ ), system state changes
- During a clock cycle, the state stays constant
- In this traffic light example, we are assuming the traffic light stays in each state an equal amount of time


## Changing State: The Notion of Clock (II)

- Clock is a general mechanism that triggers transition from one state to another in a sequential circuit
- Clock synchronizes state changes across many sequential circuit elements
- Combinational logic evaluates for the length of the clock cycle
- Clock cycle should be chosen to accommodate maximum combinational circuit delay
- More on this later, when we discuss timing


## Finite State Machines

## Finite State Machines

- What is a Finite State Machine (FSM)?
- A discrete-time model of a stateful system
- Each state represents a snapshot of the system at a given time
- An FSM pictorially shows
- the set of all possible states that a system can be in
- how the system transitions from one state to another
- An FSM can model
- A traffic light, an elevator, fan speed, a microprocessor, etc.
- An FSM enables us to pictorially think of a stateful system using simple diagrams


## Finite State Machines (FSMs) Consist of:

## - Five elements:

1. A finite number of states

- State: snapshot of all relevant elements of the system at the time of the snapshot

2. A finite number of external inputs
3. A finite number of external outputs
4. An explicit specification of all state transitions How to get from one state to another
5. An explicit specification of what determines each external output value

## Finite State Machines (FSMs)

- Each FSM consists of three separate parts:
- next state logic
- state register
- output logic


At the beginning of the clock cycle, next state is latched into the state register

## Finite State Machines (FSMs) Consist of:

- Sequential circuits
- State register(s)
- Store the current state and
- Load the next state at the clock edge
- Combinational Circuits
- Next state logic
- Determines what the next state will be

- Output logic
- Generates the outputs



## Finite State Machines (FSMs) Consist of:

- Sequential circuits
- State register(s)
- Store the current state and
- Load the next state at the clock edge

- Combinational Circuits
- Next state logic
- Determines what the next state will be

- Output logic
- Generates the outputs



## State Register Implementation

- How can we implement a state register? Two properties: 1. We need to store data at the beginning of every clock cycle


2. The data must be available during the entire clock cycle


## The Problem with Latches

Recall the
Gated D Latch


- Currently, we cannot simply wire a clock to WE of a latch - When the clock is high, $\mathbf{Q}$ will not take on $\mathbf{D}$ 's value AND
- When the clock is low, the latch will propagate $\mathbf{D}$ to $\mathbf{Q}$



## The Problem with Latches

Recall the
Gated D Latch


- Currently, we cannot simply wire a clock to WE of a latch - When the clock is high, $\mathbf{Q}$ will not take on $\mathbf{D}$ 's value AND - When the clock is low, the latch will propagate $\mathbf{D}$ to $\mathbf{Q}$



## The Problem with Latches

Recall the
Gated D Latch


How can we change the latch, so that

1) $\mathbf{D}$ (input) is observable at $\mathbf{Q}$ (output) only at the beginning of next clock cycle?
2) $\mathbf{Q}$ is available for the full clock cycle

## The D Flip-Flop

- 1) state change on clock edge, 2) data available for full cycle

- When the clock is low, master propagates $\mathbf{D}$ to the input of slave ( Q unchanged)
- Only when the clock is high, slave latches D (Q stores D)
- At the rising edge of clock (clock going from $0->1$ ), Q gets assigned D


## The D Flip-Flop

- 1) state change on clock edge, 2) data available for full cycle

- At the rising edge of clock (clock going from 0->1), Q gets assigned D
- At all other times, Q is unchanged


## The D Flip-Flop

- How do we implement this?



## We can use these Flip-Flops to implement the state register!

- At the rising edge of clock (clock going from $0->1$ ), $\mathbf{Q}$ gets assigned $\mathbf{D}$
- At all other times, Q is unchanged


## Rising-Edge Triggered Flip-Flop

- Two inputs: CLK, D
- Function
- The flip-flop "samples" D on the rising edge of CLK (positive edge)
- When CLK rises from 0 to 1, D passes through to $\mathbf{Q}$

- Otherwise, $\mathbf{Q}$ holds its previous value
- $\mathbf{Q}$ changes only on the rising edge of CLK
- A flip-flop is called an edge-triggered device because it is activated on the clock edge


## Register

- Multiple parallel flip-flops, each of which store 1 bit


CLK


This line represents 4 wires
This register stores 4 bits

## Finite State Machines (FSMs)

- Next state is determined by the current state and the inputs
- Two types of finite state machines differ in the output logic:
- Moore FSM: outputs depend only on the current state



## Finite State Machines (FSMs)

- Next state is determined by the current state and the inputs
- Two types of finite state machines differ in the output logic:
- Moore FSM: outputs depend only on the current state
- Mealy FSM: outputs depend on the current state and the inputs

Moore FSM


Mealy FSM


## Finite State Machine Example

- "Smart" traffic light controller
- 2 inputs:
- Traffic sensors: $T_{A}, T_{B}$ (TRUE when there's traffic)
- 2 outputs:
- Lights: $L_{A}$, $L_{B}$ (Red, Yellow, Green)



## Finite State Machine Black Box

- Inputs: CLK, Reset, $\mathrm{T}_{\mathrm{A}}$, $\mathrm{T}_{\mathrm{B}}$
- Outputs: $L_{A}, L_{B}$


Reset

## Finite State Machine Transition Diagram

- Moore FSM: outputs labeled in each state
- States: Circles
- Transitions: Arcs



## Finite State Machine Transition Diagram

- Moore FSM: outputs labeled in each state
- States: Circles
- Transitions: Arcs



## Finite State Machine Transition Diagram

- Moore FSM: outputs labeled in each state
- States: Circles
- Transitions: Arcs



## Finite State Machine Transition Diagram

- Moore FSM: outputs labeled in each state
- States: Circles
- Transitions: Arcs



## Finite State Machine Transition Diagram

- Moore FSM: outputs labeled in each state
- States: Circles
- Transitions: Arcs



## Finite State Machines

## State Transition Table

## FSM State Transition Table



| Current State | Inputs |  |
| :---: | :---: | :---: |
| NextState |  |  |
| S | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ |
| $\mathrm{S}^{\prime}$ |  |  |
| S 0 | 0 | X |
| S 0 | 1 | X |
|  |  |  |
| S 1 | X | X |
| S 2 | X | 0 |
| S 2 | X | 1 |
| S 3 | X | X |
|  |  |  |

## FSM State Transition Table



| Current State | Inputs |  | NextState |
| :---: | :---: | :---: | :---: |
| S | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | S' |
| S0 | 0 | X | S1 |
| S0 | 1 | X | S0 |
| S1 | X | X | S2 |
| S2 | X | 0 | S3 |
| S2 | X | 1 | S2 |
| S3 | X | X | S0 |

## FSM State Transition Table



| Current State | Inputs |  | NextState |
| :---: | :---: | :---: | :---: |
| S | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | $\mathrm{S}^{\prime}$ |
| S 0 | 0 | X | S 1 |
| S 0 | 1 | X | S 0 |
| S 1 | X | X | S 2 |
| S 2 | X | 0 | S 3 |
| S 2 | X | 1 | S 2 |
| S 3 | X | X | S 0 |
|  |  | State | Encoding |
|  |  | S 0 | 00 |
|  |  | S 1 | 01 |
|  |  | S 2 | 10 |
|  |  | S 3 | 11 |

## FSM State Transition Table



| Current State |  | Inputs |  | NextState |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | $\mathrm{S}_{1}^{\prime}$ | $\mathrm{S}_{0}^{\prime}$ |
| 0 | 0 | 0 | X | 0 | 1 |
| 0 | 0 | 1 | X | 0 | 0 |
| 0 | 1 | X | X | 1 | 0 |
| 1 | 0 | X | 0 | 1 | 1 |
| 1 | 0 | X | 1 | 1 | 0 |
| 1 | 1 | X | X | 0 | 0 |

## FSM State Transition Table



| Current State |  | Inputs |  | Next State |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | $\mathrm{S}_{1}^{\prime}$ | $S_{0}$ |
| 0 | 0 | 0 | X | 0 | 1 |
| 0 | 0 | 1 | X | 0 | 0 |
| 0 | 1 | X | X | 1 | 0 |
| 1 | 0 | X | 0 | 1 | 1 |
| 1 | 0 | X | 1 | 1 | 0 |
| 1 | 1 | X | X | 0 | 0 |
|  |  |  | State | Enc | ing |
|  |  |  | S0 |  |  |
|  |  |  | S1 |  |  |
|  |  |  | S2 |  |  |
|  |  |  | S3 |  |  |

## FSM State Transition Table



| Current State |  | Inputs |  | Next State |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | $\mathrm{S}_{1}^{\prime}$ | $\mathrm{S}_{0}$ |
| 0 | 0 | 0 | X | 0 | 1 |
| 0 | 0 | 1 | X | 0 | 0 |
| 0 | 1 | X | X | 1 | 0 |
| 1 | 0 | X | 0 | 1 | 1 |
| 1 | 0 | X | 1 | 1 | 0 |
| 1 | 1 | X | X | 0 | 0 |


| State | Encoding |
| :---: | :---: |
| S0 | 00 |
| S1 | 01 |
| S2 | 10 |
| S3 | 11 |

## FSM State Transition Table



$$
\mathrm{S}_{1}^{\prime}=\left(\overline{\mathrm{S}}_{1} \cdot \mathrm{~S}_{0}\right)+\left(\mathrm{S}_{1} \cdot \overline{\mathrm{~S}}_{0} \cdot \overline{\mathrm{~T}}_{\mathrm{B}}\right)+\left(\mathrm{S}_{1} \cdot \overline{\mathrm{~S}}_{0} \cdot \mathrm{~T}_{\mathrm{B}}\right)
$$

$$
S_{0}^{\prime}=?
$$

| Current State |  | Inputs |  | NextState |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | $\mathrm{S}_{1}$ | $\mathrm{S}_{0}^{\prime}$ |
| 0 | 0 | 0 | X | 0 | 1 |
| 0 | 0 | 1 | X | 0 | 0 |
| 0 | 1 | X | X | 1 | 0 |
| 1 | 0 | X | 0 | 1 | 1 |
| 1 | 0 | X | 1 | 1 | 0 |
| 1 | 1 | X | X | 0 | 0 |
| $)+\left(\mathrm{S}_{1} \cdot \bar{S}_{0} \cdot \mathrm{~T}_{\mathrm{B}}\right)$ |  |  | State | Encoding |  |
|  |  |  | S0 | 00 |  |
|  |  |  | S1 | 01 |  |
|  |  |  | S2 | 10 |  |
|  |  |  | S3 | 11 |  |

## FSM State Transition Table



| Current State |  | Inputs |  | NextState |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | $\mathrm{S}_{1}^{\prime}$ |  |
| 0 | 0 | 0 | X | 0 |  |
| 0 | 0 | 1 | X | 0 |  |
| 0 | 1 | X | X | 1 |  |
| 1 | 0 | X | 0 | 1 |  |
| 1 | 0 | X | 1 | 1 |  |
| 1 | 1 | X | X | 0 |  |


| State | Encoding |
| :---: | :---: |
| S0 | 00 |
| S1 | 01 |
| S2 | 10 |
| S3 | 11 |

## FSM State Transition Table



$$
\begin{aligned}
& \mathrm{S}_{1}^{\prime}=\mathrm{S}_{1} \text { xor } \mathrm{S}_{0} \quad \text { (Simplified) } \\
& \mathrm{S}_{0}^{\prime}=\left(\overline{\mathrm{S}}_{1} \cdot \overline{\mathrm{~S}}_{0} \cdot \overline{\mathrm{~T}}_{\mathrm{A}}\right)+\left(\mathrm{S}_{1} \cdot \overline{\mathrm{~S}}_{0} \cdot \overline{\mathrm{~T}}_{\mathrm{B}}\right)
\end{aligned}
$$

| Current State |  | Inputs |  | NextState |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{B}}$ | $\mathrm{S}_{1}^{\prime}$ |  |
| 0 | 0 | 0 | X | 0 |  |
| 0 | 0 | 1 | X | 0 |  |
| 0 | 1 | X | X | 1 |  |
| 1 | 0 | X | 0 | 1 |  |
| 1 | 0 | X | 1 | 1 |  |
| 1 | 1 | X | X | 0 |  |


| State | Encoding |
| :---: | :---: |
| S0 | 00 |
| S1 | 01 |
| S2 | 10 |
| S3 | 11 |

## Finite State Machines

Output Table

## FSM Output Table



| Current State |  | Outputs |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~L}_{\mathrm{A}}$ | $\mathrm{L}_{\mathrm{B}}$ |  |
| 0 | 0 | green | red |  |
| 0 | 1 | yellow | red |  |
| 1 | 0 | red | green |  |
| 1 | 1 | red | yellow |  |

## FSM Output Table



| Current State |  | Outputs |  |
| :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~L}_{\mathrm{A}}$ | $\mathrm{L}_{\mathrm{B}}$ |
| 0 | 0 | green | red |
| 0 | 1 | yellow | red |
| 1 | 0 | red | green |
| 1 | 1 | red | yellow |


| Output | Encoding |
| :---: | :---: |
| green | 00 |
| yellow | 01 |
| red | 10 |

## FSM Output Table

$$
L_{A 1}=S_{1}
$$

| Current State |  | Outputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~L}_{\mathrm{A} 1}$ | $\mathrm{~L}_{\mathrm{A} 0}$ | $\mathrm{~L}_{\mathrm{B} 1}$ | $\mathrm{~L}_{\mathrm{B} 0}$ |
| 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 0 | 0 | 1 |


| Output | Encoding |
| :---: | :---: |
| green | 00 |
| yellow | 01 |
| red | 10 |

## FSM Output Table

$$
\begin{aligned}
& \mathrm{L}_{\mathrm{A} 1}=\mathrm{S}_{1} \\
& \mathrm{~L}_{\mathrm{A} 0}=\overline{\mathrm{S}_{1}} \cdot \mathrm{~S}_{0}
\end{aligned}
$$

| Current State |  | Outputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~L}_{\mathrm{A} 1}$ | $\mathrm{~L}_{\mathrm{A} 0}$ | $\mathrm{~L}_{\mathrm{B} 1}$ | $\mathrm{~L}_{\mathrm{B} 0}$ |
| 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 0 | 0 | 1 |


| Output | Encoding |
| :---: | :---: |
| green | 00 |
| yellow | 01 |
| red | 10 |

## FSM Output Table

$$
\begin{aligned}
& \mathrm{L}_{\mathrm{A} 1}=\mathrm{S}_{1} \\
& \mathrm{~L}_{\mathrm{A} 0}=\overline{\mathrm{S}_{1}} \cdot \mathrm{~S}_{0} \\
& \mathrm{~L}_{\mathrm{B} 1}=\overline{\mathrm{S}_{1}}
\end{aligned}
$$

| Current State |  | Outputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~L}_{\mathrm{A} 1}$ | $\mathrm{~L}_{\mathrm{A} 0}$ | $\mathrm{~L}_{\mathrm{B} 1}$ | $\mathrm{~L}_{\mathrm{B} 0}$ |
| 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 0 | 0 | 1 |


| Output | Encoding |
| :---: | :---: |
| green | 00 |
| yellow | 01 |
| red | 10 |

## FSM Output Table



| Current State |  | Outputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~L}_{\mathrm{A} 1}$ | $\mathrm{~L}_{\mathrm{A} 0}$ | $\mathrm{~L}_{\mathrm{B} 1}$ | $\mathrm{~L}_{\mathrm{B} 0}$ |
| 0 | 0 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 0 | 0 | 1 |


| Output | Encoding |
| :---: | :---: |
| green | 00 |
| yellow | 01 |
| red | 10 |

## Finite State Machines

## Schematic

## FSM Schematic: State Register



## FSM Schematic: State Register


state register

## FSM Schematic: Next State Logic



$$
\begin{aligned}
& \mathrm{S}_{1}^{\prime}=\mathrm{S}_{1} \operatorname{xor} \mathrm{~S}_{0} \\
& \mathrm{~S}_{0}^{\prime}=\left(\overline{\mathrm{S}}_{1} \cdot \overline{\mathrm{~S}}_{0} \cdot \overline{\mathrm{~T}}_{\mathrm{A}}\right)+\left(\mathrm{S}_{1} \cdot \overline{\mathrm{~S}}_{0} \cdot \overline{\mathrm{~T}}_{\mathrm{B}}\right)
\end{aligned}
$$

## FSM Schematic: Output Logic


inputs
output logic outputs

$$
\begin{aligned}
& \mathrm{L}_{\mathrm{A} 1}=\mathrm{S}_{1} \\
& \mathrm{~L}_{\mathrm{A} 0}=\overline{\mathrm{S}_{1}} \cdot \mathrm{~S}_{0} \\
& \mathrm{~L}_{\mathrm{B} 1}=\overline{\mathrm{S}_{1}} \\
& \mathrm{~L}_{\mathrm{B} 0}=\mathrm{S}_{1} \cdot \mathrm{~S}_{0}
\end{aligned}
$$

## FSM Timing Diagram



$$
\begin{gathered}
\text { CLK_ } \\
\text { Reset_ } \\
\mathrm{T}_{\mathrm{A}-} \\
\mathrm{T}_{\mathrm{B}}- \\
\mathrm{S}_{1: 0}^{\prime}- \\
\mathrm{S}_{1: 0}- \\
\mathrm{C}_{1: 0}- \\
\mathrm{L}_{\mathrm{A} 1: 0}- \\
\mathrm{L}_{\mathrm{B} 1: 0}-
\end{gathered}
$$

## FSM Timing Diagram




## FSM Timing Diagram




## FSM Timing Diagram




## FSM Timing Diagram




## FSM Timing Diagram




## FSM Timing Diagram




## FSM Timing Diagram




## FSM Timing Diagram




## FSM Timing Diagram




## FSM State Encoding

- 3 common state binary encodings with different tradeoffs

1. Fully Encoded
2. 1-Hot Encoded
3. Output Encoded

- Let's see an example Swiss traffic light with 4 states
- Green, Yellow, Red, Yellow+Red



## FSM State Encoding

## 1. Fully Encoded:

- Minimizes \# flip-flops, but not necessarily output logic or next state logic
- Use $\log _{2}$ (num_states) bits to represent the states
- Example states: 00, 01, 10, 11


## 2. 1-Hot Encoded:

- Maximizes \# flip-flops, minimizes next state logic
- Simplest design process - very automatable
- Use num_states bits to represent the states
- Example states: 0001, 0010, 0100, 1000


## FSM State Encoding

## 3. Output Encoded:

- Minimizes output logic
- Only works for Moore Machines
- Each state has to be encoded uniquely, but the outputs must be directly accessible in the state encoding
- For example, since we have 3 outputs (light color), encode state with 3 bits, where each bit represents a color
- Example states: 001, 010, 100, 110
- $\mathrm{Bit}_{0}$ encodes green light output,
- $\mathrm{Bit}_{1}$ encodes yellow light output
- $\mathrm{Bit}_{2}$ encodes red light output


## FSM State Encoding

## 3. Output Encoded:

- Minimizes output logic
- Only works for Moore Machines

Fach state has to be encoded uniauelv. but the outnuts

The designer must carefully choose an encoding scheme to optimize the design under given constraints

- DIL 1 EICOUES yellow IIgIL OULPUL
- $\mathrm{Bit}_{2}$ encodes red light output


## Moore vs. Mealy Machines

## Moore vs. Mealy FSM

- Alyssa P. Hacker has a snail that crawls down a paper tape with 1's and 0's on it.
- The snail smiles whenever the last four digits it has crawled over are 1101.
- Design Moore and Mealy FSMs of the snail's brain.

Moore FSM


## Moore vs. Mealy FSM

- Alyssa P. Hacker has a snail that crawls down a paper tape with 1's and 0's on it.
- The snail smiles whenever the last four digits it has crawled over are 1101.
- Design Moore and Mealy FSMs of the snail's brain.



## State Transition Diagrams



## FSM Design Procedure

- Determine all possible states of your machine
- Develop a state transition diagram
- Generally this is done from a textual description
- You need to 1) determine the inputs and outputs for each state and 2) figure out how to get from one state to another
- Approach
- Start by defining the reset state and what happens from it - this is typically an easy point to start from
- Then continue to add transitions and states
- Picking good state names is very important
- Building an FSM is like programming (but it is not programming!)
- An FSM has a sequential "control-flow" like a program with conditionals and goto's
- The if-then-else construct is controlled by one or more inputs
- The outputs are controlled by the state or the inputs
- In hardware, we typically have many concurrent FSMs


## Implementing Sequential Logic Using Verilog

## Verilog: Last Week vs. This Week

- We have seen an overview of Verilog
- Discussed structural and behavioral modeling
- Showed combinational logic constructs


## This week

- Sequential logic constructs in Verilog
- Developing testbenches for simulation


## Combinational + Memory $=$ Sequential



## Sequential Logic in Verilog

- Define blocks that have memory
- Flip-Flops, Latches, Finite State Machines
- Sequential Logic state transition is triggered by a 'CLOCK' event
- Latches are sensitive to level of the signal
- Flip-flops are sensitive to the transitioning of clock
- Combinational constructs are not sufficient
- We need new constructs:
- always
- posedge/negedge


## The "always" Block

always @ (sensitivity list) statement;

Whenever the event in the sensitivity list occurs, the statement is executed

## Example: D Flip-Flop



- posedge defines a rising edge (transition from 0 to 1 ).
- Statement executed when the clk signal rises (posedge of clk)
- Once the clk signal rises: the value of $d$ is copied to $q$


## Example: D Flip-Flop



- assign statement is not used within an always block
- <= describes a non-blocking assignment
- We will see the difference between blocking assignment and non-blocking assignment soon


## Example: D Flip-Flop



- Assigned variables need to be declared as reg
- The name reg does not necessarily mean that the value is a register (It could be, but it does not have to be)
- We will see examples later


## Asynchronous and Synchronous Reset

- Reset signals are used to initialize the hardware to a known state
- Usually activated at system start (on power up)
- Asynchronous Reset
- The reset signal is sampled independent of the clock
- Reset gets the highest priority
- Sensitive to glitches, may have metastability issues
- Will be discussed in Lecture 8
- Synchronous Reset
- The reset signal is sampled with respect to the clock
- The reset should be active long enough to get sampled at the clock edge
- Results in completely synchronous circuit


## D Flip-Flop with Asynchronous Reset

| module flop_ar (input <br> input  <br>  input <br>  output reg $[3: 0$ | clk, reset, d, q); |
| :---: | :---: |
| ```always@ (posedge clk, negedge begin if (reset == 0) q <= 0; else q<= d; end endmodule``` | reset <br> / when reset // when clk |

- In this example: two events can trigger the process:
- A rising edge on clk
- A falling edge on reset


## D Flip-Flop with Asynchronous Reset



- For longer statements, a begin-end pair can be used
- To improve readability
- In this example, it was not necessary, but it is a good idea


## D Flip-Flop with Asynchronous Reset



- First reset is checked: if reset is $0, q$ is set to 0 .
- This is an asynchronous reset as the reset can happen independently of the clock (on the negative edge of reset signal)
- If there is no reset, then regular assignment takes effect


## D Flip-Flop with Synchronous Reset



- The process is only sensitive to clock
- Reset happens only when the clock rises. This is a synchronous reset


## D Flip-Flop with Enable and Reset



- A flip-flop with enable and reset
- Note that the en signal is not in the sensitivity list
- q gets d only when clk is rising and en is 1


## Example: D Latch

| module latch (input <br> input <br> output reg $[3: 0] ~ q) ; ~$ |
| :--- | :--- |
| $[3: 0] \mathrm{d}$, |

## Summary: Sequential Statements So Far

- Sequential statements are within an always block
- The sequential block is triggered with a change in the sensitivity list
- Signals assigned within an always must be declared as reg
- We use <= for (non-blocking) assignments and do not use assign within the always block.


## Basics of always Blocks

```
module example (input 
    wire [3:0] normal; // standard wire
    reg [3:0] special; // assigned in always
    always @ (posedge clk)
        special <= d; // first FF array
    assign normal = ~ special; // simple assignment
    always @ (posedge clk)
    q <= normal; // second FF array
endmodule
```

You can have as many always blocks as needed
Assignment to the same signal in different always blocks is not allowed!

## Why Does an always Block Memorize?

```
module flop (input clk,
    input [3:0] d,
    output reg [3:0] q);
    always @ (posedge clk)
    begin
        q <= d; // when clk rises copy d to q
    end
endmodule
```

- This statement describes what happens to signal q
- ... but what happens when the clock is not rising?
- The value of $q$ is preserved (memorized)


## An always Block Does NOT Always Memorize

```
module comb (input inv,
    input [3:0] data,
    output reg [3:0] result);
```

    always @ (inv, data) // trigger with inv, data
    if (inv) result <= ~data;// result is inverted data
    else result <= data; // result is data
    endmodule

- This statement describes what happens to signal result
- When inv is 1 , result is $\sim$ data
- When inv is not 1 , result is data
- The circuit is combinational (no memory)
- result is assigned a value in all cases of the if .. else block, always


## always Blocks for Combinational Circuits

- An always block defines combinational logic if:
- All outputs are always (continuously) updated

1. All right-hand side signals are in the sensitivity list

- You can use always @* for short

2. All left-hand side signals get assigned in every possible condition of if .. else and case blocks

- It is easy to make mistakes and unintentionally describe memorizing elements (latches)
- Vivado will most likely warn you. Make sure you check the warning messages
- Always blocks allow powerful combinational logic statements
- if .. else
- case


## Sequential or Combinational?

```
wire enable, data;
reg out_a, out_b;
always @ (*) begin
        out_a = 1'b0;
    if(enable) begin
                        out a = data;
    end
end
    No assignment for ~enable
```

Sequential

```
wire enable, data;
reg out_a, out_b;
always @ (data) begin
    out_a = 1'b0;
    out_b = 1'b0;
    if(enable begin
    out_a = data;
    out_b = data;
end Not in the sensitivity list
```

Sequential

## The always Block is NOT Always Practical/Nice

```
reg [31:0] result;
wire [31:0] a, b, comb;
wire sel,
always @ (a, b, sel) // trigger with a, b, sel
    if (sel) result <= a; // result is a
    else result <= b; // result is b
assign comb = sel ? a : b;
```

- Both statements describe the same multiplexer
- In this case, the always block is more work


## always Block for Case Statements (Handy!)

```
module sevensegment (input [3:0] data,
    output reg [6:0] segments);
```

```
always @ ( * )
```

always @ ( * )
case (data)
case (data)
// * is short for all signals
// * is short for all signals
// case statement
// case statement
4'd0: segments = 7'b111_1110; // when data is 0
4'd0: segments = 7'b111_1110; // when data is 0
4'd1: segments = 7'b011_0000; // when data is 1
4'd1: segments = 7'b011_0000; // when data is 1
4'd2: segments = 7'b110_1101;
4'd2: segments = 7'b110_1101;
4'd3: segments = 7'b111_1001;
4'd3: segments = 7'b111_1001;
4'd4: segments = 7'b011_0011;
4'd4: segments = 7'b011_0011;
4'd5: segments = 7'b101_1011;
4'd5: segments = 7'b101_1011;
// etc etc
// etc etc
default: segments = 7'b000_0000; // required
default: segments = 7'b000_0000; // required
endcase

```
    endcase
```

endmodule

## Summary: always Block

- If . . else can only be used in always blocks
- The always block is combinational only if all regs within the block are always assigned to a signal
- Use the default case to make sure you do not forget an unimplemented case, which may otherwise result in a latch
- Use casex statement to be able to check for don't cares


## Non-Blocking and Blocking Assignments

## Non-blocking (<=)

```
always @ (a)
begin
    a <= 2'b01;
    b <= a;
// all assignments are made here
// b is not (yet) 2'b01
end
```

- All assignments are made at the end of the block
- All assignments are made in parallel, process flow is not-blocked

Blocking (=)

```
always @ (a)
begin
    a = 2'b01;
    a is 2'b01
    b = a;
    b is now 2'b01 as well
end
```

- Each assignment is made immediately
- Process waits until the first assignment is complete, it blocks progress


## Why use (Non)-Blocking Statements

- There are technical reasons why both are required
- It is out of the scope of this course to discuss these
- Blocking statements allow sequential descriptions
- More like a programming language
- If the sensitivity list is correct, blocks with non-blocking statements will always evaluate to the same result
- This may require some additional iterations


## Example: Blocking Assignment

- Assume all inputs are initially ' 0 '

```
always @ ( * )
    begin
```



```
    end
```

- If a changes to ' 1 '
- All values are updated in order


## The Same Example: Non-Blocking Assignment

- Assume all inputs are initially ' 0 '

```
always @ ( * )
    begin
    pllllol
    end
```

- If a changes to ' 1 '
- All assignments are concurrent
- When $s$ is being assigned, $p$ is still 0


## The Same Example: Non-Blocking Assignment

- After the first iteration, p has changed to ' 1 ' as well

```
always @ ( * )
    begin
        l\mp@code{lo a ^ b ; }
    end
```

- Since there is a change in $p$, the process triggers again
- This time $s$ is calculated with $p=1$


## Rules for Signal Assignment

- Use always @(posedge clk) and non-blocking assignments (<=) to model synchronous sequential logic

$$
\begin{array}{r}
\hline \text { always @ (posedge clk) } \\
\text { q <= d; // non-blocking }
\end{array}
$$

- Use continuous assignments (assign) to model simple combinational logic.

$$
\text { assign } y=a \& b ;
$$

## Rules for Signal Assignment (Cont.)

- Use always @ (*) and blocking assignments (=) to model more complicated combinational logic.
- You cannot make assignments to the same signal in more than one always block or in a continuous assignment



## Recall: Finite State Machines (FSMs)

- Each FSM consists of three separate parts:
- next state logic
- state register
- output logic



## Recall: Finite State Machines (FSMs) Comprise

- Sequential circuits
- State register(s)
- Store the current state and
- Load the next state at the clock edge

- Combinational Circuits
- Next state logic
- Determines what the next state will be

- Output logic
- Generates the outputs



## FSM Example 1: Divide the Clock Frequency by 3



The output $Y$ is HIGH for one clock cycle out of every 3. In other words, the output divides the frequency of the clock by 3.


## Implementing FSM Example 1: Definitions

```
module divideby3FSM (input clk,
    input reset,
    output q);
reg [1:0] state, nextstate;
parameter S0 = 2'b00;
parameter S1 = 2'b01;
parameter S2 = 2'b10;
```

- We define state and nextstate as 2-bit reg
- The parameter descriptions are optional, it makes reading easier


## Implementing FSM Example 1: State Register


// state register
always @ (posedge clk, posedge reset)

```
    if (reset) state <= S0;
```

    else state <= nextstate;
    - This part defines the state register (memorizing process)
- Sensitive to only clk, reset
- In this example, reset is active when it is '1' (active-high)


## Implementing FSM Example 1: Next State Logic



```
// next state logic
    always @ (*)
    case (state)
        S0: nextstate = S1;
        S1: nextstate = S2;
        S2: nextstate = S0;
        default: nextstate = S0;
        endcase
```


## Implementing FSM Example 1: Output Logic


// output logic
assign $q=($ state $=$ S 0 );

- In this example, output depends only on state
- Moore type FSM


## Implementation of FSM Example 1

module divideby3FSM (input clk, input reset, output q);
reg [1:0] state, nextstate;
parameter S 0 = 2'b00; parameter S 1 = 2'b01; parameter S2 = 2'b10;
always @ (posedge clk, posedge reset) // state register if (reset) state <= S0;
else state <= nextstate;
always @ (*)
case (state)
S0: $\quad$ nextstate $=$ S1;
S1: $\quad$ nextstate $=$ S2;
S2: nextstate = S0;
default: nextstate = S0;
endcase
assign $q$ = (state == S0); // output logic
endmodule

## FSM Example 2: Smiling Snail

- Alyssa P. Hacker has a snail that crawls down a paper tape with 1's and 0's on it.
- The snail smiles whenever the last four digits it has crawled over are 1101.
- Design Moore and Mealy FSMs of the snail's brain.


We did not cover the following. They are for your preparation.

## Implementing FSM Example 2: Definitions

```
module SmilingSnail (input clk,
                                    input reset,
                                    input number,
                                    output smile);
reg [1:0] state, nextstate;
parameter S0 = 2'b00;
parameter S1 = 2'b01;
parameter S2 = 2'b10;
parameter S3 = 2'b11;
```



## Implementing FSM Example 2: State Register

```
// state register
    always @ (posedge clk, posedge reset)
        if (reset) state <= S0;
        else state <= nextstate;
```

- This part defines the state register (memorizing process)
- Sensitive to only clk, reset
- In this example reset is active when ' 1 ' (active-high)


## Implementing FSM Example 2: Next State Logic

```
// next state logic
    always @ (*)
    case (state)
        S0: if (number) nextstate = S1;
            else nextstate = S0;
        S1: if (number) nextstate = S2;
            else nextstate = S0;
        S2: if (number) nextstate = S2;
            else nextstate = S3;
        S3: if (number) nextstate = S1;
            else nextstate = S0;
        default: nextstate = S0;
    endcase
```



## Implementing FSM Example 2: Output Logic

// output logic
assign smile $=$ (number \& state $==$ S3);

- In this example, output depends on state and input - Mealy type FSM
- We used a simple combinational assignment


## Implementation of FSM Example 2

```
module SmilingSnail (input clk,
                    input reset,
                    input number,
                    output smile);
```

reg [1:0] state, nextstate;
parameter S0 = 2'b00;
parameter S1 = 2'b01;
parameter S2 = 2'b10;
parameter S3 = 2'b11;

## // state register

always @ (posedge clk, posedge reset)

```
if (reset) state <= S0;
else state <= nextstate;
```

```
always @ (*) // next state logic
    case (state)
        S0: if (number)
                                nextstate = S1;
            else nextstate = S0;
        S1: if (number)
                nextstate = S2;
        else nextstate = S0;
        S2: if (number)
            nextstate = S2;
            else nextstate = S3;
        S3: if (number)
                nextstate = S1;
                else nextstate = S0;
            default: nextstate = S0;
        endcase
        // output logic
assign smile = (number & state==S3);
endmodule
```


## What Did We Learn?

- Basics of defining sequential circuits in Verilog
- The always statement
- Needed for defining memorizing elements (flip-flops, latches)
- Can also be used to define combinational circuits
- Blocking vs Non-blocking statements
- = assigns the value immediately
- <= assigns the value at the end of the block
- Writing FSMs
- Next state logic
- State assignment
- Output logic

Next Lecture: Timing and Verification

# Design of Digital Circuits Lecture 7: Sequential Logic Design 

Prof. Onur Mutlu

ETH Zurich
Spring 2018
15 March 2018

## Backup Slides

- Different types of flip flops


## The D Flip-Flop

## Enabled Flip-Flops

- Inputs: CLK, D, EN
- The enable input (EN) controls when new data (D) is stored Function:
- EN = 1: D passes through to $Q$ on the clock edge
- $\mathbf{E N}=\mathbf{0}$ : the flip-flop retains its previous state

Internal

Circuit


## Resettable Flip-Flop

- Inputs: CLK, D, Reset
- The Reset is used to set the output to 0 .
- Function:
- Reset =1: Q is forced to 0
- Reset $=0$ : the flip-flop behaves like an ordinary D flip-flop

Symbols


## Resettable Flip-Flops

- Two types:
- Synchronous: resets at the clock edge only
- Asynchronous: resets immediately when Reset = 1
- Asynchronously resettable flip-flop requires changing the internal circuitry of the flip-flop (see Exercise 3.10)
- Synchronously resettable flip-flop?



## Settable Flip-Flop

- Inputs: CLK, D, Set
- Function:
- Set = 1: Q is set to 1
- Set = 0: the flip-flop behaves like an ordinary D flip-flop

Symbols


