D
ire predictions about the soaring cost of semiconductor test are all too familiar. Two factors primarily drive this cost: the number of test patterns applied to each chip and the time it takes to run each pattern. For example, typical semiconductor testing for each chip involves a set of 1,000 to 5,000 test patterns-sets of input values and their associated (expected) output values. These test patterns are applied through scan chains that operate at about 25-100 MHz. Depending on the size of the scan chains on the chip, a set of test patterns can take a few seconds to execute per chip.
It's easy to see that even a small decrease in either the number of patterns or the time to execute them can quickly add up to big savings across millions of fabricated chips. This potential savings forms the basis for dynamic scan, a new approach to the wellestablished scan test methodology.
Our initial studies, presented here, indicate that dynamic scan could easily reduce the time spent applying the test patterns by about 40 percent. A more theoretical analysis shows a potential savings of as much as 80 percent.
CURRENT SCAN TEST USAGE
Current design-for-test technology creates scan chains that automatic test pattern generation (ATPG) uses as control and observation points. Basic scan technology attempts to maximize the memory elements to be scanned, which supports the verification of fabrication chips.
These scan chains provide controllability and observability for the automatically generated test patterns created later in the design process. 1 All scan elements go into a set of possibly balanced chains to provide a single multichain scan configuration that automatic test pattern generators use in generating test patterns.
Prior research, however, has recognized that the maximal scan configuration is overkill for ATPG. ATPG doesn't need to scan all the memory elements to attain the required fault coverage. Instead, the partial-scan technique identifies a smaller set of memory elements, providing a single configuration that ATPG can use to attain the required fault coverage.
However, a single scan chain configuration restricts an ATPG-based method to using all the scan elements for all test patterns. Although the test must scan all memory elements at least once to detect the faults, it need not scan every element for every test pattern. A method that pares down the number of scan elements for each test pattern could provide substantial test application time and cost savings.
Past solutions have used subsections of a singlescan-chain architecture to apply tests to different design modules. For this strategy to be effective, these modules must be well bounded and have independent test patterns, 2,3 characteristics not found in today's increasingly complex designs.
Our work expands previously defined concepts for single scan chains to provide a new architecture for use in conjunction with ATPG. We want to apply test patterns to random logic, but use the shortest possible scan chains. To do so, we blend the benefits of using multiple scan chains 4 with the reconfiguration method for single scan chains. 
Williams
These methods work together to reduce test data volume and application time.
We intend this technology for use with randomlogic ATPG and its patterns. Thus, our solution avoids breaking a basic concept employed by today's scan-chain construction methods: Multiple scan chains that are active at any given time have a single path between the scan-ins and scan-outs of each scan chain. This distinguishes our solution from more radical solutions that fan out scan chains from a single scan-input. Figure 1 shows a circuit that has one scan chain containing five scan flip-flops. It has scan-in signal SI, and scan-out signal SO. The scan enable SE signal configures the flip-flops for scan operation, while the clock clk operates the scan chain. Table 1 shows the stimuli and response vectors (after compaction but before random fill) needed to detect the faults in the circuit of Figure 1 . The tester applies the stimuli at input a, and each of the five flip-flops, c 0 through c4. It records the responses at outputs u and v, and each of the five flip-flops. The inputs or outputs are logic 0, logic 1, or don'tcares (denoted by X).
5

BASIS FOR DYNAMIC SCAN
We apply these test patterns in a three-step sequence:
• scan-in T n,− scan-out Tn-1;
• stimulate inputs, measure outputs; and • pulse a capture clock.
A tester first scans the data into the flip-flops, applies a stimulus to the inputs, and measures the circuit outputs. It then applies a pulse on the clock signals. The pulse triggers an update of the scan chain flip-flops and thus captures the design's response to the test pattern. The tester then scans out the response; it simultaneously scans in the next test pattern.
For the fixed configuration in Figure 1 , the test patterns would operate the scan chain of length five. This scan operation dominates the test application time, taking five clock periods in the example scenario. Every test applying a stimulus to or measuring a response from the scan flip-flops would perform this scan operation and consume these five clock periods.
Each test pattern in our example operates the scan chain; total test time per pattern is 5 cycles for scanin of T n and scan-out of Tn-1, plus 1 cycle for updating the flip-flops, plus 5 cycles for the scan-out operation of the last test pattern (which could not be overlapped with other tests). Running the entire test of four patterns consumes (5 + 1) × 4 + 5 = 29 cycles. Of this, the scan time is 25 clock cycles. The scan operation's duration is independent of the number of scan values the test needs. The rigid configuration requires that the tester scan every cell, so typical ATPG algorithms would randomly fill the don't-cares and provide fully specified test patterns.
We recognize that the scan chain doesn't need to be the same for all tests. The scan chains should ideally provide access to the flip-flops that the tests need. Figure 2 shows the scan chain structure that would allow this access.
Signals that control the multiplexers let them either bypass or include a flip-flop in the scan chain. The multiplexer control signals can come from cir- 
cuit inputs or from a control-register-like configuration. The configuration in Figure 2 can include or exclude any flip-flop from the scan chain, tailoring the scan chain to suit the test pattern. Table 2 lists the example test results for Figure  2 . A "-" signifies a value that was omitted from the test pattern by using a scan chain configuration that did not include the associated flip-flop.
Considering the scan-ins of a test and the scanouts of the previous test that occur at the same time, test T 1 uses scan cells c2 and c3. Tests T2 and T3 use scan cells c 2, c3, and c4. Test T4 uses c0, c1, c2, c3 , and c 4. The total scan time for all test patterns is 2 + 3 + 3 + 5 + 2 = 15 cycles (because we take advantage of the overlapping scan-ins and scan-outs), which is much less than the total scan time of 25 cycles for the original scan chain. This is a very expensive configuration in terms of supplying the multiplexer control signals. It would require many inputs to control the multiplexers; using a control register, on the other hand, would require loading the register for every test pattern. Accounting for all these considerations might be impractical in an actual circuit layout.
A more realistic approach limits the number of control signals by making multiple patterns use a single configuration.
USING SCAN SEGMENTS
A practical implementation of dynamic scan must focus on ensuring the following:
• Fewer configurations mean fewer (expensive) multiplexer control signals, so a practical implementation should use a minimum number of configurations.
• An efficient implementation should order multiple test patterns to use a single configuration. This ordering should also maximize scan-in and scan-out overlap and minimize configuration setup overhead on a per-test-pattern basis.
Patterns using the same configuration should run consecutively.
• Most test patterns should use short scan chain configurations.
So for dynamic scan to be useful, we must create segments to limit the number of supported configurations. Segments are contiguous scan chain components that a scan test must bypass or use as a set. The benefits that dynamic scan could provide depend on segment identification. Numerous methods are available for identifying scan segments, including topological traversals of the design or the use of ATPG engines and test patterns to guide the selection process. Figure 3 shows some examples of dynamic-scan configurations that use segments. These configurations account for the fact that all the patterns in our example set use the last three scan cells.
Preventing test patterns from excluding individual scan cells offers a simpler solution than fullblown dynamic scan, but doesn't offer as large a reduction in test data volume and application time. In our example, the scan segments force pattern T 1 to use the c4 scan cell. In this case, ATPG can randomly fill the don't-care for c 4 in this test pattern. The dynamic scan chain implementations shown in Figure 3 provide an overall scan test application time (and proportional test data volume) of 3 + 3 + 3 + 5 + 5 = 19 cycles.
Any reasonable dynamic-scan partitioning includes several patterns that use each of the different configurations. If only one pattern needs a configuration, test engineers should revisit the segment identification process.
At one extreme of the dynamic-scan solution, a test can selectively bypass all scan elements. That is, segment length equals 1. This configuration, the most flexible one, provides maximum benefits at the expense of design-for-test and layout problems.
At the other extreme, a test does not bypass any scan cell, and the original scan chain is the only configuration available to the test patterns. This leastflexible configuration does not effectively reduce test data volume or test application time, but it has minimal additional impact on the typical scan chain layout problems. Our goal falls in between these two extremes: We seek to achieve significant benefits with a small number of segments.
DYNAMIC SCAN WITH MULTIPLE SCAN CHAINS
Although our examples use a single scan chain, applying this to all scan chains independently would create significant overhead problems. For this reason, the most promising concept in making dynamic scan a reality is the use of multiple scan chains within a dynamic scan segment.
To reduce overhead, a configuration must create multiple scan chain partitions. Each partition consists of parallel scan segments connected in series to segments of other partitions. Multiplexers, which allow activation or bypassing of all a partition's scan segments, separate the partitions. Figure 4 shows a dynamic-scan design with multiple scan chains. ATPG patterns operate three parallel scan chains. The length of the three available scan chains depends on the control register values. For example, if 0 on the multiplexer control line selects the top input for all multiplexers, then 100 in the control register would give three short parallel chains consisting of the leftmost scan segments of partition 1. A 101 code would make three scan chains available, consisting of all the segments in partitions 1 and 3.
This implementation permits each active scan chain to incorporate one scan segment from each partition. Each partition's scan segments should be as balanced in length as possible to achieve maximum benefits in terms of test application time. For maximum benefits, each partition should have the same number of scan chains.
EXPERIMENTAL RESULTS
Dynamic scan can significantly reduce test data volume and test application time. These benefits rely on the fact that designs have constraints (circuit structure dependencies) and that ATPG and its associated compaction algorithms are imperfect. Dynamic scan relies on the presence of several don'tcares in test patterns, even after ATPG compaction. So to assess dynamic scan's real-world potential, we determine the number of don't-cares in test patterns (after compaction) for realistic circuit designs. Table 3 lists characteristics for the designs we used in our experiments. The design names include the number of primitive logic gates in this circuit, as perceived by the ATPG tool. The table lists the scan flip-flop count for these multichain scan designs. Although the table includes the fault count and fault coverage for the circuit's associated scan test, the most relevant number is the total number of patterns for the original scan test without the implementation of dynamic scan.
Typically, in any test set, the first few patterns detect many faults, and most subsequent test patterns detect very few. Thus the first few patterns are by nature fully specified (with very few don't-cares)-they typically use the complete set of scan flip-flops.
The remaining patterns are more likely targets for dynamic scan. Thus, for the following experiments, we created about 200 test patterns and forced them to use the complete scan chains. After performing fault simulation for these patterns, we let the ATPG tool perform all the compaction it could. We then counted the number of don't-cares in the test patterns. Figure 5 shows that most test patterns have many don't-cares; thus an approach like dynamic scan could reduce the test data volume and test application time. This data also shows that the compacted ATPG tests are so sparsely populated that it should be possible to identify partitions that cover many tests.
We then collected data on the scan cell usage of test patterns that could benefit from dynamic scan chains. The data in Figure 6 shows that several scan cells were never used after simulation of the first few fully specified test patterns. Thus, if we can identify these scan cells, we should be able to place them in a single dynamic-scan segment of balanced scan chains and bypass them for the test patterns after the first 200. This single-partition dynamic-scan configuration is an attractive option in this type of situation.
Having more segments available in a dynamicscan implementation improves the reduction in test data volume and test application time. The final goal of our research is to prove that by adding a few multiplexers and creating some partitions, dynamic scan could provide significant gains. We use a hypergraph-based algorithm that evaluates test pattern scan cell usage to determine scan chain segments and partitions. 6, 7 The basis for this algorithm is an undirected graph having all scan cells as its nodes. Nodes in the graph are connected to each other if they contain specified values as part of a single test pattern. We complete the graph for all test patterns. Thus, if two scan cells have specified values in n tests, n edges between the two nodes will represent the scan cells. We then partition the resulting undirected graph to find "waists" (cut points with the fewest edges). Figure 7 shows the results of three possible dynamic scan configurations using designs with four to 10 partitions. We scaled the benefits of dynamic scan to the test set. The first few patterns used the entire scan chain and did not benefit from the dynamic scan configurations.
The results for a two-way split show the benefits of creating a segment that includes only the unused scan cells for the patterns that will benefit from dynamic scan. There are just two segments-one for the used scan cells and another for the unused cells.
The second set of results shows the maximum experimental reduction achieved by using a hypergraph-based algorithm to create more partitions. The maximum theoretical reduction achieved for the experiment reflects the fact that the scan can bypass every don't-care in the test patterns profiled in Figure 5 .
O ur results show that simple modifications to existing scan technology can reduce test application time and test data volume. The work presented here focuses on proving the technology. Further work focuses on refining the dynamic scan technology. We are also exploring efficient and better segment identification algorithms for the dynamic scan architecture. I 
