# Design Verification and Test of Digital VLSI Circuits NPTEL Video Course

**Module-VII** 

Lecture-I

**Introduction to Digital VLSI Testing** 

#### **VLSI** Design, Verification and Test Flow



Verification of circuit extracted from layout with logic circuit

#### **VLSI Design, Verification and Test Flow**



## Introduction to Philosophy of Testing

- "If anything can go wrong, it will"--A very well known statement known as Murphy's Law.
- Testing a system comprises subjecting it to inputs and checking its outputs to verify whether it behaves as per the specifications targeted during design.

## Example: Electrical Iron

- Plug it in 220V AC and see if is heating.
  - "functional" specification, that also partially.
- Safety:
  - All exposed metal parts of the iron are grounded
  - Auto-off on overheating
- Detailed Functionality
  - Heating when powered ON.
  - Glowing of LED to indicate power ON.
  - Temperature matching with specification for different ranges that can be set using the regulator (e.g., woolen, silk, cotton etc.)

#### Example: Electrical Iron

- Performance
  - Power consumption as per the specifications
  - Time required to reach the desired temperature when range is changed using the regulator

#### Tests for ONLY electrical parameters.

- Tests for mechanical parameters, like maximum height from which there is resistance to breaking of plastic parts if dropped on a tiled floor etc.
- Number of tests performed depends on the time, equipments etc. which in turn is decided by the target price of the product.

## **Example: NAND Gate**



| Input |       | Output      |  |
|-------|-------|-------------|--|
| $v_1$ | $v_2$ | $o_1$       |  |
| 0     | 0     | 1           |  |
| 0     | 1     | 1<br>1<br>0 |  |
| 1     | 0     |             |  |
| 1     | 1     |             |  |

This test for the NAND gate is just the starting point

- Digital Functionality
  - Verify input/output of Table 1
- Delay Test
  - 0 to 1: time taken by the gate to rise from 0 to 1.
    - v1=1, v2=1 changed to v1=1, v2=0; After this change in input, time taken by  $o_1$  to change from 0 to 1.
    - v1=1, v2=1 changed to v1=0, v2=1; After this change in input, time taken by  $o_1$  to change from 0 to 1.
    - v1=1, v2=1 changed to v1=0, v2=0; After this change in input, time taken by  $o_1$  to change from 0 to 1.

- 1 to 0: time taken by the gate to fall from 1 to 0.
  - v1=0, v2=0 changed to v1=1, v2=1; After this change in input, time taken by  $o_1$  to change from 1 to 0.
  - v1=1, v2=0 changed to v1=1, v2=1; After this change in input, time taken by  $o_1$  to change from 1 to 0.
  - v1=0, v2=1 changed to v1=1, v2=1; After this change in input, time taken by  $o_1$  to change from 1 to 0.
- Fan-out capability:
  - Number of gates connected at  $o_1$  which can be driven by the NAND gate.

- Power consumption of the gate
  - Static power: measurement of power when the output of the gate is not switching.
  - Dynamic power: measurement of power when the output of the gate switches from 0 to 1 and from 1 to 0.
- Threshold Level
  - Minimum voltage at input considered at logic 1
  - Maximum voltage at input considered at logic 0
  - Voltage at output for logic 1
  - Voltage at output for logic 0
- Test at extreme conditions
  - Performing the tests at temperatures (Low and High Extremes) as claimed in the specification document.

Tests are for the "logic level" of the NAND gate.



**CMOS** implementation for the NAND gate

- Output Characteristics
  - a set of  $I_{DS}$  vs  $V_{DS}$  curves for different constant values of the gate-source voltage  $V_{GS}$
- Transfer characteristics
  - a set of  $I_{DS}$  vs  $V_{GS}$  curves for different values of the substrate-source voltage  $V_{RS}$ , at constant  $V_{DS}$
- Threshold Voltage Test
  - Threshold Voltage obtained in test, matches the specifications



Layout of a NAND gate in a silicon die

### **Optimal Quality of Test**

- Given a digital logic gate, what tests are to be performed to assure an acceptable quality of product at reasonable price".
- Test for the NAND gate should be such that results are accurate (say 99% above) yet time for testing is low (less than a millisecond).
  - Table 1 for the NAND gate and at proper time
- DIGITAL TESTING is not testing digital circuits (comprised of logic gates).

DIGITAL TESTING is defined as testing a digital circuit to verify that it performs the specified logic functions and in proper time.

### **Optimal Quality of Test**

- Given a digital logic gate, what tests are to be performed to assure an acceptable quality of product at reasonable price".
- Test for the NAND gate should be such that results are accurate (say 99% above) yet time for testing is low (less than a millisecond).
  - Table 1 for the NAND gate and at proper time
- DIGITAL TESTING is not testing digital circuits (comprised of logic gates).

DIGITAL TESTING is defined as testing a digital circuit to verify that it performs the specified logic functions and in proper time.

## VLSI circuit testing Versus Classical System Testing

| VLSI Testing                                                                                               | Classical Systems                                     |  |
|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--|
| Technology matures and faults tend to decrease, a new technology based on lower sub-micron devices evolves | Basic technology is matured and well tested           |  |
| Diagnosed and repaired                                                                                     | Binned as defective and scrapped (i.e., not repaired) |  |
| Yield is Low                                                                                               | Yield is almost 100%                                  |  |
| Expensive equipments and Specialized Manpower                                                              | Simple Test Setups and Technicians                    |  |
| All Samples to be tested                                                                                   | Random Sample Testing                                 |  |
| Test arrangements in design                                                                                | Rarely Required                                       |  |

## Digital VLSI test process

Output response

Test pattens
Applied from tester



## **Automatic Test Equipment**



## **Taxonomy of Digital Testing**

| Criterion              | Attributes of testing method | Terminology                  |  |
|------------------------|------------------------------|------------------------------|--|
| When tested?           | 1. Once after                | 1. Manufacturing Test        |  |
|                        | manufacture                  | 2. Built in self test (BIST) |  |
|                        | 2. Once before startup of    | 3. On-line testing (OLT)     |  |
|                        | circuit                      |                              |  |
|                        | 3. Always during the         |                              |  |
|                        | system operation             |                              |  |
| Where is the source of | 1. An external tester        | 1. Automatic Test Equipment  |  |
| Test patterns?         | 2. Within the chip           | (ATE) based testing          |  |
|                        | 3. No patters applied,       | 2. BIST                      |  |
|                        | only monitoring              | 3. OLT                       |  |

## **Taxonomy of Digital Testing**

| Criterion             | Attributes of testing method | Terminology               |  |
|-----------------------|------------------------------|---------------------------|--|
| Circuit in which form | Wafer                        | 1. Non packaged IC level  |  |
| is being tested?      | IC                           | testing                   |  |
|                       | Board                        | 2. Packaged level testing |  |
|                       | System                       | 3. Board level testing    |  |
|                       |                              | 4. System level testing   |  |
| How are the test      | 1. In a fixed                | Static Testing            |  |
| patterns applied?     | predetermined order          | Adaptive testing          |  |
|                       | 2. Depending on results      |                           |  |

## Taxonomy of Digital Testing

| Criterion             | Attributes of testing method | Terminology                 |
|-----------------------|------------------------------|-----------------------------|
| How fast are the test | 1. Much slower than the      | 1. DC (static) testing      |
| patterns applied?     | normal speed of              | 2. At-speed testing         |
|                       | operation                    |                             |
|                       | 2. At normal speed of        |                             |
|                       | operation                    |                             |
| Who verifies the test | 1. On chip circuit           | 1. BIST                     |
| results by matching   | 2. ATE                       | 2. Automatic Test Equipment |
| with golden response? |                              | (ATE) based testing         |
|                       |                              |                             |

#### **Test Economics**

- Man hours for test plan development:
- Expert test engineers to make elaborate test plans.
- CAD tools for Automatic Test Pattern Generation
- Cost of ATE
- ATE is a multimillion dollar instrument.
- Cost of testing a chip in an ATE is dependent on
  - time a chip is tested,
  - the number of inputs/outputs pins
  - frequency the test patters are to be applied

#### **Test Economics**

- DFT/BIST circuitry
  - Additional circuitry kept on-chip to help in testing results in raise in chip area
  - Rise in area power and lower yield
- At-speed testing by ATE is extremely expensive.
   Tradeoff
- Returns
  - Proper binning of Chips:
  - In case of VLSI testing, it is not of much concern as how many chips are binned as faulty, rather important is how many faulty chips are binned as normal.
    - So, economic return from "VLSI testing" is the accuracy in shipping functionally perfect chips.

#### What we will study?

- Test
- Introduction to Digital Testing
- Lecture-II: Functional vs. Structural Testing
- Lecture-III: Fault Equivalence, Fault Dominance, Fault Collapsing and Checkpoint Theorem
- Fault Simulation and Testability Measures
- Lecture-I and II: Circuit Modeling and Algorithms for Fault Simulation
   Lecture-III: Combinational SCOAP Measures and Sequential SCOAP Measures
- Combinational Circuit Test Pattern Generation
- Lecture-I: Introduction to Automatic Test Pattern Generation (ATPG) and ATPG Algebras
- Lecture-II: Standard ATPG Algorithms

#### What we will study?

- Sequential Circuit Testing and Scan Chains
- Lecture-I: ATPG for Single-Clock
   Synchronous Circuits
- Lecture-II and III: Scan Chain based
   Sequential Circuit Testing

- Built in Self test (BIST)
- Lecture I: Introduction to BIST architecture
- Lecture II and III: Memory BIST

## Thank you

# Design Verification and Test of Digital VLSI Circuits NPTEL Video Course

Module-VII

Lecture-II

Functional and Structural Testing

#### Introduction



| Test     | Pattern | Test Pattern                            | Output |
|----------|---------|-----------------------------------------|--------|
| No.      |         |                                         |        |
| 1        |         | 000000000000000000000000000000000000000 | 0      |
| 2        |         | 000000000000000000000000000000000000000 | 0      |
|          |         | •••••                                   | 0      |
| $2^{25}$ |         | 11111111111111111111111                 | 1      |

#### Test patterns for functional testing

#### Introduction

- •Need to apply 2<sup>25</sup> test patterns.
- •1000000 patterns per second (Mega Hz Tester), time required is 33 Seconds per chip.
- About million chips are to be tested in a run

33000000 Seconds or 550000 Hours or 22916 Days or 62 years.

Functional Testing cannot be performed due to extremely high testing time.

#### **Structural Testing**

- Structural testing, introduced by Eldred, verifies the correctness of the specific structure of the circuit in terms of gates and interconnects
- •Structural Testing takes many fold less time compared Functional Testing yet maintaining the quality of test solution.
- Structural testing does not check the functionality of the entire circuit rather verifies if all the structural units (gates) are fault free. So structural testing is a kind of functional testing at unit (gate) level.

#### **Structural Testing Example**



## **Structural Testing Example**

- Number of test patterns required are 6.2<sup>5</sup>
   (=160), which is many fold smaller than those required for functional testing (2<sup>25</sup>).
- Time required for testing the circuit the using a 1 Mega Hz Tester is 0.000016 seconds and for a million samples is 16 seconds.

Structural testing is highly beneficial over functional testing.

## Structural Testing—Penalties

- Each individual gate is tested; however, the integration is not tested.
- To test the individual gates, controlling and observing values of intermediary nets in a circuit becomes mandatory, which adds to extra pins and hardware
- Circuit with about a million internal lines needs a million 2-1 Multiplexers and same number of extra pins. This requirement is infeasible.

## **Structural Testing—Penalties**



#### **Structural Testing With Internal Memory**



A 32-bit adder requires 2<sup>32</sup> test patterns for exhaustive functional testing.

#### **Structural Testing With Internal Memory**



- •The 32-bit adder requires 2<sup>3</sup> test patterns for exhaustive structural testing.
- Extra Pins 3
- •2 Sets of Registers
- •2:1 Muxes

## **Structural Testing With Internal Memory**

- Use of internal registers
  - Problem of huge number of extra pins could be solved
  - •Added huge size of shift registers (equal to number of internal nets). In a typical circuit there are tens of thousand of internal lines.
- •Efficient structural testing is the one with less number of on-chip components and yet maintaining the quality of test solution.

#### Structural testing with Fault Models is the answer to the requirement

"Structural testing is functional testing at a level lower than the basic inputoutput functionality of the system".

- •Bitwise ANDing circuit, unit for structural testing--gates
- •32-bit adder---full adders

Digital circuits, structural testing is ``functional testing at the level of gates and flip-flops

# **Structural Testing with Fault Models**

- Structural testing with fault models involves verifying each unit (gate and flip flop) is free from faults of the fault model.
- A model is an abstract representation of a system.
  - modeling reduces the complexity in representation but captures all the properties of the original system required for the application in question.
- Fault model is an abstraction of the real defects in the silicon such that
  - the faults of the model are easy to represent
  - should ensure that if one verifies that no faults of the model are in the circuit, quality of test solution is maintained.

# **Structural Testing with Fault Models**

- Unconnected net I1 is the defect.
- Error is, when I1=1, I2=1,I3=1,I4=1, I5=1 but OG1=0 (should be 1 in normal case).
- Fault is, net I1 is stuck at 0 (when gate is modeled at binary logic level).



# **Types of Fault Models**

- Stuck-at fault model: Faults are fixed (0 or 1)
   value to a net. Stuck at-0 and Stuck at-1
  - single stuck-at fault model
  - Multiple stuck at fault model
- Delay fault model: Increase the input to output delay of one logic gate, at a time.
- Bridging Fault: A short between a group of nets
  - AND Bridge
  - OR Bridge

#### Single Stuck-at Fault Model: Fanouts



If fanout along with all its branches is a single electrical net, then why fault in a branch does not affect the others?

- •Only one net is faulty at a time.
- •The faulty net is permanently set to either 0 or 1.
- •The branches of a fanout net are independent with respect to locations and affect of a stuck-at fault.

## Single Stuck-at Fault Model

- •Several stuck-at faults can be simultaneously present in the circuit.
  - •A circuit with *n* lines can have 3<sup>n</sup>-1 possible stuck line combinations; each net can be: s-a-1, s-a-0, or fault-free.
- •Handling multiple stuck-at faults in a typical circuit with some hundreds of thousands of nets is infeasible.

Single stuck-at fault model is manageable in number and also provides acceptable quality of test solution, it is the most accepted fault model.



I1=1, I2=1,....,I25=1, is a test pattern for the stuckat-0 fault at net I1



I1=0, I2=1,....,I25=1, is a test pattern for the stuck-at-1 fault at net I1.



I1=0, I2=1,....,I25=1, is a test pattern for the stuckat-1 fault at net output of G1.

I1=0, I2=1,....,I25=1 tests both s-a-1 at net I1 and output of G1.

In structural testing with stuck-at fault model, one test pattern can test more than one fault.

# Pros and cons for structural testing with stuck-at fault model

#### Pors

- No extra pin outs or DFT circuitry like 2-1 Multiplexers and shift resisters for controlling and observing internal nets
- Low test time as one test pattern can test multiple stuck-at faults

#### Cons

 Functionality is not tested, even for the units (gates and Flip-flops). However, testing history reveals that even with this price paid, quality of test solution is maintained.

# Comparison of structural and functional testing

| Structural Testing                                                   |
|----------------------------------------------------------------------|
| With fault models.                                                   |
| Automatic test pattern generation (ATPG).                            |
| Efficient and automated.                                             |
| Fault Coverage is a quantified metric.                               |
| Less Test Patterns                                                   |
| Difficult to be applied at the speed the design is expected to work. |
|                                                                      |

# **Questions and Answers**

 What are the problems of structural testing without fault models, if the units are as atomic as gates and as large as arithmetic block like 32-bit adder and 64-multiplier

 How many silicon level defects result in nets getting stuck? Explain relevance of stuck-fault model from that perspective

# Thank you

# Design Verification and Test of Digital VLSI Circuits NPTEL Video Course

Module-VII

Lecture-III

Fault Equivalence

# Introduction

- If there are n nets in a circuit then there can be 2n stuck-at faults
- The number of test patterns is liner in the number of nets in a circuit.
- The total number of test patterns required 2n??





I1=0, I2=1,....,I25=1, is a test pattern for the stuck-at-1 fault at net I1.



I1=0, I2=1,....,I25=1, is a test pattern for the stuckat-1 fault at net output of G1.

I1=0, I2=1,....,I25=1 tests both s-a-1 at net I1 and output of G1.

In structural testing with stuck-at fault model, one test pattern can test more than one fault.

#### Fault Equivalence For Single Stuck-At Fault Model

 Two stuck-at faults f1 and f2 are called equivalent iff the output function represented by the circuit with f1 is same as the output function represented by the circuit with f2.
 Obviously, equivalent faults have exactly the same set of test patterns.



In the AND gate of Figure 1, all stuck-at-0 faults are equivalent as they transform the circuit to O=0 and have I1=1, I2=1 as the test pattern.

#### Fault Equivalence For Single Stuck-At Fault Model



(a) Fault Equivalence of AND gate



(b) Fault Equivalence of NAND gate



(c) Fault Equivalence of OR gate



(d) Fault Equivalence of NOR gate



(f) Fault Equivalence of NOT gate

All stuck-at-0 faults are equivalent as they transform the circuit to O=0 and have I1=1, I2=1 as the test pattern.

#### **Fault Equivalence For Single Stuck-At Fault Model: Fanouts**





The faults in the stem and branches are not equivalent.

Fault at stem results in same output functions of the stem and the branches Fault is in branch I1', then function of stem is I1=0/1 (as driven) and for the branch I1' (I1") function is I1'=0 (I1"=I1).

Output function of I1' is different from I1 and I1".

#### **Fault Equivalence based Collapsing: Example**



(a) Circuit with all possible stuck at faults

#### **Fault Equivalence based Collapsing: Example**



(b) Circuit after collapsing equivalent faults at level 1

#### **Fault Equivalence based Collapsing: Example**



(c) Circuit after collapsing equivalent faults at level 2

#### **Fault Equivalence based Collapsing: Example with fanouts**



(a) Circuit (having fanout) with all possible stuck at faults

#### **Fault Equivalence based Collapsing: Example with fanouts**



(b) Circuit after collapsing equivalent faults at level 1

#### **Fault Equivalence based Collapsing: Example with fanouts**



(c) Circuit after collapsing equivalent faults at level 2

## Fault Dominance For Single Stuck-At Fault Model

• If all tests of a stuck-at fault f1 detect fault f2 then f2 dominates f1. If f2 dominants f1 then f2 can be removed and only f1 is retained.



### Fault Dominance For Single Stuck-At Fault Model





(a) Fault Dominance of AND gate and Collapsing

Can be deleted s-a-1

(c) Fault Dominance of OR gate and Collapsing



(b) Fault Dominance of NAND gate and Collapsing

s-a-1

(d) Fault Dominance of NOR gate and Collapsing

#### **Fault Dominance based Collapsing: Example**



(a) Circuit after collapsing all equivalent faults

#### Fault Dominance based Collapsing: Example



(b) Circuit after collapsing all dominating faults at level 1

#### **Fault Dominance based Collapsing: Example**



(c) Circuit after collapsing all dominating faults at level 2

#### **Fault Dominance based Collapsing: Example with fanouts**



(a) Circuit (having fanout) after collapsing equivalent faults

#### **Fault Dominance based Collapsing: Example with fanouts**



(b) Circuit (having fanout) after collapsing all dominated faults at level 1

#### **Fault Dominance based Collapsing: Example with fanouts**



(c) Circuit (having fanout) after collapsing all dominated faults at level 2

# Check point theorem.

- A circuit with no fanouts, s-a-0 and s-a-1 faults is to be considered only at the primary inputs. So in a fanout free circuit test patters are 2x(Number of primary inputs).
- For circuit with fanout, checkpoints are primary inputs and fanout branches. Faults are to be kept only on the checkpoints.
- So a test pattern set that detects all single stuck-at faults of the checkpoints detects all single stuck-at faults in that circuit.

# **Questions and Answers**

 For what class of circuits, maximum benefit is achieved due to fault collapsing and when the benefits are less? What is the typical number for test patterns required to test these classes of circuits?

 What faults can be collapsed by equivalence in case of XOR gate?

## **Answers**

$$I1=1$$
 $I2=1$ 
 $I1=1$ 
 $I1=1$ 

$$I1=1$$
 $I2=1$ 
 $O$ 
 $I2 ext{ if fault}$ 
 $I1 ext{ XOR I2}, ext{ if no fault}$ 

$$I1=1$$
 $I2=1$ 
 $O$ 
 $I1 \text{ if fault}$ 
 $I1 \text{ XOR } I2$ , if no fault}
 $S-a-1$ 

# Thank you