

# Using Mentor FastScan to Generate At speed Scan Vectors

**Bob Neil** 

## At Speed Testing With Scan

At .13 micron and below IC manufacturers are starting to see more defects that are not caught by traditional stuckat fault testing. Defects like high impedance metal, high impedance shorts and cross talk are not caught by traditional stuckat scan vectors. Instead they show up as timing failures that can only be caught by at speed testing. Some ASIC vendors require at speed test vectors and many others have plans to add that requirement.

In the past at speed testing was usually done by running a small number of functional vectors. This approach is time consuming and it produces poor coverage. Mentor FastScan can use scan to generate at speed vectors with good coverage. FastScan allows two types of at speed testing, Transition Delay testing and Path Delay testing. Both work by generating scan patterns that are scanned in at a slow speed. After a scan vector is scanned in, two or more capture clocks are applied at full speed and then the captured result is scanned out at slow speed.

## Launch-Off-Shift vs Broadside

There are two ways to transition from scan shifting to capture clocks. With the launch-off-shift approach one clock is generated exactly one at speed clock cycle after the last shift clock. This can work with muxed flop scan chains but it requires that the scan chains run at speed and the Scan Enable signal must work at speed. The launch-off-shift approach doesn't really make sense for LSSD designs.

With the broadside approach a pattern is scanned into the chains at a slow speed. Some time after the pattern is scanned in, two at speed capture clocks are applied to the scan flops. Then some time later the pattern captured in the scan flops is scanned out. This approach allows the scan clocks and the Scan Enable signal to run at a slow speed. It also works well with LSSD designs.

### **Clock Control Requirements**

As with any DFT tool you need to understand what constraints it places on the design of the chip. If the chip is already designed to use scan and you plan to use broadside capture, the only additional constraint is clock control. It must be possible to control the clocks so that they produce two consecutive at speed clock pulses. If the clocks are derived internally there must be an external pin that, when asserted, causes the clock logic to generate two at speed clock pulses. If the clock is sourced externally you need to be sure that the target tester can run at the required clock speed.

If the clocks are generated internally, by logic or a PLL, there will be specific capture clock patterns that the chip can generate. These patterns must be described as one or more named capture procedures in test procedure file. Including named capture procedures in the test procedure file constrains the ATPG tool so that it uses only those clock patterns for the capture phase of scan.

# Transition Delay Methodology

Transition Delay testing is used to test as many paths as possible at speed. FastScan inserts transition faults for all cell inputs in the chip and determines which flops to use for launch points and capture points. From the users perspective, the process used to generate these scan vectors is very similar to generating scan vectors for stuck-at faults. Transition Delay vectors do not replace stuck-at fault vectors but they can reduce the number of required stuck-at fault scan vectors. This is done by generating Transition Delay vectors first and then generating stuck-at vectors for faults that were missed by transition delay vectors.

#### Path Delay Methodology

Path Delay testing is used to test known critical paths at speed. For Path Delay testing FastScan generates a pattern which, when scanned into a chain, sensitizes the path of interest and sets up the value to be sent through the path. Many of the gates in the path will have several inputs in addition to the one that is part of the path and the scan vector must also control those inputs. Sensitizing the path means that those additional inputs will be driven to values that allow the signal from the launching scan flop to propagate to the capture scan flop. After the pattern is scanned in you must generate two or more capture clocks whose period matches the operating frequency. Then the chain is scanned out at a slow speed. The test passes if the capture flop captured the correct values. Scanning a pattern into and out of the scan chains occurs at slow speeds. FastScan can not generate Path Delay scan vector for paths that include RAM. Generating path delay scan vectors requires a FastScan CPA license in addition to the normal FastScan license.

## Path Delay Flow

The path delay flow starts with the output of the static timing verifier. This information must be converted into a .pathdef file that is essentially a netlist for each flop to flop path or flop to output path with critical timing. Mentor has a script available that reads in a Prime Time report and generates a .pathdef file. FastScan reads in the .pathdef file along with the .do file, the .testproc file and the verilog netlist.

FastScan checks the .pathdef file to verify that it can trace the path. It then checks whether the path is real. A surprising number of the paths reported by static timing analyzers are not real paths. When FastScan checks the path to verify that it can be sensitized it often finds that one gate input in the path needs to be forced high and another needs to be forced low. If those two points have the same source then the path is not real. After FastScan verifies the paths it attempts to generate scan vectors to test the critical paths.

Even if the chip clocking does not support critical path analysis this tool can be very useful when writing functional vectors for at speed testing. You can simply declare the clocks as primary inputs and use the tool to identify which paths are real and which are not. This should not be taken as an endorsement of using functional vectors for speed testing. That approach is terribly inefficient and it generally produces poor results.

#### .Pathdef File

The .pathdef file describes every cell in a critical path starting with a scan flop and ending with another scan flop or a primary output. It also contains information on which cells are inverting. The following shows a typical critical path from a .pathdef file:

```
PATH "block_name" =
PIN /<path_to_module>/launch_flop_name/output_port +;
PIN /<path_to_module>/gate1_name/input_port +;
PIN /<path_to_module>/gate2_name/input_port -;
PIN /<path_to_module>/gate2_name/output_port -;
PIN /<path_to_module>/gate2_name/output_port -;
PIN /<path_to_module>/gate3_name/input_port +;
PIN /<path_to_module>/gate3_name/output_port +;
PIN /<path_to_module>/gate4_name/input_port +;
PIN /<path_to_module>/gate4_name/output_port +;
PIN /<path_to_module>/gate5_name /input_port +;
PIN /<path_to_module>/gate5_name/output_port +;
PIN /<path_to_module>/capture_flop_name/d_input_+;
```

END;

#### Size of Vector Sets

The vector sets for Transition Delay Fault testing tend to be three to five times as large as stuck-at vector sets. A portion of this can be recovered since Transition Delay Fault testing catches many of the same faults that would be detected by stuck-at testing. In other words the number of stuck-at vectors could be reduced but that still leaves you with a much larger vector set.

Also Path Delay vectors are very inefficient so the number of paths tested would probably be limited to a few dozen per chain. There are some new compression tools and methods of sorting the vectors that can help reduce the size of the vector sets.

#### Conclusions

There are several reasons for doing at speed testing:

- 1. Screening out parts that have subtle problems that cause timing failures. These problems are becoming more common at .13u.
- 2. Characterizing the process.
- 3. Debugging speed problems.
- Speed binning parts.

Transition Delay scan testing is the most efficient way of generating at speed test patterns. It can provide good coverage and the time and effort required to do this is short and predictable.

Path Delay scan testing is useful when you want to create vectors for specific critical paths. It is less efficient than Transition Delay scan testing but the paths it checks are true critical paths. It is particularly useful for generating patterns for speed binning.

The broadside approach is the easiest to implement because it allows the scan clocks and the Scan Enable signal to run at slow speeds for muxed flop scan designs. It also works well with LSSD designs. If the capture clocks are driven by the tester then you must be sure that the tester can operate at the required frequency. If the capture clocks are generated internally the required clock control needs to be designed into the clock generation logic and you need an input put that triggers the generation of two capture clocks.

#### About the Author

Bob Neil is a Senior Consulting Engineer working for Paradigm Works and has over 20 years of ASIC design experience. Bob can be reached at <a href="mailto:bob.neil@paradigm-works.com">bob.neil@paradigm-works.com</a>.

Paradigm Works is a consulting and technology company specializing in ASIC & FPGA Architecture, Design, Synthesis, Verification, Verification IP and Test. www.paradigm-works.com