# Lecture 10 EE 421 / C\$ 425 Digital System Design

Fall 2023

**Shahid Masud** 



#### Topics

- State Reduction by Implication Charts to complete
- -----
- Metastability
- Synchronizers for capturing Asynchronous Inputs
- Signal Transfer with and without Clock
- Communication between modules in Complex Digital System



#### State Reduction using Implication Charts

- Graphical Technique for State Reduction
- Definition:
- Redundant State:
  - One state is equivalent to another (and hence redundant) if the state functions are in-distinguishable
- When all states that have (i) different next states and (ii) different outputs, have been identified, the remaining states are considered to be redundant



#### State Equivalence Theorem

• Two states SA and SB are equivalent iff for every possible input X sequence, the outputs are same and the next states are equivalent

- Properties of Equivalent States:
- Symmetry: If SA=SB, then SB=SA
- Reflexivity: SA = SA for any state
- Transitivity: If SA=SB, and SB=SC, then SA=SC



#### **Construction of Implication Charts**

The Chart is constructed by listing all of the states except the last, along horizontal axis, and Listing all of the states except the first, along the vertical axix Intersection of the horizontal and vertical spaces indicates a possible state equivalene





## **Example of State Reduction using Implication Charts**

Given the State Table as follows:

| Present   | Next       | State     | Output   |          |
|-----------|------------|-----------|----------|----------|
| State     | When X=0   | When X=1  | When X=0 | When X=1 |
| S0        | <b>S4</b>  | S3        | 0        | 1        |
| <b>S1</b> | <b>S</b> 5 | S3        | 0        | 0        |
| <b>S2</b> | <b>S4</b>  | <b>S1</b> | 0        | 1        |
| <b>S3</b> | S5         | <b>S1</b> | 0        | 0        |
| <b>S4</b> | S2         | S5        | 0        | 1        |
| <b>S5</b> | <b>S1</b>  | S2        | 0        | 0        |

Total 6 states, S0 to S5



#### Filling the Implication Chart

- Place X in squares where outputs are different, as such states cannot be equivalent
- For other squares, we look at State Equivalence Pairs, i.e.:
  - $S0 \equiv S2$ , iff  $S1 \equiv S3$

Thus we write S1,S3 in the square at intersection of S0, S2

$$S0 \equiv S4$$
, iff  $S2 \equiv S3$ , and  $S3 \equiv S5$ 

$$S1 \equiv S5$$
, iff  $S2 \equiv S3$ 

$$S2 \equiv S4$$
, iff  $S1 \equiv S5$ 

$$S3 \equiv S5$$
, iff  $S1 \equiv S5$ , and  $S1 \equiv S2$ 



#### Filled Implication Chart with conditions of equivalent states

| <b>S1</b> | X              |                |                |                | Present   | Nex        |
|-----------|----------------|----------------|----------------|----------------|-----------|------------|
|           |                |                |                |                | State     | When X=0   |
|           |                |                |                |                | S0        | S4         |
| CO        | C1 C2          | V              |                |                | <b>S1</b> | <b>S</b> 5 |
| <b>S2</b> | <b>S1,S3</b>   | X              |                |                | S2        | <b>S4</b>  |
|           |                |                |                |                | S3        | <b>S</b> 5 |
|           |                |                |                | _              | S4        | S2         |
| <b>S3</b> | X              | <b>S1,S3</b>   | Х              |                | <b>S5</b> | <b>S1</b>  |
| <b>S4</b> | S2,S4<br>S3,S5 | X              | S2,S4<br>S1,S5 | X              |           |            |
| <b>S5</b> | X              | S1,S5<br>S2,S3 | X              | S1,S5<br>S1,S2 | Х         |            |
|           | S0             | S1             | S2             | S3             | <b>S4</b> |            |



One by one, examine all table entries and refer to the state transition table

Output

When X=1

When X=0

**Next State** 

When X=1

**S3** 

S1

**S5 S2** 

#### X is inserted where outputs of states is different Check conditions of equivalence in respective squares



To check for: {S1,S3}, {S1,S5}, {S2,S3}, {S1,S2}



To check for: {\$1,\$3}, {\$1,\$5}, {\$2,\$3}, {\$1,\$2}

| Present<br>State | Next        | State       | Output      |             |
|------------------|-------------|-------------|-------------|-------------|
|                  | When<br>X=0 | When<br>X=1 | When<br>X=0 | When<br>X=1 |
| S0               | <b>S4</b>   | <b>S3</b>   | 0           | 1           |
| <b>S1</b>        | S5          | <b>S3</b>   | 0           | 0           |
| S2               | <b>S4</b>   | <b>S1</b>   | 0           | 1           |
| <b>S3</b>        | S5          | <b>S1</b>   | 0           | 0           |
| <b>S4</b>        | S2          | <b>S5</b>   | 0           | 1           |
| <b>S</b> 5       | <b>S1</b>   | S2          | 0           | 0           |

#### In {S1,S3}:

Outputs are same for S1, and S3 In Next States, When X=1, S1 goes to S3 and S3 goes to S1 Hence S1 and S3 are equivalent

In {S1,S2}, output is different when X=1, hence these cannot Be equivalent, so this square will get 'X'

In {S2,S3}, output is different when X=1, hence these cannot be equivalent, so this square will be 'X'.

This means that S1 cannot be equivalent to S5 as it is dependent on S2 and S3 as Next State

Similarly, check all conditions in all squares

#### **Updated Implication Chart**

| Present    | Next       | State      | Output   |          |
|------------|------------|------------|----------|----------|
| State      | When X=0   | When X=1   | When X=0 | When X=1 |
| S0         | <b>S4</b>  | S3         | 0        | 1        |
| <b>S1</b>  | <b>S</b> 5 | <b>S3</b>  | 0        | 0        |
| <b>S2</b>  | <b>S4</b>  | <b>S1</b>  | 0        | 1        |
| <b>S3</b>  | <b>S</b> 5 | <b>S1</b>  | 0        | 0        |
| S4         | <b>S2</b>  | <b>S</b> 5 | 0        | 1        |
| <b>S</b> 5 | <b>S1</b>  | S2         | 0        | 0        |

This condition is established So SO and S2 are Equivalent States



Hence S1 and S3 are Equivalent states

Result: S0 ≡ S2 And S1 ≡ S3



#### **Updated further - Implication Chart**





#### **Updated State Table**

Original table with six states

| Present<br>State | Next        | State       | Output      |             |
|------------------|-------------|-------------|-------------|-------------|
|                  | When<br>X=0 | When<br>X=1 | When<br>X=0 | When<br>X=1 |
| S0               | <b>S4</b>   | <b>S3</b>   | 0           | 1           |
| <b>S1</b>        | S5          | <b>S3</b>   | 0           | 0           |
| S2               | <b>S4</b>   | <b>S1</b>   | 0           | 1           |
| <b>S3</b>        | S5          | <b>S1</b>   | 0           | 0           |
| <b>S4</b>        | S2          | <b>S</b> 5  | 0           | 1           |
| <b>S5</b>        | <b>S1</b>   | <b>S2</b>   | 0           | 0           |

X

Only four states are left

| Present<br>State | Next State        |                 | Output      |              |
|------------------|-------------------|-----------------|-------------|--------------|
|                  | When When X=0 X=1 |                 | When<br>X=0 | When<br>X=1  |
| S0               | <b>S4</b>         | <mark>S1</mark> | 0           | 1            |
| <b>S1</b>        | <b>S</b> 5        | <mark>S1</mark> | 0           | 0            |
| <del>S2</del>    | <del>\$4</del>    | <del>S1</del>   | 0           | <del>1</del> |
| <del>S3</del>    | <del>\$5</del>    | <del>S1</del>   | 0           | 0            |
| <b>S4</b>        | <mark>S0</mark>   | <b>S</b> 5      | 0           | 1            |
| <b>S</b> 5       | <b>S1</b>         | <mark>S0</mark> | 0           | 0            |



**Result:** 

**S0 ≡ S2** 

**S1 ≡ S3** 

And

#### Practice Example: 4-Bit Sequence Detector

| Input                           |               | Next State |          | Output   |          |
|---------------------------------|---------------|------------|----------|----------|----------|
| Sequence                        | Present State | When X=0   | When X=1 | When X=0 | When X=1 |
| Reset                           | S0            | <b>S1</b>  | S2       | 0        | 0        |
| 0                               | <b>S1</b>     | S3A        | S4A      | 0        | 0        |
| 1                               | S2            | S4A        | S7A      | 0        | 0        |
| 00, 11                          | S3A           | S7A        | S7A      | 0        | 0        |
| 01, 10                          | S4A           | S7A        | S10A     | 0        | 0        |
| 000, 001, 010,<br>100, 110, 111 | S7A           | S0         | S0       | 0        | 0        |
| 011 or 101                      | S10A          | S0         | SO SO    | 1        | 0        |



#### See if states can be reduced further:

| Input                              |                  | Next State |             | Output   |          |
|------------------------------------|------------------|------------|-------------|----------|----------|
| Sequence                           | Present<br>State | When X=0   | When X=1    | When X=0 | When X=1 |
| Reset                              | S0               | <b>S1</b>  | S2          | 0        | 0        |
| 0                                  | <b>S1</b>        | S3A        | S4A         | 0        | 0        |
| 1                                  | S2               | S4A        | S7A         | 0        | 0        |
| 00, 11                             | S3A              | S7A        | S7A         | 0        | 0        |
| 01, 10                             | S4A              | S7A        | <b>S10A</b> | 0        | 0        |
| 000, 001,<br>010, 100,<br>110, 111 | S7A              | S0         | S0          | 0        | 0        |
| 011 or<br>101                      | S10A             | S0         | S0          | 1        | 0        |





#### Filled Implication Chart





## Metastability, and Asynchronous Data Management



## Objective – to reduce possible Metastability in capturing Asynchronous Input





Synchronizer Failure: When flipflop hangs in a Metastable State for a long time (indefinitely)

Normally, the flipflop output would settle to a stable 0 or 1 state after some time



#### **Output Behaviour with Metastability**



DFF is connected to produce metastability
As setup time is violated



**Eventually a stable state is reached** 

Problem occurs when flipflop is not stable within One clock period



19

#### Synchronizers

- Asynchronous inputs are problematic as their transitions are not predictable
- High speed digital circuits rely on synchronizers to create a time buffer for recovering from a metastable event; thus reducing the possibility that metastability will cause circuit to malfunction
- An asynchronous signal should be synchronized by one synchronizer only. If not, then multiple synchronized signals could be present in the system and one of these could be driven into metastable state



Asynchronous Inputs to a Synchronous Digital System





#### Synchronizer 1

Condition: The width of asynchronous input pulse is greater than period of the clock

Synchronizer is a multistage shift register



Reset Input 'R' is used as control to bring Synch\_Out back to '0', as required



#### Timing Diagram – Synchronizer 1





### Synchronizer 2

Condition: Width of the asynchronous input pulse is less than the period of the clock



#### Timing Diagram – Synchronizer 2





## **Self-Timed and Speed Independent Circuits**

- Having a completed Synchronous system is at times too challenging for a complex and fast digital system
- The limiting problem becomes how to distribute a single global clock without introducing intolerable clock skew
- The alternate is to partition the digital system into locally clocked pieces that communicate with each other using delay-insensitive signaling techniques (i.e. local clock for local communication)
- Each block proceeds at its own speed without the need for a global clock, synchronizing local communication whenever needed
- Usually a Request-Response Signalling method is employed



#### Data Reading across two Clock Domains



frequency of Clk1 is less than Clk2
Otherwise, the Synchronizer-2 is versatile and can be used here



## Communication across modules in Complex SoC

- Communication Signaling across modules at different clock speeds
- Self-timed circuits



## Self-Timed and Speed Independent Circuits

- Having a completed Synchronous system is at times too challenging for a complex and fast digital system
- The limiting problem becomes how to distribute a single global clock without introducing intolerable clock skew
- The alternate is to partition the digital system into locally clocked pieces that communicate with each other using delay-insensitive signaling techniques (i.e. local clock for local communication)
- Each block proceeds at its own speed without the need for a global clock, synchronizing local communication whenever needed
- Usually a Request-Response Signaling method is employed



#### Request / Acknowledge Signaling

Independently clocked Subsystems







#### Synchronous Req / Ack Signaling





#### Synchronous Req with Wait Signaling



Slave can delay the Master by asserting Wait signal as it prepares the data and needs more clock cycles When the slave un-asserts Wait signal, it acknowledges that data is now available for the Master to read All interface signals are synchronized with Clock edge

#### Four Cycle Asynchronous Signaling

RTZ – Return to Zero Signaling with No Clock





### Two Cycle Asynchronous Signaling





#### **Self-Timed Circuits**

- A self-timed circuit can determine on its own when a request has been serviced by mimicking the worst-case propagation delay path by using special logic to delay the request signal.
- This guarantees sufficient time to compute the correct output.



