# TetraMAX® ATPG Quick Reference

Version A-2007.12, December 2007

Comments?
Send comments on the documentation by going to http://solvnet.synopsys.com, then clicking "Enter a Call to the Support Center."



#### **Copyright Notice and Proprietary Information**

Copyright © 2007 Synopsys, Inc. All rights reserved. This software and documentation contain confidential and proprietary information that is the property of Synopsys, Inc. The software and documentation are furnished under a license agreement and may be used or copied only in accordance with the terms of the license agreement. No part of the software and documentation may be reproduced, transmitted, or translated, in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without prior written permission of Synopsys, Inc., or as expressly provided by the license agreement.

**Right to Copy Documentation** 

The license agreement with Synopsys permits licensee to make copies of the documentation for its internal use only. Each copy shall include all copyrights, trademarks, service marks, and proprietary rights notices, if any. Licensee must assign sequential numbers to all copies. These copies shall contain the following legend on the cover page:

|                                    | e permission of Synopsys, Inc., for the |
|------------------------------------|-----------------------------------------|
| exclusive use of                   | and                                     |
| its employees. This is copy number | "                                       |

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### Disclaimer

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### Registered Trademarks (®)

Synopsys, AMPS, Cadabra, CATS, CRITIC, CSim, Design Compiler, DesignPower, DesignWare, EPIC, Formality, HSIM, HSPICE, iN-Phase, in-Sync, Leda, MAST, ModelTools, NanoSim, OpenVera, PathMill, Photolynx, Physical Compiler, PrimeTime, SiVL, SNUG, SolvNet, System Compiler, TetraMAX, VCS, Vera, and YIELDirector are registered trademarks of Synopsys, Inc.

#### Trademarks (™)

AFGen, Apollo, Astro, Astro-Rail, Astro-Xtalk, Aurora, AvanWaves, Columbia, Columbia-CE, Cosmos, CosmosEnterprise, CosmosLE, CosmosScope, CosmosSE, DC Expert, DC Professional, DC Ultra, Design Analyzer, Design Vision, DesignerHDL, Direct Silicon Access, Discovery, Encore, Galaxy, HANEX, HDL Compiler, Hercules, Hierarchical Optimization Technology, HSIMP<sup>lus</sup>, HSPICE-Link, i-Virtual Stepper, iN-Tandem, Jupiter, Jupiter-DP, JupiterXT, JupiterXT-ASIC, Liberty, Libra-Passport, Library Compiler, Magellan, Mars, Mars-Xtalk, Milkyway, ModelSource, Module Compiler, Planet, Planet-PL, Polaris, Power Compiler, Raphael, Raphael-NES, Saturn, Scirocco, Scirocco-i, Star-RCXT, Star-SimXT, Taurus, TSUPREM-4, VCS Express, VCSi, VHDL Compiler, VirSim, and VMC are trademarks of Synopsys, Inc.

#### Service Marks (SM)

MAP-in, SVP Café, and TAP-in are service marks of Synopsys, Inc.

SystemC<sup>™</sup> is a trademark of the Open SystemC Initiative and is used under license.

APM and AMPA are registered trademarks of APM Limited.

ARM and AMBA are registered trademarks of ARM Limited. Saber is a registered trademark of SabreMark Limited Partnership and is used under license.

All other product or company names may be trademarks of their respective owners.

# **Contents**

Conventions 1

Online Help 2

TetraMAX ATPG Commands 3

Index to Commands 69

٧

## Conventions

This quick reference uses the following conventions in the command syntax:

- Brackets ([]) denote optional choices. A command is still valid if you omit these choices.
- A vertical bar ( | ) separate different items from which you choose a single item.
- An asterisk (\*) indicates the default setting in a list of choices.
- Angle brackets ( < > ) denote a grouping of related items.
- Ellipses ( ... ) indicate that the previous item in the syntax can be repeated one or more times.
- Italics indicate a user-defined item for which you substitute a value or character string.
- Uppercase letters shown in the command syntax represent the minimum characters necessary to enter the command. For example, to enter the command REMOVE CApture Masks -All, it is sufficient to type REM CA M -A.

## **Online Help**

TetraMAX provides online help in the following forms:

- Text-only help on TetraMAX commands, displayed in the transcript window. Use the help command in the command-line window.
- Window-based, hyperlinked help on commands, design flows, error messages, design rules, fault classes, and many other topics. Use the pull-down menu command Help > Help Topics, or use the man command and specify the topic of interest.
- The TetraMAX ATPG User Guide, available in online form. Use the pull-down menu command Help > User's Guide.
- The TetraMAX Release Notes, available in online form. Use the pull-down menu command Help > Release Notes.

For text-only help, use the help command. For a list of help topics available, type the following command in the command-line window:

> help

To display a list of all commands and a summary of their supported syntax, type the following command in the command-line window:

> help -usage

To display the syntax of a specific command, type the following command in the command-line window:

> help command name

where command name is the command whose syntax you want to view.

## TetraMAX ATPG Commands

The TetraMAX ATPG commands are described in alphabetical order. An index to the commands is provided at the end of this manual.

#### Add ATPG Constraints

```
Add Atpg Constraints <name> <0 | 1 | Z> [-Module <module_name>] <atpg_gate_name | gate_id | module_pinname | pin_pathname> [-Drc | -Iddq]
```

This command defines constraints on nets that must be satisfied during pattern generation. In the command, specify a name to identify the constraint, the constraint value (0, 1, or Z), and the place in the design to apply the constraint.

#### **Add ATPG Primitives**

```
Add Atpg Primitives <name> <And | Or | SEL1 | SEL01 | Equiv> [-Module <module_name>] [input_connection_list]
```

This command creates a primitive that is added to the design and has its inputs connected to specified nets. When you constrain the output of the added primitive, it forces the pattern generation algorithm to conform to specified logical conditions at the connection points. In the command, specify a name for the added primitive, its logical function, and its input connections.

## **Add Capture Masks**

```
Add CApture Masks <instance_names | gate ids>
```

This command masks off any potential value captured into a specified scan or nonscan sequential cell. The cell is treated as though the data input were connected to a TieX gate, which means that scan cells with capture masks might still have non-X values in a pattern.

#### Add Cell Constraints

```
Add CEll Constraints
<[0 | 1 | X | OX | XX]>
<[chain_name | instance_name> [-POSition
<cell_pos1 | SCI [cell_pos2 | SCI]> |
-All]
```

This command specifies the load and unload values allowed for specified scan cells. The test pattern generator creates patterns that always satisfy these cell constraints. In the command, specify the type of constraint (end-of-load value or observe-X type constraint) and the cells where you want the constraint applied. You can specify one cell, a range of cells, or all cells in a scan chain; or a specific latch or flip-flop instance.

## **Add Clocks**

```
Add CLocks <0 | 1> <pin_names_list>
[-Timing <<period> <LE> <TE>
<measure_time>>]
[-Unit <ps | ns>]
[-Shift] [-Ref_Timing <<period> <LE> <TE>>]
[-PLLclock] [-INTclock] [-REfclock]
[-PLL_Source <node_name>]
[-Cycle <<cycle_id> <-Always <ON | Off> |
int_node_name <0 | 1>>>]
```

This command defines a primary input port to be a clock. For ATPG purposes, a clock is a pulsed input port that can change the state of a flip-flop, latch, or RAM. This includes any ordinary activehigh or active-low clock, asynchronous set/reset signal, or RAM write signal.

In the command, specify the off state of the clock (0 or 1) and one or more port names. You can optionally specify the clock timing characteristics: period, leading-edge time, trailing-edge time, and measure time. You can also specify that the clock is a shift clock, which is used to shift data through a scan chain.

## **Add Delay Paths**

Add DElay Paths filename

This command reads in a delay path list from a specified file.

## Add Display Gates

This command adds gates associated with the pin\_pathname, the gate ID, or all gates to the GSV.

#### Add Distributed Processors

```
Add Distributed Processors [-32bit]
[-Options <name>] [-Nslaves <d>]
[-Min_slaves <d>] <hostnames | -Lsf
<bsub_exec_name> | -Grd <bsub_exec_name> |
-GEneric <generic exec name>>
```

This command identifies the slave processors sharing a distributed fault simulation or test generation task.

## **Add Equivalent Nofaults**

```
Add Equivalent Nofaults
```

This command propagates the existing list of nofaults (created with the add nofaults command) to their equivalent fault sites and adds these equivalent sites to the nofault list. The

existing list includes user-defined nofaults as well as netlist modules that have nofault attributes on module pins or internal gate pins.

#### **Add Faults**

```
Add Faults
[instance | pin_pathname | -Module <module name> | -All | -CLocks | -SCan_enable | -bridge_location <br/>bridge_location2> | -Node_file <filename>] [-LAunch <launch_clock>] [-CApture <capture_clock>] [-EXclusive] [-SHared] [-INTER_clock_domain] [-INTRA_clock_domain] [-Stuck <0|1|01> | -Slow <R|F|RF>] [-Bridge <0 | 1 | 01>] [-AGgressor_node <First | Second | Both>] [-MAx_invalid_report <d>]
```

This command creates a list of faults for test generation or fault simulation. Potential fault sites include all top-level ports and all input and output pins of cells that have a netlist-defined pin name. You can add faults to the pins of a specified instance, to a single pin, to pins of all instances of a specified module, or to all potential fault sites in the design.

#### Add Net Connections

```
Add Net Connections <net_type> [net_names | pin_pathnames] [-port <port_names>] [-Module <module_names> | -All] [-Disconnect | -Remove] [-Buf] [-Inv]
```

This command changes the behavior of specified nets in the netlist. TetraMAX considers these changes the same as netlist data when it performs fault simulation and test generation.

By default, these changes affect the in-memory image of the design and modules, thereby affecting patterns and netlists written by TetraMAX.

#### Add Nofaults

Add Nofaults [instance | pin\_pathname | - Module <list of module name and its pin names>] [-Stuck <0|1|01>] [-Instance <list of intance name and its pin names>]

This command adds the nofault attribute to specified locations in the design, thus preventing placement of faults at those locations. In order to be effective, you must use this command before you use the add faults or read faults command.

You can add the nofault attribute to all pins associated with a specific instance, to a specific pin, or to one or more pins of every instance of a specified module.

#### Add PI Constraints

```
Add PI Constraints <0 | 1 | X | Z> <pin_names | -All | -ALL_Bidis | -ALL_BIDIS_Except_clocks | -ALL_Except_clocks>
```

This command constrains one or more primary input ports to a specified value (0, 1, X, or Z). The ATPG algorithm only generates patterns that satisfy the defined constraints on these ports. An alternative to using this command is to define the constraints in the STIL procedure file.

This command does not constrain the ports during scan chain loading or unloading. To control the port values at these times, set the desired values in the STIL procedure file.

#### Add PI Equivalences

```
Add PI Equivalences <<reference port name | constrained port name>> [-Invert <name, <reference port name | constrained port name>> | -Differential <name, <reference port name | constrained port name>> | -Same_polarity <name, <reference port name | constrained port name>> |
```

This command defines an equivalence or inverse relationship between one or more pairs of primary inputs. The ATPG algorithm only generates patterns that satisfy the defined logical relationships between these pairs of input ports.

This command does not constrain the ports during scan chain loading or unloading. To control the port values at these times, set the desired values in the STIL procedure file.

#### Add PO Masks

```
Add PO Masks <-All | pin name>
```

This command specifies a primary output port (or bidirectional port) whose output is to be masked. The test generator and fault simulator do not give fault detection credit for these ports, and the expected value is set to X. Masking can be useful when there are circuit outputs that might not be observable in a particular tester or system environment, such as boundary scan.

The PO mask does not mask data from scan chain outputs during scan-shift cycles.

#### **Add Scan Chains**

```
Add Scan Chains chain_name input_pin output_pin
```

This command defines a scan chain in the absence of a DRC file. You can use this command before the write drc file

command to create a template STIL procedure file or before the run drc command to specify the scan chains.

Scan chains defined by this command are ignored if you specify a DRC file with the run drc command or set drc command.

#### Add Scan Enables

```
Add Scan Enables 0 | 1 | Z pin name
```

This command defines a pin that must be initialized to a specific value for scan shifting. You can use this command before the write drc file command to create a STIL procedure file, or before the run drc command to specify the conditions for scan shifting.

#### Add Slow Bidis

```
Add Slow Bidis <port_name | -All>
```

This command modifies the associated BUS primitives to output an X if any TSD or SW primitives are not driving a Z onto the BUS primitive.

#### Add Slow Cells

```
Add Slow Cells < instance names | gate id>
```

This command modifies the simulation behavior of scan DFF or DLAT cells such that any transition launched from those cells is simulated as an X.

#### **Add Slow Path**

```
Add SLow Path [-from <from, from pin name>]
[-through <pin name>] [-to <to, to pin name>]
[-MAX fails < \overline{d}>]
```

The add slow path command defines timing exceptions in a way that is similar to the way that they are defined in PrimeTime.

You can use the add slow path command to define timing exceptions the way you define them in PrimeTime. Note: The add slow path command is supported for Basic Scan and Fast Sequential engines only. There is no Slow Path support in Full Sequential, including path delay ATPG.

## **Add Waveform Signals**

```
Add Waveform Signals [pin pathname | gate id
| net names | -All]
```

This command adds waveforms associated with the pin pathname, gate ID, or net name, or all gates to the simulation waveform viewer.

If you enter a net name on the command line, the simulation waveform viewer keeps the net name as the signal name. If you pick a net from the GSV and add it to the simulation waveform viewer, the net name is the signal name. The remove waveform signals command must have the same options as the add waveform signals command.

#### Alias

```
ALias [alias_name [alias_text]
```

This command defines an alternative symbolic name for a command, along with potential command arguments and switches. The alias can then be used in place of the original command.

## **Analyze Buses**

```
ANalyze Buses

gate_id ... | -All

[-Exclusive* [First* | All] |

-Prevention | -Zstate ] [-Update]
```

This command analyzes a specified bus or all buses (BUS primitives) to determine whether each bus can be placed into a contention state, contention-free state, or Z state.

In the command, specify the type of bus analysis to perform: exclusive (a check for mutually exclusive control circuitry), prevention (simultaneous prevention of contention on all BUS devices), or Z state (a check for the possibility of a floating net). You can also specify whether to update the DRC results with the bus analysis.

## **Analyze Compressors**

```
ANalyze COmpressors <-NUM_Chains <d>> <-
NUM_Inputs <d>> <-NUM_SCANOuts <d>> [-
NODiag] [-Verbose] [-XTOLerance <Default |
High>]
```

This command enables you to run ATPG by creating a virtual compressor. You can select parameters for the compressor and the decompressor and run ATPG. Use the analyze compressors command to perform a what-if analysis and explore the benefit of scancompression on your design. This command deletes the internal patterns after an analyze compressors run. You must run ATPG in scan mode separately and compare results to the scan mode.

The analyze compressors command prints out estimated data volume and test volume reductions you can achieve. These estimates assumes that you have exactly same coverage

and same pattern count in regular scan atpg. You also get an estimate of number of gates per chain required to create the compressor's you have chosen

You can run this analysis only after you run regular scan DRC. You cannot run it after scancompression mode DRC.

## **Analyze Faults**

```
ANalyze Faults <pin_pathname |
delay pathname | -Class < list of
fault_classes>> [-stuck <0|1>] [-Observe
<d>] \overline{[-Display]} [-Slow < R|F>]
[-FAUlt simulation] [-FASt sequential |
-FUll sequential] [-Max <d>]
[-TRAnsition clocking] [-Verbose]
[bridge location] [-Bridge <0 | 1>]
```

This command analyzes a specific fault, or one or more classes of faults, to help determine why the faults are not detected. The analysis is affected by the set atpg, set delay, and set contention command settings.

In the command, specify either a single fault at a specific location, an entire class of faults (such as NO or AN), or multiple classes of faults for analysis. For a single stuck-at fault, you can optionally specify a particular observe point and whether to display the results in the schematic viewer.

## Analyze Feedback Path

```
ANalyze Feedback Path loop id [-Verbose]
```

This command determines whether a specified feedback network has a sensitizable feedback path. If TetraMAX can create a pattern to satisfy a sensitization condition, you can display the simulation values for that pattern by using the set pindata pattern 0 COMMand.

To obtain a list of feedback path loop ID numbers, use the report feedback paths - all command.

## Analyze Simulation Data

```
ANalyze Simulation Data [file_name]
[-FAst_sequential <d>] [-FUll_sequential
<pat#1 pat#2>]
[-Top <top_instance_name>]
[-Sensitive | -INSensitive]
[-Bidi_events] [-MAX_Values_reported <d>]
[-MAX_Fails_reported <d>] [-Diag]
```

This command compares the results of two different simulations or displays the results from a single simulation. In the command, specify either one or two of the following possible sources of simulation data: a VCD (Value Change Dump) simulation file, a set of patterns generated with the Fast-Sequential simulator, or a set of patterns generated with the Full-Sequential simulator.

If the two sources of simulation data are patterns from Fast-Sequential and Full-Sequential simulations, you can optionally perform an automated diagnosis of the simulation differences.

## **Analyze Violation**

```
ANalyze Violation violation id
```

This command analyzes the cause of a rule violation detected by the run drc command (for example, "Z1-4") and generates a report on that violation. The gates associated with the violation are displayed in the schematic viewer, annotated with data that was used to perform rule checking.

## **Analyze Wires**

```
ANalyze Wires <-All | gate id> [-Update]
```

This command analyzes potential contention problems associated with WIRE primitives.

#### Build

```
BUILD [-Force]
```

This command manually returns a TetraMAX session to the BUILD command mode, allowing you to execute commands that operate only in that mode.

#### Cat

```
CAT filename [-Max n] [-Line_numbers]
```

This command displays the contents of a specified file, like the UNIX cat command. You can optionally limit the number of lines displayed or show line numbers along with the lines of text.

#### Cd

```
CD directory_path
```

This command changes the current working directory, like the UNIX ca command. It works only in the GUI mode of TetraMAX (not in the shell mode).

#### Clear

CLEAR

This command clears the text from the transcript window.

## Ср

```
CP source_filename destination_filename
```

This command copies a file, like the UNIX "cp" command. It does not support wildcards (\*) in the specified file names.

#### DRC

```
DRC [-Force]
```

This command manually returns a TetraMAX session to the DRC command mode, allowing you to execute commands that operate only in that mode.

#### Exit

```
EXIt [-Force]
```

This command ends the current TetraMAX session and returns you to the Windows or shell environment.

#### **Get Licences**

Get Licenses

```
<TEST-ANalysis | TEST-Faultsim | TEST-ATPG-
Max | TEST-DIagnosis | TEST-Map | TEST-
Fault-max | TEST-Accelerate-max> [-Wait <d>]
```

Use this command to manually check out selected licenses. Normally, this is not required because licenses are automatically checked out as needed.

The -Wait option helps the distributed ATPG to check out multiple copies of the ATPG license if distributed processing licenses are not available. This option tries to get a license multiple times until d seconds have passed.

d is an integer in seconds. It does not have a default value. If d < 60, the ATPG retries every 60 seconds until the time left is less than 60 seconds. It then retries every second before it times out.

## Gui\_Start

```
gui start
```

This command displays the TetraMAX GUI in its current state in the shell mode.

## Gui\_Stop

```
gui_stop
```

This command stops the TetraMAX GUI session and reverts to the TetraMAX shell command prompt If you did not use the gui\_start command to start the GUI, the gui\_start command exits the TetraMAX application.

You can also use the <code>gui\_start</code> command from the pulldown menu File > Exit GUI. If you use the <code>gui\_stop</code> command before invoking TetraMAX using the <code>gui\_start</code> command, TetraMAX displays an error message.

#### **GSV GET Selected Cells**

GSVGET SELected CElls

When the GSV is active, this command returns the instance name of the gate(s) selected. If the selected gates are displayed in the design view, it outputs a single line that shows the instance names of the gates, separated by spaces. If any of the selected gates are at the primitive level, it displays the gateid in a second line. As a single library cell contains several primitives, the cell's instance name might be repeated for each primitive object. There is no correpondence between the order of instance names in the first line and the gateids in the second line.

This command is similar to the get\_cells - selected feature in Tcl mode. You can use it to identify the gates selected in the GSV.

#### **GSV Print**

GSV Print

This command creates a grayscale PostScript file, which captures the schematic displayed in the Graphical Schematic Viewer (GSV).

You can add the GSV Print command into the TetraMAX scripts and capture schematic output automatically. The computman\_writing host must have PostScript drivers installed (usually with lpr/lp). You can enclose the arguments in double quotes (" ").

## Help

```
Help [command name | -All] [-Usage]
```

This command lists all of the available commands or reports the supported command switches and arguments for a specific command. For a restricted list of commands, use a wildcard character (for example, help report\*).

For a more detailed description of a specific command, use man command name.

#### Ls

```
LS [-L] [pathname]
```

This command displays information about a specified file or directory, like the UNIX 1s command. By default, it lists the names of the files in the current working directory.

#### Man

```
Man [command | rule_id | rule_violation_id |
  message_id | COMmands | GETting_started |
  FAUlt_classes | STIL_examples |
  RAM examples]
```

This command invokes the TetraMAX online help and displays information on a specified command, rule ID, violation ID, message ID, or topic. For example: man read netlist, man z9, man C17-1, man fault\_classes. The man command by itself returns a list of all commands.

#### Mkdir

MKDIR pathname

This command creates a new directory, like the UNIX "mkdir" command.

#### Mν

MV source\_filename destination\_filename

This command moves or renames a file, like the UNIX my command.

#### Pwd

PWD

This command displays the current working directory, like the UNIX pwd command.

#### Quit

QUIt [-Force]

This command terminates the current session and returns you to the Windows or shell environment. You can also use the exit command to terminate the current session.

#### Read DRC

Read Drc <filename>

This command, used in conjunction with the update wft and update clock commands, reads the specified SPF file, but will not further process it through DRC. It must be specified immediately before the update wft and update clock commands. Any changes made with the update commands will only be saved, and usable, if the write drc command is used immeditely after these commands, and then run drc is used with the newly generated file.

#### **Read Faults**

```
REAd Faults <file_name> [-Retain_code | -
Maintain_detection | -Force_retain_code] [-
Add | -Delete]
```

This command reads a list of faults from a file and adds those faults to (or removes them from) the current fault list. If you are adding new faults, you can optionally retain the fault classification codes provided in the fault file for each fault location.

## Read Image

```
REAd Image file_name
```

This command reads and restores the TetraMAX database saved by a write image command.

## Read Layout

```
REAd LAyout <lib_name> <-Cell_name
<cell_name>> [-Version <d>]
[-MAX mismatch report <d>]
```

This command reads the Milkyway database (Synopsys physical database) and displays the corresponding physical data for the resulting fault candidates in its diagnosis output.

Milkyway database consists of a library that holds all the cell views of the design. There is a cell in the library matching the top-level module in TetraMAX. The library cells in TetraMAX also have a corresponding cell in Milkyway. TetraMAX can identify the missing correspondences. Physical data for corresponding objects is stored for each TetraMAX primitive.

This command sends any messages from the Milkyway database parser to the standard output of the TetraMAX process. These messages are

related to the physical implementation and might not be useful for TetraMAX users. TetraMAX does not store the output in its log file.

## Read Memory\_file

```
REAd Memory_file
<gate_id | instance_name>
filename [-Binary | -Hex*]
[-Range first_address last_address]
```

This command loads a specified RAM or ROM instance with a memory image obtained from a data file in Verilog format. You can use this command to alter the RAM or ROM contents specified in the netlist model.

#### **Read Netlist**

```
REAd NEtlist

filename
[-Format Edif | VErilog | VHdl]
[-Library] [-Master_modules]
[-Sensitive | -INSensitive]
[-Delete] [-Noabort]
[-Verbose]
```

This command reads a design netlist. TetraMAX can automatically identify and accept any combination of netlists in Verilog, EDIF, and VHDL formats; and in either ASCII or compressed (GZIP or binary) form.

Typically, you only need to specify the file name to successfully read in a netlist file. However, options are available to control the interpretation of the netlist data. You can read in multiple files with a single command by using a wildcard character (for example, read netlist mux1\*).

#### **Read Nofaults**

```
REAd NOfaults filename
```

This command adds the nofault attribute to the list of locations specified in a file, thus preventing the placement of faults at those locations.

#### read\_sdc

```
read_sdc file_name[-echo][-syntax_only]
-version sdc_version]
```

This command reads in setup timing exceptions directly from an SDC (Synopsys Design Constraints) file. You must be in Tcl and DRC mode to use this command (after you successfully run the run\_build command, but before running run drc).

#### **Read Slow Path**

```
REAd Slow Path <file name> -delete
```

This command reads a file of add slow path commands and processes them.

## Read Timing

```
Read Timing <filename> [-Delete]
```

This command causes TetraMAX to read a file of data that will be interpreted as the minimum slacks (timing margins) for each faultable pin in the design. This minimum slack information can be printed from PrimeTime using a procedure defined in the pt2tmax Tcl script provided within the TetraMAX release.

The format for the input file is a single line for each faultable pin. The line contains three fields: the pinpathname for the pin, the minimum slack for a rising transition through that pin, and the minimum slack for a falling transition through the pin.

#### Refresh Schematic

REFresh Schematic

This command redraws the diagram in the graphical schematic viewer (GSV). You can use this command to update the schematic display labels after you use the set pindata command.

#### Remove ATPG Constraints

```
REMove Atpg Constraints
atpg constraint name | -All
```

This command removes a specified ATPG constraint, or all ATPG constraints, previously added with the add atpg constraints command.

#### **Remove ATPG Primitives**

```
REMove Atpg Primitives
atpg_primitive_name | atpg primitive id |
-All
```

This command removes a specified ATPG primitive, or all ATPG primitives, previously added with the add atpg primitives command.

## Remove Capture Masks

```
REMove Capture Masks
instance_names | gate_id | -All
```

This command removes a specified scan or nonscan cell capture mask, or all such capture masks, previously added with the add capture masks command.

#### Remove Cell Constraints

```
REMove CEll Constraints <chain name
instance name | -All> [-POSition <cell pos1
 SCI [cell pos2 | SCI]>]
```

This command removes a specified cell constraint, or all cell constraints, previously added with the add cell constraints command.

#### Remove Clocks

```
REMove CLocks <pin names | -All>
```

This command removes one or more clock declarations, or all clock declarations, previously added with the add clocks command or implicitly defined in the STIL procedure file and implemented with the run drc command.

## Remove Compressors

```
REMove COmpressors < compressor name | -Load
-Unload | -All>
```

This command removes compressors from the defined compresors list. Note that this command is valid in DRC mode only.

## **Remove Delay Paths**

```
REMove DElay Paths [-All | path_name] [-
MIN Cycle <d>| -MAX Cycle <d>]
[-MIN Slack <d>| -MAX Slack <d>]
```

This command removes delay path definitions from TetraMAX memory, thus excluding them from being used for fault seeding and ATPG.

## Remove Display Gates

```
REMove Display Gates <pin_pathname |
gate id | -All>
```

This command removes gates associated with the pin\_pathname, the gate ID, or all gates from the GSV.

#### Remove Distributed Processors

```
REMove Distributed Processors
<hostnames | -Lsf | -Grd | -All>
```

This command removes machines from the current list of slave machines sharing a distributed task.

#### Remove Faults

```
REMove Faults
[pin pathname | instance name | -Module
<module_name> | -bridge location
<bridge location1 bridge location2> | -CLass
<fault_class> | -All | -CLOcks | -
SCan enable | -Retain sample <sample number>
| -Slow < R|F|RF > |
[-LAunch <launch clock>]
[-CApture <capture clock>]
[-EXclusive] [-SHared]
[-INTER_clock_domain]
[-INTRA clock domain] [-Bridge <0 | 1 | 01>]
[-AGgressor_node <First | Second | Both>]
[-COMBINATIonal feedback]
[-NON Strength sensitive]
```

This command removes faults from the current fault list, which means that the pattern generator will not attempt to detect the removed faults. You can remove faults associated with a specific pin, specific instance, or all instances of a named module: or remove a random sampling of all faults while retaining a statistical percentage; or remove all faults.

#### Remove Licenses

```
REMove Licenses <TEST-ANalysis | TEST-
Faultsim | TEST-ATPG-Max | TEST-DIagnosis |
TEST-Map | TEST-Fault-max | TEST-Accelerate-
```

This command manually releases and checks in one or more specified licenses so that others may use them. Before you remove a Test-Delay

or Test-Iddg license, you must first change the fault model to "stuck-at" using set faults -model stuck.

#### Remove Net Connections

REMove Net Connections < net names | -All> This command removes net connections previously added with the add net connections command. You can remove net connections from one or more specified nets or from all nets.

#### Remove Nofaults

```
REMove Nofaults <instance name |
pin pathname | -All | -Module <module name>>
[-Stuck <0|1|01>] [pin names]
```

This command removes some or all of the nofault attributes in the design. Nofault attributes can exist because they were defined in the netlist, added with the add nofaults command, or added with the add equivalent nofaults command.

You can use the remove nofaults command only when the current fault list does not contain any faults.

#### Remove PI Constraints

```
REMove PI Constraints <pin_names | -All>
```

This command removes one or more specified primary input constraints, or all such constraints, previously added with the add pi constraints command or implicitly defined in the test protocol file.

## Remove PI Equivalences

REMove PI Equivalences <-All | pin names>

This command removes one or more specified primary input equivalences, or all such equivalences, previously added with the add piequivalences command.

#### Remove PO Masks

```
REMove PO Masks <pin_name | -All>
```

This command removes one or more specified primary output masks, or all such masks, previously added with the add po masks command.

#### Remove Scan Chains

```
REMove Scan Chains <-All | chain names>
```

This command removes a specified scan chain or all scan chains previously defined by the add scan chains command. It does not affect any scan chains defined by the test protocol file and implemented with the run drc command.

#### Remove Scan Enables

```
REMove Scan Enables <pin_names | -All>
```

This command removes a specified scan enable initialization definition, or all such definitions, previously defined by the add scan enables command. It does not affect any scan enable initialization defined by the test protocol file and implemented with the run drc command.

#### Remove Slow Bidis

```
REMove SLow Bidis <port name | -All>
```

This command removes the modified simulation behavior of the bus associated with a specified bidi pin, or of the buses associated with all bidi pins previously defined as slow bidis by the add slow bidis command.

#### Remove Slow Cells

```
REMove SLow Cells <instance name | gate id |
```

This command removes the modified simulation behavior of a specified scan or nonscan DFF or DLAT cell, or of all such cells previously defined as slow cells by the add slow cells command.

#### Remove Slow Path

```
REMove SLow Path
[-All] [-from <from, from pin name>]
[-through <pin name>] [-to <to, to pin name>]
```

This command removes slow paths that have been defined by the add slow path command.

## Remove Waveform Signals

```
Remove Waveform Signals [pin pathname | gate
id | net names | -All]
```

This command removes gates associated with the pin pathname, gate ID, net names, or all gates from the GSV.

## **Report ATPG Constraints**

```
REPort Atpg Constraints [-Verbose | -
NOVerbose | -Summary | -All] [-Max <d>]
```

This command generates a report on the ATPG constraints added with the add atpg constraints command.

You can choose to get a summary report or a complete report. A summary report tells you how many ATPG constraints exist and how many are monitored during DRC analysis. A complete report shows the name, constraint value, DRC monitoring status, and location of each ATPG constraint.

## Report ATPG Primitives

```
REPort Atpg Primitives < name | -Summary | -
All> [-Max <d>] [-Verbose | -NOVerbose]
```

This command generates a report on a specified ATPG primitive or all ATPG primitives added with the add atpg primitives command.

You can choose to get a summary report or a complete report. A summary report tells you how many ATPG primitives exist for each type (AND, or, sel1, sel01, and equiv). A complete report shows the name, gate ID number, gate type, and input connections for each ATPG primitive in the design.

## Report Bist

```
REPort BIst [-Lfsr chain | -
Prpg shadow chains]
```

This command reports puesdo random pattern generator (PRPG) and multiple input signature register (MISR) cell data.

## Report Buses

```
REPort Buses <gate_id | -BEhavior <Buf | Inv
| And | Or | Xor | Mux | TIEO | TIE1 | TIEZ>
| -BIdis | -CLock | -Contention <Fail | Pass
| Abort | Bidi | Ignore> | -Keepers | -Pull |
-Weak | -Zstate <Fail | Pass | Abort | Bidi |
Ignore> | -Summary | -All> [-Max <d>] [-
Verbose] [-NOVerbose]
```

This command generates a report on the contention status of Bus primitives in the design. You can choose to get a report on a specific BUS primitive, on Bus primitives that fall into a specific category, or on all Bus primitives in the design. You can choose a summary report, which lists the number of BUS primitives in each category; or a complete report, which shows the gate ID number, contention status, Z-state status, number of strong/weak drivers, and learned behavior category for each Bus primitive.

## Report Capture Masks

```
REPort CApture Masks
```

This command generates a report on any capture masks added with the add capture masks command. The report shows the gate ID number, sequential cell type, and instance name associated with each capture mask.

## **Report Cell Constraints**

```
REPort CEll Constraints
```

This command generates a report on any cell constraints added with the add cell constraints command. The report shows the type of constraint, chain name, position in the chain, and instance name associated with each constraint.

## Report Clocks

```
REPort CLocks
[-Command report | -Verbose | -Matrix | -
Dominant | -INTClocks | -PLLClocks|
[-by id]
```

This command generates a report on all pins defined to be clocks, either explicitly by the add clocks command or implicitly by the test protocol file. These clock pins include active-high clocks, active-low clocks, asynchronous set/reset pins defined to be clocks, and memory-write control lines. You can optionally have the clocks reported in the form of add clock commands

## Report Commands

```
REPort COMmands [command name | -All] [-
Usage] [-History | -History_depth <d>] [-
depth]
```

This command provides information on a specified command or all commands, like the help command; or displays a history of commands executed in the current session.

## Report Compressors

```
REPort COMPressors <compressor_name | -Load
-Unload | -All> [-Verbose]
```

This command generates a report containing data for the specified compressors. Note that this command is valid in both DRC and TEST modes.

## **Report Delay Paths**

```
REPort DElay Paths <-All | path name> [-
Verbose] [-Display] [-Pindata]
```

This command generates individual paths for viewing with the GSV and exports a delay path list.

## Report Display Gates

```
REPort Display Gates
```

This command generates a report information about the gates currently being displayed in the GSV.

## Report Distributed Processors

```
REPort Distributed Processors
```

This command gets information on the distributed processors performing a distributed fault simulation task.

## Report Faults

```
REPort FAults [instance name | pin pathname]
[-CLass <fault class list>]
[-Unsuccessful | -SUmmary | -Profile | -All]
[-Stuck <0|1|01> | -Slow <R|F|RF>]
[-COllapsed | -UNCollapsed] [-Max <d>]
[-Verbose] [-PER clock domain]
[-Level <depth min count>] [-Pattern id <d>]
[bridge_location] [-Bridge <0 | 1 | 01>]
[-AGgressor_node <First | Second | Both>]
[-BRIDGE Feedback] [-BRIDGE Strong]
[-NDetects <Histogram | Faults <d>>]
[-Slack <Faults <d1> <d2> | Sdql | TMgn |
TDet | DElta | Effectiveness>]
```

Allowed fault class codes are:

DS - detected\_by\_simulation

DI - detected\_by\_implication

DR - detected\_robustly

NP - not\_analyzed-pos\_detected

NC - not-controlled

NO - not-observed

UU - undetectable-unused

UT - undetectable-tied

UB - undetectable-blocked

UR - undetectable-redundant

AN - atpg\_untestable-not\_detected

AP - atpg\_untestable-pos\_detected

DT - detected (DS + DR + DI)

PT - possibly detected (NP + AP)

UD - undetectable (UU + UT + UB + UR)

ND - not detected (NC + NO)

AU - ATPG untestable (AN)

This command generates a report on the faults contained in the current fault list.

You can specify the type of information to be reported: faults associated with a specific instance or pin in the design, faults falling into specific classes (such as DS and UU), and all unsuccessful faults (those not identified as detected during fault simulation), a summary report that lists the numbers of faults in each category, or a complete report on all faults.

# Report Feedback Paths

```
REPort FEedback Paths [path_id | -All | -Gate <gate_id | pin_pathname | instance_name>] [-Verbose] [-Summary]
```

This command generates a report on combinational feedback path networks in the design. A summary report just shows the number of feedback paths. A full report shows the loop ID number, number of gates, number of sources,

and sensitization status of each feedback path. To get a report on a specific feedback path, you can specify its loop ID number or a gate contained in the feedback path.

### Report Instances

```
REPort INstances
instance_name [-Module name] [-Netnames]
```

This command generates a report on a specified instance. You specify either a hierarchical instance name or the name of an instance within a specified module.

### Report Layout

```
REPort LAyout <layout | Tmax object_name>
[-Instance | -Cell_type | -Tmax_cell_type |
-Net]
```

This command extracts physical data and finds corresponding objects (instances, nets) between the layout and the TetraMAX design.

# Report Licenses

REPort Licenses

This command lists all licenses currently checked out by your TetraMAX session.

# **Report Memory**

```
REPort MEmory <instance name | Gate Id | -
All | -Summary> [-Contents <address | All>]
[-Max <d>] [-Verbose]
```

This command generates a summary report on all MEMORY primitives in the design, or a detailed report on one or all such primitives. A summary report shows the total number of RAMs and ROMs having certain stability and off-state characteristics. A standard or verbose report shows information on each memory primitive, including the type, gate ID number, instance path, and associated memory file.

### Report Modules

```
REPort MOdules [name | -UNReferenced | -
UNDefined | -UNSpecified | -Behavioral | -
Errors | -Summary | -All] [-Verbose] [-udp]
```

This command generates a report on one or more netlist modules in the design. You can get a report on a specific module, all modules falling into one category, or all modules in the design.

A summary report lists the number of modules that have been specified by various means (structural Verilog, behavioral Verilog, and so on). A standard report lists the module names and provides information on each module's usage and I/O pins.

### **Report Net Connections**

```
REPort NEt Connections
```

This command generates a report on all net connections added with the add net connections command.

# Report Nets

```
REPort NEts net name [-Module name]
```

This command generates a report on a specified net. You specify either a hierarchical net name or the name of an net within a specified module. The report lists the module input and output pins connected to the net.

# **Report Nofaults**

```
REPort NOFaults
instance_name |
pin_pathname [-Stuck<0|1|01>] |
-Summary | -All
[-Max <d>]
```

This command generates a report on the nofault attributes in the design. Nofault attributes can exist because they were defined in the netlist,

added with the add nofaults command, or added with the add equivalent nofaults command.

# Report Nonscan Cells

```
REPort NONscan Cells
<-Summary | -All |
 CO | C1 | CU | LO | L1 | TLA | LE | TE |
 LS | Unstable set resets>
[-Max <d>] [Ram out] [-Verbose]
```

This command generates a report on the nonscan flip-flops and latches contained in the design. You can get a summary report, which shows the number of cells falling into different categories or a detailed report on all nonscan cells falling into a specific category. A detailed report shows the nonscan cell category, behavior data, ID number, instance name, and instance type of each cell.

### Report Patterns

```
REPort PAtterns <pat specification | -All |
-Summary> [-Internal | -External] [-Chain
<name>] [-Types] [-Path delay] [-SLack] [-
CHAIN Mapping]
```

This command generates a report on the pattern data in the internal or external pattern buffer. A summary report shows the number of patterns of each type (Basic-Scan, Fast-Sequential, and so on). A standard report shows the pattern data for the specified range of patterns.

# Report PI Constraints

```
REPort PI Constraints [-Command report]
```

This command generates a report on all primary input and bidirectional ports that are constrained explicitly by the add pi constraints command or implicitly by the test protocol file.

# Report PI Equivalences

```
REPort PI Equivalences [-Command report]
```

This command generates a report on all sets of primary input and bidirectional ports that are constrained to be equivalent by the add piequivalences command.

## Report PO Masks

REPort PO Masks

This command generates a list of all primary output ports that are constrained to be masked by the add po masks command.

# Report Primitives

```
REPort PRimitives [primitive ID number | instance_name | net_name | pin_pathname | - PORts | -PIS | -POS | -PIOs | -Type <type> | -Summary] [-Max <d>] [-pins] [-all]
```

This command generates a report on primitives contained in the design built by TetraMAX. A summary report shows the number of primitives of various types: primary inputs, primary outputs, DFFS, NANDS, and so on. To get a detailed report on one or more primitives, specify the ID number, instance name, net name, pin path name, primitive category, or primitive type. You can request multiple reports in a single command.

# **Report Rules**

```
REPort RUles [rule type | rule ID | -All] [-Fail] [-verbose]
```

This command generates a report on the number of rule violations detected by TetraMAX. The report shows the rule ID number, severity level, number of failures, and a brief description of each rule.

In the command, specify the rules you want reported, such as c4 for "clock unable to capture," c for all clock rules, or -all for all rules. You can optionally show only the rules for which failures occurred

# Report Scan Ability

```
REPort SCan Ability [-Max <d>]
```

This command generates a report on nonscan cells that have been selected to behave as scan cells with the set scan ability command.

# Report Scan Cells

```
REPort SCan CElls [chain_name [position] |
-Shadows | -Unstable_set_resets | -All] [-
MAX <d>] [-MASter_only] [-Reverse_order] [-
Verbose] [-SHIft_clocks | -Clocks] [-Pins]
[-IGNORE_constraints]
```

This command generates a report on scan cells in the design. The report shows the name of the scan chain, the position of the cell within the scan chain, the type of behavior identified for the cell (master, slave, shadow, and so on), the inversion status, the primitive ID of the cell, and the instance name of the cell.

In the command, specify the scan cells to report. You can specify one or all cells of a particular scan chain, all shadow gates of scan cells, all scan cells with unstable set or reset controls, or all scan cells.

# Report Scan Chains

```
REPort SCan CHains
[-Command_report] [-Shift_clocks] [-Verbose]
```

This command generates a report on the scan chains in the design. For each scan chain, the report shows the scan chain name, load/unload group, length, input port name, and output port name.

# Report Scan Enables

```
REPort SCan Enables
```

This command generates a report on the scan enable attributes previously defined with the add scan enables command.

### report sdc

```
report sdc [-clocks] [-to cells] [-groups]
[-case analysis] [-false paths]
[-multicycle_paths] [-case_paths]
[-disable paths] [-all paths]
```

This command reports timing exceptions read in from a SDC (Synopsys Design Constraints) file. It is used only in TEST mode, and must be used in conjunction with the read sdc command, which reads in an SDC file. Note that this command is valid only Tcl mode.

# Report Scan Path

```
REPort SCan Path <chain_name> <SCO |
cell position SCI | cell position> [-
Reverse] [-Verbose]
```

This command generates a detailed report on the gates contained in a specified scan chain. In the command, specify the name of the scan chain and the numeric range of scan cells for the report. Use sco to represent the scan chain output and sci to represent the scan chain input.

# Report Settings

```
REPort SEttings [command type | -All] [-
Command report]
```

This command generates a report on the option settings controlled by the set commands: set atpg, set build, and so on. To restrict the scope of the report, specify the type of settings you want reported (for example, report settings atpg).

### Report Slow Bidis

```
REPort Slow Bidis
```

This command generates a report on the bidi pins defined as slow bidis by the the add slow bidis command.

### Report Slow Cells

```
REPort Slow Cells
```

This command ggenerates a report on the scan or nonscan DFF or DLAT cells previously defined with the add slow cells command.

### Report Slow Path

```
REPort SLow Path [-All] [-from
<from,from pin name>] [-through <pin name>]
[-to <to,to pin name>]
```

This command reports slow paths that have been defined by the add slow path command.

## **Report Summaries**

```
REPort SUmmaries [PRimitives] [Faults]
[PAtterns] [Library cells] [Memory usage]
[Optimizations] [Sequential depths]
[Cpu usage] [-launch <launch clock>] [-
capture <capture clock>] [-exclusive] [-
shared] [-inter_clock_domain] [-
intra_clock_domain] [-PER_clock_domain]
```

This command generates a summary report on one or more of the following topics: primitives, faults, patterns, library cells, memory usage, build optimization, control/observe sequential depth, or CPU usage.

# Report TRC

REPort Tro

This command reports the currently selected tester rules check.

### Report Version

```
REPort VErsion [-Full] [-Short] [-Banner] [-Verbose] [-Address] [-Release]
```

This command reports the TetraMAX version number or virtual address space.

# Report Violations

```
REPort VIolations <rule_type | -All> [-max <d>]
```

This command generates a report on the rule violations detected by TetraMAX. The report shows the severity, description, location, and rule ID number of each violation.

In the command, specify which violations you want reported: the violation ID number, the rule ID number (such as c4) for violations of that rule, the rule type (such as c) for all violations of that type, or -all for all violations.

### **Report Wires**

```
REPort Wires [gate_id | -Summary | -All] [-Contention <Fail | Pass | Abort>] [-Max <d>] [-Verbose]
```

This command generates a report on the wire gates in the design. A summary report shows the number of wire gates falling into different contention status categories. A full report shows the gate ID number, contention status, Z-state status, number of strong and weak drivers, and behavior data for each gate.

#### Reset AU Faults

```
RESet Au Faults
```

This command changes the detection status of all AU (ATPG untestable) faults to ND (not detected).

### **Reset State**

RESet State

This command resets the session state in preparation for restarting fault simulation or test generation using the current fault list. Any existing internal patterns are deleted and faults are set to their initial classification, giving credit for any current redundancy and ATPG untestable conditions.

#### Rm

RM filename

This command removes an existing file, like the UNIX rm command. It does not support the use of wildcard (\*) characters.

#### **Run ATPG**

```
RUn Atpg [Basic_scan_only |
FAst_sequential_only | FUll_sequential_only]
[-Auto_compression] [-Random] [-Distributed]
[-Observe_file <file_name>] [-NDEtects <d>]
[-NOdisturb clock grouping]
```

This command generates test patterns for the current set of faults using the pattern source set by the set patterns command. To specify the parameters for ATPG, use the set atpg command.

# Run Build\_model

```
RUn Build_model [top_module] [-Weakgates]
[-all] [-remove_pio_pull] [-prt < >]
```

This command builds the in-memory simulation model from the design modules that have been read into TetraMAX. To control the build process, use the set build command. After the build process is completed, TetraMAX performs a learning process, which you can control with the set learning command.

### Run Diagnosis

```
RUn DIagnosis <file name> [-Truncate <d>]
[-Chain failure] [-Display] [-
Only_report_failures] [-Verbose]
Write_fault_list <file name>] [-Replace] [-
COMPress <Gzip | Binary>] [-RANk faults]
```

This command performs a device failure diagnosis, given a file that identifies its failing tester measures. This diagnosis assumes the test patterns were originally generated by TetraMAX and that these patterns are available. Note that you use the set diagnosis command to make specifications relevant to this command.

The pattern set must be external, as specified by the set patterns command. For a selected fault, you can use the run simulation command to create a representative failure file to use for a diagnosis.

In the run diagnosis command, you can optionally specify a truncation point for the test patterns, request a chain load/unload diagnosis instead of a the standard functional diagnosis, and request a graphical schematic display of the results.

#### Run DRC

```
RUn DRc [file_name] [-Test | -Delete] [-
prescan] [-DFt] [-PATTERNEXEC <exec name>]
[-APpend]
```

This command performs design rule checking. TetraMAX checks the scan structure of the design and determines how to use this structure for test generation and fault simulation. The DRC process is affected by the set drc and set atpg commands.

You can optionally specify the name of a DRC file (the STIL procedure file) to be used for design rule checking. This file can specify DRC

information such as clock definitions, tester cycle periods, output measure values, scan chains, and scan shift initialization. You can also specify this file name using the set drc command.

# Run Fault sim

```
RUn FAult sim [-First pattern <d>] [-
Last_pattern <d>] [-STore] [-CHeckpoint
<fault filename>] [-NODrop faults | -
SEquential | -SEquential nodrop faults] [-
Distributed] [-DETected pattern storage] [-
STRong_bridge] [-NDEtects <d>]
```

This command performs fault simulation for the current fault list and pattern source, allowing you to determine the test coverage obtained by an externally generated test pattern.

You can optionally specify a truncation point (last pattern number), request a sequential simulation rather than a scan-based combinational simulation, or store the external patterns that detect faults in the internal pattern buffer.

#### Run Justification

```
RUn Justification [-Set <<gate_id |
pin pathname > < 0 | 1 | Z | R | F >> ] [-
Verbose] [-STore] [-Previous] [-
NOConstraints] [-NOPrevention] [-
FUll sequential] [-Replace pattern <d>]
```

This command creates a pattern that satisfies a given set of conditions placed on specified internal or external circuit nodes. If this process is successful, you can optionally place the resulting pattern into the internal pattern buffer and then write it out to a file. The justification process uses ATPG techniques, as defined by the set atpg command.

To specify the conditions for justification, use the -set option and specify one or more circuit locations and the desired value (0, 1, Z, R, or F) at each location.

# Run Mapping

```
RUn Mapping
<instance_name | -Module <module name>>
<-Pattern file <file name>>
[-DELete] [-DEPendent pattern mapping]
[-NOMAp_pin <pin_name>]
[-Sensitive | -INSensitive] [-Verbose]
[-CLock merge] [-MAX Errors <d>]
[-Analyze <d>]
[-STORE_Debug_data | -NOSTORE_Debug_data] [-
Merge | -MIXed event merge | -NOMErge]
[-REAd write overlapping |
NOREAd write overlapping]
[-Reload after unload |
NOReload after unload]
[-STRobe_offset <<d> FS | PS | NS | US | MS | S>]
[-STRobe period <<d>FS PS NS US MS S>]
[-STRobe rising <port name>]
[-STRobe_falling <port_name>]
[-STRobe comments < comments>]
[-STRobe event < >]
[-VCd_clock <<0|1> <port>>]
```

This command maps functional test patterns for an embedded submodule into new test patterns for the whole device under test. Based on the connectivity of the embedded submodule, TetraMAX determines how to control the inputs and observe the outputs of the submodule, and then constructs its own patterns that apply the pattern data to the submodule within the larger design.

# Run Observe Analysis

```
RUn Observe Analysis <-Observe file <file
name>> [-Replace] [-MAX_Observe_points <d>]
[-Num observe points per cell \langle \overline{d} \rangle]
```

This command performs an observability analysis of the design based on controllability and observability SCOAP numbers, and then

suggests the best places in the design to modify for improved test coverage. TetraMAX lists the identified locations in the transcript in rank order as the analysis progresses.

### Run Pattern\_compression

```
RUn Pattern_compression [num_passes]
[-RESet_au_faults] [-MIn_eliminated_pats
<d>] [-MAx_useless_passes <OFf | d>]
[-Order <RAndom | REverse>]
[-Verbose | -NOVerbose] [-RETain_order] [-NDetects <d>]
```

This command attempts to reduce the number of patterns by eliminating unnecessary patterns from the current pattern list. TetraMAX identifies the unnecessary patterns by performing fault simulation of the current patterns, retaining only those patterns that are required for detection of additional faults. Then, for a multiple-pass compression, it reorders the patterns and repeats the same elimination process. To avoid repeating the same pattern order, the reordering algorithm alternates between reversing the current order and rearranging the order randomly for each pass.

#### Run Simulation

```
RUn Simulation [-SEquential]
[-SEQUENTIAL_Update] [-STore] [-NOCompare]
[-Nox_difference] [-pin <<pathname> <0 | 1>>
| -Chain <<chain_name> <position>>]
[-Max_fails <d>] [-Failure_file <file_name>]
[-Replace] [-Last_pattern <d>]
[-Bridge <WAnd | WOr | Adom | Bdom> <nodea> <nodeb>>] [-SLow <R | F | RF>]
[-FASt <R | F | RF>] [-STuck <0 | 1>]
[-Update]
```

This command performs a simulation using the current pattern source, as determined by the set patterns command, and reports any differences between the simulated and expected values.

You can run this simulation in the presence of a single specified fault, which shows all simulation failures resulting from that fault. You can optionally save the failure data in a file and use that file as input to the run diagnosis command.

### Run Testpoint Analysis

```
RUn TestPoint Analysis
<-Test point file <file name>> [-Replace]
[-MAX Test points <d>]
[-Num_observe_points_per_cell <d>]
[-Class <list of fault classes>]
[-Dont touch <module name>]
```

This command controls test-point insertion based on undetected fault topology. Note that this command can only be used in the TEST command mode.

#### Run TRC

RUn TRc

This command performs design tester rule checking.

#### Set ATPG

```
Set Atpg
[-ADJacent fill range <d>]
[-ALlow_clockon_measures | -
NOALlow_clockon_measures]
[-ANalyze untestable faults |
NOANalyze untestable faults]
[-Abort_limit <d>]
[-BASIC Min detects per pattern <d [d]>]
[-CApture cycles <d>]
[-CHAin_test <OFf | 0011 | 0101 | 1000 |
0111 | <bit string> <R | C>>]
[-CHeckpoint <<interval time>
```

```
<fault filename> <pattern filename>> | -
NOCHeckpoint] [-COverage <f>] [-DEcision
<Random | NORandom>] [-DI_analysis |
NODI analysis] [-
FAST_Min_detects_per_pattern <<d> [d] >]
[-FIll <Random | 0 | 1 | X | Adjacent>]
[-FULL Min detects per pattern <<d> [d]>]
[-FULL_SEQ_ABort_limit <d>]
[-FULL SEQ ATpg | -NOFULL SEQ ATpg]
[-FULL SEQ Merge <Off | Low | Medium | High
<d>>1
[-LETE_fastseq | -NOLETE_fastseq]
[-FULL SEQ Time <max secs per fault
[max secs per run] >]
[-MErge <Off | Low | Medium | High | <d> [Low
| Medium | High | <d>]>]
[-NEW_Capture | -NONEW_Capture]
[-PATterns <d>] [-PRevention <Random |
NORandom>]
[-POST Capture contention prevention | -
NOPOST_Capture_contention_prevention]
[-RESET Bidis | -NORESET Bidis]
[-SINGle_load_per_pattern |
NOSINGle_load_per_pattern]
[-STore | -NOSTore] [-SUmmary | -NOSUmmary]
[-Time <<max_secs_per_fault>
[max secs per run] >]
[-Verbose | -NOVerbose]
[-OPTIMIZE Bridge strengths | -
NOOPTIMIZE Bridge_strengths]
[-min detects per pattern <d>]
[-MIN PATterns threshold <d>]
[-MIN Ateclock cycles <d>]
```

This command sets the parameters that control the ATPG process. It also affects all analyses that use the test pattern generation algorithm, including DRC and justification. You can display the current settings with the report settings command.

#### **Set Bist**

```
Set BIst
[-CHAin test | -NOCHAin test]
[-DBist | -NODBist] [-DEbug <d> | -NODEbug]
[-DUmp <interval_id | None>] [-Hex | -NOHex]
[-MAX Intervals <d>] [-MAX Routing <d>]
[-MAX Seed patterns <d>]
[-NUM_Dbist_patterns_per_interval <d>]
[-NUM Patterns per interval <d>]
[-Randomize pis | -NORandomize pis]
[-USE_CEll_constraints | -
NOUSE CEll constraints]
[-USE COnstant value cells | -
NOUSE COnstant value cells]
[-OPTimize fault sim | -
NOOPTimize_fault_sim]
[-Verbose | -NOVerbose]
[-FORCE Xdbist scalable selector |
[-HEX Diag data | -NOHEX_Diag_data]
[-force lfsr load] [-min l < >]
[-noforce_lfsr_load] [-PO_assumed_scan] [-NOPO_assumed_scan] [-ASSUME_Bist_setup]
[-NOASSUME Bist setup]
[-Trailing edge checking]
[-NOTrailing_edge_checking]
```

This command is the primary interface for controlling BIST related ATPG pattern generation options, such as patterns per interval, and maximum seeds

### Set Build

```
Set BUIld
[-DELete unused gates |
NODelete unused gates]
[-Merge < Equivalent dlat dff |
EQUIVALENT_Initialized_dlat_dff |
NOEquivalent dlat dff | FLipflop from dlat |
FLIPFLOP Cell from dlat |
NOFLipflop from dlat | Dlat from flipflop |
NODlat from flipflop | Wire to buffer |
NOWire to buffer | Mux from gates |
MUXPins_from_gates | MUXX_from_gates |
NOMux from gates | Xor from gates |
XORPins from gates | NOXor from gates |
Cascaded_gates_with_pin_loss
NOCascaded gates with pin loss
Tied gates with pin loss
NOTied gates with pin loss
Global tie propagate |
```

```
NOGlobal tie propagate | Bus keepers |
NOBus keepers | FEedback paths
NOFEedback paths >]
[-Undriven bidi <PIO | PI | PO >]
[-Hierarchical delimiter <c>]
[-Coerce_port_directions |
NOCoerce port directions]
[-Fault boundary <Lowest | Hierarchical>]
[-Add buffer | -NOAdd buffer]
[-Limit fanout <d>]
[-Black box <module name> | -Empty box
<module_name> | -DESign_box <module_name> |
-Portfault box <module name> | -NOBox
<module name> | -Reset_boxes]
[-INStance modify <<instance name>
<gate type>> | -NOINStance modify
<instance_name> | -NOINStance_modify_all]
[-Net connections change netlist | -
NONet connections change netlist]
```

This command sets the parameters that control the building of simulation models with the run build\_model command. You can designate black box modules and control optimization features such as gate merging and unused gate deletion.

Changes to the build settings only affect future use of the run build\_model command; they do not affect the flattened image already created by a prior build operation.

#### Set Buses

```
Set BUSes
[-External_z <X | 0 | 1 | Z>]
[-Fault_contention <And | Or | X>]
[-Contention_status <<Ignore | NOIgnore>
<gate_id |pin_pathname | All>]
[-Zstate_status <<Ignore | NOIgnore>
<gate_id | pin_pathname | All>>]
```

This command controls the behavior of bus gates. It sets the behavior of the Z state for external pins and the fault machine contention value for buses with contending values.

#### **Set Colors**

```
Set COLors <Error | Warning | User_commands
| File commands> <red number>
<green number> <blue number>
```

This command sets the text display color in the transcript for messages of a specified type: errors, warnings, user command messages, or file command messages. You specify the intensity of each color as a integer value from 0 to 255.

#### **Set Commands**

```
Set COMmands [History | NOHistory] [NOAbort
| Abort | Exit]
```

This command determines whether TetraMAX maintains a command history and the action taken when an error occurs during command file execution (abort, continue, or exit).

# **Set Compressor Connections**

```
Set COMPressor Connections
<compressor_name> [-Mode <d>]
[-Internal <<input id> <output id>...>]
[-LOAD input <<input id> <port name>>]
[-LOAD Output <<output_id> <chain_name>>]
[-UNLOAD Input <<input id> <chain name>>]
[-UNLOAD Output <<output_id> <port_name>>]
```

#### **Set Contention**

```
Set CONtention [ABus | NOABus] [BIdi |
NOBIdi] [Bus | NOBus]
[Dff dlat | NODff dlat] [Float | NOFloat]
[Ram | NORam]
[WIre | NOWIre]
[-Atpg | -NOAtpg] [-Capture | -NOCapture]
[-Multiple_on | -NOMultiple_on]
[-REtain_bidi | -NOREtain bidi]
[-Severity < Error | WArning | Ignore>]
[-Preclock | -NOPreclock]
[-Verbose | -NOVerbose]
```

This command specifies the manner in which TetraMAX performs contention checking, the types of design elements checked (bidirectional ports, buses, RAMs, and so on), and the action taken when a contention condition occurs.

# Set Delay

```
Set DElay
[-PI changes | -NOPI changes]
[-PO_measures | -NOPO_measures]
[-ALLOW Reconverging paths |
NOALLOW Reconverging_paths]
[-DIagnostic propagation | -
NODIagnostic propagation]
[-Mask nontarget paths | -
NOMask nontarget paths] [-RElative edge | -
NORElative edge]
[-RObust fill | -NORObust fill]
[-Launch cycle <Last shift | System clock |
[-DAta <path name>]
[-Simulate_hazards | -NOSimulate_hazards]
[-COmmon launch capture clock |
NOCOmmon launch capture clock]
[-TWO clock transition optimization | -
NOTWO clock transition optimization]
[-ALLOW Multiple common clocks |
NOALLOW_Multiple_common_clocks]
[-SLow_equivalence | -NOSLow_equivalence]
[-DISturb clock grouping]
[-NODISturb clock grouping]
[-TRAnsition clocking checks]
[-NOTRAnsition clocking checks]
[-MAX_Delta_per_fault <value>]
[-SLACKDATA FOR Atpg]
[-NOSLACKDATA FOR Atpg]
[-SLACKDATA FOR Faultsim]
[-NOSLACKDATA FOR Faultsim]
[-Clock period <f>]
[-SDQL coefficient <{n1 n2}>]
[-MAX_Tmgn <f>] [-MUlticycle_length <d>]
```

This command sets options for use in transition fault and path delay fault test generation and fault simulation.

### Set Diagnosis

```
SEt DIagnosis
[-Time limit <d> | -NOTime limit]
[-Verbose | -NOVerbose]
[-CHEck expected data |
NOCHEck expected data]
[-LAyout_data | -NOLAyout_data]
[-Sample <<d> <d>>]
[-INcomplete failures |
NOINcomplete failures]
[-REPOrt_net_data <d> | -NOREPOrt_net_data]
[-Max report failures <d>]
[-CYcle offset <d>]
[-Pt credit | -NOPt credit]
[-COMposite | -NOCOMposite]
```

This command specifies the parameters associated with performing a diagnosis of a failing device (specified by the run diagnosis command).

#### Set Distributed

```
Set DIstributed [-SHELL Timeout <d>]
[-SLave_setup_timeout <d>]
[-PRint stats timeout <d>]
[-SCript <user defined tmax script>]
[-Work dir <work directory>]
[-SHELL <type of shell: rsh, ssh, remsh>]
[-Verbose | -NOVerbose]
```

This command controls the amount of time the system is given to perform various distributed processor-related communications, and identifies the location of a common working directory that the machines performing a distributed fault simulation task will share to exchange information. Every machine sharing this task must have read/write/execute rights to this directory.

#### Set DRC

```
Set Drc
[file name | -NOFile] [-Oscillation <d>]
[-TRace | -Chain_trace < chain_name > | -
NOTRace
[-clock gating init cycles integer <d>]
[-SHadows | -NOSHadows | -
SErial_shadows_only]
[-TLas | -NOTLas]
[-STORE SEtup | -NOSTORE SEtup]
[-STORE_STability_patterns | -
NOSTORE STability patterns]
[-Bidi control pin <0 | 1 <name>> | -
Bidi control none]
[-SKew <d>] [-Remove false clocks | -
NORemove false clocks]
[-Initialize_dff_dlat <0 | 1 | X | Random>]
[-Allow unstable set resets |
NOAllow_unstable_set_resets]
[-CLock <pin name> | -Any | -Dynamic | -
One hot | -Seq capture]
[-MUlti captures per load | -
NOMulti_captures_per_load]
[-DISturb clock grouping |
NODISturb clock grouping]
[-COntroller_clock <pin_name> | -
NOCOntroller clock]
[-Z_Check_with_all_constraints | -
NOZ Check with all constraints]
[-Unstable_lsrams | -NOUnstable_lsrams]
[-Dslave remodel | -NODslave remodel]
[-OBServe procedure <Master | Any>]
[-Pipeline | -NOPipeline] [-optimize]
[-NUM Pll cycles <d>]
[-MAX_Pll_simulation_passes <d>]
[-PLL Simulate test setup | -
NOPLL_Simulate_test_setup]
[-USE Cell constraints | -
NOUSE Cell constraints]
[-COMPressor debug data]
[-NOCOMPressor_debug_data]
[-report x sink] [-noreport x sink]
[-STORE UNload mode data]
[-NOSTORE_UNload_mode_data]
[-PLL launch on shift
NOPLL_launch_on_shift]
[-CONStraints | -NOCONStraints]
[-SDC environment <Tmax drc
Sdc case analysis | None>]
```

This command sets various parameters that control the DRC process carried out by the run drc command. You can control features such as the use of a DRC file (STIL procedure file), the use of unstable set/reset inputs on sequential devices, clock characteristics, sequential device initialization, false clock removal, shadow register detection, transparent latch detection, and scan chain tracing.

#### Set Environment GUI

```
Set Environment Gui [-Max history length
<d>] [-ERror messages <Transcript |
Message box>] [-TOolbar <Text |
BItmap only>] [-ENd scroll | -NOEnd scroll]
[-TITLE Prefix <Window banner prefix>] [-
CMDbar | -NOCMDbar]
```

This command provides an alternative method for setting up the graphical user interface (GUI). Instead of using the Edit > Environment command in the GUI and interactively setting up the environment, you can use this command (possibly in a command file) to accomplish the same setup tasks.

#### Set Environment Info

```
Set Environment Info [-Always on top | -
NOAlways on top] [-Save dimensions | -
NOSave dimensions]
```

This command provides an alternative to the Edit > Environment command for controlling the overlap of the gate information window over other windows and the session-to-session window dimensions.

### **Set Environment Reports**

```
Set Environment Reports
[-MAX lines <d>] [-Line length <d>]
[-Color_text <red_number green_number
blue number>1
[-Color background < red number green number
blue number>1
[-Xpos <d>] [-Ypos <d>]
[-Width <d>] [-Height <d>] [-Font size <d>]
```

This command provides an alternative to the Edit > Environment command for controlling the text display characteristics resulting from various report commands. You can control the text color, text size, initial window location/dimensions, and so on.

### Set Environment Transcript

```
Set ENVironment Transcript
[-Font_size <d>]
[-Line length <d>]
[-MAX_lines <d>]
```

This command provides an alternative to the Edit > Environment command for controlling the transcript window characteristics: text size, line length, line buffer size, and left margin size.

#### Set Environment Viewer

```
Set Environment Viewer
[-Buf inv | -NOBuf inv]
[-DEsign symbols <Block | Primitives>]
[-DFf_dlat_symbol <MODE1|MODE2|MODE3>]
[-Font <System | Hershey>]
[-Instance names | -NOInstance names]
[-Left justify pis | -NOLeft justify pis]
[-Max_gates <d>] [-Primitive | -NOPrimitive]
[-Redraw <Always | If necessary>]
[-MAX Pindata length <d>]
```

```
[-Scheme < Default | Black on white |
Synopsys>] [-TIme out < d>]
[-TRuncate | -NOTRuncate]
[-Color <BAckground | BIdi | BLock |
BUfinv removed | EDge connector | ID
|INstance_name | HIghlight | NEt |
PINData text | PINName text | RUbberband |
TIE | TITLE Background | TITLE_Text |
Type name text <red number> <green number>
<br/><blue number>>]
```

This command provides an alternative to the Edit > Environment command for controlling the display characteristics of the graphical schematic viewer. You can control the colors of objects, the D flip-flop display mode, the text font, the presence of instance name labels, the redraw parameters, and so on.

#### Set Faults

```
Set Faults
[-Model <Stuck | Iddq | Transition |
Path delay | Bridging>]
[-Report <Collapsed | Uncollapsed>]
[-Pt credit <d>] [-AU credit <d>]
[-ATpg effectiveness | -
NOAtpg effectiveness]
[-Fault_coverage | -NOFault_coverage]
[-Equiv code <code name> | -NOEquiv code]
[-Summary <Verbose | NOVerbose>]
[-BRIDGE Inputs | -NOBRIDGE Inputs]
```

This command specifies the type of fault model used for pattern generation and the characteristics of the fault report.

The three primary fault models are the stuck-at model, used for standard test pattern generation; the IDDQ model, used to generate guiescent states for IDDQ testing; and the transition delay fault model, used to detect slow-to-rise and slowto-fall faults.

You can control fault reporting characteristics such as collapsed versus uncollapsed faults, credit for potentially detected (PT) and ATPG

untestable (AU) faults, and coverage types reported (test coverage, fault coverage, and ATPG effectiveness).

#### Set IDDQ

```
Set Iddq
[Float | NOFloat] [Strong | NOStrong]
[WEak | NOWEak] [WRite | NOWRite]
[-Atpg | -NOAtpg] [-Toggle | -NOToggle]
[-Exclude ports <None | Bidis | All>]
```

This command specifies the conditions considered during IDDQ test pattern generation. The command settings are valid only if the IDDQ fault model has been selected with the set faults command.

In the set iddg command, an assertive keyword such as float means that the condition is considered and therefore avoided for IDDQ pattern generation. A negative keyword such as nofloat means that the condition is not considered and therefore allowed for IDDQ pattern generation.

# Set Learning

```
Set Learning
[-Atpg_equivalence | -NOAtpg_equivalence]
[-Module_learning | -NOModule_learning | -
Common_input | -NOCommon_input]
[-Equivalent_latches |
NOEquivalent latches]
[-Implication <Low | Medium | High> | -
NOImplication]
[-MAX FEedback sources <d>]
[-Sim passes <d>] [-Test passes <d>]
[-Verbose | -NOVerbose] [-nomodule]
[-DISable time limit]
[-NODISable time limit]
```

This command sets the parameters for the learning process that TetraMAX performs immediately after it builds a model. During this process, each gate can be assigned a learned behavior characteristic (blocked, constrained, equivalent, and so on). TetraMAX uses this information during test pattern generation.

With this command, you can specify whether to perform various types of analysis (ATPG equivalence, common input, equivalent latch, and implication), and you can specify certain parameters for the learning analysis.

# **Set Messages**

```
Set Messages
[-Display | -NODisplay]
[-Double_slash | -NODouble_slash]
[-NOLog | -Log <filename>] [-Replace | -Append]
[-Level <Expert | Standard>]
[-Transcript_comments |
-NOTranscript_comments]
```

This command sets the parameters for the generation and display of messages in the transcript window.

#### Set Netlist

```
Set Netlist [-Pin assign | -NOPin assign]
[-EScape <Cond | All | None>] [-SCalar net |
-NOSCalar net]
[-Max errors <d>]
[-REDefined module <First | Last>]
[-Dominance_detection <ON | OFf | Boolean>]
[-CElldefine | -NOCElldefine]
[-ENable_portfaults | -NOENable_portfaults]
[-SUppress faults | -NOSUppress faults]
[-Xmodeling | -NOXmodeling]
[-SEquential modeling |
NOSEquential modeling]
[-CHeck only used udps | -
NOCHeck_only_used_udps]
[-COnservative_mux < None | Combinational_udp
| All>1
```

This command sets the parameters that control the reading of netlists with the read netlist command. It only affects the subsequent reading of netlists, not netlists that have been read in already.

#### Set Patterns

```
Set PAtterns [Internal|Random|Bist|External
<filename>1
-Delete
[-SEnsitive | -INSensitive]
[-STROBE Comments < comments>]
[-STROBE Period <<d> <FS | PS | NS | US | MS | S>>]
[-STROBE Rising <port name>]
[-STROBE Falling <port name>]
[-STROBE_Event < >] [-STROBE Offset < >]
[-Histogram_summary | -NOHistogram_summary]
[-Load summary | -NOLoad summary]
[-NOVCD_clock | -VCD_clock <<Auto> | <0|1>
<port>>]
[-VERIlog last scan | -NOVERIlog last scan]
[-translate dbist patterns]
[-EXPAND_xdbist_patterns]
[-Cycle count | -NOCycle count]
[-Netlist independent]
[-NONetlist_independent] [-APPend]
[-Measure forced bidis | -
NOMeasure_forced_bidis]
[-external <filename>]
```

This command specifies the source of patterns to use for simulation, fault simulation, or test generation. You can select internally generated patterns, random patterns (as defined by the set random patterns command), or an external pattern file (the method used to read ATPG or functional patterns).

External pattern files can be in any of the following formats: binary, extended VCD (VCDE), STIL, Verilog, VHDL, and WGL. For patterns in VCDE format, you can optionally specify the strobe trigger conditions for measuring expected values.

#### Set Pindata

```
Set PIndata
[-None | -CLOCK Cone <pin name> | -CLOCK ON
<pin_name> | -CLOCK_OFf | -Constrain_data |
-Debug sim data | -DELAY data | -Error data
| -FAULT Sim results <<pre> <<pre>pin pathname | gate
pin number> <0 | 1> <pattern>> | -Fault data |
-Good sim_results <d> | -Load | -
Master observe | -Pattern <<d> | All |
Fast_sequential> | -FULL_SEQ_Scoap_data | -FULL_SEQ_Tg_data | -SCoap_data | -
SEQ Sim data | -SHAdow observe | -SHIft | -
BIST Data | -BIST Setup |
STability patterns | -TEst_setup | -TIe_data
| -Bidi control value]
[-Refresh] [-Shift character <<c>>]
[-Constrain character <<c>>]
[-UNLOAD mode]
[-DRCdata < UNLOAD Mode <d>>]
[-SDC case analysis]
```

This command specifies the type of pin data displayed by the report primitives command and by the graphical schematic viewer. You select any one of several pin data types: clock cone data, clock-off data, constraint data, fault data, SCOAP data, simulation event data, test setup data, and so on. You can optionally have the schematic display refreshed (redrawn with the new pin data) immediately.

# Set Primitive\_report

```
Set PRimitive report
[-Max fanout <d>]
[-Interval <d>]
[-Time <Clock | PReclock | POstclock | Lete
| All>]
[-Verbose | -FAST lookup | -FAST NOLCS |
NOFAST lookup]
```

This command specifies the type of information displayed by the report primitives command, including the pin data spacing interval, the number of fanout connections, and the time with respect to the capture clock at which to display the data.

### Set Random patterns

```
Set RAndom patterns
[-Clock <pinname> | -Clock none]
[-Length <d>]
[-Observe <Master | SLave | SHadow>]
```

This command sets the parameters that control the application of random patterns, including the capture clock (if any), the number of patterns to apply, and the cell observe points.

#### Set Rules

```
Set RUles
[rule id] [Error | Warning | Ignore]
[-Mask | -NOMask]
[-AUtofix | -NOAUtofix] [-reset]
```

This command sets the rule severity (error. warning, or ignore) for a specified rule (for example, C1 or N2). For certain DRC rules, you can optionally mask the control or observe functionality of the affected sequential elements to improve the ability to create patterns that pass in simulation, at the cost of lowered test coverage.

# Set Scan Ability

```
Set SCan Ability
ON | OFf
nonscan cell gate | -DFf | -Dlat | -All
```

This command temporarily converts one or more specified nonscan cells into scan cells (or changes them back to nonscan cells), allowing you to explore the effects of these changes on test coverage.

#### set sdc

```
set sdc [-Verbose | -NOVerbose]
[-CAse paths | -NOCase paths]
[-Instance <instance name>]
[-Environment <Tmax_drc | Sdc_case_analysis
None>]
```

This command controls how TetraMAX interprets an SDC file used for specifying setup timing exceptions. It will only work if you specify it before the read sac command. You must be in DRC mode to use this command (after you successfully run the run build command, but before running run drc). Note that the set sdc command is valid only Tcl mode.

#### Set Simulation

```
Set Simulation
[-Bidi_fill | -NOBidi_fill | -
STRong_bidi_fill | -WEAk_bidi fill]
[-Data <<first pattern> <last pattern>>]
[-Measure <Sim | Pat>]
[-Oscillation <<num_passes>
<num_additional_fault_passes>>]
[-Words per pass <d>] [-Verbose | -
NOVerbose] [-BAsic_scan | -NOBAsic_scan]
[-STOre_memory_contents <pattern_id | LAst>
-NOSTOre memory contents]
[-XClock gives xout | -NOXClock gives xout]
[-XFill_out_of_range_write | -
NOXFill out of range write]
```

This command sets the parameters for simulations run with the run simulation and run fault sim commands. You can control the simulation algorithm (Basic-Scan or sequential). the bidirectional port driving mode, the source of expected data for fault simulation, and so on.

#### Set TRC

```
Set TRc
filename [label...]
-NOFile < [label] ... |
-All >
```

This command selects the Tester Rule Checks to be performed after DRC or with the run tro command. Note: The syntax for the -nofile option requires either a label or the -All option. The need for the labels is different for the filename and the -nofile versions of this command.

For filename, the labels are optional; if labels are not specified, the first label in the tester rule check file is read. However, one or more labels (or -All) are required when specifying the nofile Option.

#### Set WGL

```
Set WGl
[-Bidi map <<ab> <cd>>]
[-Scan_map <Dash | Bidi | Keep | None >]
[-Macro_usage | -NOMacro_usage]
[-PAd | -NOPad] [-Last scan | -NOLast scan]
[-Group_bidis | -NOGroup_bidis]
[-Tester_ready | -NOTester_ready | -
PRe measured]
[-INversion reference <Master | Cell | Omit
[-FOrces during load <Allow x |
Previous_values | No_x>]
[-Chain list <All | Shift>]
[-0] [-1] [-x] [-identical bidi map]
```

This command sets the parameters for WGL pattern generation. You can specify whether to force unspecified inputs during load, whether to generate scan or parallel vectors for the last patterns, whether to use macros, whether to pad the shorter scan chains, and so on.

# Set Workspace Sizes

```
Set WOrkspace Sizes
[-Atpg_gates <d>] [-CONnectors <d>]
[-Decisions <d>] [-DRC buffer size <d>]
[-Line <d>] [-String <d>]
[-COMMAND Line <d>] [-COMMAND Words <d>]
```

This command specifies the maximum number of items of a specific type allowed in the current TetraMAX environment: user-defined ATPG gates, fanout connections for the graphical schematic viewer, active decisions, state element candidates, line numbers per input file. or characters per string.

### Source

Source <file\_name> [echo]

Use this command for executing UNIX shell commands. The command string is passed to the default shell and executed. The command string may be enclosed in double quotes. When you use the echo option during TCL Mode, it echoes the commands in the file\_name and displays them them in the GUI transcript or shell xterm.

### **System**

SYstem command string

This command executes UNIX shell commands. The command string is passed to the default shell and executed. The command string may be enclosed in double quotes.

NOTE: The standard input and standard output of this command is not available in TetraMAX. Progress or status from this command is not shown in the transcript.

#### **Test**

TEST

This command manually returns a TetraMAX session to the TEST command mode, allowing you to execute commands that operate only in that mode.

#### **Unalias**

```
UNALias <alias_name | -All>
```

This command removes a specified alias definition, or all definitions, created by the alias command.

# **Update Clock**

```
Update Clock <-Wft <wft_name>>
<-Clock <clock_name>>
[-Pulse <<d>>,leading and failing edge>]
[-Unit <ps | ns>]
```

This command changes the pulse timing of a specific clock in a specific named WaveformTable. It can be used only after the read drc command. All optional parameters not otherwise specified in this command will remain at existing values. The time values specified by this command, scaled based the specified unit value, will be modified to fit within the current scale of the WaveformTable being changed.

# **Update Wft**

```
Update Wft <-Wft <wft_name>> [-Period <d>]
[-Force <d>] [-Strobe <d>] [-Unit <ps | ns>]
```

This command changes any of the period, forceevent timing, or measure-event timing parameters within a specific named WaveformTable. It can be used only after the read drc command.

### Write Drc file

```
Write Drc_file
filename
[-Replace] [-Compress <Gzip | Binary> ]
[-Scancells] [-Generic captures]
```

This command writes a test protocol file in STIL format based on the current clocks, PI constraints, PI equivalences, pin timing, and known STIL procedure files or Synopsys protocol files.

#### Write Faults

```
Write Faults
<filename> [instance_name | pin_pathname]
[-CLass <fault_class_list> | -SUmmary | -
All] [-Stuck < 0 | 1 | 01 > | -Slow < R | F | RF > ]
[-COMpress <Gzip | Binary>]
[-COllapsed | -UNCollapsed]
[-Max <d>] [-Replace] [-Profile]
```

This command writes fault data to an external file. In the command, specify the name of the external file and the scope of the fault list: the faults associated with a specified instance or pin. the faults belonging to a specified class or classes of faults, all faults, or a summary report. You can optionally specify a collapsed or uncollapsed list, thus overriding the set faults command setting.

### Write Image

```
Write Image <file name> [-COMpress <Gzip |
Binary | Off>] [-Replace] [-Violations] [-
NEtlist datal
```

This command after a successful DRC run writes the TetraMAX database to a file.

**Note:** This command does not write patterns out to the image file.

#### Write Netlist

```
Write Netlist <filename> [-Replace] [-Top
<top name>] [-Format <Edif [External] |</pre>
VErilog>] [-Compress <Gzip | Binary>] [-STOp
<Edif | VErilog | VHdl | Design level>]
```

This command writes netlist data to an external netlist file in a specified format. You can use compression to minimize the size of the file.

Note: Net connections added with the add net connections command are not reflected in the netlist written.

WARNING: Do not consider the write netlist command a tool for converting netlists between Verilog, EDIF, and VHDL formats, or to produce legal Verilog syntax for some other tool. The netlist written is intended for ATPG tool use and does not contain many of the items which can have been in the original netlist or module definitions.

For example, any behavioral module, with the exception of recognized RAM/ROM definitions, is converted to black box modules. Any timing information is stripped away. Any "specify" blocks may be stripped away. Any undefined modules will become black box definitions. Verilog UDPs are converted to gate-level functional netlists using ATPG primitives.

#### Write Patterns

```
Write Patterns
<filename> [-CELlnames <Internal | Verilog>]
[-COMpress <Gzip | Binary>]
[-EXClude <Setup | Repeat_setup | Patterns |</pre>
All>] [-FIrst <d>] [-Last <d>]
[-FOrmat <Binary | Stil | STIL99 |
VErilog_tables | VERILOG_Single_file | VHdl
| VHDL93 | Wgl | TStl2 | Ftdl | TDl91 |
WGL Flat>]
[-CONfig_file <cfilename>] [-Internal | -
EXTernal] [-Measure forced bidis]
[-NOCompaction] [-NOOverlap_load]
[-Order pins] [-PAD character <0 | 1 | X >]
[-Replace] [-SErial | -PARallel |
num shifts]
[-SOrted | -REOrder <file_name> | -Type
<Basic scan | Clock on measure |
FAst sequential | FUll sequential>]
[-SPlit <d>]
[-Verilog testbench name <<name>>] [-STil]
[-NOEXPAND_VEctor | -EXPAND_VEctor] [-VCS]
[-MTI] [-XL] [-NC]
```

This command writes ATPG patterns to a file in one of the supported formats: FTDL, STIL, TDL91, TSTL2, Verilog, VHDL, VHDL93, WGL,

WGL\_FLAT, and the ATPG tool's proprietary binary. Optionally, the file may be written using one of two forms of compression: GZIP or binary.

Using FTDL, TDL91, TSTL2, or WGL\_FLAT format causes TetraMAX to invoke a separate translation process, which opens a new window in which the translation process runs independently. The pattern formats FTDL, TDL91, and TSTL2 are write only; they cannot be read back in. This is important if you want to use the diagnostics capability of TetraMAX to assist in diagnosing device failures at the tester. If supporting diagnostics is part of your flow, you should also save the same patterns in a format that may be read back in, such as STIL or binary.

#### Write Simtrace

```
Write SImtrace <filename> [-Replace] [-Scan
<scanchainref>] [-Gate <gateidref>] [-Length
<d>>] [-Verilog | -Dpv]
```

This command assists in debugging ATPG pattern miscompares found during Verilog simulation. It facilitates the creation of a Verilog module by adding simulation data to be used for comparison with TetraMAX.

#### Write Slow Path

```
Write SLow Path
<filename> [-Replace] [-Compress <Gzip |
Binary>]
```

This command writes a file of add\_slow\_path commands. This file can be used to reinstate the set of slow paths that are currently defined at the time the file is written.

### Write TRC

```
Write Trc_file
<file_name> <label... | -All> [-Replace]
```

This command writes a tester rule file in CTL format based on the defined defaults.

# Index to Commands

| Add ATPG Constraints        |
|-----------------------------|
| Add ATPG Primitives3        |
| Add Capture Masks4          |
| Add Cell Constraints        |
| Add Clocks                  |
| Add Compressors             |
| Add Delay Paths             |
| Add Display Gates5          |
| Add Distributed Processors5 |
| Add Equivalent Nofaults5    |
| Add Faults6                 |
| Add Mode Ports6             |
| Add Net Connections6        |
| Add Nofaults                |
| Add PI Constraints          |
| Add PI Equivalences         |
| Add PO Masks8               |
| Add Scan Chains8            |
| Add Scan Enables9           |
| Add Slow Bidis9             |
| Add Slow Cells              |
| Add Slow Path9              |
| Add Waveform Signals10      |
| Alias                       |
| Analyze Buses11             |
| Analyze Compressors         |
| Analyze Faults12            |
| Analyze Feedback Path       |
| Analyze Simulation Data     |
| Analyze Testability13       |
| Analyze Violation           |
| Analyze Wires13             |
| Build                       |
| Cat                         |
| cd14                        |
| clear                       |
| cp                          |
| DRC14                       |
|                             |

| Exit                            |
|---------------------------------|
| Get Licences                    |
| GSV GET Selected Cells          |
| GSV Print                       |
| Gui_Start                       |
| Gui_Stop                        |
| Help                            |
| Layout                          |
| ls17                            |
| man                             |
| mkdir                           |
| $mv \ldots \ldots 18$           |
| pwd                             |
| quit                            |
| Read DRC18                      |
| Read Faults19                   |
| Read Image19                    |
| Read Layout                     |
| Read Memory_file                |
| Read Netlist20                  |
| Read Nofaults                   |
| Read Slow Path21                |
| Read Timing                     |
| read_sdc21                      |
| Refresh Schematic22             |
| Remove ATPG Constraints22       |
| Remove ATPG Primitives22        |
| Remove Capture Masks22          |
| Remove Cell Constraints         |
| Remove Clocks $\dots 23$        |
| Remove Compressors              |
| Remove Delay Paths23            |
| Remove Display Gates            |
| Remove Distributed Processor 24 |
| Remove Faults                   |
| Remove Licenses                 |
| Remove Mode Ports $\dots 25$    |
| Remove Net Connections25        |
| Remove Nofaults25               |
| Remove PI Constraints           |

| Remove PI Equivalences    |   |
|---------------------------|---|
| Remove PO Masks           |   |
| Remove Scan Chains26      |   |
| Remove Scan Enables       |   |
| Remove Slow Bidis         |   |
| Remove Slow Cells         |   |
| Remove Slow Path27        |   |
| Remove Waveform Signals27 |   |
| Report ATPG Constraints27 |   |
| Report ATPG Primitives27  |   |
| Report Bist28             | 3 |
| Report Buses28            |   |
| Report Capture Masks29    |   |
| Report Cell Constraints29 |   |
| Report Clocks             |   |
| Report Commands29         |   |
| Report Compressors        |   |
| Report Delay Paths        |   |
| Report Display Gates30    | ) |
| Report Faults30           | ) |
| Report Feedback Paths     |   |
| Report Instances          |   |
| Report Layout             |   |
| Report Licenses           |   |
| Report Memory             |   |
| Report Mode Ports33       |   |
| Report Modules33          |   |
| Report Net Connections33  |   |
| Report Nets33             |   |
| Report Nofaults           |   |
| Report Nonscan Cells      |   |
| Report Patterns34         |   |
| Report PI Constraints34   |   |
| Report PI Equivalences35  |   |
| Report Pin Data35         |   |
| Report PO Masks35         |   |
| Report Primitives35       |   |
| Report Rules35            | 5 |
| Report Scan Ability       |   |
| Report Scan Cells         | 3 |

| Set Environment GUI        |    |
|----------------------------|----|
| Set Environment Info       |    |
| Set Environment Reports    |    |
| Set Environment Transcript |    |
| Set Environment Viewer     |    |
| Set Faults                 |    |
| Set IDDQ                   |    |
| Set Learning               |    |
| Set Messages               | 57 |
| Set Netlist                | 57 |
| Set Patterns               | 58 |
| Set Pindata                | 59 |
| Set Primitive_report       | 59 |
| Set Random_patterns        | 30 |
| Set Rules                  | 60 |
| Set Scan Ability           | 30 |
| Set Simulation             |    |
| Set TRC                    | 31 |
| Set WGL                    |    |
| Set Workspace Sizes        | 32 |
| set_sdc                    | 30 |
| Source                     |    |
| System                     | 33 |
| Test                       | 33 |
| Unalias                    | 33 |
| Update Clock               | 34 |
| Update Wft                 | 34 |
| Usage                      |    |
| Write DRC_file             | 34 |
| Write Faults               |    |
| Write Image                | 35 |
| Write Netlist              |    |
| Write Patterns             |    |
| Write Sim Trace            |    |
| Write Slow Path            |    |
| Write TRC                  |    |
|                            |    |