# Strategy to Disentangle Multiple Faults to Identify Random Defects within Test Structures

Christopher Hess, Larg H. Weiland

Institute of Computer Design and Fault Tolerance (Prof. Dr. D. Schmid) University of Karlsruhe, P. O. Box 6980, 76128 Karlsruhe, Germany Phone: +49-721-6084217; FAX: +49-721-370455; email: hess@ira.uka.de; http://goethe.ira.uka.de/ddg

*Abstract* - Defect inspection is required for process control and to enhance chip yield. Electrical measurements at test structures are commonly used to detect faults. To improve the accuracy to evaluate the defects that have caused such faults, this paper presents a strategy to analyze single and multiple faults to precisely determine the number, layer and location of randomly distributed defects within a test structure layout. For that we first discuss the possibilities to analyze faults within known test structure layouts. Then, we present modified test structure layouts to improve the analysis of multiple faults. Finally we introduce a methodology to disentangle multiple faults by calculating and comparing the probability of possible defect locations within large test structure layout areas.

### **1** INTRODUCTION

EFECTS (e. g. particles) can become the cause of electrically measurable faults (killer defects) dependent on the chip layout and the defect size. These faults are responsible for manufacturing related malfunctions of chips. So, defect density distributions are important for yield enhancement and to control quality of process steps and product chips [StRo95]. Test structures will be used to detect faults as well as to identify and localize defects. Faults will be detected measuring voltage and current values between different pads of a test chip. Due to the known test structure layout, specific measurement limits will be expected, if no defect occurs. Measured values outside the limit will be called a fault. A single fault enables a precise assignment to a specific region within the test structure that contains the defect, which caused the measured fault. So - without doubt - it will be possible to provide the layer and the layout elements containing a defect. If such a layout specific assignment is not clear, the measured fault will be called a multiple fault, because there are multiple possibilities where one or even more defects occur within the test structure layout. In most cases, single faults are the result of measurements between two pads only. Multiple faults occur, if more than just two pads are involved in the collection of faulty measurement values.

To provide precise defect densities for yield enhancement, it is necessary not only to handle single faults, but also to handle multiple faults. For that, we present strategies to disentangle multiple faults that occur within test structures. So, Section 2 describes known test structures to measure faults and evaluate defects. Section 3 introduces novel algorithms to disentangle multiple short circuit faults. Section 4 discusses methodologies to improve the evaluation of defects that result in open circuits. Finally we present some experimental results and conclude our approach.

## 2 Test Structures to Provide Fault Analysis

Generally two different principles will be used to design test chips to detect faults and defects that may occur during semiconductor manufacturing. The first principle to design test chips contains many small test structures, each electrically distinguishable to each other and therefore connected to an individual 2-by-N pad array [Bueh83]. Comb lines will be used to detect short circuits and meandrous lines and strings of vias and contacts will be used to detect open circuits. Each test structure just covers a small chip area to ensure that no more than one defect may occur [KhMT94]. This design principle prevents the occurrence of multiple faults. But, more than half of the test chip area will be covered by the 2-by-N pads itself and not by the defect sensitive test structures. So, many test chips are necessary, to successfully detect random faults. For this reason, 2-by-N organized test chips will mainly be used to detect systematic faults only. They should not be used to detect any random problems, due to their enormous waste of chip area.

To save money when investigating random problems, it is required to more efficiently use the area within a test chip. For that, a second principle to design test chips provides a large consecutive area within boundary pads that contains just one large test structure layout. So, for example memory chips are used to detect defects. [KMGS94] provides procedures to detect and count defects. But, memory chips require a well working frontend and backend process. To just investigate selected process steps, large area comb lines or meandrous lines and strings of vias and contacts will be implemented within boundary pads in specific layers only [IpSa77]. But, due to the large area covered by a single test structure, it remains unknown how many defects caused a measured fault. So, defect density values tend to be to small. Furthermore, it is difficult to assign a multiple fault to the defects that are responsible for the measured fault pattern. So, we have to discuss ways to improve the evaluation of defects, that result either in short circuits or open circuits.

### **3 EVALUATION OF SHORT CIRCUITS**

To explain the principle to extract defects that result in short circuits, it is worth to model a test structure using the neighborhood graph introduced by [HeWe94] and [HeSt94] and summarized in the following table:

| layout<br>elements to<br>detect defects             | comb lines<br>(e. g. [Bueh83], [LYWM86])                                                                                                                                                                       |  |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| test structure<br>and<br>model of<br>test structure | 2 1 1 2<br>3<br>4<br>5<br>6<br>7 8 8 7<br>Fig. 1:<br>Left: Known test chip arrangement.<br>Right: Neighborhood graph (model).                                                                                  |  |
| nodes of graph                                      | <b>maximal conductive component (MCC)</b> :<br>Maximal set of conductive components (layout objects) that<br>are connected to each other by the designer.                                                      |  |
| edges of graph                                      | <b>pair of MCCs</b> (=possible undesigned short circuits):<br>Two nodes are connected by an edge if anywhere inside the<br>test chip these MCCs are adjacent with only nonconducting<br>material between them. |  |

Tab. 1: Neighborhood graph to model a test structure.

An undesigned short circuit defect is only detectable between two different MCCs - therefore called **MCC-pair**. The number of different MCCs is limited to the number of pads. To increase the number of MCC-pairs or separable short circuits, respectively, all MCCs have to be arranged inside a test chip in a way that each MCC is once adjacent to every other MCC with only nonconducting material between them. This results in the complete neighborhood graph containing all possible edges as can be seen in the following figure.



Fig. 2: Complete neighborhood graph (here e. g. m=8 nodes and  $\binom{m}{2}=28$  edges).

The complete neighborhood graph will be implemented within Checkerboard Test Structures described at [Hess94], [HeSt94], [HeWe95b] and [HeWB97a]. Checkerboard Test Structures partition the chip area into a large number of subchips, each containing different edges of the complete neighborhood graph, which enables the separation and localization of defects anywhere inside or in between numerous layers. There is no limitation to the number of layers and no requirement of any active semiconductor devices. More than 90% of the total chip area is completely filled with defect sensitive structures. So, there is a large defect sensitive area to detect random defects even if the average defect density is low.

If just two pads are connected by a short circuit, it is possible to conclude the subchip that contains the defect, because each MCC-pair can be clearly assigned to a specific subchip and its containing test structure layout objects. But, a short circuit measured between more than just two pads results in a **multiple fault** that indicates an undefined number of defects. So, the following methodology to disentangle multiple faults will help to separate and localize the minimum number of defects that are the reason for a measured multiple fault.

| PROCEDURE                                                                    | GET_MCC_PAIR (S)                                                                                                                        |  |
|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| S :=<br>k :=                                                                 | $\{MCC_i     1 \leq i \leq k \ k \in \mathbb{N}\};$ set of shorted MCCs number of MCCs in S                                             |  |
| i,j :=                                                                       | temporary indices of MCCs in S                                                                                                          |  |
| P <sub>n</sub> :=                                                            | <pre>{p,q,row,col,subset,weight}; pair of</pre>                                                                                         |  |
| <pre>p,q :=<br/>row :=<br/>col :=<br/>subset :=<br/>weight :=<br/>n :=</pre> | MCCs<br>row index of subchip<br>column index of subchip<br>subset index<br>factor to count a defect<br>number of possible pairs of MCCs |  |
| n = 0                                                                        |                                                                                                                                         |  |
| FOR i=1 TO k STEP i=i+1 DO                                                   |                                                                                                                                         |  |
| FOR j=i+1 TO k STEP j=j+1 DO                                                 |                                                                                                                                         |  |
| n<br>P <sub>n</sub><br>q <sub>n</sub><br>(row <sub>n</sub> ,                 | $ = n+1 = MCC_i = MCC_j col_n) = GET_POSITION (p_n, q_n) $                                                                              |  |
| REPEAT                                                                       |                                                                                                                                         |  |
| REPEAT                                                                       |                                                                                                                                         |  |
| RETURN ({p                                                                   | $(q, row, col)_n \in P_n)$                                                                                                              |  |

Fig. 3: Procedure to extract MCC-pairs *P* out of the set *S* of MCCs measured in a multiple short circuit.

| <b>PROCEDURE</b> GET_SUBSET (P <sub>n</sub> )                                                   |
|-------------------------------------------------------------------------------------------------|
| P <sub>n</sub> := {p,q,row,col,subset,weight}<br>n := number of pairs of MCCs                   |
| j, start, ptr := temporary indices of P                                                         |
| <pre>start = 1 ptr = start+1 subset<sub>start</sub> = 1</pre>                                   |
| WHILE start < n DO                                                                              |
| j = ptr                                                                                         |
| WHILE $j \leq n DO$                                                                             |
| IF COMPARE_POSITION( $P_{start}, P_{j}$ ) = true THEN                                           |
| subset; = subset <sub>start</sub><br><b>EXCHANGE</b> $P_j$ <b>WITH</b> $P_{ptr}$<br>ptr = ptr+1 |
| ENDIF                                                                                           |
| j = j+1                                                                                         |
| REPEAT                                                                                          |
| <pre>IF start+1 = ptr THEN</pre>                                                                |
| <pre>subset<sub>ptr</sub> = subset<sub>start</sub> + 1 start = ptr ptr = ptr+1</pre>            |
| ELSE                                                                                            |
| <pre>start = start+1</pre>                                                                      |
| ENDIF                                                                                           |
| REPEAT                                                                                          |
| <b>PETTIPN</b> ({subset} $\in \mathbb{P}$ ): $\mathbb{P}$ also sorted by {subset}               |

Fig. 4: Procedure to determine subset indices indicating comparable MCC-pairs and also to sort all MCC-pairs  $P_n$  by these index values.

The set  $S = \{MCC_i | 1 \le i \le k \land k \in \mathbb{N}\}$  will contain the indices of all k MCCs that are involved in a multiple fault. The first step is now to extract all n MCC-pairs each described in the data set  $P = \{p, q, row, col, subset, weight\}$  where p and q represent the two MCC indices. (ref. procedure "GET\_MCC\_PAIR" of Fig. 3). The sub-procedure "GET\_POSITION" (ref. Fig. 3) provides the location of an MCC-pair within a test structure layout. If e. Checkerboard Test Structures are used, [HeSt94], g. [HeWe95b] and [HeWB97a] provide the necessary localization procedures that yield the row and column index {row,col} of the subchip containing the MCCs p and q. The second step is to evaluate those MCC-pairs that are neighbored within the test chip area. For that, the procedure "GET\_SUBSET" will give the same subset index to all neighbored MCC-pairs *P*={*p*,*q*,*row*,*col*,*subset*,*weight*} (ref. Fig. 4).

PROCEDURE COMPARE\_POSITION (P<sub>i</sub>, P<sub>i</sub>) := {p,q,row,col,subset,weight} Pindex of P i,j := Position of MCC pair comparable (yes/no) := cmp cmp = false CASE design = Checkerboard Test Structure AND designed subchip rows ≥ designed subchip columns THEN  $(|row_i - row_j| \le 1 \text{ AND } col_i = col_j)$ IF **OR**  $(|col_i - col_i| \le 1$  **AND**  $row_i = row_i)$  **THEN** cmp = trueENDIF design = Checkerboard Test Structure CASE AND designed subchip rows < designed subchip columns THEN **IF**  $|col_i - col_j| \le 1$  **AND**  $row_i = row_j$  **THEN** cmp = true ENDIF

ENDCASE

RETURN (cmp)

Fig. 5: Sub-procedure to evaluate comparable subchip positions within Checkerboard Test Structures.

```
PROCEDURE GET_BUNDLE (P<sub>n</sub>)
Pr
      := {p,q,row,col,subset,weight};
                                                    has to be sorted
                                                    by {subset}
n
      := number of pairs of MCCs
j
      := temporary index of P
      := \{ MCC_i \mid 1 \le i \le b \le k \land b \in \mathbb{N} \}
B.
b
       := number of MCCs in B
      := number of bundles
t
t = 0
FOR j=1 TO n STEP j=j+1 DO
   IF subset<sub>j</sub> \neq t THEN
            = t + 1
      b.
             = 0
   ENDIF
   IF p_i \not\subset B_t THEN
              = b, + 1
      b
      MCC_{t,bt} = p_j
   ENDIF
   IF q_j \not\subset B_t THEN
               = b<sub>t</sub> + 1
      MCC<sub>t,bt</sub>
                = q<sub>i</sub>
   ENDIF
REPEAT
RETURN (B.)
```

Fig. 6: Procedure to determine MCC-bundles containing all MCCs of neighbored MCC-pairs.

If Checkerboard Test Structures are used, the decision weather two MCC-pairs are neighbored or not will be made using the procedure "COMPARE\_POSITION" (ref. Fig. 5). The third step is to create **MCC-bundles**  $B_i = \{MCC_i | 1 \le i \le b \le k \land$  $b \in \mathbb{N}$  each containing the MCC indices of neighbored MCCpairs having the same subset index (ref. procedure "GET\_BUNDLE" of Fig. 6). Now, step four will determine the minimal set of d MCC-bundles B in a way that they together contain all k MCC-indices of S. To get a valid solution, it is also required that each MCC-bundle within the solution must have at least one common MCC index with at least one other MCC-bundle within the solution. For that, the procedure "GET\_DEFECT\_NUMBER" first checks whether there is an MCC-bundle containing all k MCCs of S (ref. Fig. 7). If there such MCC-bundle, the recursive procedure is no "COMBINE\_BUNDLE" tries to find solutions for an initial number d=2 of combined MCC-bundles and returns the number mcl of valid solutions (ref. Fig. 8).

| <b>PROCEDURE</b> GET_DEFECT_NUMBER (S, B <sub>t</sub> )                                 |
|-----------------------------------------------------------------------------------------|
| $\begin{array}{llllllllllllllllllllllllllllllllllll$                                    |
| i := temporary index of B                                                               |
| mcl := total number of solutions                                                        |
| $ \begin{array}{l} mcl = 0 \\ d = 0 \end{array} $                                       |
| /* check for single defect */                                                           |
| FOR i=1 TO t STEP i=i+1 DO                                                              |
| <b>IF</b> $b_i = k$ <b>THEN</b>                                                         |
| d = 1<br>mcl = mcl + 1<br>occ <sub>i</sub> = 1                                          |
| ELSE                                                                                    |
| $occ_i = 0$                                                                             |
| ENDIF                                                                                   |
| REPEAT                                                                                  |
| /* check for multiple defect */                                                         |
| IF mcl = 0 THEN                                                                         |
| d = 1                                                                                   |
| WHILE mcl = 0 AND d < k-1 DO                                                            |
| ptr = 1<br>d = d+1<br>$tmp = \emptyset$<br>$mcl = COMBINE_BUNDLE (S, B_t, ptr, d, tmp)$ |
| REPEAT                                                                                  |
| END                                                                                     |
| /* delete MCC-pairs not involved in a solution */                                       |
| IF mcl > 0 THEN                                                                         |
| FOR i=1 TO t STEP i=i+1 DO                                                              |
| IF occ <sub>i</sub> = 0 THEN                                                            |
|                                                                                         |
| $B_i = \emptyset; \Rightarrow b_i = 0$                                                  |
| $B_i = \emptyset; \Rightarrow b_i = 0$<br>ENDIF                                         |
| $B_i = \emptyset_i \Rightarrow b_i = 0$<br>ENDIF<br>REPEAT                              |
| $B_i = \emptyset; \Rightarrow b_i = 0$<br>ENDIF<br>REPEAT<br>ENDIF                      |

Fig. 7: Procedure to determine the minimal set of MCC-bundles to be responsible for a measured multiple fault.

```
PROCEDURE
                COMBINE_BUNDLE (S,Bt,ptr,d,tmp)
       := \{ MCC_i | 1 \le i \le k \land k \in \mathbb{N} \}
S
       \begin{array}{l} := \text{ number of MCCs in S} \\ := \{\text{MCC}_i | 1 \le i \le b \le k \land b \in \mathbb{N}\} \end{array}
k
В.
       := number of MCCs in B
b
      := occurrence of B in at least one solution
occt
t
       := number of bundles
       := index of B
ptr
d
       := number of defects
tmp
       := {MCC<sub>i</sub> | 1 \le i \le k \land k \in \mathbb{N}}; temporary set of MCCs
       := temporary index of B
:= temporary number of solutions
j
mcl := total number of solutions
mcl = 0
IF d > 1 THEN
   FOR i=ptr TO t-d+1 STEP i=i+1 DO
       IF tmp = \emptyset OR tmp \cap B_i \neq \emptyset THEN
          IF i > ptr THEN
              EXCHANGE B_i WITH B_{ptr}
              i = ptr
          ENDIF
           j = COMBINE_BUNDLE (S, B_t, i+1, d-1, (tmp \cup B_i))
          mcl = mcl + j
occ_i = occ_i + j
                              i
                          + 1
          ptr
                 = ptr
       ENDIF
   REPEAT
ELSE
   FOR i=ptr TO t STEP i=i+1 DO
       IF tmp \cap B<sub>i</sub> \neq \emptyset AND tmp \cup B<sub>i</sub> = S THEN
          mcl = mcl + 1
          occ_i = occ_i + 1
       ENDIF
   REPEAT
ENDIF
RETURN (mcl)
```

Fig. 8: Recursive sub-procedure to combine MCC-Bundles.

PROCEDURE WEIGHT\_MCC\_PAIR (P<sub>n</sub>, B<sub>t</sub>, d) := {p,q,row,col,subset,weight}; MCC-pair Ρ, := number of pairs of MCCs $:= \{MCC_i | 1 \le i \le b \le k \land b \in \mathbb{N}\}; MCC-bundle$ n B₊ := number of MCCs in B := number of bundles b t d := number of defects := temporary index of B
:= temporary indices of P i j h := number of MCC-pairs in disentangled solutions h = 0FOR j=1 TO j<n STEP j=j+1 DO i = subset, IF  $B_i \neq \emptyset$  THEN h = h + 1ENDIF REPEAT FOR j=1 TO j<n step j=j+1 do i = subset; IF  $B_i \neq \emptyset$  THEN weight<sub>i</sub> = d / hENDIF REPEAT **RETURN** ({weight}\_n  $\in P_n$ )

Fig. 9: Procedure to weight each MCC-pair.

If a solution has not been found, *d* has to be increased by "1" and the procedure "**COMBINE\_BUNDLE**" has to be run again until at least one solution will be found (*mcl>0*). At the end of this procedure *mcl* indicates the total number of possible solutions for the smallest possible number *d* of combined MCC-bundles. Furthermore all MCC-bundles, that are not part of at least one solution will be deleted ( $B=\emptyset$ ). Now, the value of *d* gives the minimum number *d* of defects that have caused the measured multiple fault. And all still existing MCC-bundles indicate possible defect locations within the chip area. So, we get the MCC-pairs and also the subchips that may contain a defect. If there are more MCC-pairs than the minimum number *d* of defects, we finally have to weight each MCC-pair  $P=\{p,q,row,col,subset,weight\}$  using the procedure "WEIGHT\_MCC\_PAIR" (ref. Fig. 9).

The following example will explain the procedure to disentangle multiple short circuits as illustrated in Figure 10 and described in Table 2. A multiple short circuit is measured between the pads or MCCs, respectively  $S = \{3, 13, 16, 18, 20\}$ . The tracks of the MCCs are marked with differently dashed lines. First, all possible MCC-pairs P will be extracted and clearly assigned to a so-called faulty subchip. Then, MCCbundles B will be determined by collecting the MCCs of those MCC-pairs, that are located in neighbored subchips. There is no MCC-bundle that contains all k=5 MCCs, but the procedure "COMBINE\_BUNDLE" detects, that the MCC-bundles B<sub>3</sub> and  $B_4$  contain all MCCs of the multiple short circuit. So, the minimum number of defects is d=2. This is the only possible solution (mcl=1), because no other pair of MCC-bundles  $B_i, B_j$ will meet:  $S = B_i \cup B_i \land B_i \cap B_i \neq \emptyset$ . So, one defect located within the subchips  $\{5,10\}$  and  $\{5,11\}$  as well as another defect located within the subchips {2,14} and {2,15} are responsible for the measured multiple fault.



Fig. 10: Checkerboard Test Structure containing defects connecting 5 pads.

The described disentangling procedure should be individually done per layer, if defects may be located within a single layer only. The disentangling procedure will be done just once over all layers, if defects may be located within a layer as well as between adjacent layers. The disentangling procedure is applicable to all kind of test structures that enable the localization of short circuits or MCC-pairs, respectively. For "GET\_POSITION" that. only the algorithms and "COMPARE POSITION" have to be adapted to a specific test structure design. So, not just Checkerboard Test Structures but also SRAM based test structures as well as Harp Test Structures [HeWe97a] may be evaluated.

| subset index $\{subset\}_{10} \subset P_{10}$ | MCC-pairs $\{p,q\}_{10} \subset P_{10}$ | faulty subchip<br>{row,col} <sub>10</sub> ⊂P <sub>10</sub> | MCC-bundles $B_7$                   | weight $\{weight\}_{10} \subset P_{10}$ |
|-----------------------------------------------|-----------------------------------------|------------------------------------------------------------|-------------------------------------|-----------------------------------------|
| $\{1\}_1$                                     | {3,13} <sub>1</sub>                     | {9,19} <sub>1</sub>                                        | $\{3,13\}_1 \rightarrow \emptyset$  | $\{0\}_1$                               |
| $\{2\}_2$                                     | {3,16} <sub>2</sub>                     | {4,9} <sub>2</sub>                                         | $\{3,16\}_2 \rightarrow \emptyset$  | $\{0\}_2$                               |
| {3} <sub>3</sub>                              | {3,18} <sub>3</sub>                     | $\{5,10\}_3$                                               | {3,18,20} <sub>3</sub>              | $\{0.5\}_3$                             |
| {3} <sub>4</sub>                              | $\{3,20\}_4$                            | $\{5,11\}_4$                                               |                                     | $\{0.5\}_4$                             |
| {4} <sub>5</sub>                              | {13,16} <sub>5</sub>                    | {2,14} <sub>5</sub>                                        | $\{13, 16, 18\}_4$                  | $\{0.5\}_5$                             |
| $\{4\}_{6}$                                   | $\{13,18\}_{6}$                         | $\{2,15\}_6$                                               |                                     | $\{0.5\}_6$                             |
| {5} <sub>7</sub>                              | $\{13,20\}_7$                           | {3,16} <sub>7</sub>                                        | $\{13,20\}_5 \to \emptyset$         | $\{0\}_{7}$                             |
| {6} <sub>8</sub>                              | $\{16,18\}_8$                           | {9,1} <sub>8</sub>                                         | $\{16,18\}_6 \rightarrow \emptyset$ | $\{0\}_{8}$                             |
| {7} <sub>9</sub>                              | $\{16, 20\}_9$                          | {10,2}9                                                    | $\{16, 18, 20\}_7$                  | {0} <sub>9</sub>                        |
| {7} <sub>10</sub>                             | {18,20} <sub>10</sub>                   | $\{10,1\}_{10}$                                            | $\rightarrow \emptyset$             | $\{0\}_{10}$                            |

Tab 2. Procedure to disentangle the multiple short circuit measured among the 5 pads of Figure 10. The white boxes mark the minimum set of MCCbundles indicating that at least 2 defects have caused this multiple short.

# 4 EVALUATION OF OPEN CIRCUITS

To explain the principle to extract defects that result in open circuits, it is worth to model a test structure using the geometry graph introduced by [HeWe94] which is summarized in Table 3.



Tab. 3: Geometry graph to model a test structure.

An undesigned open circuit defect is only detectable on an implemented conductive component (CC) measuring the resistance between its two pads. But, in case of a measured open circuit it is generally impossible to determine how many defects have interrupted the conductive component between the pads. So, open circuits are always single faults, but they are the result of either a single defect or more than just one defect then called a multiple defect. To separate single defects and multiple defects it is necessary to implement a large number of CCs so that each CC just covers a small portion of the total test structure area. But, the number of different CCs is limited to the number of pads.

In contrast to the neighborhood graph, there is no possibility to increase the number of distinguishable CCs without either increasing the number of pads or using directed CCs which results in the so-called geometry digraph [HeWe94a] as can be seen on the left side of Figure 12. Directed CCs should restrict the measurement current to flow in one direction only. If diodes are available in addition to the backend polysilicon and metal layers, a diode array increases the number of distinguishable CCs for a given number of pads. In this case each diode stands for a distinguishable serpentine line or a via (or contact) string, respectively.



Fig. 12: Geometry digraph and diode array to detect defects that result in open circuits.

So, test structure designs based on a diode array reduce the area covered by a single CC and therefore even multiple defects will be measurable as a distinguishable set of single faults per defect (ref. [WWGH92], [HeWe94a]).

### **5** EXPERIMENTAL RESULTS

Over the past years different test structure designs including Checkerboard Test Structures and Harp Test Structures were manufactured at several fabs. The following Figure 13 shows the percentage of single faults (k=2) and multiple faults (k>2)dependent on the ability to evaluate an unambiguous set of defect locations within the test structures. Within the Checkerboard Test Structures "A25", "A26", "D13", and "C11", up to 25% of the faults occur as multiple faults. About 2/3 of them may be assigned to an unambiguous set of defect locations. Within the Harp Test Structure more than 45% of the faults occur as multiple faults, because the design provokes multiple faults to determine the defect size between connected parallel lines [HeWe97a]. More than 90% of these multiple faults may clearly be disentangled because most of them are caused by a single large defect.



test structure designs.

For the Checkerboard Test Structure design "C11", the following Figure 14 gives the distribution of defects and faults dependent on the type of fault. As mentioned in Section 4, the

number of open circuits is identical to the number of defects that have caused them. Also, all single short circuits ( $k \le 2$ ) are the result of a single defect each. More than 80% of them are unambiguously locatable. We also get some single short circuits where just one MCC is involved (k=1) which is the result of connections to permanent power supply. There are multiple possible locations of those faults and defects, because a single MCC is implemented in several subchips (ref. dashed lines of Fig. 10). Some single short circuits (k=2) connecting MCCs coincidently placed in adjacent layers will result in the same problem. Multiple short circuits (k>2) are caused by an average of two defects per fault. So, the actual number of defects within a test structure is higher than the number of measured faults which has a detrimental impact on the determination of defect densities, if multiple faults are not disentangled.



Finally, Figure 15 gives the relative occurrence of defects within the different test structure designs after disentangling all detected multiple faults. Up to 40% of unambiguously locatable defects result in multiple faults. Comparing these data to the chart displayed in Figure 13 indicate the impact of multiple faults and multiple defects on the evaluation of defect densities. If test structures are used, that do not support the separation and localization of defects, both charts would result in nearly identical density distributions, which does not correspond to the actual occurrence of defects within semiconductor manufacturing processes.



### 6 CONCLUSION

Generally, errors in yield prediction are assigned to wrong critical area calculations and faulty selections of the models to describe defect densities. The occurrence of multiple faults that are the result of more than just one defect is the reason, why defect density distributions based on just counting the number of faults are insufficient. Our results clearly show, that the number of defects and therefore also the defect density is to small, if multiple faults are not disentangled, which may also be one reason for trouble in yield prediction.

To handle this problem, one way is to design test structures that prevent the occurrence of multiple faults or at least reduce the probability that they occur. A second way will analyze measured data of multiple faults using methodologies to calculate and compare the probability of possible locations of defects within a test structure layout. To determine the minimum number of defects that have caused a multiple fault, we describe procedures how to weight and count these defects to finally provide layer specific defect densities that correspond to the known product model for yield prediction. These procedures may be adapted to any test structure design that enables the localization of defects like SRAM, Checkerboard Test Structures, and Harp Test Structures.

#### ACKNOWLEDGMENT

Parts of this research were supported by *Deutsche* Forschungsgemeinschaft (DFG), Schm 623/3.

### REFERENCES

| [Bueh83]       | Buehler, M. G.                                                                     |
|----------------|------------------------------------------------------------------------------------|
|                | Microelectronic Test Chips for VLSI Electronics                                    |
|                | VLSI Electronics Microstructure Science, pp. 529-576, Vol. 9, Chap.9, Academic     |
|                | Press, 1983                                                                        |
| [Hess94]       | Hess. C.                                                                           |
| [              | Strategy to Optimize the Development, Use, and Dimension of Test Structures to     |
|                | Control Defect Appearance in Backend Process Steps                                 |
|                | Proc. Advanced Semiconductor Manufacturing Conference (ASMC) pp. 282-280           |
|                | Proton (USA) 1004                                                                  |
| TT-64041       | Lisse C. Strille A                                                                 |
| [[[103194]]    | ness, C., Suble, A.                                                                |
|                | Modeling of Real Defect Outlines and Defect Parameter Extraction Using a           |
|                | Checkerboard Test Structure to Localize Defects                                    |
|                | IEEE Transactions on Semiconductor Manufacturing, pp. 284-292, Vol. 7, No. 3, 1994 |
| [HeWB97a]      | Hess, C., Weiland, L. H., Bornefeld, R.                                            |
|                | Customized Checkerboard Test Structures to Localize Interconnection Point Defects  |
|                | Proc. VLSI Multilevel Interconnection Conference (VMIC), pp. 163-168, Santa Clara  |
|                | (USA), 1997                                                                        |
| [HeWe94a]      | Hess, C., Weiland, L. H.                                                           |
|                | Drop in Process Control Checkerboard Test Structure for Efficient Online Process   |
|                | Characterization and Defect Problem Debugging                                      |
|                | Proc. ICMTS, pp. 152-159, San Diego (USA), 1994                                    |
| [HeWe94]       | Hess, C., Weiland, L. H.                                                           |
| . ,            | Modeling of Test Structures for Efficient Online Defect Monitoring Using a Digital |
|                | Tester                                                                             |
|                | Proc ICMTS np. 108-113 San Diego (USA) 1994                                        |
| [HeWe95b]      | Hess C Weiland I H                                                                 |
| [neweyso]      | Defect Parameter Extraction in Backand Process Stans using a Multilayer            |
|                | Chackerboard Test Structure                                                        |
|                | Brog ICMTS pp 51 56 Nore (Japan) 1005                                              |
| [HaWa07a]      | Heee C. Weiland J. H.                                                              |
| [Hewe9/a]      | ness, C., weitand, L. H.                                                           |
|                | Determination of Defect Size Distributions Based on Electrical Measurements at a   |
|                | Novel Harp Test Structure                                                          |
|                | Proc. ICM1S, pp. 1-6, Monterey (USA), 1997                                         |
| [IpSa77]       | Ipri, A. C., Sarace, J. C.                                                         |
|                | Integrated Circuit Process and Design Rule Evaluation Techniques                   |
|                | RCA Review, pp. 323-350, Volume 38, Number 3, September 1977                       |
| [KhMT94]       | Khare, J. B., Maly, W., Thomas, M. E.                                              |
|                | Extraction of Defect Size Distributions in an IC Layer Using Test Structure Data   |
|                | IEEE Transactions on Semiconductor Manufacturing, pp. 354-368, Vol. 7, No. 3, 1994 |
| [KMGS94]       | Khare, J., Maly, W., Griep, S., Schmitt-Landsiedel, D.                             |
|                | SRAM-based Extraction of Defect Characteristics                                    |
|                | Proc. ICMTS, San Diego, USA, 1994                                                  |
| [LYWM86]       | Lukaszek, W., Yarbrough, W., Walker, T., Meindl J.                                 |
|                | CMOS Test Chip Design for Process Problem Debugging and Yield Prediction           |
|                | Experiments                                                                        |
|                | Solid State Technology, pp. 87-92. March 1986                                      |
| [StRo95]       | Staper, C. H., Rosner, R. J.                                                       |
| [biito)b]      | Integrated Circuit Vield Management and Vield Analysis: Development and            |
|                | Implementation                                                                     |
|                | IEEE Transactions on Semiconductor Manufacturing np. 05-102 Vol. 9, No. 2, 100     |
| IWWGH021       | Ward D. Walton A. I. Commin W. G. Holwill P. J.                                    |
| [ ** ** 01192] | The Use of a Digital Multiplever to Deduce Process Control Chin Ded Count          |
|                | The Use of a Digital Multiplexer to Reduce Process Control Chip Pad Count          |
|                | Proc. ICM115, San Diego (USA), 1992                                                |