# Sequential Circuit Testing Sequential Circuits and Finite State Machines

#### Priyank Kalla



Professor
Electrical and Computer Engineering, University of Utah
kalla@ece.utah.edu
http://www.ece.utah.edu/~kalla

Slides updated Dec 1, 2021



#### Agenda

- Review of Sequential Circuits and Mealy Finite State Machines (FSM)
- The concept of FSM equivalence
- Fault excitation and propagation conditions in FSM
- Reset states, synchronizing sequences and redundant states
- Untestable faults in sequential circuits

## Sequential Circuits

- We consider sequential circuits with edge-triggered D-flip-flops
- Underlying a sequential circuit is a finite state machine (FSM)
- We will consider only FSMs of the Mealy-type (Moore machine ATPG is similar)
- An example of sequential circuit:



# FSM and Circuit example



# Sequential Circuit Testing: Sequential Miter



• Find a **sequence of inputs** (or input vectors) that produces an output 1 at the miter output, sometime in the future clock cycles

# FSM Equivalence

Two Machines,  $\mathcal{M}_1$  and  $\mathcal{M}_2$ , are equivalent if

- They are identical; or
- They have identical states but different encoding; or
- $\mathcal{M}_1 \subseteq \mathcal{M}_2$  or vice-versa; or
- They have different reachable states but same distinguishable states (same condition as above); or
- Different unreachable states, and unreachable states are a don't care condition

Prove that two machines (sequential circuits) produce the same output response on application of all possible input **sequences** 

### Sequential ATPG is Harder than Combinational

- Given: A sequential circuit, generate ATPG. Sometimes reset (starting) state available, sometimes not!
- Procedure: Activate a fault, and propagate it to PO
- Bottlenecks: Fault activation requires an "activation state". How to get to the activation state? Fault can be propagated to the next-state line, but not to PO? Unroll the machine, or in other words, traverse to other states.
- How to distinguish between Faulty and Fault-free machines? The concept of state distinguishing sequences.
- In absence of resets, how to synchronize both faulty and fault-free machines to the same states. Concept of synchronizing sequences.

## Untestable Faults in Sequential Circuits

A fault in a sequential circuit can be untestable due to four reasons:

- Redundancy in a combinational logic
- Lack of a common synchronizing sequence that can drive both faulty and fault-free machines to a common (starting) state
- Sequential Redundancy: a fault causes a transition to a (faulty) state which may be equivalent to a fault-free state
- Fault excitation or propagation requires getting to an unreachable state

We will look at all these cases!

- Start the machine in a reset state (00), traverse FSM
- At some point in the future, faulty and fault-free machines will diverge



Test:  $x_0 = 1, x_1 = 1, x_2 = 0, x_3 = 1$ 

- Start the machine in a reset state (00), traverse FSM
- At some point in the future, faulty and fault-free machines will diverge



Test:  $x_0 = 1, x_1 = 1, x_2 = 0, x_3 = 1$ 

- Start the machine in a reset state (00), traverse FSM
- At some point in the future, faulty and fault-free machines will diverge



Test:  $x_0 = 1, x_1 = 1, x_2 = 0, x_3 = 1$ 

- Start the machine in a reset state (00), traverse FSM
- At some point in the future, faulty and fault-free machines will diverge



Test:  $x_0 = 1, x_1 = 1, x_2 = 0, \underline{x_3 = 1}$ 

# Meaning of the above Test

- Fault D or  $\overline{D}$  gets into next state line.
- Faulty and Fault-free machines go to different states.
- Machine operation diverges....
- Sometime in the future, you can catch that effect.
- You can distinguish between faulty and faulty-free states of the machine.
- How? Using state distinguishing experiments.

#### When there is no reset state?

- Power up the machine, it can be in any (unknown) state
- Does there exist a sequence of inputs that can drive the machine to some singleton state?
- Some machines have a synchronizing sequence, others do not
- Given an FSM, how to find a synchronizing sequence?
- For ATPG: we are not given the FSM, only the circuit
- For ATPG: We need to find a synchronizing sequence for both the faulty and fault-free machines that can drive both to a common state. This can be hard.

# Synchronizing Sequence on an FSM

Table: State Transition Table

| P.S. | Next State, Z |       |
|------|---------------|-------|
|      | x = 0         | x = 1 |
| Α    | B, 0          | D, 0  |
| В    | A, 0          | B, 0  |
| C    | D,1           | A,0   |
| D    | D,1           | C,0   |

# This machine has no Synchronizing Sequence





## No Reset State Example: Test Exists

- No reset state. Start w/ Fault excitation state:  $y_1 = 0, y_2 = 1$ .
- x = 1 propagates the fault effect!
- Problem: How to get to the fault excitation state?
- Answer: Sequential backtrack! Unroll the m/c backwards until you can get unknown values in FFs. This implies there exists a state (backward in time from F.E. state) where you can "control" the FFs (control the state).
- Called Self-Initializing tests! This test implies that both faulty and fault-free machines can be initialized to a "common initial state"; i.e., you can get a common starting point.

Y = Next state FF inputs, y = present state FF output Generate a self initializing test: Start in Time Frame (TF) 1:

$$Y_2 = 1, Y_1 = 1, Z = D$$

This requires:  $y_1 = 0, y_2 = 1, x = 1$ 



If in TF 1, present states are  $y_1 = 0$ ,  $y_2 = 1$ , then in the previous state TF 0:  $Y_1 = 0$ ,  $Y_2 = 1$ . Make x = 1,  $y_1 = 0$ ,  $y_2 = 0$ 



In TF 0 :  $y_1 = 0$ ,  $y_2 = 0$ , then go back in time again TF -1:  $Y_1 = 0$ ,  $Y_2 = 0$  is needed, so apply x = 0



Test: TF -1 x = 0, TF 0 x = 1, TF 1 x = 1.





Slides updated Dec 1, 2021





Therefore, no test exists, deduced after 4 clock cycles of sequential backtrace!

#### Untestable Faults: Unreachable State



# Untestable Fault: Sequential Redundancy



States (110) and (010) are equivalent -> cannot be distinguished! What if fault takes m/c to 110 (faulty state), instead of 010 (fault free)?

#### Redundanct Circuit ATPG



#### Redundanct Circuit ATPG



Propagate from 
$$62 \rightarrow 7$$

$$32=1=) 3/2=0$$

$$62=0$$

#### Redundanct Circuit ATPG





# Simplify Sequential ATPG using Scan Design

- Primary inputs = controllable, Primary outputs = observable
- Lack of controllability and observability of Flip-Flops
- For testing purposes, make the flip-flops both controllable and observable
- Approach: Introduce Scan-registers
- Make a sequential circuit combinational for Testing



# Scan Flip-Flop Design

normal mode TI= TO= 8



# Scan Based ATPG: Use Shift-register Scan Chain



#### Other Test Problems: False Paths



- Input  $i_3 o r_1 o o_2$  is a multi-cycle False Path
- Cannot be sensitized: Need  $o_3 = 1$  in clock cycle 1, and  $o_3 = 0$  in clock cycle 2. Not possible

### IDDQ Testing: Measure Leakage Current

- Fault Location in Transistors: Test I<sub>DDQ</sub>
- Transistor can be stuck-ON or stuck-open. CMOS gates comsume NO static power.
- Test for  $N_c$  stuck-open:  $\langle V_1, V_3 \rangle$  Two vector test



## Delay Fault Testing

# BIST = built-in sey- test

- Gates do not switch at desired speed
- Find vectors that detect delay faults!
- Big challenge in Test Application: How to apply 2-vector tests using scan flip-flops at speed?



# Delay Fault Testing

- Gates do not switch at desired speed
- Find vectors that detect delay faults!
- Big challenge in Test Application: How to apply 2-vector tests using scan flip-flops at speed?

