A new approach to optimize a configurable twodimensional (2-D) linear feedback shift registers (LFSR) for both embedded and random test pattern generation in built-in self-test (BIST) is proposed. This configurable 2-D LFSR based test pattern generator generates: 1) a deterministic sequence of test patterns for random-pattern-resistant faults, and then 2) random patterns for random-pattern-detectable faults. The configurable 2-D LFSR test generator can be adopted in two basic BIST execution options: test-per-clock (parallel BIST) and test-per-scan (serial BIST). Experimental results of test-per-clock BIST for benchmark circuits show with the configurable scheme the number of flip-flops of 2-D LFSR is reduced by 79%. The average number of faults detected by configurable 2-D LFSR is 9.27% higher than the conventional LFSR. Experimental results of testper-scan BIST for benchmark circuits demonstrate the effectiveness of the proposed technique in which high fault coverage can be achieved.
Introduction
BIST has been proven to be an effective design-fortestability technique to achieve sufficiently high fault coverage in which testing is accomplished through built-in hardware for test generation and response analysis. There are typically two basic BIST execution options: 1) test-per-clock (parallel BIST) and 2) test-per-scan (serial BIST). In testper-clock BIST, test patterns are applied to the circuit under test (CUT) by the test generator and the responses are captured by response analyzer every clock cycle. In test-perscan BIST, test patterns are shifted into a serial scan path or multiple scan paths to test the CUT. The test responses are subsequently captured by the scan flip-flops and shifted out to the response analyzer while new patterns are being shifted in.
There have been various test generation techniques based on pseudo-random testing [1, 9] , pseudo-exhaustive testing [2, 10, 11] , weighted random testing [3, 12, 13] , and reseeding of LFSR [5] [6] [7] . Justification of use of any of these techniques includes test application time, test length, test storage, hardware overhead, and fault coverage. The major limitations with these techniques are the test length, the fault coverage, and the complexity of implementation. Several approaches have been proposed to overcome these disadvantages, one of which is to embed a set of pre-computed test vectors, called deterministic patterns, to reach high fault coverage within a shorter time. Such deterministic patterns can be obtained by an automatic test pattern generation tool and implemented with a ROM to store the patterns, or the traditional LFSR with pre-designed seeds to generate the patterns. However, a number of weakness and problems still remain unsolved, which has a great impact on testing cost and performance. It is expected that easy and regular structure for implementation will result in a reduction of the product development cycle and cost, and the cost of system maintenance can be significantly reduced.
2-D LFSR
A conventional LFSR can be used to generate a large number of pseudo-random test patterns with very small area overhead that is composed of exclusive-or gates (XORs) and flip-flops (FFs). The general structure is shown in Fig. 2 , which can be expressed with the polynomial in Eq. (1). The coefficients Ci ( i = 1~M-1) are zero or one. Fig. 2 . A conventional LFSR.
An LFSR goes through a cyclic sequence of states and the outputs produced are also periodic. The maximum length of this period is , where M is the number of stages. So the patterns generated by an LFSR are pseudo-random and the random properties depend on its initial state and its generating function
. Once the generating function and the initial state are fixed, the patterns produced are also determined. It cannot produce a sequence of deterministic ordered patterns that are required to detect the random-patternresistant faults. A number of the LFSR based techniques [5] [6] [7] have been developed to generate deterministic ordered test patterns but the encoding and decoding procedures and the implementation of control logic are relatively complex. This 2-D LFSR can generate a set of pre-computed test vectors for detecting random-pattern-resistant faults. In addition, it can generate better random patterns than a conventional LFSR. Fig. 3 shows the general representation of a 2-D LFSR based on N primitive polynomials: 
where The synthesized results are shown below and the synthesized 2-D LFSR is as shown in Fig. 4 .
The synthesis procedure for a configurable 2-D LFSR has two main tasks: (1) find a set of deterministic ordered patterns and (2) The longer the deterministic sequence is, the more stages of a 2-D LFSR are required. For some practical circuits, a large overhead is unacceptable. In the next section, a feasible configuration scheme based on a 2-D LFSR to reduce the overhead is proposed.
Configurable 2-D LFSR
A configurable 2-D LFSR based test pattern generator is proposed to generate an embedded deterministic sequence of test patterns followed by pseudo-random patterns. The generator mainly consists of four types of function blocks -the flip-flop array (FFA), the configuration networks (CN), the multiplexers (MUXs), and the control unit (CU) as shown in The synthesized results are shown below and the synthesized 2-D LFSR is as shown in Fig. 6 .
Example 2 shows the effectiveness of the configurable 2-D LFSR based generator. Given a deterministic sequence of 18 6-bit patterns with the initial seed <101010>, both a configurable and a non-configurable 2-D LFSRs are generated. Fig. 6 shows the configurable 2-D LFSR with one stage of FFA, M = 1 and p = 2. Feeding the initial seed <101010> back to FFA through the configuration network CN1 generates the first test pattern <101001>. Other patterns are generated subsequently till the ninth pattern <110100> is generated. In this configurable test generator, the CN1 generates the first 9 patterns of subsequence 1, <101001>, <011100>, <111111>, <001111>, <010111>, <000001>, <010010>, <111010> and <110100>. The CN2 generates the next 9 patterns of subsequence 2, <100011>, <001001>, <001111>, <110111>, <000011>, <100000>, <101001>, <100110> and <010001>. The tenth pattern is generated with the ninth pattern <110100> of subsequence 1 feeding through the CN2. The CU is a modulo-9 counter controlling this switch. Optimizing the feedback network is equivalent to assigning minimal number of 1's to a ijk 's of Eq. (3). An optimized configurable 2-D LFSR is shown in Fig. 7 . Without configuration, 6 stages of FFA are required. 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 1 1 0 1 0 0 0 0 1 1 1 0 0 0 0 1 0 2 0 1 1 0 1 0 0 1 1 0 0 0 0 0 1 0 3 1 1 1 1 0 0 0 1 0 0 1 1 0 0 1 1 4 0 1 1 1 1 0 1 0 1 0 0 1 1 0 1 
Experimental Results
Five synthesized benchmark circuits are used to evaluate the configuration structure of the 2-D LFSR scheme. The characteristics of the five circuits are summarized in Table I . First, we applied the configurable 2-D LFSR for test-perclock BIST of the benchmark circuits. In Table II , the configuration and the non-configuration results of 2-D LFSR for benchmark circuits are compared. The second column is the number of embedded deterministic patterns detecting the random-pattern-resistant faults for each circuit. The third and fourth columns give the stage number of shift registers and the total number of flip-flops for the non-configurable test generator. The number of configurations, the stage number of shift registers, and the number of flip-flops for the configurable 2-D LFSR are given in the fifth, sixth and seventh columns. The synthesis results of am2910 and mul16 in Table II show the number of flip-flops is significantly reduced from 260 to 40 (84.62%) and from 252 to 36 (85.71%), respectively. Because the number of embedded patterns for div16, pcont2 and piir8 is small, the synthesis procedure results in no reconfiguration. Among the benchmark circuits, div16 requires the largest number of flip-flops (330) due to its large number of primary inputs (33). The number of flip-flop's stage (M) for div16 can be reduced from 10 to 2 by increasing the number of iterations while solving Eq. (3). The number of flip-flop's is also reduced by 81.82%, from 330 to 60. Table III shows the comparison of the test generation and fault simulation. The third and fourth columns show the number of single stuck-at faults and ATPG results of HITEC [4] where "Det" denotes the number of detected faults and "Vec" denotes the number of test patterns. The fault simulation of the conventional LFSR is summarized in the fifth and sixth columns. Columns seven to ten summarizes the fault simulation of 2-D LFSR and configurable 2-D LFSR. As shown in Table III Next, we applied the configurable 2-D LFSR for testper-scan BIST to the benchmark circuits that were optimized by Synopsys Design Compiler. In Table IV, the number 
Conclusion
A configurable 2-D LFSR based test generator and an automated synthesis procedure have been presented. Without storage of test patterns, a 2-D LFSR based test pattern generator can generate a sequence of pre-computed test patterns (detecting random-pattern-resistant faults) and followed by random patterns (detecting random-pattern-detectable). The hardware overhead is decreased considerably through configuration. To improve the fault coverage and reduce the hardware overhead, a minimal set of deterministic test patterns detecting random-pattern-resistant faults is needed. Choosing different partition of the embedded sequence of deterministic test patterns may result in different reconfiguration networks and generate different sequence of random patterns. Furthermore, logic optimization is necessary to reduce the hardware of the configuration networks.
[ 
