

# Tutorial intitulé "Power-Aware Testing and Test Strategies for Low Power Devices"

Patrick Girard, Xiaoqing Wen, Nicola Nicolici

# ▶ To cite this version:

Patrick Girard, Xiaoqing Wen, Nicola Nicolici. Tutorial intitulé "Power-Aware Testing and Test Strategies for Low Power Devices". ITC'2009: International Test Conference, Nov 2009, Austin, Texas, United States. lirmm-00820646

# HAL Id: lirmm-00820646 https://hal-lirmm.ccsd.cnrs.fr/lirmm-00820646v1

Submitted on 6 May 2013  $\,$ 

**HAL** is a multi-disciplinary open access archive for the deposit and dissemination of scientific research documents, whether they are published or not. The documents may come from teaching and research institutions in France or abroad, or from public or private research centers. L'archive ouverte pluridisciplinaire **HAL**, est destinée au dépôt et à la diffusion de documents scientifiques de niveau recherche, publiés ou non, émanant des établissements d'enseignement et de recherche français ou étrangers, des laboratoires publics ou privés.

# Full-day tutorial on Power-Aware Testing and Test Strategies for Low Power Devices

Patrick GIRARD LIRMM / CNRS France

Nicola NICOLICI McMaster University Canada

Xiaoqing WEN Kyushu Institute of Technology Japan







#### **Motivation and Objectives**

# **Power Impact on Test**

- Power constraints have severe impact on test
- Implications to test and DfT engineers / test tool developers :
  - Reduce power consumption also in test mode
  - Dedicated test strategies for low-power devices are needed
- Objectives of this tutorial:
  - Learning more about the impact of power during test
  - How to alleviate test power issues
  - How low-power devices and power management structures can be tested safely







#### 1. Introduction

Many industrial experiences reported in the literature

[ITC 2003] : Texas Inst. & Siemens AG ASIC (arithmetic) with Scan, 1M gates, 300kbits SRAM

Toggle activity under functional mode : 15%-20% Toggle activity under test mode : 35%-40%

[ITC 2008] : Freescale

Power under test mode up to 3.8X power during functional mode

And many other experiences ...



#### 1. Introduction

#### Many reasons (ii)

#### • Typical power management schemes are disabled during testing

- Clock gating is turned off to improve observability of internal nodes
- Dynamic frequency scaling is turned off because:
  - ✓ The system clock is bypassed, or
  - ✓ The PLL suffers from a relocking time overhead during which no meaningful test can be conducted
- Dynamic voltage scaling is usually avoided due to time constant in stabilizing supply voltage







#### 2. Power Issues during Test

**Chapter 2** 

# **Power Issues during Test**

#### 2. Power Issues during Test

# 2.1 Power and Energy Basics

- Static Leakage Power
  - Power consumed when the circuit is idle
  - The static power dissipation of a circuit is given by

$$P_{stat} = \sum_{i=1}^{n} I_{stat_i} \cdot V_{DD}$$

where  ${\rm I}_{\rm stat}$  is the current that flows between the supply rails in the absence of switching activity and i is the index of a gate in a circuit consisting of n gates.



























# <section-header><section-header><section-header><list-item><list-item><list-item><list-item>





#### 2. Power Issues during Test

## 2.7 Test Power Metrics and Estimation

- Instantaneous Power:
  - Power consumed at any given instant during test
- · Peak Power:
  - Highest value of instantaneous power measured during test
  - $P_{Peak} = max_k P_{inst}(V_k) = max_k (E_{Vk} / t_{small})$
  - Determines the thermal and electrical limits of components and the system packaging requirements
- Weighted Switching Activity (WSA):
  - WSA<sub>i</sub> = F<sub>i</sub> . S<sub>i</sub> where F<sub>i</sub> is the fanout at node i and S<sub>i</sub> is the switching activity factor (ave. # of transitions during a time interval)
  - Often used as a metric for test power evaluation

#### 2. Power Issues during Test

# 2.7 Test Power Metrics and Estimation

- Impact of the various metrics:
  - The switching activity factor (s<sub>i</sub>) affects E<sub>Total</sub>, P<sub>average</sub> and P<sub>peak</sub>
  - Clock frequency during test affects P<sub>average</sub> and P<sub>peak</sub>
  - Test length affects E<sub>Total</sub>
- Static power dissipation:
  - For a given technology, depends only on input patterns and T°
  - Static power dissipation is not a concern, except during during I<sub>DDQ</sub> testing (reduced sensitivity) and during Burn-In test (can result in thermal runaway condition and yield loss)



- Estimation is performed at various PVT corners
- Challenges for multi-million gate SoCs
  - ✓ Time-consuming
  - ✓ Memory sizes can be very large
- The weigthed transition metric is quick but approximate

 $WeightedTransitions = \sum (ScanChainLength - TransitionPositionInVector)$ 



























### 3.2 Low-Power Test Compaction

# **Content**

- $\textcircled{0} \ \ \, \text{Low-Shift-Power Static Dynamic Compaction}$
- **②** Low-Capture Static Compaction





| 3.3 Low-Power X-F                                             | illing                                  |                             |
|---------------------------------------------------------------|-----------------------------------------|-----------------------------|
|                                                               | <u>Outline</u>                          |                             |
|                                                               | Low-Shift-Power X-Filling               |                             |
| Shift-In Power Reduction                                      | Shift-Out Power Reduction               | Total Shift Power Reduction |
| 0-fill<br>1-fill<br>MT-fill<br>adjacent fill / repeat fill    | output-justification-based<br>X-filling | MTR-fill                    |
|                                                               | Low-Capture-Power X-Filling             |                             |
| FF-Oriented                                                   | Node-Oriented                           | Critical-Area-Oriented      |
| PMF-fill<br>LCP-fill<br>preferred fill<br>JP-fill<br>CTX-fill | PWT-fill<br>state-sensitive X-filling   | CCT-fill                    |
| Lov                                                           | v-Shift-and-Capture-Power X-F           | illing                      |
| impact-oriented X-filling                                     | hybrid X-filling                        | bounded adjacent fill       |
| Low-Pow                                                       | er X-Filling for Compressed Sc          | an Testing                  |
| 0-fill                                                        | PHS-fill                                | CJP-fill                    |







| Procedure XID (C, T)<br>C: circuit model;<br>T: initial test vector set;<br>{<br>/* Pass-1 */<br>for each test vector v <sub>i</sub> in T {<br>EF = find_essential_fault (v <sub>i</sub> ); /* Step-1 */<br>initial_c <sub>i</sub> = create_test_cube (EF); /* Step-2 */<br>3_valued_fault_simulation (initial_c <sub>i</sub> ); /* Step-3 */<br>}<br>/* Pass-2 */<br>for each test vector t <sub>i</sub> in T {<br>UF = find_undetected_fault (v <sub>i</sub> , c <sub>i</sub> ); /* Step-4 */<br>final_c <sub>i</sub> = adjust_test_cube (UF); /* Step-5 */<br>3_valued_fault_simulation (final_c <sub>i</sub> ); /* Step-6 */ | Test Cube Generation<br><u>Test Relaxation</u><br>[Basic Procedure] |              |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--------------|--|
| C: circuit model;<br>T: initial test vector set;<br>{<br>/* Pass-1 */<br>for each test vector v <sub>i</sub> in T {<br>EF = find_essential_fault (v <sub>i</sub> ); /* Step-1 */<br>initial_c <sub>i</sub> = create_test_cube (EF); /* Step-2 */<br>3_valued_fault_simulation (initial_c <sub>i</sub> ); /* Step-3 */<br>}<br>/* Pass-2 */<br>for each test vector t <sub>i</sub> in T {<br>UF = find_undetected_fault (v <sub>i</sub> , c <sub>i</sub> ); /* Step-4 */<br>final_c <sub>i</sub> = adjust_test_cube (UF); /* Step-5 */<br>3_valued_fault_simulation (final_c <sub>i</sub> ); /* Step-6 */                         | Procedure XID (C, T)                                                |              |  |
| <pre>/: initial test vector set; {     /* Pass-1 */     for each test vector v<sub>i</sub> in T {         EF = find_essential_fault (v<sub>i</sub>); /* Step-1 *,         initial_c<sub>i</sub> = create_test_cube (EF); /* Step-2 *,         3_valued_fault_simulation (initial_c<sub>i</sub>); /* Step-3 *,     }     /* Pass-2 */     for each test vector t<sub>i</sub> in T {         UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 *,         final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 *,         3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */     } </pre>          | C: circuit model;                                                   |              |  |
| <pre>{     /* Pass-1 */     for each test vector v<sub>i</sub> in T {         EF = find_essential_fault (v<sub>i</sub>); /* Step-1 *,         initial_c<sub>i</sub> = create_test_cube (EF); /* Step-2 *,         3_valued_fault_simulation (initial_c<sub>i</sub>); /* Step-3 *,     }     /* Pass-2 */     for each test vector t<sub>i</sub> in T {         UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 *,         final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 *,         3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */     } </pre>                                      | I: initial test vector set;                                         |              |  |
| <pre>/* Pass-1 */ for each test vector v<sub>i</sub> in T {     EF = find_essential_fault (v<sub>i</sub>); /* Step-1 */     initial_c<sub>i</sub> = create_test_cube (EF); /* Step-2 */     3_valued_fault_simulation (initial_c<sub>i</sub>); /* Step-3 */ } /* Pass-2 */ for each test vector t<sub>i</sub> in T {     UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 */     final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 */     3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */</pre>                                                                                           | {                                                                   |              |  |
| <pre>F = find_essential_fault (v<sub>i</sub>); /* Step-1 */ initial_c<sub>i</sub> = create_test_cube (EF); /* Step-2 */ 3_valued_fault_simulation (initial_c<sub>i</sub>); /* Step-3 */ } /* Pass-2 */ for each test vector t<sub>i</sub> in T { UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 */ final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 */ 3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */</pre>                                                                                                                                                                           | /^ Pass-1 ^/                                                        |              |  |
| <pre>EF = find_essential_rauit (v<sub>i</sub>); /* Step-1 *,<br/>initial_c<sub>i</sub> = create_test_cube (EF); /* Step-2 *,<br/>3_valued_fault_simulation (initial_c<sub>i</sub>); /* Step-3 *,<br/>}<br/>/* Pass-2 */<br/>for each test vector t<sub>i</sub> in T {<br/>UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 *,<br/>final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 *,<br/>3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */</pre>                                                                                                                                          | for each test vector $V_i$ in $T \{$                                | /* Chan 1 */ |  |
| <pre>initial_ci = create_test_cube (EF); /* Step-2 *, 3_valued_fault_simulation (initial_ci); /* Step-3 *, } /* Pass-2 */ for each test vector ti in T {     UF = find_undetected_fault (vi, ci); /* Step-4 *,     final_ci = adjust_test_cube (UF); /* Step-5 *,     3_valued_fault_simulation (final_ci); /* Step-6 */</pre>                                                                                                                                                                                                                                                                                                   | $EF = find_essential_fault (V_i);$                                  | /* Step-1 */ |  |
| <pre>3_valued_fault_simulation (initial_c_i); /* Step-3 *, } /* Pass-2 */ for each test vector t<sub>i</sub> in T {     UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 *,     final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 *,     3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */</pre>                                                                                                                                                                                                                                                                                            | initial_c <sub>i</sub> = create_test_cube (EF);                     | /^ Step-2 ^/ |  |
| <pre>} /* Pass-2 */ for each test vector t<sub>i</sub> in T {     UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 *,     final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 *,     3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */</pre>                                                                                                                                                                                                                                                                                                                                                  | $3_valued_fault_simulation (initial_c_i);$                          | /^ Step-3 ^/ |  |
| <pre>/* Pass-2 */ for each test vector t<sub>i</sub> in T {     UF = find_undetected_fault (v<sub>i</sub>, c<sub>i</sub>); /* Step-4 *,     final_c<sub>i</sub> = adjust_test_cube (UF); /* Step-5 *,     3_valued_fault_simulation (final_c<sub>i</sub>); /* Step-6 */</pre>                                                                                                                                                                                                                                                                                                                                                    | }                                                                   |              |  |
| UF = find_undetected_fault (v <sub>i</sub> , c <sub>i</sub> ); /* Step-4 *,<br>final_c <sub>i</sub> = adjust_test_cube (UF); /* Step-5 *,<br>3_valued_fault_simulation (final_c <sub>i</sub> ); /* Step-6 */                                                                                                                                                                                                                                                                                                                                                                                                                     | /^ Pass-2 ^/                                                        |              |  |
| final_c <sub>i</sub> = adjust_test_cube (UF); /* Step-4 *<br>3_valued_fault_simulation (final_c <sub>i</sub> ); /* Step-6 */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | for each test vector $t_i \ln I $                                   | /* Chan 4 */ |  |
| 3_valued_fault_simulation (final_ci); /* Step-5 */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $OF = find\_undetected\_fault (V_i, c_i);$                          | /* Step-4 */ |  |
| 3_valued_fault_simulation (final_c <sub>i</sub> ); /* Step-6 */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | final_c <sub>i</sub> = adjust_test_cube (UF);                       | /^ Step-5 ^/ |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 3_valued_fault_simulation (final_c <sub>i</sub> );                  | /* Step-6 */ |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | }                                                                   |              |  |

























### 3.4 Low-Power Test Ordering

## **Content**

- ① Internal-Transition-Based Ordering
- ② Inter-Vector-Hamming-Distance-Based Ordering






| <u>Add</u>                                                                          | Address Switching Activity Reduction                                                                                                                                                                          |                                                                                                                                                                            |  |  |  |  |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                                                                     | Original Test<br>Algorithm                                                                                                                                                                                    | Low-Power Test<br>Algorithm                                                                                                                                                |  |  |  |  |
| Zero-One                                                                            | t (W0);                                                                                                                                                                                                       | ¢s (W0, R0, W1, R1);                                                                                                                                                       |  |  |  |  |
| Checker Board                                                                       | $\begin{array}{l} \updownarrow (W(1_{odd}/0_{even})); \updownarrow (R(1_{odd}/0_{even})) \\ \updownarrow (W(0_{odd}/1_{even})); \updownarrow (R(0_{odd}/1_{even})) \end{array}$                               | ¢s (W(1 <sub>odd</sub> /0 <sub>even</sub> ), R(1 <sub>odd</sub> /0 <sub>even</sub> )<br>-W(0 <sub>odd</sub> /1 <sub>even</sub> ),R(0 <sub>odd</sub> /1 <sub>even</sub> )); |  |  |  |  |
| <ul> <li>Reorde<br/>any fai</li> <li>Origina</li> <li>Low-po<br/>Example</li> </ul> | er test patterns to minimize switching ac<br>ult coverage loss.<br>Il test algorithm's addressing order:<br>ower test algorithm's addressing order:<br>$b/e: 00 \rightarrow 01 \rightarrow 11 \rightarrow 10$ | tivity on address lines without<br>↓<br>↓ <sub>S</sub> ( <i>single bit change</i> )                                                                                        |  |  |  |  |



### 4. Power-Aware Design-for-Test

Chapter 4

# **Power-Aware Design-for-Test**

### 4. Power-Aware Design-for-Test

# 4.1 Overview of Power-Aware DFT

- Low-power scan cells
- Scan path organization
- Partitioning for low power







| 4. Power-Av<br>4.2 L | vare Do<br>ow-po  | esign<br>ower             | -for-1<br>scai            | โ <b>ย</b> ะ<br>า ( | <sup>st</sup><br>cells | / clo        | ck ga           | ating |  |
|----------------------|-------------------|---------------------------|---------------------------|---------------------|------------------------|--------------|-----------------|-------|--|
|                      | index             | binary                    | # faults                  |                     | index                  | binary       | #faults         |       |  |
|                      | 0                 | 0000                      | 17                        |                     | 8                      | 1000         | 2               |       |  |
|                      | 1                 | 0001                      | 9                         |                     | 9                      | 1001         | 0               |       |  |
|                      | 2                 | 0010                      | 4                         |                     | 10                     | 1010         | 0               |       |  |
|                      | 3                 | 0011                      | 0                         |                     | 11                     | 1011         | 1               |       |  |
|                      | 4                 | 0100                      | 5                         |                     | 12                     | 1100         | 0               |       |  |
|                      | 5                 | 0101                      | 2                         |                     | 13                     | 1101         | 0               |       |  |
|                      | 6                 | 0110                      | 3                         |                     | 14                     | 1110         | 0               |       |  |
|                      | 7                 | 0111                      | 0                         |                     | 15                     | 1111         | 0               |       |  |
|                      | {0000,0<br>0110,1 | 0001,0<br>1000,1<br>0111. | 010,01<br>011,11<br>1001. | 00<br>00]<br>10     | , 0101,<br>}           | o            | n-set<br>ff-set |       |  |
|                      | {1101,            | 1110 ,<br>mplem           | 11111}<br>ienting         | the                 | e pattei               | d<br>rn deco | o-set<br>der    |       |  |
|                      | (S. Gersten       | dorfer and                | d HJ. Wu                  | nder                | lich, Proc.            | ITC, pp. 77  | -84, 1999       | )     |  |





























5. Power-Aware BIST and Test Data Compression

# Chapter 5

**Power-Aware BIST and Test Data Compression** 

## 5. Power-Aware BIST and Test Data Compression

## 5.1 Overview of power-aware BIST and compression

- Coding-based compression methods
- LFSR-decompression-based compression methods
- Low-power BIST techniques



| <u>5. Power-Awa</u><br>5.2 | re Bl             | ST and T                                 | est Da<br>sed c | ata C<br>comp                                        | ompression                                                         |  |
|----------------------------|-------------------|------------------------------------------|-----------------|------------------------------------------------------|--------------------------------------------------------------------|--|
|                            | Group             | Run-Length                               | Group<br>Prefix | Tail                                                 | Codeword                                                           |  |
| -                          | A <sub>1</sub>    | 0                                        | 0               | 0<br>1                                               | 00<br>01                                                           |  |
| -                          | A <sub>2</sub>    | 2<br>3<br>4<br>5                         | 10              | 00<br>01<br>10<br>11                                 | 1000<br>1001<br>1010<br>1011                                       |  |
|                            | A <sub>3</sub>    | 6<br>7<br>8<br>9<br>10<br>11<br>12<br>13 | 110             | 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111 | 110000<br>110001<br>110010<br>110011<br>110100<br>110101<br>110110 |  |
|                            | Frequ<br>(courtes | uency-direc<br>sy: K. Chakrabai          | ted run         | -length<br>K. Goel, L                                | (FDR) code<br>Duke Univ)                                           |  |









|           | Slice        | code         |                                                              |  |
|-----------|--------------|--------------|--------------------------------------------------------------|--|
| Slice     | Control code | Data<br>code | Description                                                  |  |
| XX00 010X | 00           | 0101         | Start a new slice, map X to 0,<br>set bit 5 to 1             |  |
| 1110 0001 | 00           | 0111         | Start a new slice, map X to 0,<br>set bit 7 to 1             |  |
|           | 11           | 0000         | Enter group-copy-mode, startin<br>from bit 0 (i.e., group 0) |  |
|           | 11           | 1110         | The data is 1110                                             |  |
| XXXX XX11 | 01           | 1000         | Start a new slice, map X to 1,<br>no bits are set to 0       |  |





































| ow-Power Design Techniques and Test Implications 7.1 Low Power Design Trends |     |  |  |  |
|------------------------------------------------------------------------------|-----|--|--|--|
| Efficiency of LPD Techniques                                                 | *   |  |  |  |
| Micro architecture (pipelining, parallelism)                                 | 50% |  |  |  |
| <ul> <li>Clock gating and power gating</li> </ul>                            | 40% |  |  |  |
| Logic design                                                                 | 20% |  |  |  |
| <ul> <li>Technology mapping</li> </ul>                                       | 30% |  |  |  |
| <ul> <li>Cell sizing and wire sizing</li> </ul>                              | 30% |  |  |  |
| <ul> <li>Voltage scaling, multi-Vdd, multi-Vth</li> </ul>                    | 75% |  |  |  |
| <ul> <li>Floor planning and placement</li> </ul>                             | 25% |  |  |  |
| •                                                                            |     |  |  |  |
|                                                                              |     |  |  |  |
|                                                                              |     |  |  |  |
| (K. Keutzer, UC Berkeley, SDC panel, 2005)                                   |     |  |  |  |



| 7.1 Low Power Design Trends |         |                 |  |  |  |
|-----------------------------|---------|-----------------|--|--|--|
|                             | Power r | Power reduction |  |  |  |
| Main LPD techniques         | Dynamic | Leakage         |  |  |  |
| Clock gating                | ✓       |                 |  |  |  |
| Power gating                | ✓       | ✓               |  |  |  |
| Multi-Voltage domains       | ✓       |                 |  |  |  |
| Multi-Threshold cells       |         | ✓               |  |  |  |

















### 7. Low-Power Design Techniques and Test Implications

### 7.1 LPD Trends - Power Gating

• Adopted in regular structures (data paths) where the gating transistor can be easily shared

• Power gating cells usually cost 10% area overhead and about 2% performance degradation

• Power-on and power-down sequences can be extremely complex to design and verify

• Careful sizing of gating transistors (wide enough to sustain worstcase switching condition)

• Impact on the design flow may be high

#### 7. Low-Power Design Techniques and Test Implications

## 7.2 Power Specification Formats

• Need of specifying properties of a circuit block wrt power dissipation during design, verification and implementation

Interpreted by designers and design automation tools

• To achieve a unified and efficient design flow, various EDA tools need to use a common language

Common Power Format (CPF) created by Cadence

 Unified Power Format (UPF) supported Synopsys, Mentor and Magma and standardized by IEEE (P1801 std. working group)

• 90% same concepts, but different syntaxes

• Both formats are based on the *Tool Control Language* (TCL) embedded in most EDA tools





### 7. Low-Power Design Techniques and Test Implications

### 7.3 Implications to Test Requirement and Cost

• Reduce (even more) test power by using the PM infrastructure and/or applying the previous dedicated solutions (chapters 3 to 6)

- Preserve the functionality of the test infrastructure
- Test the power management (PM) structures
- Consider the influence of LPD on test conditions
- Provide high quality delay fault coverage

#### And still target:

High fault coverage, short test application time, small test data volume, low area overhead, etc ... while making test power dissipation (dynamic and leakage) comparable to functional power



## 7.3 Implications use of PM infrastructure

- Existing solutions
  - ATPG and DfT for multi-voltage designs (addressed in Chapter 8)
  - ATPG and DfT for gated clock designs (addressed in Chapter 9)
  - Test planning for multi-power domains architectures (addressed in Chapter 11)



### 7. Low-Power Design Techniques and Test Implications

# 7.3 Implications Preserving Test Functionality

### Main Challenge

• Test infrastructures like scan chain or TAM may cross several power domains and can be broken if some of these domains are temporarily powered-down for low-power constraints

Specific test control strategies and extra DfT insertion are required for preserving functionality of the test infrastructure !

• Similar challenges exist for gated clock designs (addressed in Chapter 9)



(M. Hirech, Synopsys, DATE 2008)












## 8. Test Strategies for Multi-Voltage Designs

## 8.1 Test for Multi-Voltage (MV) Design

Multi-Voltage design

• Use dedicated multiple power supplies on chip, or adaptive voltage scaling circuitry consisting of DC-DC converters and voltage controlled oscillators.

- MV design and Test
  - Some manufacturing defects have Vdd-dependency
  - Impact on defect coverage
  - Testing at all Vdd settings is costly !!
  - Multi-Vdd Test determines the minimum number of voltage settings to ensure the highest level of defect coverage

















(V.R. Devanathan et. al., ITC 2007)





**Chapter 9** 

**Test Strategies for Gated Clock Designs** 















































































## **Summary and Conclusions**

## **Summary and Conclusions**

### **Summary and Conclusions**

• Reliability, test throughput and manufacturing yield may be affected by excessive test power

• Therefore, lowering test power has been and is still a focus of intense research and development

- Following points have been surveyed:
  - Test power parameters and contributors
  - Problems induced by an increased test power
  - Structural and algorithmic solutions for low power test along with their impacts on parameters such as fault coverage, test time, area overhead, circuit performance penalty, and design flow modification
  - Test implications of low power design and emerging test strategies for low-power devices

## **Summary and Conclusions**

• Past work explored primarily four directions:

• ATPG-based low power test approaches are not intrusive; they are pattern dependent and may incur additional computational cost in the design flow.

• DFT-based low power test approaches change the scan infrastructure; can be pattern independent and hence can guarantee power reduction in a certain range.

• Low power test data compression techniques combines reduction of test data volume and test application time with power consumption during test

• System-level low power test considerations can be combined with any of the above and improve test concurrency.

- Future work will be mainly on:
  - Test strategies for low power designs

# THANK YOU!

And let us make testing "cool".