Recently, a new Built-In Self Test (BIST) methodology based on balanced bistable sequential kernels has been proposed that reduces the area overhead and performance degradation associated with the conventional BILBO-oriented BIST methodology. This new methodology guarantees high fault coverage but requires special test sequences and test pattern generator (TPG) designs. In this paper, we demonstrate the use of the retiming technique in designing TPGs for balanced bistable sequential kernels. Experimental results on ISCAS benchmark circuits demonstrate the effectiveness of the designed TPGs in achieving higher fault coverage than the conventional maximal-length LFSR TPGs.
Introduction
In a conventional BILBO [ l ] test design methodology (TDM), each Combinational logic block in a circuit is tested by applying a test sequence generated by the BILBO registers at its inputs and capturing its response by the BILBO registers at its outputs. The area overhead and performance impact of such a technique can be excessive due to the need to replace each register in the original circuit by a BILBO register. In order to reduce the area overhead and performance degradation associated with the BILBO registers, the circuit needs to be partitioned into larger kernels, usually sequential structures. Such kernels need to be identified so that high fault coverage. short test time, and reduction in test resources can be achieved. The problem of designing bistable circuits that employ sequential kernels has been previously investigated and several BIST TDMs have been proposed to reduce the hardware overhead associated with these circuits [2, 3, 4, 5] . The technique in [5] , called BIBS (Built-In test for Balanced Structures) TDM, is an approach that achieves low area overhead, low performance degradation, and high fault coverage by allowing only balanced bistable sequential kernels. To achieve high fault coverage in testing balanced bistable sequential kernels, special TPGs need to be designed. Procedures for desigmng TPGs that guarantee high fault coverage for balanced bistable sequential kernels have been presented in [5] .
In this paper. we show that TPGs for balanced bistable sequential kernels can be efficiently designed based on the well-known retiming technique [ 6 ] . The paper begins by giving a brief description about balanced bistable sequential kernels, their properties, and test requirements. A motivation example illustrating the need for new TPG designs for such kernels is then demonstrated. After that, the application of the retiming technique in the design of the TPGs is described. Finally, experimental results are given to show that the TPGs designed using the retiming technique can achieve significantly higher fault coverage than the traditional LFSR TPGs.
Balanced Bistable Sequential Kernels
A synchronous sequential kernel K is said to be balanced BISTable [5] if it is (1) acyclic, ( 3 ) for any two vertices (say V I and v2) in its circuit graph, all directed paths (if any) from V I to v 2 are of equal sequential length, and ( 3 ) there does not exists a pair of input and output ports in K that is directly driven by and drives a common register. It has been shown in [7] that all detectable single stuck-at faults in a balanced circuit are single pattern testable. This single test pattern is applied to the circuit and the circuit is clocked for a number of clock cycles allowing the fault effect to propagate to a primary output. A fault is I-step testcrble [5] if it can be detected by a test sequence where the value for each bit position in the sequence is specified as either 0 or 1 in at most one vector in the sequence. Thus, a 1-step testable fault can be detected by applying a single test vector to the circuit for a number of clock cycles. In other words, such a fault is detectable by a sequence of test vectors formed from skewing some bits of this single test vector. Testing a circuit that is not 1-step testable is much harder than a 1-step testable circuit [7, 8] . This is because testing such a circuit requires sequences of test vectors to be applied to the circuit to ensure high fault coverage. It has been shown in (51 that all single stuck-at faults in a balanced BISTable kernel are 1-step testable.
Motivation Example
To illustrate the need for special TPGs for testing balanced bistable sequential circuits, let us consider the circuit shown in Figure l bistable circuit. In order to test this circuit under the BIBS TDM, a TPG is connected to its inputs, which is in this case a maximal-length LFSR. The sequences generated by the LFSR and the vectors applied to the inputs of the AND gate are shown in Figurel(b). As can be seen, regardless of the number of cycles applied to the LFSR, only the vectors (00, 1 1 } will be applied to the inputs of the AND gate. This is due to the unequal sequential lengths of the paths from the LFSR inputs to the AND gate. Thus, only the stuck-at-0 faults on the AND gate will be detected and none of the stuck-at-1 faults can be detected by the LFSR. To gurantee full coverage of all the detectable faults in the kernel, it has to be ensured that all the paths from the TPG to every combinational block in the kernel have equal sequential length. A simple solution to achieve this is to insert registers in the kemels to make all paths of equal sequential length [53. However, this would add significant area overhead and the circuit performance may be adversely affected. A simpler and much more efficient solution is to modify the TPG to achieve this goal. To compensate for the imbalance in the sequential lengths of the two paths from the LFSR to the AND gate, we need to add one sequential element along the path between F2 and IZ. The same balancing effect can be achieved by adding one D-type flip-flop (D-FF) before F2, as shown in- Figure 2(a) . Considering the test vectors generated by the modified LFSR and the test vectors applied to the inputs of the AND gate, shown in Figure 2 (b), we can see that all the faults in the AND gate will be detected. The area overhead of this approach is much smaller than modifying the kemel itself and no additional performance degradation is introduced apart from the LFSR circuitry. The addition of this extra D-FF to the LFSR design to achieve the balancing effect can be easily achieved based on the retiming technique. Figure 3 illustrates Figure ? (a), which achieves full coverage of all the faults in the AND gate.
Design of TPGs Based on Retiming
A balanced bistable sequential kernel having a single cone of logic can be represented generally as shown in Figure 4 Figure 4 can be a data path between Ri and C , or a set of parallel data paths between Ri and C all having the same sequential length. In our work, we assume that the TPG will be designed based on a type 1 LFSR [9] . Let G=(R. X, C, E, w ) be a weighted directed graph, where 
1.

8.
( C ) Figure 5 A balanced bistable sequential kernel and its TPG design.
To illustrate the retiming-based TPG design algorithm, let us consider the example given in Figure 5 . Given the kernel in Figure 5 (a), a graph is constructed and the maximum weight on any path from the TPG to C is determined. which is 1 in this example. Then, the weights on the edges are computed as indicated in step?. The retiming of each node is then performed as indicated in step 3 and the result of this step is shown in Figure 5 (b). Finally, the designed TPG is constructed, based on steps 4-8, as shown in Figure 5 (c). Figure 6 demonstrates the application of the proposed algorithm on another balanced bistable sequential kernel. As can be seen the algorithm is simple and its correctness is guaranteed since it is based on the well-known retiming technique. Figure 5 (a). For the ISCASS5 cirucits. the first half of the primary inputs (rounded up) has a sequential length of 1 and the the second half has a sequential length of 0.
Algorithm
For the full-scanned versions of the ISCAS89 circuits, the first set of primary inputs (obtained from making the circuit full-scanned) has a sequential length of 1. These inputs are equal to the number of FFs in the original circuit. The original primary inputs in the circuit have a sequential length of 0. Table 1 shows the fault coverage obtained for each case. As can be seen from the table, for all the circuits, the modified TPGs achieve higher fault coverage than the original TPGs based on the convential LFSR. In the results obtained in Table 1 , we have used the primitive polynomials given in [lo] . Furthermore. the LFSR seeds used are a 1 in the most significant position followed by 0's. We have also performed experiments on the benchmark circuits using a configuration similar to the one shown in Figure 6 (a).
We have observed that for this configuration the convential TPGs achieve fault coverages similar to the modified TPGs in most of the cases. The results of this experiment are not included due to space limitation. It is worth mentioning here that the modified TPGs guarantee exhaustive patterns applied to the kernel under test if a maximum-length LFSR is used and a maximum-length sequence is applied. However, this is not the case if the convential LFSR is used.
s.52611 Conv.
-. 
Conclusions
