# Sequential Circuit Design 

## COE 202

Digital Logic Design
Dr. Muhamed Mudawar
King Fahd University of Petroleum and Minerals

## Presentation Outline

* The Design Procedure
* Moore Sequence Detector
* Mealy Sequence Detector
* Tracing State Diagrams and Verifying Correctness
* Binary Counter
* Up/Down Counter with Enable
* Sequential Comparator
* Bus Controller


## The Design Procedure

Given a Description (or Specification) of the Problem

1. Obtain a state diagram for the sequential circuit
2. Assign binary codes to the states and fill the state table
3. Select the type of Flip-Flops and derive the FF input equations
4. Derive the output equations
5. Draw the circuit diagram
6. Verify the correctness of the final design (verification)

## The State Diagram

* A state is an abstraction of memory
* A state remembers a history of inputs applied to the circuit
* Examples:
$\triangleleft$ State S0 represents the fact that the last input is a 0
$\diamond$ State S1 represents the fact that the last input is a 1
$\diamond$ State $\mathbf{S} 2$ represents the fact that the last two-input sequence is "11"
* Obtaining the state diagram is the most important step
* Requires experience and good understanding of the problem


## Example: Sequence Detector

* A sequence detector is a sequential circuit
* Detects a specific sequence of bits in the input
* The input is a serial bit stream:

One input bit $\boldsymbol{x}$ is fed to the sequence detector each cycle

* The output is also a bit stream: One output bit z each cycle

Indicates whether a given sequence is detected or not


## State Diagram for a Sequence Detector

* Example: Design a circuit that detects the input sequence "111"
* Begin in an initial state: call it $\mathbf{S}_{\mathbf{0}}$
$\mathrm{S}_{0}$ indicates that a 1 is NOT detected yet
As long as the input $x$ is 0 , remain in the initial state $\mathbf{S}_{0}$
$\star$ Add a state (call it $\mathbf{S}_{1}$ ) that detects the first 1 in the input
* Add a state (call it $\mathbf{S}_{2}$ ) that detects the input sequence "11"
* Add a state (call it $\mathbf{S}_{3}$ ) that detects the input sequence "111"



## Complete the State Diagram

Moore Design: Assign Output to States
The output in $\mathbf{S}_{0}, \mathrm{~S}_{1}$, and $\mathbf{S}_{\mathbf{2}}$ should be 0
The output in $\mathrm{S}_{3}$ should be 1

Now complete the state diagram:
Add transitions from $\mathbf{S}_{\mathbf{1}}, \mathbf{S}_{\mathbf{2}}, \mathbf{S}_{\mathbf{3}}$ back to $\mathbf{S}_{0}$ if the input is 0

Add transition from $\mathbf{S}_{\mathbf{3}}$ to itself if the input is 1 to detect sequences longer than three 1's


## State Assignment

* Each state must be assigned a unique binary code
* If there are $m$ states then

The minimum number of state bits: $n=\left\lceil\log _{2} m\right\rceil$
$\lceil x\rceil$ is the smallest integer $\geq x$ (ceiling function)
$*$ In our example, there are four states: $\mathbf{S}_{0}, \mathbf{S}_{1}, \mathbf{S}_{2}$, and $\mathbf{S}_{\mathbf{3}}$
Therefore, the minimum number of state bits (Flip-Flops) $=2$

* State assignment: $\mathbf{S}_{\mathbf{0}}=\mathbf{0 0}, \mathrm{S}_{1}=\mathbf{0 1}, \mathbf{S}_{\mathbf{2}}=10$ and $\mathrm{S}_{\mathbf{3}}=\mathbf{1 1}$
* If $n$ bits are used, the number of unused states $=2^{n}-m$
* In our example, there are NO unused states


## From State Diagram to State Table



| Present <br> State | Next State |  | Output |
| :---: | :---: | :---: | :---: |
| $\mathrm{S}_{0}$ | $\mathrm{~S}_{0}$ | $\mathrm{~S}_{1}$ | 0 |
| $\mathrm{~S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{~S}_{2}$ | 0 |
| $\mathrm{~S}_{2}$ | $\mathrm{~S}_{0}$ | $\mathrm{~S}_{3}$ | 0 |
| $\mathrm{~S}_{3}$ | $\mathrm{~S}_{0}$ | $\mathrm{~S}_{3}$ | 1 |
| Present | Next State |  | Output |
| State | $\boldsymbol{x}=0$ | $x=1$ | $Z$ |
| 00 | 00 | 01 | 0 |
| 01 | 00 | 10 | 0 |
| 10 | 00 | 11 | 0 |
| 11 | 00 | 11 | 1 |

## Structure of a Moore Sequence Detector



* In our design examples, only D-type Flip-Flops will be used
* They are the simplest to analyze and implement
* Next, we need minimal expressions for

1. Next State Logic
2. Output Logic

## Derive Next State an Output Equations

| Present | Next State |  | Output |
| :---: | :---: | :---: | :---: |
| State | $\boldsymbol{x}=0$ | $\boldsymbol{x}=1$ | $\boldsymbol{z}$ |
| 00 | 00 | 01 | 0 |
| 01 | 00 | 10 | 0 |
| 10 | 00 | 11 | 0 |
| 11 | 00 | 11 | 1 |


|  | $D_{1}$ |  |
| :---: | :---: | :---: |
| $Q_{1} Q_{0}$ | 0 | 1 |
| 00 | 0 | 0 |
| 01 | 0 | 1 |
| 11 | 0 | 1 |
| 10 | 0 | 1 |

$$
Q_{1} x+Q_{0} x \quad Q_{1} x+Q_{0}^{\prime} x
$$

|  | $D_{0}$ |  |
| :---: | :---: | :---: |
| $Q_{1} Q_{0}$ |  | 1 |
| 00 | 0 | 1 |
| 01 | 0 | 0 |
| 11 | 0 | 1 |
| 10 | 0 | 1 |

Two D-type Flips-Flops
Present State $=$ Flip-Flop Outputs $Q_{1}$ and $Q_{0}$
Next State $=$ Flip-Flop Inputs $D_{1}$ and $D_{0}$
Next State equations: $D_{1}=Q_{1} x+Q_{0} x$ and $D_{0}=Q_{1} x+Q_{0}^{\prime} x$
Output equation: $z=Q_{1} Q_{0}$ (from the state diagram)

## Draw the Moore Sequence Detector Circuit

$$
D_{1}=Q_{1} x+Q_{0} x, D_{0}=Q_{1} x+Q_{0}^{\prime} x
$$

$$
z=Q_{1} Q_{0}
$$

Clock


## Mealy Type Sequence Detector

* Let us redesign a Mealy type "111" sequence detector
* The initial state $\mathbf{S}_{0}$ indicates that a 1 is NOT detected yet

As long as the input $x$ is 0 , remain in the initial state $\mathbf{S}_{0}$
Notice that input / output is written on the arc (Mealy type)
$*$ Add a state (call it $\mathbf{S}_{1}$ ) that detects the first 1 in the input

* Add a state (call it $\mathbf{S}_{2}$ ) that detects the input sequence "11"



## Complete the Mealy State Diagram

* State $\mathbf{S}_{\mathbf{2}}$ is reached after detecting the input sequence "11"
$\star$ At $\mathbf{S}_{2}$, if the next input is 1 then the output should be $\mathbf{1}$
Make a transition from $\mathbf{S}_{\mathbf{2}}$ back to itself labeled 1 / 1
No need for state $\mathbf{S}_{3}$, because output is on the arc
* Now complete the state diagram

Add transitions from $\mathbf{S}_{1}$ and $\mathbf{S}_{\mathbf{2}}$ back to $\mathbf{S}_{\mathbf{0}}$ when input is $\mathbf{0}$


Mealy Machines typically use less states than Moore Machines

## State Assignment and State Table

Three States $\rightarrow$ Minimum number of state bits (Flip-Flops) $=2$ Assign: $S_{0}=00, S_{1}=01$, and $S_{2}=10$ (State 11 is Unused)


| Present State | Next State |  | Output $z$ |  | Present <br> State | Next State |  | Output $z$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $x=0$ | $x=1$ | $x=0$ | $x=1$ |  | $x=0$ | $x=1$ | $x=0$ | $x=1$ |
| $\mathrm{S}_{0}$ | $\mathrm{S}_{0}$ | $\mathrm{S}_{1}$ | 0 | 0 | 00 | 00 | 01 | 0 | 0 |
| $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ | $\mathrm{S}_{2}$ | 0 | 0 | 01 | 00 | 10 | 0 | 0 |
| $\mathrm{S}_{2}$ | $\mathrm{S}_{0}$ | $\mathrm{S}_{2}$ | 0 | 1 | 10 | 00 | 10 | 0 | 1 |

## Derive Next State and Output Equations



Present State $=$ Flip-Flop Outputs $Q_{1}$ and $Q_{0}$ (state 11 is unused)
Next State $=$ Flip-Flop Inputs $D_{1}$ and $D_{0}$
Flip-Flop Input equations: $D_{1}=Q_{1} x+Q_{0} x$ and $D_{0}=Q_{1}^{\prime} Q_{0}^{\prime} x$
Output equation: $z=Q_{1} x$

## Draw the Mealy Sequence Detector Circuit

$$
D_{1}=Q_{1} x+Q_{0} x \quad D_{0}=Q_{1}^{\prime} Q_{0}^{\prime} x \quad z=Q_{1} x
$$



## Mealy versus Moore Sequence Detector

Mealy Sequence Detector


In general, Moore state diagrams have more states than corresponding Mealy.

The drawback of Mealy is that glitches can appear in the output if the input is not synchronized with the clock.

Moore
Sequence


## Verification

* Sequential circuits should be verified by showing that the circuit produces the original state diagram
* Verification can be done manually, or with the help of a simulation program
* All possible input combinations are applied at each state and the state variables and outputs are observed
* A reset input is used to reset the circuit to its initial state
* Apply a sequence of inputs to test all the state-input combinations, i.e., all transitions in the state diagram
* Observe the output and the next state that appears after each clock edge in the timing diagram


## Input Test Sequence

* Required to verify the correct operation of a sequential circuit
$\%$ It should test each state transition of the state diagram
* Test sequences can be produced from the state diagram
* Consider the Mealy sequence detector, starting at $\mathbf{S}_{0}$ (reset), we can use an input test sequence to verify all state transitions: Input test sequence: reset then $\mathbf{x}=\mathbf{0 , 1 , 0 , 1 , 1 , 0 , 1 , 1 , 1 , 1}$

> Reset input forces initial state to be $\mathbf{S}_{0}$

## Verifying the Mealy Sequence Detector



Input test sequence: reset then $\mathrm{x}=0,1,0,1,1,0,1,1,1,1$


## Design of a Binary Counter

## Problem Specification:

* Design a circuit that counts up from 0 to 7 then back to 0

$$
000 \rightarrow 001 \rightarrow 010 \rightarrow 011 \rightarrow 100 \rightarrow 101 \rightarrow 110 \rightarrow 111 \rightarrow 000
$$

When reaching 7 , the counter goes back to 0 then goes up again

* There is no input to the circuit
* The counter is incremented each cycle
* The output of the circuit is the present state (count value)
* The circuit should be designed using D-type Flip-Flops


## Designing the State Diagram

* Eight states are needed to store the count values 0 to 7
* No input, state transition happens at the edge of each cycle



## Three Flip-Flops are required for the eight states

## Each state is

 assigned a unique binary count value
## State Table

Only two columns: Present State and Next State

State changes each cycle


|  |  | State <br> $\mathrm{Q}_{0}$ | Next State$D_{2} D_{1} D_{0}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 | 1 |
| 0 | 1 | 1 | 1 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 1 | 1 | 0 |
| 1 | 1 | 0 | 1 | 1 | 1 |
| 1 | 1 |  | 0 | 0 | 0 |

Next State
$\mathrm{D}_{2} \mathrm{D}_{1} \mathrm{D}_{0}$
001
010
011
100
101
110
111
000

## Deriving the Next State Equations

| $\begin{aligned} & \text { Present State } \\ & \mathrm{Q}_{2} \mathrm{Q}_{1} \mathrm{Q}_{0} \end{aligned}$ | Next State$D_{2} D_{1} D_{0}$ | $Q_{2} Q_{1}{ }^{Q_{0}}{ }_{0}^{D_{2}} \quad 1$ |  |  | $Q_{2} Q_{1}{ }^{Q_{0}}{ }_{0}{ }^{D_{1}}{ }_{1}^{1}$ |  |  | $Q_{2} Q_{1}{ }^{1} 0$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  | 00 | 0 | 0 | 00 | - |  | 00 |  | 0 |
| 000 | 01 | 01 | 0 | 1 | 01 | 1 | 0 | 01 | 1 | 0 |
| 001 | 010 | 11 | 1 | 0 | 11 |  | 0 | 11 |  | 0 |
| 010 | 11 | 10 | 1 | 1 | 10 |  | 1 | 10 |  | 0 |
| 011 | 100 | $D_{2}=$ | $Q_{2} Q^{1}$ | ${ }_{1}^{\prime}+$ | $Q_{0}^{\prime}+$ |  | $Q_{1} Q_{0}$ |  |  |  |
| 100 | 01 | $D_{2}=$ | $Q_{2}\left(Q_{1}\right.$ | $Q_{1}^{\prime}+$ | $\left.Q_{0}^{\prime}\right)+$ |  | $Q_{1} Q_{0}$ |  |  |  |
| 01 | 10 | $D_{2}=$ | $Q_{2}(Q$ | $Q_{1}$ | ${ }^{\prime}+Q_{2}^{\prime}$ |  | $Q_{0}$ |  |  |  |
| 110 | 111 |  |  |  |  |  |  |  |  |  |
| 111 | 000 | $D_{0}=$ |  |  |  |  |  |  |  |  |

## 3-Bit Counter Circuit Diagram



## Up/Down Counter with Enable

## Problem Specification:

* Design a 2-bit Up / Down counter
* Two inputs: E (Enable) and U (Up)

If $\mathrm{E}=0$ then counter remains in the same state (regardless of U )
If $\mathrm{EU}=11$ then count up from 0 to 3 , then back to 0
If $\mathrm{EU}=10$ then count down from 3 down to 0 , then back to 3

* The output of the counter is the present state (count value)
* The circuit should be designed using T Flip-Flops
* A reset signal resets the counter to its initial state


## Designing the State Diagram

* Four states are required to store the count 0 to 3
* Count up if EU = 11
* Count down if EU = 10
* Disable counter if E = 0

Transition to same state if
$\mathrm{EU}=00$ or 01

* Asynchronous reset to start initially at state S0



## State Assignment and State Table

* Four States $\rightarrow$ Two State variables (2 Flip-Flops)
* State Assignment: $\mathrm{S} 0=00, \mathrm{~S} 1=01, \mathrm{~S} 2=10$, and $\mathrm{S} 3=11$


| Present State $\mathrm{Q}_{1} \mathrm{Q}_{0}$ | Next State |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { E U } \\ & 00 \end{aligned}$ | $\begin{aligned} & \text { E U } \\ & 01 \end{aligned}$ | $\begin{gathered} \text { E U } \\ 10 \end{gathered}$ | E U |
| 00 | 00 | 00 | 11 | 01 |
| 01 | 01 | 01 | 00 | 10 |
| 10 | 10 | 10 | 0 | 11 |
|  |  | 11 | 10 | 00 |

## Excitation Table for Flip-Flops

* Excitation Table:

Lists the required input for next state transition

* For D Flip-Flops: Input $D=$ Next State $Q(t+1)$
* For T and JK Flip-Flops, excitation tables are different
* Excitation tables are used to find the Flip-Flop input equations


## Excitation Tables for different types of Flip-Flops

| $\boldsymbol{Q}(\boldsymbol{t})$ | $Q(t+1)$ | D | $Q(t)$ | $Q(t+1)$ | T | $Q(t)$ | $Q(t+1)$ | $J$ | $K$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X |
| 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | X |
| 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | X | 1 |
| 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | X | 0 |

## Deriving the T-Flip-Flop Input Equations

| Present |  |  | Next | State |  |  |  | Present | Flip | Flop | puts | $\mathrm{T}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| State | E U |  |  |  | U |  |  | State |  |  |  |  |
| $\mathrm{Q}_{1} \mathrm{Q}_{0}$ | 00 |  | 01 | 10 | 1 |  |  | $\mathrm{Q}_{1} \mathrm{Q}_{0}$ | 00 | 01 | 10 | 11 |
| 00 | 00 | 0 | 00 | 110 | 1 |  |  | 00 | 00 | 00 | 11 | 01 |
| 01 | 01 | 0 | 01 | 001 | 0 | $\square$ |  | 01 | 00 | 00 | 01 | 11 |
| 10 | 10 | 1 | 10 | 011 | 1 |  |  | 10 | 00 | 00 | 11 | 01 |
| 11 | 11 | 1 | 11 | 100 | 0 |  |  | 11 | 00 | 00 | 0 | 11 |
| EU | $T_{1}$ |  |  | ${ }_{0} O_{0}^{E U} 00 \quad I_{0} \quad 01 \quad 11$ |  |  |  |  |  |  |  |  |
| $Q_{1} Q_{0} \bigcirc 00$ |  | 11 |  |  |  |  |  | 10 | $T_{1}=Q_{0} E U+Q_{0}^{\prime} E U^{\prime}$ |  |  |  |
| 000 | 0 | 0 | 1 | Q100 | 0 | 0 | 1 | 1 |  |  |  |  |
| 010 | 0 | 1 | 0 | 01 | 0 | 0 | 1 | 1 | $T_{1}=E\left(Q_{0} \oplus U\right)^{\prime}$ |  |  |  |
| 110 | 0 | 1 | 0 | 11 | 0 | 0 | 1 | 1 |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
| 100 | 0 | 0 | 1 | 10 | 0 | 0 | 1 | 1. |  |  |  |  |

## 2-bit Up/Down Counter Circuit Diagram



## Sequential Comparator

## Problem Specification:

$\star$ Design a sequential circuit that compares two numbers A and B

* Two Inputs: A and B

A consists of $n$ bits
B consists of $n$ bits
Bit streaming starting at bit 0


Clock Reset

Compare $A_{0}$ with $B_{0}, A_{1}$ with $B_{1}$, etc. (Bit 0 is least significant bit)

* A reset signal resets the comparator to its initial state

Reset is required before starting a new comparison

* Two outputs: GT (Greater Than) and LT (Less Than)


## Designing the State Diagram

* Reset: start initially in state $\mathbf{S}_{0}$
$\mathrm{S}_{0}$ indicates Equality (output is 00 )
Stay in $\mathbf{S}_{0}$ as long as $A_{i} B_{i}=00$ or 11
$*$ Go to $\mathrm{S}_{1}$ if $A_{i}<B_{i}\left(A_{i} B_{i}=01\right)$
$\mathrm{S}_{1}$ indicates LT (output is 01)
$*$ Go to $\mathrm{S}_{2}$ if $A_{i}>B_{i}\left(A_{i} B_{i}=10\right)$
$\mathrm{S}_{2}$ indicates GT (output is 10)
* Complete the state diagram $\mathrm{S}_{1} \rightarrow \mathrm{~S}_{2}$ and $\mathrm{S}_{2} \rightarrow \mathrm{~S}_{1}$
$\mathrm{S}_{1} \rightarrow \mathrm{~S}_{1}$ and $\mathrm{S}_{\mathbf{2}} \rightarrow \mathrm{S}_{\mathbf{2}}$

Moore State Diagram


## State Assignment and State Table

Three States $\boldsymbol{\rightarrow}$ Two Flip-Flops
D-type Flip-Flops will be used
State Assignment: $\mathbf{S}_{\mathbf{0}}=\mathbf{0 0}, \mathbf{S}_{\mathbf{1}}=\mathbf{0 1}, \mathbf{S}_{\mathbf{2}}=10$
Output = Present State $\left(\mathbf{Q}_{\mathbf{1}}\right.$ and $\left.\mathbf{Q}_{\mathbf{0}}\right)$

| Present State <br> $Q_{1} Q_{0}$ | Next State ( $\mathrm{D}_{1} \mathrm{D}_{0}$ ) |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | AB | A | AB | AB |
|  | 00 | 01 | 10 | 11 |
| 0 | 00 | 0 | 1 | 0 |
| 01 | 01 | 0 | 1 | 01 |
| 10 | 10 | 0 | 1 | 1 |
| 11 | $\mathrm{x} \times$ | x |  | X X |



## Deriving the Next State Equations

Present Next State $\left(D_{1} D_{0}\right)$

| State $\mathrm{Q}_{1} \mathrm{Q}_{0}$ | $\begin{aligned} & \text { A B } \\ & 00 \end{aligned}$ | $\begin{aligned} & \text { A B } \\ & 01 \end{aligned}$ | $\begin{gathered} \text { A B } \\ 10 \end{gathered}$ | $\begin{gathered} \text { A B } \\ 11 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 00 | 0 | 10 | 00 |
| 01 | 01 | 0 | 10 | 0 |
| 10 | 10 | 0 | 10 | 1 |
| 11 | $\mathrm{X} \times$ | $\mathrm{X} \times$ | X X | X X |

State 11 is unused
When present state is 11 , don't cares are used to fill the next state.

Output = Present state

| $Q_{1} Q_{0}^{A}$ | $D_{1}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 00 | 01 | 11 | 10 |
| 00 | 0 | 0 | 0 | 1 |
| 01 | 0 | 0 | 0 | 1 |
| 11 | X | X | X | X |
| 10 | 1 | 0 | 1 | 1 |


| $Q_{1} Q_{0}^{A B}$ | $D_{0}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 00 | 01 | 11 | 10 |
| 00 | 0 | 1 | 0 | 0 |
| 01 | 1 | 1 | 1 | 0 |
| 11 | X | X | X | X |
| 10 | 0 | 1 | 0 | 0 |

$$
\begin{aligned}
& D_{1}=Q_{1} A+Q_{1} B^{\prime}+A B^{\prime} \\
& D_{1}=Q_{1}\left(A+B^{\prime}\right)+A B^{\prime} \\
& D_{0}=Q_{0} A^{\prime}+Q_{0} B+A^{\prime} B \\
& D_{0}=Q_{0}\left(A^{\prime}+B\right)+A^{\prime} B
\end{aligned}
$$

## Sequential Comparator Circuit Diagram

$$
D_{1}=Q_{1}\left(A+B^{\prime}\right)+A B^{\prime} \quad D_{0}=Q_{0}\left(A^{\prime}+B\right)+A^{\prime} B
$$



## Bus Controller

* A shared bus is used to connect multiple modules
* Each clock cycle, one driver module can put data on the bus
* The receiver module gets the data on the bus
* Each driver sends a request (R signal) to the bus controller
* The bus controller outputs an enable (E signal) to each driver
* If enabled, a driver can put data on the bus; Otherwise, it waits



## Designing a Bus Controller

## Specification:

* Bus controller has 3 inputs
$R_{1}, R_{2}$, and $R_{3}$ are requests from bus drivers
Any combination of requests is possible
$R_{1}, R_{2}, R_{3}$ can range from 000 to 111

* Bus controller has 3 outputs
$E_{1}, E_{2}$, and $E_{3}$ are enable signals sent to bus drivers
At most one bus driver can be enabled to put data on the bus
Different designs are possible


## Design 1 of the Bus Controller

* Four States:
$\mathrm{S}_{0}=$ Bus is idle
$\mathrm{S}_{1}=$ Enable Driver 1
$\mathrm{S}_{\mathbf{2}}=$ Enable Driver 2
$\mathrm{S}_{3}=$ Enable Driver 3
* Driver 1 is given the highest priority, then driver 2, then 3
* Transitions between $\mathrm{S}_{1}, \mathrm{~S}_{2}$, and $\mathrm{S}_{3}$ according to priority



## Design 2 of the Bus Controller

* Drawback of Design 1 :

As long as driver 1 is requesting the bus, other drivers must wait No fairness to bus drivers 2 and 3

* Design 2:

Cyclic transitions between $\mathbf{S}_{1}, \mathbf{S}_{2}$, and $\mathrm{S}_{3}$ if all drivers are requesting the bus

