# Parity-Scan Design to Reduce the Cost of Test Application ## Hideo Fujiwara and Akihiro Yamamoto Department of Computer Science Meiji University 1-1-1 Higashimita, Tama-Ku, Kawasaki 214, Japan #### Abstract: The cost of testing consists mainly of the cost of test generation and the cost of test application. Scan design approach is a representative of those techniques that can reduce the cost of test generation for sequential circuits. However, the length of a test sequence for the scan design approach can grow quite large due to the scan operation shifting the values into the scan chain, which makes the cost of test application large. This paper proposes a design-for-testability approach called Parity-Scan Design which can reduce the cost of test application as well as the cost of test generation for sequential The parity-scan design approach is a combination of scan technique and parity testing. Two types of parity-scan designs, pre-parity and post-parity scan design, are presented. Experiments on ISCAS89 circuits show that as high as 91.2% (91.1%) test length reduction and 32.4% (27.0%) average reduction can be obtained for pre-parity (post-parity) scan design under the single scan chain approach. More reduction can be achieved by applying a multiple scan chain technique. #### Key words: Cost of Test Application, Cost of Test Generation, Design for Testability, Parity Test, Sequential Circuits, Scan Design #### I. Introduction Testing has two main stages: the generation of tests for a given circuit and the application of these tests to the circuit. The cost of testing consists mainly of the cost of test generation and the cost of test application. Hence, design for testability should be considered to reduce both costs of test generation and test application. As a representative of those techniques that can reduce the cost of test generation, scan design approach [1, 2] can greatly reduce the cost of test generation for sequential circuits. However, the length of test sequence for scan design approach can grow quite large due to the scan operation shifting the values into and out of the scan chain, which makes the cost of test application quite large. Suppose a sequential circuit with a single scan chain of Nf flip-flops and an automatic combinational test generator generates Nt test patterns for the combinational logic part of the sequential circuit. Each generated test pattern is expanded into as many steps or shift clocks as are required to serially shift the Nf pseudo-input values into the scan chain. Hence, a set of N, test patterns results in a test sequence of length Nf(Nt+1)+Nt where the first term N<sub>f</sub>(N<sub>t</sub>+1) indicates the total number of shift clocks and the second term Nt is the total number of Several approaches have been proposed to reduce test application time. Parallel scan chains [1] can be used whereby the total number of scan chains are divided into K chains of length $N_f$ divided by K. Therefore, the total number of shift clocks can be reduced from $N_f(N_t+1)$ to $N_f(N_t+1)$ K. This reduction can be very high if K is large. However, K parallel scan chains require large pin overhead; additional K primary inputs and K primary outputs for K shift registers. Test set compaction [3] is considered to reduce the number of test patterns by combining some test patterns into one test pattern. However, one cannot expect high reduction of test length from the test set compaction approach. Partial scan design [4] can also reduce the length of test sequence by including only a subset of flip-flops in the scan chain. However, this requires a sequential test generator which increases the cost of test generation and again one cannot expect high reduction of test length from the partial scan approach. The test application time can be reduced by ordering the flip-flops in the scan chain [5]. However, only a low reduction in range 14% to 18.8% can be obtained according to the experimental results shown in [5]. A selectable length partial scan approach [6] is proposed where test length reductions in range 63% to 70.5% have been achieved for five large circuits. However, the test length reduction achieved depends highly on how effectively the scan flip-flops can be partitioned into a high-frequency group and low-frequency group. This paper proposes a design-for-testability approach which can reduce the cost of test application as well as the cost of test generation for sequential circuits. The proposed method called Parity-Scan Design is a combination of scan technique and parity testing. First, we shall show that the potential testability by parity testing is very high according to the experiments on ISCAS89 benchmark circuits [7]. Then we shall introduce the parity-scan design method by combining a scan design technique and parity testing of pseudooutputs, and present the condition of an input sequence to be a test sequence for a sequential circuit with parity-scan design under a single scan chain. Two types of parityscan designs, pre-parity and post-parity scan design, are presented. To obtain more reduction of test length, we shall extend the parity-scan design under a single scan chain to that under a multiple scan chain. The multiple scan chain approach divides a scan chain into plural scan chains without pin overhead by sharing scan-in and scanout pins among them. Experiments on ISCAS89 circuits show that as high as 91.2% (91.1%) test length reduction and 32.4% (27.0%) average reduction can be obtained for pre-parity (post-parity) scan design under the single scan chain approach. More reduction can be achieved by applying the multiple scan chain technique. ### II. Parity Testability of Flip-Flops As mentioned in the preceding section, here we consider a design-for-testability method that can reduce both costs of test generation and test application for sequential circuits. To satisfy the former, i.e., to reduce the cost of test generation, we adopt the scan design technique. Assuming scan design we further consider to reduce the cost of test application. In a scan design approach, all flip-flops in the circuit are interconnected into one or more shift registers and the contents of the shift registers are shifted in and out. All the states of the circuit are completely controlled and observed from primary inputs and outputs, and thus all flip-flops can behave as primary inputs/outputs. Therefore, it turns out that the sequential circuit can be thought of as purely combinational and the complexity of test generation for the circuit can be substantially reduced. Suppose that a sequential circuit is scan-designed with a single scan chain of Nf flip-flops and an automatic combinational test generator such as FAN [8] generates N, test patterns for the combinational logic part of the circuit. Then the length of the test sequence becomes (number of flip-flops) $\times$ (frequency of scan) + (number of test-patterns) = $N_f(N_t+1)+N_t$ . Here, if we can reduce the frequency of scan process, the length of the test sequence, and hence the cost of test application, can be reduced. The purpose of scan process is (a) to set the flipflops in a circuit to any desired state and (b) to observe the internal state of the flip-flops in a circuit. The former is the controllability enhancement of flip-flops, and the latter is the observability enhancement of flip-flops. To reduce the scan process, we have to consider something to substitute for it. Before resolving the controllability issue, let us first consider what can be substituted for the scan process to enhance the observability of flip-flops. Figure 1 shows a sequential circuit with a double-latch design. All clocked flip-flops are implemented as a set of master-slave latches L<sub>1</sub> and L<sub>2</sub>. Cutting the feedback loops where the clocked flip-flops are, we can get pseudo-inputs and pseudo-outputs as shown in Figure 2. Further, inserting a cascade of Exclusive-OR gates on pseudo-outputs, we can get a circuit with parity testing for pseudo-outputs in Figure 2. In this circuit of Figure 2, if an error of a fault propagates to the odd number of pseudo-outputs, the error can be observed at the output of the Exclusive-OR cascade. Here, it is an interesting issue to investigate how many percentage of faults can be detected by such a parity testing. To see this, we have made an experiment on the ISCAS89 circuits [7]. The ISCAS89 circuits have been changed into the structure of Figure 2. Then the FAN algorithm [8] has been applied to the modified ISCAS89 circuits with the structure of Figure 2. The results are given in Table 1. The following columns are contained in the table: - 1. Circuit Name The assigned name for the circuit. - #gates The number of logic gates. Primary inputs and primary outputs are considered gates. - #DFFs The number of D flip-flops which are contained in the circuit. - #faults (total) The total number of fault equivalence classes generated from the circuit. - #faults (redund) Then number of redundant faults identified by FAN - #faults (abort) The number of faults aborted by FAN due to a backtrack limit of 100. Figure 1 A Sequential Circuit - #patterns The number of test patterns generated by FAN. - #detected faults (PO) The number of faults that can be detected at primary outputs with test patterns generated by FAN. - 9. #detected faults (odd) The number of faults that can be detected at the odd number of pseudo-outputs with at least one test pattern generated by FAN but that cannot be detected at primary outputs (i.e., detectable at the parity output with at least one test pattern but undetectable at the primary outputs). - 10. #detected faults (even) The number of faults that can be detected only at the even number of pseudo-outputs when detected with test patterns generated by FAN (i.e., detectable at the peudo-outputs but neither detectable at the parity output nor at the primary outputs). - Parity Testability The ratio of the number of detectable faults by parity testing to the total number of detectable faults, i.e., Figure 2 Parity Testing of Pseudo-Outputs Table 1 ISCAS89 ATPG Results by FAN | Circuit<br>Name | # gates | # DFPs | # faults | | | # patterns | # detected faults | | | Parity | |-----------------|---------|--------|----------|--------|-------|------------|-------------------|-------|------|-------------| | | | | total | redund | abort | e paracine | PO | odd | even | Testability | | s208 | 133 | 8 | 217 | 0 | 0 | 44 | 90 | 124 | 3 | 98.6 | | s298 | 170 | 14 | 308 | 0 | 0 | 41 | 18 | 283 | 7 | 97.7 | | s344 | 225 | 15 | 342 | 0 | 0 | 36 | 33 | 282 | 27 | 92.1 | | s349 | 226 | 15 | 350 | 2 | 0 | 37 | 32 | 292 | 24 | 93.1 | | s382 | 232 | 21 | 399 | 0 | 0 | 48 | 12 | 369 | 18 | 95.5 | | s386 | 199 | 6 | 384 | 0 | 0 | 90 | 148 | 232 | 4 | 99.0 | | s400 | 239 | 21 | 424 | 6 | 0 | 46 | 12 | 387 | 19 | 95.5 | | s420 | 265 | 16 | 455 | 0 | 0 | 93 | 194 | 245 | 16 | 96.5 | | s444 | 255 | 21 | 474 | 14 | 0 | 55 | 12 | 429 | 19 | 95.9 | | s510 | 255 | 6 | 564 | 0 | 0 | 74 | 158 | 398 | 8 | 98.6 | | s526 | 265 | 21 | 555 | 1 | 0 | 90 | 18 | 530 | 6 | 98.9 | | s526n | 266 | 21 | 553 | 0 | 0 | 91 | 18 | 528 | 7 | 98.7 | | s641 | 495 | 19 | 467 | 0 | 0 | 80 | 160 | 305 | 2 | 99.6 | | s713 | 508 | 19 | 581 | 38 | 0 | 72 | 168 | 372 | 3 | 99.4 | | s820 | 368 | 5 | 850 | 0 | 0 | 162 | 277 | 566 | 7 | 99.2 | | s832 | 367 | 5 | 870 | 14 | 0 | 156 | 277 | 572 | 7 | 99.2 | | s838 | 523 | 32 | 931 | 0 | 0 | 191 | 402 | 487 | 42 | 95.5 | | s953 | 521 | 29 | 1079 | 0 | 0 | 114 | 46 | 958 | 75 | 93.0 | | s1196 | 615 | 18 | 1242 | 0 | 0 | 191 | 550 | 692 | 0 | 100.0 | | s1238 | 598 | 18 | 1355 | 69 | 0 | 208 | 587 | 698 | 1 | 99.9 | | s1423 | 906 | 74 | 1515 | 14 | 0 | 126 | 42 | 1385 | 74 | 95.1 | | s1488 | 741 | 6 | 1486 | 0 | 0 | 170 | 838 | 644 | 4 | 99.7 | | s1494 | 735 | 6 | 1506 | 12 | 0 | 166 | 844 | 646 | 4 | 99.7 | | e5378 | 3400 | 179 | 4603 | 40 | 0 | 497 | 1332 | 2997 | 234 | 94.9 | | s9234 | 6326 | 211 | 6927 | 413 | 40 | 580 | 151 | 6144 | 179 | 97.2 | | s13207 | 10167 | 638 | 9815 | 149 | 2 | 721 | 707 | 7360 | 1597 | 83.5 | | s15850 | 11739 | 534 | 11725 | 388 | 1 | 670 | 751 | 10166 | 419 | 96.3 | | e35932 | 21903 | 1728 | 39094 | 3984 | 0 | 1009 | 2507 | 32573 | 30 | 99.9 | | s38417 | 27379 | 1636 | 31180 | 161 | 4 | 2386 | 267 | 28461 | 2287 | 92.6 | | s38584 | 24173 | 1426 | 36303 | 1500 | 6 | 1562 | 1600 | 30853 | 2344 | 93.3 | (a) Pre-Parity Type (b) Post-Parity Type Figure 3 Parity-Scan Flip-Flop From the results shown in Table 1, we can see that the parity testability of ISCAS89 circuits is 94.6% on average and is in the range of 83.5% to 100%. Hence, most of the detectable faults can be tested at primary outputs including the parity output. This suggests that the parity testing approach of Figure 2 could be substituted for the scan process of observing the contents of flip-flops. ### III. Parity-Scan Design Parity-Scan Design is a variation of the scan design approach which is a combination of the scan design and parity testing. Examples of parity-scan flip-flops are shown in Figure 3 which consist of a shift-register latch (SRL) used in LSSD [2] and an Exclusive-OR gate for parity test. The SRL consists of two latches, $L_1$ and $L_2$ , which have the scan input I, the data input D, the system clock C, and two shift-control inputs, A and B. Figure 3 (a) shows a *pre-parity type* parity-scan flip-flop where the Exclusive-OR gate is located before the flip-flop to take the parity of the data input to the flip-flop. On the other hand, Figure 3 (b) shows a *post-parity* type parity-scan flip-flop where the Exclusive-OR gate is located after the flip-flop to take the parity of the flip-flop. Using these parity-scan flip-flops, two types of general structures for double-latch parity-scan design are obtained as illustrated in Figures 4 (a) and (b). All storage elements are implemented as a set of master-slave latches, L<sub>1</sub> and L<sub>2</sub>. Each of master-slave latches is connected in series and clocked by two nonoverlapping clocks C<sub>1</sub> and C<sub>2</sub>, where C<sub>2</sub> is equivalent to B. Each of Exclusive-OR gates is also connected to form an Exclusive-OR cascade with a parity output. Figures 4 (a) and (b) show the pre-parity type and post-parity type parity-scan designs, respectively. In the shift register mode, these latches are chained to form a shift register under the control of clocks A and B. Test patterns are applied to the combinational circuit by scanning them into the shift register and applying them at the primary inputs. Then the clock $C_1$ is set to 1 and the response of the combinational circuit is captured in the $L_1$ latches and at the primary outputs. The result of the test captured in the register is then scanned out. The Parity-Scan Design has also the capability of parity testing for the contents captured in the L<sub>2</sub> latches or flip-flops before or after capturing. The preparity scan design can take the parity of the data input to the flip-flops and the post-parity scan design can take the parity of the flip-flops. If an error of a fault propagates to the odd number of flip-flops, the error can be observed at the parity output of the Exclusive-OR cascade. This parity test operation will be used as a substitute for the scan operation of observing the contents of flip-flops. (a) Pre-Parity Type Figure 4 Parity-Scan Design ### IV. Test Sequence for Parity-Scan Design Let us consider a sequential circuit with scan design. The circuit can operate either in its normal mode or in the scan mode. Testing of the circuit can be separated into two parts; testing of the shift-register (or testing the scan operation) and testing of the combinational logic part of the circuit. The former can be performed easily by shifting in and out an alternating sequence of ones and zeros. Most part of the test sequence for the circuit is composed of the latter, i.e., the testing of the combinational logic part, which is as follows: - Switch to the scan mode and set the starting state (or the pseudo-input pattern) for the first test by shifting the pseudo-input pattern into the flip-flops. - (2) Return to the normal mode and apply the primary input pattern for the present test. - (3) Switch to the scan mode and shift out the final state (or the pseudo-output pattern) while setting the starting state (or the pseudo-input pattern) for the next test. Return to step 2. (b) Post-Parity Type Figure 4 Parity-Scan Design Next, suppose a sequential circuit which is parity-scan designed with a single scan chain of N<sub>f</sub> flip-flops. Suppose also that an automatic combinational test generator such as FAN [8] generates N<sub>t</sub> test patterns to get 100% fault coverage for the combinational logic part of the circuit. If the function of parity testing of the parity-scan design is not used and only the function of scan operation is used, the length of the test sequence becomes (number of flip-flops) x (frequency of scan) + (number of test-patterns) $$= N_f (N_t + 1) + N_t.$$ This length can be reduced if some of the scanning operations are omitted from the test sequence. Scan operation has two objectives; observation and control of flip-flops. To omit a scan operation from a test sequence, these two functions of observation and control provided by the scan operation have to be substituted by others. Let us classify all detectable faults in the combinational logic part of a sequential circuit, i.e., combinational irredundant faults, into two groups; one is a set of faults that are detectable at primary outputs and/or a parity output, and the other is a set of faults that are detectable only at the even number of pseudo-outputs. Let us call the former parity-testable faults and the latter parity-untestable faults. Suppose two consecutive test patterns T(i) and T(i+1). Suppose also a fault f that is tested by the test pattern T(i). If the fault f is parity-testable, it is detected at the primary outputs when T(i) is applied and/or at the parity output. In case of pre-parity scan design, the fault is detected at the parity output at the same time when T(i) is applied. In case of post-parity scan design, the fault is detected at the parity output at the next time when T(i+1) is applied. For parity-testable faults in both cases, hence, the scan operation to observe the flip-flops can be omitted. Furthermore, the scan operation for setting flipflops to the values of pseudo-inputs for the next test T(i+1) can be omitted if the values at the pseudo-outputs of the current test T(i) is identical to the values at the pseudo-inputs of the next test T(i+1). Therefore, if the values at the pseudo-outputs of the current test T(i) is identical to the values at the pseudo-inputs of the next test T(i+1) and if T(i) is aimed at testing parity-testable faults only, then the scan operation between T(i) and T(i+1) can be omitted. Let us call this state no scan with clock. This is illustrated in Figure 5 (a). In case of pre-parity scan design, we can further omit scan operation. If no system clock to the flip-flops is applied between T(i) and T(i+1), the flip-flops can hold the same contents and hence the values at the pseudoinputs of the next test T(i+1) is identical to the values at the pseudo-inputs of the current test T(i). In case of pre-parity scan design, hence, if the values at the pseudo-inputs of the current test T(i) is identical to the values at the pseudo-inputs of the next test T(i+1) and if T(i) is aimed at testing parity-testable faults only, then the scan operation between T(i) and T(i+1) can be omitted. Let us call this state no scan without clock. This is illustrated in Figure 5 (b). If the fault f is parity-untestable, the error caused by the fault is propagated only to the even number of pseudo-outputs when the test pattern T(i) is applied. So, in order to detect the fault f at this time by the test pattern T(i), the values with error captured at flip-flops have to be shifted out to observe at the scan output. Therefore, either if the values at the pseudo-outputs of the current test T(i) is not identical to the values at the pseudo-inputs of the next test T(i+1) or if T(i) is aimed at testing some parity-untestable fault, then the scan operation between T(i) and T(i+1) cannot be omitted. Let us call this state scan. This is illustrated in Figure 5 (c). Without loss of generality, a test sequence for a circuit with parity-scan design is represented by where each S(i) indicates either scan or no scan. Obviously, S(0) is scan. Let us abbreviate this test sequence as T(1)T(2)...T(n)/S(0)S(1)...S(n). From the above discussion, we can define a test sequence for a sequential circuit with parity-scan design. A test sequence T(1)T(2)...T(n)/S(0)S(1)...S(n) satisfying the following conditions is called a parity-scan test sequence: - for each detectable fault f, f is tested by some test pattern T(i) (i=1,2,...,n), - (2) S(0) is scan, - (3) for each S(i) (i=1,2,...,n-1), (i) S(i) is no scan with clock if the values at the pseudo-outputs of the current test T(i) is identical to the values at the pseudo-inputs of the next test T(i+1) and if T(i) is aimed at testing parity-testable faults only, (ii) S(i) is no scan without clock (in case of pre-parity type only) if the values at the pseudo-inputs of the current test T(i) is identical to the values at the pseudo-inputs of the next test T(i+1) and if T(i) is aimed at testing parity-testable faults only, and (iii) S(i) is scan either if the values at the pseudo-outputs of the current test T(i) is not identical to the values at the pseudo-inputs of the next test T(i+1) or if T(i) is aimed at testing some parity-untestable fault, (4) S(n) is no scan with clock if T(n) is aimed at testing only parity-testable faults, and S(n) is scan if T(n) is aimed at testing some parity-untestable fault. Let us evaluate the length of a parity-scan test sequence. Let $N_f$ and $N_t$ be the number of flip-flops and test patterns, respectively. Let $N_s$ and $N_{ns}$ be the number of scan states and no scan (with/without clock) states, respectively. If each test pattern appears only once in the parity-scan test sequence, $N_s + N_{ns} = N_t + 1$ . Then the length of the parity-scan test sequence becomes (number of flip-flops) x (frequency of scan) + (number of test-patterns) $$= N_f N_s + N_t.$$ The test length reduction of the parity-scan design to the original scan design is $$1 - \frac{N_f N_s + N_t}{N_f (N_t + 1) + N_t} = \frac{N_f N_{ns}}{N_f (N_t + 1) + N_t}$$ For given $N_f$ and $N_t$ , this reduction is maximized when $N_{ns}$ is maximized or $N_s$ (= $N_t$ +1 - $N_{ns}$ ) is minimized. Since the values $N_{ns}$ and $N_s$ are influenced by the ordering of test patterns in a parity-scan test sequence, the problem is how to determine an ordering of test patterns that leads to the minimum test sequence. For $N_t$ test patterns, however, the number of possible orderings is $N_t$ !, which makes it almost impossible to get the optimum length when $N_t$ is large. It is also important to construct a parity-scan test sequence with low time overhead compared to the test generation time for the combinational logic part of the circuit under test. So, we shall consider a simple procedure for searching an ordering of test patterns that reduces the number of scan operations. The procedure for constructing a parity-scan test sequence T(1) T(2) ... T(n) / S(0) S(1) S(2) ... S(n) operates as follows. SO(T(i)) = SI(T(i+1)) and T(i) is aimed at testing parity-testable faults only T(i) No Scan No Clock T(i+1) (a) SI(T(i)) = SI(T(i+1)) and T(i) is aimed at testing parity-testable faults only Scan T(i+1) (b) Either $SO(T(i)) \neq SI(T(i+1))$ or T(i) is aimed at testing some parity-untestable fault (c) Figure 5 Scan / No Scan States First, choose a fault f from the fault table of the circuit under test. Generate a test pattern $T_f$ for the fault f by using the combinational test generation algorithm such as FAN [8]. Specify all undetermined values or X's at primary inputs and/or pseudo inputs of $T_f$ by arbitrary values 0 or 1 and perform fault simulation to find all detectable faults by the test pattern $T_f$ and to classify those detected faults into parity-testable and parity-untestable faults. Then, select $T_f$ as the first test pattern T(1) for the parity-scan test sequence. Let S(0) be the scan state to initialize the pseudo-inputs of $T_f$ . Those parity-testable faults can be detected by $T_f$ even when S(1) is non-scan. Those parity-untestable faults, however, can be detected by $T_f$ only when S(1) is scan, i.e., by scan-out processing. Next, for some fault g which has not yet been detected, find a test pattern Tg such that the values at the pseudo-inputs of T<sub>p</sub> are identical to those at the pseudooutputs of T(1). In case of pre-parity scan design, find a test pattern Tg such that the values at the pseudo-inputs of Tg are identical to those either at the pseudo-inputs or at the pseudo-outputs of T(1). Here, the test pattern To is either generated by FAN or taken from a hash table which stores test patterns generated by FAN for reuse. For each fault, FAN is used at most once to avoid wasting CPU time. If such a test pattern Tg is exists, put it on the second test pattern T(2) and make the state S(1) between T(1) and T(2) be no scan. pattern Tg does not exist, put an arbitrary test pattern, which can detect a new fault, on the second test pattern T(2) and make the state S(1) between T(1) and T(2) be scan. During this process of searching a test pattern Tg, all test patterns, which have been newly generated by FAN and have not been adopted as a test pattern, are stored in the hash table to reuse them afterward. After test pattern generation, fault simulation is performed to find all other detectable faults by the test pattern To and to classify those faults into parity-testable and parityuntestable faults. Again, those parity-testable faults can be detected by T<sub>g</sub> even when S(2) is non-scan. On the other hand, those parity-untestable faults can be detected by Tg only when S(2) is scan, i.e., by scan-out processing. Continue the above process until all faults are detected. The test sequence T(1) T(2) ... T(n) / S(0) S(1) S(2) ... S(n) generated by the process mentioned above always satisfy the condition of the parity-scan test sequence. ### V. Experimental Results We have made experiments on the ISCAS89 circuits [7]. The ISCAS89 circuits contain flip-flops which are assumed to be fully scannable and parity-testable as shown in Figures 4 (a) and (b). The FAN algorithm [8] was used to generate test patterns for each combinational logic part of ISCAS89 circuits. From the generated test patterns, parity-scan test sequences were constructed for both pre-parity and post-parity types. The experiments ran on a SUN 4 / 330, a 16 MIPS machine with a 32 Megabytes of memory. The results for preparity and post-parity types are given in Tables 2 and 3, respectively. The following columns are contained in the tables: - 1. Circuit Name The assigned name for the circuit. - #scan frequency (scan) The frequency of scan operation for scan design, - #scan frequency (parity-scan) The frequency of scan operation for parity-scan design. - Test Sequence Length (scan) The length of test sequences for scan design. - Test Sequence Length (parity-scan) The length of test sequences for parity-scan design. - Test Length Reduction The ratio of the reduced test length for parity-scan design to the test length for scan design, i.e., 1 - Length of Parity-Scan Test Sequence × 100% - CPU time (scan) The total CPU time in seconds required to generate test patterns for scan design (including fault simulation time). - CPU time (parity-scan) The total CPU time in seconds required to construct a parity-scan test sequence for parity-scan design (including fault simulation time). From the results shown in Table 2, as high as 91.2% test length reduction (32.4% on average) is achieved for pre-parity scan designs of ISCAS89 benchmarks. From Table 3, as high as 91.1% test length reduction (27.0% on average) is achieved for post-parity scan designs of ISCAS89 benchmarks. The time overhead or the extra CPU time required to construct a parity-scan test sequence from generated test patterns is not so high for both types. Both of the pre- and post-parity scan design approaches can reduce the cost of test application. Tables 2 and 3 show the results for parity-scan designs under a single scan chain technique. One can easily extend the single scan chain approach to a multiple scan chain. More reduction can be expected to achieve by applying the multiple scan chain technique, which is described in the next section. # VI. Multiple Scan Chain Let N<sub>f</sub> be the number of flip-flops and N<sub>t</sub> be the number of test patterns for the combinational logic part of a circuit under test. For a circuit with a single scan chain, the length of the test sequence is $N_f(N_t+1)+N_t$ . To reduce the length of the test sequence, parallel scan chains can be used whereby the total number of scan chains are divided into K chains of length $N_f$ divided by K (see Figure 6 (a)). The total number of shift clocks can be reduced from Nf ### $N_{t}(N_{t}+1)$ (N<sub>t</sub>+1) to K. However, K parallel scan chains require large pin overhead, i.e., additional K primary inputs and K primary outputs for K shift registers. To overcome this pin overhead, we consider a variation of the parallel scan chain approach. Figure 6 (b) shows the approach called a multiple scan chain. In this scan design, a long scan chain is divided into K scan chains without pin overhead by sharing one scan-in pin and one scan-out pin among them. Parallel scan chains can get K different serial input sequences from K scan-in pins and shift in and out them in parallel. The multiple scan chain, however, cannot get K different input sequences in Table 2 ISCAS89 Test Length Reduction for Pre-Parity Type Table 3 ISCAS89 Test Length Reduction for Post-Parity Type | Circuit<br>Name | Scan | Prequency | Test Sequ | ence Length | Test Length | CPU Time (sec) | | |-----------------|------|-------------|-----------|-------------|-------------|----------------|-------------| | | BCAN | Parity-Scan | scan | Parity-Scan | Reduction % | scan | Parity-Scan | | s208 | 45 | 25 | 404 | 279 | 30.9 | - 1 | 1 | | s298 | 42 | 32 | 629 | 495 | 21.3 | 1 | 1 | | s344 | 37 | 28 | 591 | 461 | 22.0 | 1 | 1 | | £349 | 38 | 27 | 607 | 443 | 27.0 | 1 | 1 | | £382 | 49 | 37 | 1077 | 828 | 23.1 | 1 | 2 | | s386 | 91 | 48 | 636 | 380 | 40.3 | 1 | 3 | | <b>\$400</b> | 47 | 37 | 1033 | 829 | 19.7 | 1 | 2 | | s420 | 94 | 75 | 1597 | 1296 | 18.8 | 2 | 2 | | <b>5444</b> | 56 | 42 | 1231 | 936 | 24.0 | 1 | 1 | | a510 | 75 | 47 | 524 | 354 | 32.4 | 2 | 3 | | s526 | 91 | 77 | 2001 | 1707 | 14.7 | 2 | 3 | | a526n | 92 | 78 | 2023 | 1730 | 14.5 | 1 | 4 | | s641 | 81 | 26 | 1619 | 579 | 64.2 | 1 | 3 | | s713 | 73 | 34 | 1459 | 729 | 50.0 | 2 | 5 | | s820 | 163 | 66 | 977 | 487 | 50.2 | 6 | 12 | | s832 | 157 | 63 | 941 | 471 | 49.9 | 6 | 11 | | s838 | 192 | 169 | 6335 | 5602 | 11.6 | 7 | 15 | | s953 | 115 | 78 | 3449 | 2391 | 30.7 | 5 | 9 | | s1196 | 192 | 5 | 3647 | 359 | 90.2 | 11 | 18 | | s1238 | 209 | | 3970 | 351 | 91.2 | 15 | 21 | | s1423 | 127 | 105 | 9524 | 7894 | 17.1 | 6 | 11 | | s1488 | 171 | 75 | 1196 | 617 | 48.4 | 13 | 22 | | s1494 | 167 | 88 | 1168 | 702 | 39.9 | 13 | 25 | | s5378 | 498 | 426 | 89639 | 76739 | 14.4 | 67 | 133 | | s9234 | 581 | 552 | 123171 | 117074 | 5.0 | 293 | 439 | | s13207 | 722 | 666 | 461357 | 425622 | 7.7 | 278 | 364 | | s15850 | 671 | 537 | 358984 | 287429 | 19.9 | 309 | 607 | | £35932 | 1010 | 305 | 1746289 | 527385 | 69.8 | 1996 | 1827 | | <b>s</b> 38417 | 2387 | 2096 | 3907518 | 3431203 | 12.2 | 2231 | 4251 | | <b>£38584</b> | 1563 | 1384 | 2230400 | 1975036 | 11.4 | 2064 | 3444 | | Circuit<br>Name | Scan Fr | | | ence Longth | Test Length<br>Reduction | CPU Time (sec) | | |-----------------|---------|------------|---------|-------------|--------------------------|----------------|-------------| | Name | scan F | arity-Scan | scan | Parity-Scan | % | scan | Parity-Scan | | s208 | 45 | 29 | 404 | 275 | 31.9 | 1 | 1 | | s298 | 42 | 33 | 629 | 507 | 19.4 | 1 | 1 | | 1344 | 37 | 32 | 591 | 519 | 12.2 | 1 | 1 | | £349 | 38 | 27 | 607 | 442 | 27.2 | 1 | 1 | | s382 | 49 | 37 | 1077 | 827 | 23.2 | 1 | 1 | | 1386 | 91 | 71 | 636 | 515 | 19.0 | 1 | 3 | | s400 | 47 | 38 | 1033 | 849 | 17.8 | 1 | 1 | | s420 | 94 | 76 | 1597 | 1309 | 18.0 | 2 | 2 | | 5444 | 56 | 45 | 1231 | 1002 | 18.6 | 1 | 1 | | s510 | 75 | 59 | 524 | 430 | 17.9 | 2 | 4 | | s526 | 91 | 84 | 2001 | 1860 | 7.0 | 2 | 4 | | a526n | 92 | 80 | 2023 | 1772 | 12.4 | 1 | 6 | | s641 | 81 | 35 | 1619 | 742 | 54.2 | 1 | 3 | | s713 | 73 | 48 | 1459 | 997 | 31.7 | 2 | , | | s820 | 163 | 91 | 977 | 606 | 38.0 | 6 | 9 | | s832 | 157 | 104 | 941 | 685 | 27.2 | 6 | 11 | | s838 | 192 | 172 | 6335 | 5696 | 10.1 | 7 | 13 | | s953 | 115 | 74 | 3449 | 2266 | 34.3 | 5 | 11 | | s1196 | 192 | 7 | 3647 | 324 | 91.1 | 11 | 18 | | s1238 | 209 | 9 | 3970 | 370 | 90.7 | 15 | 21 | | s1423 | 127 | 107 | 9524 | 8038 | 15.6 | 6 | 14 | | s1488 | 171 | 135 | 1196 | 981 | 18.0 | 13 | 20 | | s1494 | 167 | 142 | 1168 | 1027 | 12.1 | 13 | 23 | | £5378 | 498 | 429 | 89639 | 77262 | 13.8 | 67 | 133 | | 19234 | 581 | 588 | 123171 | 124674 | -1.2 | 293 | 483 | | s13207 | 722 | 674 | 461357 | 430716 | 6.6 | 278 | 497 | | s15850 | 671 | 591 | 358984 | 316256 | 11.9 | 309 | 618 | | s35932 | 1010 | 222 | 1746289 | 383872 | 78.0 | 1996 | 1595 | | s38417 | 2387 | 2084 | 3907518 | 3411544 | 12.7 | 2231 | 4219 | | s38584 | 1563 | 1416 | 2230400 | 2020675 | 9.4 | 2064 | 3499 | parallel but in series. So, the multiple scan chain approach cannot be expected to achieve the same high reduction of the number of shift clocks as the parallel scan chain approach. For the conventional scan design approach, the multiple scan chain cannot contribute to the reduction of the number of shift clocks. For the parity-scan design approach proposed in this paper, however, the multiple scan chain can contribute to reduce the number of shift clocks. When we construct a parity-scan test sequence from the generated test patterns, we have to put scan operation between two consecutive test patterns if the values at the pseudo-outputs of the current test pattern is not equal to the values at the pseudo-inputs of the next test pattern. However, this inequality of values occurs usually at very few scan locations or flip-flops, i.e., most of the flip-flops retain their state. Hence, in the multiple scan chain, only the sub-chains at which the inequality occurs need to be updated by scan operation while the remaining sub-chains retain their state without scan operation. This partial scan operation in the multiple scan chain can thus reduce the number of shift clocks or the number of scan operations. The advantage of this partial scan operation can also be applied in the case that we have to observe the contents of flip-flops when a parity-untestable fault is tested (see the conditions of a parity-scan test sequence). #### VII. Conclusions A new design for testability approach called parity-scan design which can reduce the cost of test application as well as the cost of test generation has been presented. This technique is useful in reducing the scan operations or the number of shift clocks, and hence the overall test sequence length. Significant reductions of test sequence length have been achieved on ISCAS89 benchmark circuits, as high as 91.2% (91.1%) reduction, and 32.4% (27.0%) on average for pre-parity (post-parity) scan design under the single scan chain approach. More reduction can be achieved by applying the proposed multiple scan chain technique. We are currently implementing a program for constructing a parity-scan test sequence of a circuit with multiple scan chain design. #### References - H. Fujiwara, Logic Testing and Design for Testability, The MIT Press, 1985. - [2] E.B. Eichelberger and T.W.Williams, "A logic design structure for LSI testability," Proc. Design Automation Conf., pp. 462-468, June 1877. - [3] P. Goel and B.Rosales, "Test generation and dynamic compaction of tests," Proc. 1979 Intl. Test Conf., pp. 189-192, 1979. - [4] V.D.Agrawal, K.Cheng, D.Johnson, and T.Lin, "Designing circuits with partial scan," *IEEE Design and Test of Computers*, pp. 8-15, April 1988. - [5] R.Gupta and M.A.Breuer, "Ordering storage elements in a single scan chain," Proc. Intl. Conf. on Computer-Aided Design, pp. 408-411, 1991. - [6] S. P. Morley and R. A. Marlett, "Selectable length partial scan: a method to reduce vector length," Proc. Intl. Test Conf., pp. 385-392, 1991. - [7] F. Brglez, D. Bryan, and K. Kozminski, "Combinational profiles of sequential benchmark circuits," Proc. IEEE Int. Symp. Circuits and Systems, pp. 1929-1934, May 1989. - [8] H. Fujiwara and T. Shimono, "On the acceleration of test generation algorithms," *IEEE Trans. Comput.*, vol. C-32, pp. 1137-1144, Dec. 1983.