

# ATG FOR SSFs IN SEQ. CIRCUITS TEST OF BRIDGING FAULTS

Weidong Li

Electronics System, Dept. of EE. Linköping University, Sweden

Testing of Digital Systems, 2000-11-29





## **ATG FOR SSFs IN SEQUENTIAL CIRCUITS**

- **X** Introduction
- **X** TG using iterative array models
- **X** Simulation-based TG
- **X** Random TG
- **X** Other TG methods





## Introduction

## **X** Sequential circuits:

Synchronous seq. circuits and asynchronous seq. circuits



#### **X** What make(s) differences?

States: controllability (how to ensure state q) and observability (how to know state q+) State for sure?





# TG Using Iterative Array Models

#### **X** Basic instinct

State => Stateless

### **X** Terminology

Iterative combinational array: Unrolling of syn. seq. circuits into combinational cell array.

\* time domain ==> space domain

Time frame: each cell in iterative comb. array (both state and PIs at certain clk period).

#### **X** TG using iterative array models

Direct extension of from combinational circuits:

- \* Target Fault => Combinational test vector & Error propagation
- \* Combinational vector => PIs and State q (line justification)
- \* "Justify" state q (state initiation)
- \* Error propagation => POs and State q+
- \* POs => Bingo! State q+ => "propagate" q+ to POs

Known initial state => state generation from initial state ==> NP-problem

Unknown initial state => state learning (self-initialization) ==> NP-problem





#### **X** General algorithm (Under assumption that clock line is fault-free)

```
r=1
                                               p=0
repeat
 Begin
                                               repeat
    Build model with r time frames
                                                 begin
    ignore the POs in the first r-1 frames
                                                   build model with p+r time frames
    ignore the q+ outputs in the last frame
                                                   ignore the POs in the first p+r-1 frames
    q(1)=given initial state
                                                   ignore the q+ outputs in the last frame
                                                   if (test generation success) and every q
    if (test generation success) then return
       SUCCESS
                                                       input in the first frame has value x)
                                                       then return SUCCESS
    r=r+1
  end
                                                   increment r or p
until r = f_{\text{max}}
                                                 end
return FAILURE
                                               until (r+p=f_{\max})
                                               return FAILURE
```

#### Algorithm for known initial state

Algorithm for unknown initial state

fmax: maximum number of frames, determined by cost function.





## **X** Example 6.18:



 $y_2(0)$ 

 $y_1(0)$ 

line a: s-a-1 fault. Known state (0, 0).

Time frame 1:

Fault activation: I(1)=1.

Fault propagation ==> PO Z: y2=>y1=>Z

Time frame 2:

 $I(2)=1: y2(1) \overline{D} => y1(2).$ 

Time frame 3:



I(0)



#### **X** Drawbacks:

- \* non a priori problem (unknown r/p)
- \* Discard of r-1 (r+p-1) computations => reuse
- \* Fault absorption could cause infinite loop => state monitor and/or  $f_{\text{max}}$ .





- **✗** EBT (Extended BackTrace)
  - \* Don't like *r*>0
  - \* Increase only *p*

## X Critical-path TG

- \* Start with a known state (reset)
- \* Start with fault activation, search the error propagation path towards POs





#### **X** Clock(s)

Fault at clock line => No state updating

Explicit clock line

Propagate both  $1/q_i$  and  $0/q_i$  fault effect to POs (?)

#### **X** Complexity issues

Relative to

- \* number of cycles
- \* number of F/Fs per cycle
- \* number of cycles a F/F is involved in

#### **MUCH MORE COMPLICATED**



# Asynchronous circuits

#### **X** Difficulties

Race problem

Why it is less in synchronous circuits?

Feedback identification

Delay variation

#### **X** Iterative models

PIs do not change until stable state is reached.

#### **X** Discussion

"Global asynchronous, local synchronous" is a favour strategy for SoC. As observed from above, the asynchronous circuits are much difficult for testing. How to meet this challenge?



## Simulation-Based TG

## **X** Principle

- ◆ Generate test vectorsRandom generate or non random generate
- ◆ Evaluate cost of test vectors according to the simulation
- ◆ Select test vectors to test sequence

#### **✗** Cost function evaluation [Agrawal88]

- ◆ Initialization: number of F/Fs with unknown state.
- ◆ TG for group faults: summarize all cost value of activated faults.
- ◆ TG for individual faults: measurement from current state.

Heuristic optimization





# TG Using RTL Models

Know functionality of component, don't care or unknown gate-level model.

#### **X** Extensions of *D*-Algorithm

- ◆ Keep overall structure, extend operations.
- ◆ Line-justification: find operation set to create fault.
- ◆ Implication based on component operators at RTL (state).
- ◆ Error-propagation: find operation set that propagate fault to output registers. In text book, the output registers are limited to data output (?).
- Advantage:
  - ♦ Higher level ==> increase the efficiency
  - ◆ IP-core
  - ♦ Suitable for DFT methods like scan-test etc.
- Disadvantage:
  - ◆ Limited to operations



# TG Using RTL Models (cont.)

#### **X** Heuristic State-Space Search

SCIRTSS(Sequential CIRcuit Test Search System)

- ◆ Separation of datapath and control-part
- ◆ Utilize combinational TG to activate fault
- ◆ Find state set to propagate the fault involving heuristic function

$$H_n = G_n + wF_n$$
  
 $G_n$ : sequence length,  $w$ : weight,  $F_n$ : heuristic function.  
 $F_n$ : fault proliferation function, or distance to goal node, or state trans.



## Random TG

#### **X** Problem

- ◆ Initialization: initial state requires a deterministic sequences
- ◆ "Coloured lines: control lines are more weighted
- **♦** Evaluation

#### **X** Solution

- ◆ Initialization difficulty ==> semirandom
- ◆ "Coloured lines"==> nonuniform signal probability
- ◆ Evaluation ==> modify the goal function, take account of propagation



## Other TG Methods

## **X** Hardware support for TG

◆ Advantage: concurrence

◆ Disadvantage: reuse?

## **X** Artificial intelligence techniques

◆ HITEST: combines algorithmic procedures and user-provided knowledge



#### **TESTING OF BRIDGING FAULTS**

- **X** Bridging-fault model
- **X** Detection of NFBFs
- **X** Detection of FBFs
- **X** BFs simulation
- **X** TG for BFs





# Bridging-Fault Model

## **X** Bridging fault

Faults are caused by shorts between two (or more) normally unconnected signal lines.

## **X** Bridging-fault model



Logic function Z(x, y)



#### **X** BF model used in text book

- lacktriangle Z(x, y) = x.y AND BFs
- lacktriangle Z(x, y) = x + y OR BFs

#### **X** Multiple bridging-fault model

Multiple signal lines short

◆ AND/OR BFs?

Enough with this model? (Resistive BF model, Pattern dependent model etc.)

#### **X** Fault activation

Short signal lines must have different logic values.

Behave differently from proposed function.



## Detection of NFBFs

#### **X** AND NFBFs

- Non Feedback Bridging Faults: No combinational loop.
- ◆ Theorem 7.1: bridge between SSFs and BFs.
  A test detects the (x.y) iff either t detects x s-a-0 and sets y=0 or sets x=0 and y s-a-0.
- lacktriangle Corollary 7.1: Fanout-free x and y are inputs to the same OR/NOR gate, then the AND BF(x.y) dominates both x s-a-0 and y s-a-0.
- Corollary 7.2: Let x be a line with fanout and y a line without. If x and y are inputs to the same OR/NOR gate, then the AND BF(x.y) dominates y s-a-0.





## Detection of FBFs

#### **X** AND FBFs

- ◆ Combinational logic ==> sequential logic (Loop ==> Oscillation possible)
- lacktriangle Theorem 7.2: A test t detects f s-a-0 and sets b=0 detects the AND FBF(b.f).
- ♦ Theorem 7.3: A test t detects b s-a-0 and sets f=0 without sensitizing f detects the AND FBF(b.f).
- Corollary 7.3: Let (b.f) be an AND FBF such that all paths between b and f have even inversion parity. A test t detects either f s-a-0 and sets b=0, or b s-a-0 and sets f=0, also detects (b.f).
- Corollary 7.4: Let (b.f) be an AND FBF such that any path between b and a primary output goes through f. A test t detects (b.f) iff t detects f s-a-0 and sets b=0.





# Detection of FBFs(cont.)

#### **X** AND FBFs(cont.)

- Corollary 7.5: Let (b.f) be an AND FBF where b and f are such that f=1 whenever b=0 (in the fault-free circuit). A test t detects (b.f) iff t detects f s-a-0 and sets b=0.
- Corollary 7.6: No signal test can detect an AND FBF (b.f) such that every path between b and a primary output goes through f, and f=0 whenever b=0.





# Bridging Faults Simulation

#### **X** Complexity (compare with SSFs)

- ◆ Structure and function
- ◆ The number of feasible BFs

#### **X** Implicit simulation method

- ◆ Based on relation between BFs and SSFs
- ◆ Layout information available ==> Complexity reduction!
- lacktriangle AND BFs: detects x s-a-0, find possible sets y y=0 in the neighbours, check propagation path.

Good fault coverage of SSFs ==> good fault coverage of BFs?





## TG for BFs

$$X$$
 TG of BFs = SSFs + sets

- ◆ Based of relationship of BFs and SSFs
- lacktriangle Generate TG for x s-a-v
- Justify y  $y=\overline{v}$
- lacktriangle FBFs: find y  $y=\overline{v}$  between x's successors and implications

Of the same complexity order.

