Product Version ICADVM20.1 October 2020 © 2020 Cadence Design Systems, Inc. All rights reserved.

Printed in the United States of America.

Cadence Design Systems, Inc. (Cadence), 2655 Seely Ave., San Jose, CA 95134, USA.

Open SystemC, Open SystemC Initiative, OSCI, SystemC, and SystemC Initiative are trademarks or registered trademarks of Open SystemC Initiative, Inc. in the United States and other countries and are used with permission.

**Trademarks**: Trademarks and service marks of Cadence Design Systems, Inc. contained in this document are attributed to Cadence with the appropriate symbol. For queries regarding Cadence's trademarks, contact the corporate legal department at the address shown above or call 800.862.4522. All other trademarks are the property of their respective holders.

**Restricted Permission:** This publication is protected by copyright law and international treaties and contains trade secrets and proprietary information owned by Cadence. Unauthorized reproduction or distribution of this publication, or any portion of it, may result in civil and criminal penalties. Except as specified in this permission statement, this publication may not be copied, reproduced, modified, published, uploaded, posted, transmitted, or distributed in any way, without prior written permission from Cadence. Unless otherwise agreed to by Cadence in writing, this statement grants Cadence customers permission to print one (1) hard copy of this publication subject to the following conditions:

- **1.** The publication may be used only in accordance with a written agreement between Cadence and its customer.
- 2. The publication may not be modified in any way.
- **3.** Any authorized copy of the publication or portion thereof must include all original copyright, trademark, and other proprietary notices and this permission statement.
- **4.** The information contained in this document cannot be used in the development of like products or software, whether for internal or external use, and shall not be used for the benefit of any other party, whether or not for consideration.

**Disclaimer:** Information in this publication is subject to change without notice and does not represent a commitment on the part of Cadence. Except as may be explicitly set forth in such agreement, Cadence does not make, and expressly disclaims, any representations or warranties as to the completeness, accuracy or usefulness of the information contained in this document. Cadence does not warrant that use of such information will not infringe any third party rights, nor does Cadence assume any liability for damages or costs of any kind that may result from use of such information.

**Restricted Rights:** Use, duplication, or disclosure by the Government is subject to restrictions as set forth in FAR52.227-14 and DFAR252.227-7013 et seq. or its successor

# **Contents**

| <u>Preface</u>                                            |
|-----------------------------------------------------------|
| <u>Scope</u>                                              |
| Licensing Requirements                                    |
| Related Documentation                                     |
| What's New and KPNS                                       |
| Installation, Environment, and Infrastructure             |
| Technology Information                                    |
| Virtuoso Design Editing and Simulation Environment Tools  |
| Virtuoso Layout Suite Tools                               |
| Additional Learning Resources                             |
| Video Library                                             |
| Virtuoso Videos Book                                      |
| Rapid Adoption Kits                                       |
| Help and Support Facilities10                             |
| Customer Support                                          |
| Feedback about Documentation1                             |
| Typographic and Syntax Conventions                        |
| Identifiers Used to Denote Data Types13                   |
|                                                           |
| <u>1</u>                                                  |
| Virtuoso Voltage Dependent Rules Flows 15                 |
|                                                           |
| Types of VDR Labels                                       |
| Prerequisites for the VDR Flows                           |
| Specifying a Minimum Voltage Spacing Constraint           |
| Specifying Layers and Purposes for Generic Voltage Labels |
| Specifying Layers and Purposes for Voltage Markers        |
| Specifying Layers and Purposes for Synced Nets            |
| Simulation Driven VDR Flow                                |
| Setting Up Testbenches and Corners in Virtuoso ADE        |
| Enabling Voltage Capture in Virtuoso ADE                  |
| Running Simulations and Capturing Voltage Data            |

|            | Populating Voltages and Generating Labels or Markers            | 29 |
|------------|-----------------------------------------------------------------|----|
|            | Showing Voltage Information in Info Balloons                    |    |
|            | Checking for Voltage Dependent Spacing Violations using DRD     |    |
|            | Customizing the Voltage Calculation                             |    |
| Sc         | hematic Driven VDR Flow                                         |    |
|            | Propagating Voltage Values from Schematic to Layout             |    |
|            | Checking Voltage Values between Schematic and Layout            | 46 |
|            | Updating Voltage Values in the Layout to Match the Schematic    |    |
|            | Backannotating Voltage Values from Layout to Schematic          |    |
|            | Sanity Checking Voltage Values in Constrained Labels            | 48 |
|            | Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only) | 52 |
| <u>Lay</u> | yout-centric VDR Flow                                           |    |
|            | Entering Voltage Values in the Property Editor Assistant        | 57 |
|            | Generating Voltage Labels for Manually Entered Voltages         | 58 |
|            | Viewing Voltage Labels in the Layout View                       | 62 |
|            | Checking Voltage Labels in the Layout View                      | 63 |
|            | Generating Voltage Markers for Manually Entered Voltages        | 64 |
| <u>Po</u>  | st-Processing Voltage Labels and Markers                        |    |
| <u>De</u>  | eleting Voltage Labels and Markers                              | 67 |
|            |                                                                 |    |
| Α          |                                                                 |    |
| <u>_</u>   | oltage Dependent Rules Forms                                    | 60 |
| <u> </u>   |                                                                 |    |
|            | EAD Setup                                                       |    |
|            | VDR Dataset                                                     |    |
|            | VDR Sanity Checker                                              |    |
|            | Voltage Dependent Rules                                         |    |
|            | Voltage Dependent Rules (from net voltages)                     |    |
|            | VSync Constraints Visualizer                                    | 79 |
| _          |                                                                 |    |
| <u>B</u>   |                                                                 |    |
| <u>E</u> 1 | nvironment Variables                                            | 81 |
|            | vdrConstraintGroupName                                          |    |
|            | vdrGenerateLabels                                               |    |
|            | <u>vdrGenerateLabelsOn</u>                                      |    |
|            | vdrGenerateMarkers                                              |    |
|            | <u> </u>                                                        |    |

|          | vdrHierarchyStopLevel8              |
|----------|-------------------------------------|
|          | vdrHighVoltagePurpose8              |
|          | vdrLabelHeight89                    |
|          | vdrLayerPurposeFile9                |
|          | vdrLowVoltagePurpose9               |
|          | vdrNetVoltageMode9                  |
|          | vdrPostLabelCreationCallback9       |
|          | vdrSanityCheckerCheckAgainst9       |
|          | vdrSanityCheckerGenLogFile9         |
|          | vdrSanityCheckerLogFile9            |
|          | vdrSanityCheckerObjectType9         |
|          | vdrSanityCheckerTolerance9          |
|          | vdrSanityCheckerToleranceType99     |
|          | vdrVoltagePurposeFile               |
|          | vdrVoltageRounding                  |
|          | vdrVSyncCreateCheckLayer102         |
|          | vdrVSyncSanityCheckLayer103         |
|          | vdrZeroVoltageNets                  |
|          |                                     |
| C        |                                     |
| \/       | oltage Dependent Rules Functions    |
| <u>v</u> | •                                   |
|          | vdrCheckVoltageLabels               |
|          | vdrCreateVoltageLabel               |
|          | vdrCreateVoltageLabelEx             |
|          | vdrCreateVoltageLabelOnNets         |
|          | vdrCreateVoltageMarkers             |
|          | vdrCreateVoltageMarkersOnNets       |
|          | vdrCreateVSyncConstraintsFromFile13 |
|          | vdrDeleteLabels                     |
|          | vdrGenerateLabelsGUI                |
|          | vdrGenerateVSyncShapes13-           |
|          | vdrGetValidLayers                   |
|          | vdrRunSanityChecker13               |
|          | vdrRunVSyncSanityChecker13          |
|          | vdrSanityCheckerGUI                 |

| vdrSetNetVoltageRange       | 141 |
|-----------------------------|-----|
| vdrSetValidLayers           | 144 |
| vdrTransferVSyncConstraints | 146 |
| vdrVsvncVisualizerGUI       | 148 |

# **Preface**

This document describes three Virtuoso® voltage dependent rules (VDR) flows available in Virtuoso Layout Suite XL and higher tiers.

The complete **simulation driven VDR flow** lets you capture minimum and maximum voltage values from a simulation run in Virtuoso ADE and propagate the values to a layout view. They are stored in the OpenAccess database for the design and can be referenced by design rule driven (DRD) editing, the interactive wire editor, and the Virtuoso space-based router (VSR) to ensure that minimum voltage spacing constraints are honored during the physical implementation of your design. You can also use them to generate labels or markers in the layout view, which in turn can be used by tools like the Cadence<sup>®</sup> Pegasus physical verification system or Cadence PVS to verify the correctness of the implementation.

Alongside the simulation driven VDR flow, this document also covers **schematic driven** and **layout-centric VDR flows**, which let you add voltage values as properties directly on nets in a schematic or layout view. The property values are saved to the OpenAccess database for the design and can be used by DRD, the wire editor, and VSR.

**Note:** This document describes only the VDR flow and the various enhancements made to the Virtuoso Analog Design Environment and Virtuoso Layout Suite tools to support them. Links are provided to more detailed information on specific products available elsewhere in the Virtuoso documentation set.

This preface contains the following topics:

- Scope
- Licensing Requirements
- Related Documentation
- Additional Learning Resources
- Customer Support
- Feedback about Documentation
- Typographic and Syntax Conventions
- Identifiers Used to Denote Data Types

### Scope

Unless otherwise noted, the functionality described in this guide can be used in both mature node (for example, IC6.1.8) and advanced node and methodologies (for example, ICADVM20.1) releases.

| Label             | Meaning                                                                                   |
|-------------------|-------------------------------------------------------------------------------------------|
| (ICADVM20.1 Only) | Features supported only in ICADVM20.1 advanced nodes and advanced methodologies releases. |
| (IC6.1.8 Only)    | Features supported only in mature node releases.                                          |

# **Licensing Requirements**

The VDR flows require the following licenses:

| oso |
|-----|
|     |

- □ 111: Cadence Design Framework II
- 95011: Virtuoso Advanced Node Framework (ICADVM20.1 Only)

#### Capturing Voltages and Saving Datasets in Virtuoso ADE

- □ 95250: Virtuoso ADE Explorer
- □ 95260: Virtuoso ADE Assembler

Plus **one** of the following:

- □ 95265: Virtuoso Variation Option
- □ 95600: Virtuoso Layout Suite EAD (IC6.1.8 Only)
- □ 95800: Virtuoso Layout Suite EXL (ICADVM20.1 Only)

You also need appropriate licenses for the simulation engines you use to generate simulation data (e.g. Spectre).

#### ■ Populating Voltages in Layout XL

95310: Virtuoso Layout Suite XL or 95321: Virtuoso Layout Suite GXL (IC6.1.8 Only)

95511: Virtuoso Advanced Node Options for Layout (ICADVM20.1 Only)

For detailed information on the license requirements for Virtuoso and other Cadence tools, see the *Virtuoso Software Licensing and Configuration Guide*.

#### **Related Documentation**

#### What's New and KPNS

- <u>Virtuoso Voltage Dependent Rules Flow What's New</u>
- There are no known problems reported for this flow

#### Installation, Environment, and Infrastructure

- Cadence Installation Guide
- Cadence Application Infrastructure User Guide
- <u>Virtuoso Design Environment User Guide</u>
- Virtuoso Design Environment SKILL Reference

### **Technology Information**

- <u>Virtuoso Technology Data User Guide</u>
- <u>Virtuoso Technology Data ASCII Files Reference</u>
- Virtuoso Technology Data Constraints Reference
- <u>Virtuoso Technology Data SKILL Reference</u>

### Virtuoso Design Editing and Simulation Environment Tools

- Cadence Hierarchy Editor User Guide
- Component Description Format User Guide
- <u>Virtuoso ADE Assembler User Guide</u>
- Virtuoso ADE Explorer User Guide
- Virtuoso ADE Verifier User Guide

- <u>Virtuoso AMS Designer Environment User Guide</u>
- Virtuoso Schematic Editor User Guide

#### **Virtuoso Layout Suite Tools**

#### **IC6.1.8 Only**

- Virtuoso Layout Suite L User Guide
- Virtuoso Layout Suite XL User Guide
- Virtuoso Lavout Suite GXL Reference

#### ICADVM20.1 Only

- Virtuoso Layout Viewer User Guide
- Virtuoso Layout Suite XL: Basic Editing
- <u>Virtuoso Layout Suite XL: Connectivity Driven Editing</u>
- Virtuoso Layout Suite EXL Reference
- <u>Virtuoso Concurrent Layout User Guide</u>
- <u>Virtuoso Design Planner User Guide</u>
- <u>Virtuoso Multi-Patterning Technology User Guide</u>
- Virtuoso Placer User Guide
- <u>Virtuoso Simulation Driven Interactive Routing User Guide</u>
- <u>Virtuoso Width Spacing Patterns User Guide</u>

#### IC6.1.8 and ICADVM20.1

- Virtuoso Design Rule Driven Editing User Guide
- <u>Virtuoso Electrically Aware Design Flow Guide</u>
- <u>Virtuoso Floorplanner User Guide</u>
- Virtuoso Layout Suite SKILL Reference
- Virtuoso Module Generator User Guide

- Virtuoso Space-based Router User Guide
- <u>Virtuoso Interactive and Assisted Routing User Guide</u>
- <u>Virtuoso Symbolic Placement of Devices User Guide</u>

### **Additional Learning Resources**

#### **Video Library**

The <u>Video Library</u> on the Cadence Online Support website provides a comprehensive list of videos on various Cadence products.

To view a list of videos related to a specific product, you can use the *Filter Results* feature available in the pane on the left. For example, click the *Virtuoso Layout Suite* product link to view a list of videos available for the product.

You can also save your product preferences in the Product Selection form, which opens when you click the *Edit* icon located next to *My Products*.

#### Virtuoso Videos Book

You can access certain videos directly from Cadence Help. To learn more about this feature and to access the list of available videos, see Virtuoso Videos.

### **Rapid Adoption Kits**

Cadence provides <u>Rapid Adoption Kits</u> that demonstrate how to use Virtuoso applications in your design flows. These kits contain design databases and instructions on how to run the design flow.

In addition, Cadence offers the following training courses which are relevant to the content of this manual:

- Virtuoso Layout Design Basics
- Virtuoso Layout Suites Update Training
- Virtuoso Connectivity-Driven Layout Transition
- Virtuoso Layout Pro: T3 Basic Commands (XL)

#### Virtuoso Schematic Editor

Cadence also offers the following training courses on the SKILL programming language, which you can use to customize, extend, and automate your design environment:

- SKILL Language Programming Introduction
- SKILL Language Programming
- Advanced SKILL Language Programming

The courses listed above are available in North America. For specific information about the courses available in your region, visit <u>Cadence Training</u> or write to training\_enroll@cadence.com.

**Note:** The links above open in a separate browser window when clicked in Cadence Help.

#### **Help and Support Facilities**

Virtuoso offers several built-in features to let you access help and support directly from the software.

- The Virtuoso *Help* menu provides consistent help system access across Virtuoso tools and applications. The standard Virtuoso *Help* menu lets you access the most useful help and support resources from the Cadence support and corporate websites directly from the CIW or any Virtuoso application.
- The Virtuoso Welcome Page is a self-help launch pad offering access to a host of useful knowledge resources, including quick links to content available within the Virtuoso installation as well as to other popular online content.

The Welcome Page is displayed by default when you open Cadence Help in standalone mode from a Virtuoso installation. You can also access it at any time by selecting *Help – Virtuoso Documentation Library* from any application window, or by clicking the *Home* button on the Cadence Help toolbar (provided you have not set a custom home page).

For more information, see Getting Help in Virtuoso Design Environment User Guide.

# **Customer Support**

For assistance with Cadence products:

Contact Cadence Customer Support

Cadence is committed to keeping your design teams productive by providing answers to technical questions and to any queries about the latest software updates and training needs. For more information, visit <a href="https://www.cadence.com/support">https://www.cadence.com/support</a>.

Log on to Cadence Online Support

Customers with a maintenance contract with Cadence can obtain the latest information about various tools at <a href="https://support.cadence.com">https://support.cadence.com</a>.

#### **Feedback about Documentation**

You can contact Cadence Customer Support to open a service request if you:

- Find erroneous information in a product manual
- Cannot find in a product manual the information you are looking for
- Face an issue while accessing documentation by using Cadence Help

You can also submit feedback by using the following methods:

- In the Cadence Help window, click the *Feedback* button and follow instructions.
- On the Cadence Online Support <u>Product Manuals</u> page, select the required product and submit your feedback by using the <u>Provide Feedback</u> box.

# **Typographic and Syntax Conventions**

The following typographic and syntax conventions are used in this manual.

| text              | Indicates names of manuals, menu commands, form buttons, and form fields.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| text              | Indicates text that you must type exactly as presented. Typically used to denote command, function, routine, or argument names that must be typed literally.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| z_argument        | Indicates text that you must replace with an appropriate argument name or value. The prefix (in this example, $z_{-}$ ) indicates the data type the argument can accept and must not be typed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                   | Separates a choice of options.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| { }               | Encloses a list of choices separated by vertical bars from which you <b>must</b> choose one.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| [ ]               | Encloses an optional argument, or a list of choices separated by vertical bars from which you <b>may</b> choose one.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| [?argName t_arg ] |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                   | Denotes a <i>key argument</i> . The question mark and argument name must be typed as they appear in the syntax and must be followed by the required value for that argument.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| •••               | To Produce that the control of the c |  |
|                   | Indicates that you can repeat the previous argument.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                   | Used with brackets to indicate that you can specify zero or more arguments.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                   | Used with brackets to indicate that you can specify zero or more                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| ,···              | Used with brackets to indicate that you can specify zero or more arguments.  Used without brackets to indicate that you must specify at least                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| , · · · · =>      | Used with brackets to indicate that you can specify zero or more arguments.  Used without brackets to indicate that you must specify at least one argument but may specify more.  Indicates that if you specify more than one argument, you must                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| / · · · · => /    | Used with brackets to indicate that you can specify zero or more arguments.  Used without brackets to indicate that you must specify at least one argument but may specify more.  Indicates that if you specify more than one argument, you must separate those arguments with commas.  Precedes the values returned by a Cadence® SKILL language                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |

If a command line or SKILL expression is too long to fit inside the paragraph margins of this document, the remainder of the expression is put on the next line and indented. When writing the code, put a backslash (\) at the end of any line that continues on to the next line.

# **Identifiers Used to Denote Data Types**

Data type identifiers are used to indicate the type of value required by an API argument. These data types are denoted by a single letter that is prefixed to the argument label and is separated from the argument by an underscore; for example, t is the data type in  $t\_viewName$ . Data types and underscores are used only as identifiers; they must not be typed when specifying the argument in a function.

| Prefix | Internal Name     | Data Type                                   |
|--------|-------------------|---------------------------------------------|
| а      | array             | array                                       |
| А      | amsobject         | AMS object                                  |
| b      | ddUserType        | DDPI object                                 |
| В      | ddCatUserType     | DDPI category object                        |
| C      | opfcontext        | OPF context                                 |
| d      | dbobject          | Cadence database object (CDBA)              |
| е      | envobj            | environment                                 |
| f      | flonum            | floating-point number                       |
| F      | opffile           | OPF file ID                                 |
| g      | general           | any data type                               |
| G      | gdmSpecIIUserType | generic design management (GDM) spec object |
| h      | hdbobject         | hierarchical database configuration object  |
| I      | dbgenobject       | CDB generator object                        |
| K      | mapiobject        | MAPI object                                 |
| 1      | list              | linked list                                 |
| L      | tc                | Technology file time stamp                  |
| m      | nmpllUserType     | nmpll user type                             |
| M      | cdsEvalObject     | cdsEvalObject                               |
| n      | number            | integer or floating-point number            |
|        |                   |                                             |

| Prefix         | Internal Name         | Data Type                                                                                |
|----------------|-----------------------|------------------------------------------------------------------------------------------|
| 0              | userType              | user-defined type (other)                                                                |
| p              | port                  | I/O port                                                                                 |
| q              | gdmspecListIIUserType | gdm spec list                                                                            |
| r              | defstruct             | defstruct                                                                                |
| R              | rodObj                | relative object design (ROD) object                                                      |
| S              | symbol                | symbol                                                                                   |
| ${\mathcal S}$ | stringSymbol          | symbol or character string                                                               |
| t              | string                | character string (text)                                                                  |
| T              | txobject              | transient object                                                                         |
| и              | function              | function object, either the name of a function (symbol) or a lambda function body (list) |
| U              | funobj                | function object                                                                          |
| V              | hdbpath               | hdbpath                                                                                  |
| W              | wtype                 | window type                                                                              |
| SW             | swtype                | subtype session window                                                                   |
| dw             | dwtype                | subtype dockable window                                                                  |
| X              | integer               | integer number                                                                           |
| Y              | binary                | binary function                                                                          |
| &              | pointer               | pointer type                                                                             |

For more information, see *Cadence SKILL Language User Guide*.

1

# Virtuoso Voltage Dependent Rules Flows

Many foundry processes base the minimum spacing requirements between shapes on metal layers on the maximum voltage difference between those shapes. These minimum spacing requirements are defined in the technology file as minVoltageSpacing constraints, which can be used by design rule checkers and by interactive and automatic routers to ensure that the circuit designer's intent is maintained in the physical implementation of the design.

This document describes three voltage dependent rules (VDR) flows that help automate the process and reduce the number of costly design iterations.

■ The <u>Simulation Driven VDR Flow</u> lets the designer capture minimum and maximum voltage values on nets derived from simulation runs in Virtuoso ADE and propagate the data to the OpenAccess layout view. Because this information is stored in the OpenAccess database, it can be used by Virtuoso tools, such as design rule driven (DRD) editing or the interactive wire editor, to verify in real time that the design is DRC correct. The Virtuoso space-based router (VSR) also considers the voltage values and avoids violating the minimum spacing rules when routing the design.

You can also use this flow to automatically create voltage labels or markers in the layout view based on the values captured during a simulation. This eliminates the need to manually annotate the layout design with voltage information, lets you visualize the voltages that apply in different areas of your design, and facilitates the use of DRC signoff tools, such as the Cadence<sup>®</sup> Pegasus physical verification system or Cadence PVS, to check that design rules are being honored and that the design is correct-by-construction.

If the schematic design is changed, you can rerun the simulation to update the voltage values in the simulation datasets and update the referenced voltage data in the layout view to take account of the changes.

■ The <u>Schematic Driven VDR Flow</u> lets the circuit designer specify the required minimum and maximum voltage values as properties directly on the nets in the schematic, eliminating the need for guesswork on the part of the layout designer. The properties are saved in the OpenAccess schematic view and are transferred to the layout view using the usual Layout XL generation and update commands. Once in Layout XL, the values can be used by DRD, the interactive wire editor, and VSR as described above.

Note: You cannot use the schematic driven VDR flow to automatically create labels or

Virtuoso Voltage Dependent Rules Flows

markers from voltage values specified as schematic properties. They must first be transferred to the layout view.

■ The <u>Layout-centric VDR Flow</u> lets the layout designer set minimum and maximum voltage values as properties directly on the nets in the layout view. This data is then saved in the OpenAccess layout view and can be used by DRD, the interactive wire editor, and VSR, as described above. You can generate voltage labels or markers for all the nets at the current level of layout hierarchy or for a set of nets selected in the Navigator assistant.

# Types of VDR Labels

The minimum and maximum voltage values specified for each net are displayed in the canvas as labels attached to the in question. There are two types of VDR labels.

■ **Generic VDR labels** are generated by Virtuoso and are identified by a CDNS\_VDR\_LABEL property.

They are based on voltage data captured in simulation datasets, specified manually for nets in schematic or layout designs, or specified in a voltage information CSV file. Virtuoso reads the values from the specified source and creates labels for Vmin and Vmax values. The layer on which the label is drawn is derived from the parent net shape at create time, while the purpose is specified in the Voltage Dependent Rules form or the voltage purpose file.

During ECO, Virtuoso first deletes all existing labels and then creates a new set of labels from the updated source data.

■ Constrained VDR labels can be generated by Virtuoso, or they can be created, copied, or manually edited by the user directly in the layout view.

They are created on the layer-purpose pairs defined in a <code>voltageLabelMapping</code> constraint in a technology file constraint group specified by the <code>vdrConstraintGroupName</code> environment variable. If <code>vdrConstraintGroupName</code> is defined and the specified constraint group contains a <code>voltageLabelMapping</code> constraint for at least one layer, then the constrained label flow is automatically enabled.

During ECO, Virtuoso does not delete constrained labels, but rather updates any existing labels with new values and creates any labels that are missing.

The consistency of constrained labels can be checked using the <u>VDR Sanity Checker</u>. See <u>Sanity Checking Voltage Values in Constrained Labels</u> for information.

Virtuoso Voltage Dependent Rules Flows

The two types of labels cannot be mixed in a the same design. If constrained labels are defined for layers Metal1 through Metal5 and a generic label needs to generated by VDR for Metal6, then Virtuoso issues an error.

### **Prerequisites for the VDR Flows**

To allow DRD editing, the interactive wire editor, and Virtuoso space-based router to recognize violations of voltage dependent spacing rules, you must first specify the required minimum voltage spacing rules in the process technology file used by your design. For information, see <u>Specifying a Minimum Voltage Spacing Constraint</u>.

To create labels and markers in the layout view which can be used by Pegasus or PVS to verify the design, you must additionally specify the layer purposes on which voltage labels or markers are to be created. For more information, see <u>Specifying Layers and Purposes for Generic Voltage Labels</u> and <u>Specifying Layers and Purposes for Voltage Markers</u>.

If your process features nets the voltage of which must transition in phase with each other, you can also define *Voltage Synced Nets* constraints for the nets in question. You can then use the constraints to draw *vsync* shapes in the layout view and check them using the VDR Sanity Checker. For more information, see <u>Specifying Layers and Purposes for Synced Nets</u>.

#### **Specifying a Minimum Voltage Spacing Constraint**

The minimum spacing allowed between two wires with different voltages on the same metal layer is defined using a minVoltageSpacing constraint. The example below defines minimum voltage spacings for wire shapes on Metall and Metall:

Virtuoso Voltage Dependent Rules Flows

) ; spacing Tables

In this example, wires on Metal1

- With voltages between 0.0V and 1.8V must be spaced at least 0.38 microns apart
- With voltages between 1.8V and 3.3V must be spaced at least 0.39 microns apart
- With voltages higher than 3.3V must be spaced at least 0.4 microns apart

For detailed information, see <u>minVoltageSpacing</u> in the *Virtuoso Technology Data ASCII Files Reference*.

#### Specifying Layers and Purposes for Generic Voltage Labels

By default, voltage labels are always generated on the same layer as the shape over which they are placed, but they use a different layer purpose. All specified layers and purposes must be defined in the technology file and the LPP must be set as valid in the <u>techDisplays</u> section. If there is no valid LPP for a net on a particular layer, the label is generated on the valid layer with the lowest mask number.

You control the LPPs on which labels are drawn using the following options.

You can limit the *layers* on which labels are drawn by using the <u>vdrSetValidLayers</u> SKILL API to specify a list of valid layers for VDR label generation. The software generates labels only for nets on one of the listed layers.

**Note:** Use <u>vdrGetValidLayers</u> to see the current list of valid layers.

- You control the *purposes* on which a label is drawn by using the *High Voltage Purpose* and *Low Voltage Purpose* options on the <u>Voltage Dependent Rules</u> form. The defaults are "vlo" for minimum and "vhi" for maximum voltage labels and are set using the following environment variables:
  - vdrHighVoltagePurpose
  - □ <u>vdrLowVoltagePurpose</u>
- If your process requires greater control over the specific purpose on which a label is drawn, you can define a *Special Voltage LPP File*, which lets you override the default purpose settings on a per-layer basis.

The file is a simple text file stored at an accessible location in your file system with the format indicated below. You can specify it using the <u>vdrLayerPurposeFile</u> environment variable.

Virtuoso Voltage Dependent Rules Flows

```
#This is vdrLayerPurpose.map

#LayerName Vlow_Purpose Vhigh_Purpose

* default_low default_high
PO sp_low sp_high
OD sp_low sp_high
```

Each entry specifies a layer name and the purposes on which to draw high and low voltage labels for that layer. If the same layer is listed twice, the first entry is taken and a warning issued to indicate that subsequent mappings were ignored. If the highest priority LPP is not defined in the technology file, no label is created and an appropriate warning is issued. Wildcard ( $^*$ ), tab ( $^t$ ), and newline ( $^t$ ) characters are also supported.

See <u>Generating Voltage Labels from Simulation Data for All Nets</u> for more information on how to use the options.

#### **Specifying Layers and Purposes for Voltage Markers**

In the marker-based VDR flows, the voltage purpose file lists the layer-purpose pairs on which markers for different voltage values are to be created.

The file is a simple text file stored in an accessible location in your file system with the format indicated below. Tab ( $\t$ ) and newline ( $\n$ ) characters are also supported.

```
#This is volt_LPP.map
```

| #Layer1 | Pur     | Metal  | Voltage    |
|---------|---------|--------|------------|
| #       |         |        |            |
| HVD tes | st0     | Metal1 | <b>-</b> 5 |
| Metal1  | vlo     | Metal1 | 0.0        |
| Metal1  | dummy2  | Metal1 | 0.1        |
| Metal1  | dummy3  | Metal1 | 0.2        |
| Metal1  | dummy4  | Metal1 | 0.3        |
| Metal1  | dummy5  | Metal1 | 0.4        |
| Metal1  | dummy6  | Metal1 | 0.5        |
| Metal1  | dummy7  | Metal1 | 0.6        |
| Metal1  | dummy8  | Metal1 | 0.7        |
| Metal1  | dummy9  | Metal1 | 0.8        |
| Metal1  | dummyb  | Metal1 | 1.0        |
| Metal1  | dummya  | Metal1 | 0.9        |
| Metal1  | drawing | Metal1 | 1.5        |
| Metal1  | vhi     | Metal1 | 2.5        |

Each entry specifies the layer and purpose on which to create a marker based on the metal layer and voltage specified for the net in question. For example:

| If a net voltage is | The marker is drawn on |
|---------------------|------------------------|
| > -5.0 && <= 0.0    | Metal1 vlo             |

Virtuoso Voltage Dependent Rules Flows

| > 0.0 && <= 0.1 | Metal1 dummy2  |
|-----------------|----------------|
| > 0.1 && <= 0.2 | Metal1 dummy3  |
| > 0.9 && <= 1.5 | Metall drawing |
| > 1.5 && <= 2.5 | Metal1 vhi     |

See <u>Generating Voltage Markers from Simulation Data for All Nets</u> and <u>Generating Voltage Markers for Manually Entered Voltages</u> for information about how the file is specified and used.

#### **Specifying Layers and Purposes for Synced Nets**

Some advanced node processes feature the concept of *synchronized* (or *synced*) *nets*, for which voltage values must always transition in phase. The voltage difference that triggers a DRC violation for the synced nets is lower than in mature node processes.

The ICADVM20.1 release supports the enhanced voltage check by allowing you to tag pairs of nets as *synced* using a *Voltage Synced Nets* constraint in the schematic, and to specify in the process technology file the layer-purpose pairs on which to draw shapes for the nets in the layout view. For example:

■ To specify that the synced net delta voltage calculation should be performed for nets on a single layer (e.g., M1), use the <u>voltageLayerMarkerMapping</u> constraint to specify that shapes are drawn for synced nets on layer M1 and purpose vsync:

```
(voltageLayerMarkerMapping "M1" 'layer "M1" 'purpose "vsync" )
```

Shapes are drawn on the specified layer and purpose provided at least one of the following constraints is defined in the technology file for the layer in question:

- minCornerSpacing
- minCornerVoltageSpacing
- minSideSpacing
- □ minSpacing
- □ minVoltageSpacing
- If the synced nets in the constraint are on two different layers, you need to specify on which layer the marker should be drawn. For example, for synced nets on layers MD and PO, you can use the <a href="mailto:voltageLayerPairMarkerMapping">voltageLayerPairMarkerMapping</a> constraint to specify that markers are drawn on layer MD and purpose vsync as follows:

```
(voltageLayerPairMarkerMapping "MD" "PO" 'layer "MD" 'purpose "vsync" )
```

Virtuoso Voltage Dependent Rules Flows

Shapes are drawn on the specified layer and purpose provided at least one of the following constraints is defined in the technology file for the layer in question:

- □ minCornerSpacing (Two layers)
- minCornerVoltageSpacing (Two layers)
- □ minSideSpacing (Two layers)
- minSpacing (Two layers)
- □ minVoltageSpacing (Two layers)

See the *Virtuoso Technology Data Constraints Reference* for more information on these constraints.

You can then use the VDR synced nets flow to generate the required marker shapes in the layout view. When DRD detects shapes on the specified LPPs it automatically applies the synced delta voltage calculation for the nets in question. See <u>Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)</u> for more information.

Virtuoso Voltage Dependent Rules Flows

#### Simulation Driven VDR Flow

The simulation driven VDR flow automates the creation of voltage labels or markers in the layout by leveraging the voltage values derived from simulations run in Virtuoso ADE. The flow comprises the following steps:

- 1. Setting Up Testbenches and Corners in Virtuoso ADE
- 2. Enabling Voltage Capture in Virtuoso ADE
- 3. Running Simulations and Capturing Voltage Data
- 4. Populating Voltages and Generating Labels or Markers

For more information about how you can view voltage information in canvas info balloons, use DRD editing to report when minimum spacing rules are violated during interactive editing, and how you can write your own SKILL procedures to exclude transient spikes during simulation runs, see the following topics:

- Showing Voltage Information in Info Balloons
- Checking for Voltage Dependent Spacing Violations using DRD
- Customizing the Voltage Calculation

### **Setting Up Testbenches and Corners in Virtuoso ADE**

Open your design in Virtuoso ADE and set up tests and corners for simulation. These define a combination of variables or process models to describe a scenario in which you want to measure the performance of your design. See the following topics in the <u>Virtuoso ADE</u>

<u>Explorer User Guide</u> and <u>Virtuoso ADE Assembler User Guide</u> for more information:

- Specifying Tests and Analyses
- Working with Design Variables and Instance Parameters
- Adding Corners

When you have completed the tasks, your design is ready to run simulations in Virtuoso.

### **Enabling Voltage Capture in Virtuoso ADE**

When your testbenches and corners are in place, you need to enable voltage capture for the design under test. To do this:

Virtuoso Voltage Dependent Rules Flows

**1.** In the Virtuoso ADE window, choose *EAD* — *Setup* from the menu bar.

The **EAD Setup** form appears.



**2.** Ensure that *Enable Electrical Data Capture for EAD Flow* is selected at the top of the form.

Virtuoso Voltage Dependent Rules Flows

- **3.** Choose the required *Design Under Test* in the Design Selection group box.
- **4.** Check the *Min and Max Voltage (Vmin/Vmax)* option in the Voltage Dependent Rules group box to capture minimum and maximum voltage values during the simulation run.
  - If needed, use the *Scale* option to specify a multiplier by which the voltage data is scaled before it is transferred to the layout view. The default is 1.00, which means that voltage data is not scaled.
- **5.** Click *OK* to accept the settings and enable voltage capture.

For more information on the other options available in the EAD Setup form, see <u>The EAD Setup Form</u> and <u>Preparing the EAD Setup for Simulation</u> in the *Virtuoso Electrically Aware Design Flow Guide*.

#### **Running Simulations and Capturing Voltage Data**

After specifying the test and corner details, enabling voltage capture by EAD, and specifying any custom calculation you need, click *Run Simulation* on the Run toolbar in Virtuoso ADE to run the simulation and display the results on the Results tab. You can now view the voltage data in the results and create datasets that can be transferred and used in Layout XL. The following sections describe how to view the voltage data from the simulation results and how to create datasets that can be transferred to the layout view.

- Viewing Voltage Data
- Creating Datasets for the Voltage Data

Virtuoso Voltage Dependent Rules Flows

#### **Viewing Voltage Data**

The voltage data for the selected nets is saved in the testbench results. To view the data:

**1.** Ensure that the correct results history is loaded.



2. Select the *EAD* view on the *Results* tab of the Design Environment XL window.

The EAD view appears.

Virtuoso Voltage Dependent Rules Flows

By default, the data for the first test, first design point, and the first corner in the Virtuoso ADE results database is shown in the Results Table:



The test name, design point number, and the corner name are displayed in the title of the result tree node:



You can filter the results by changing the values in the various drop-down lists shown above the Results Table.

Virtuoso Voltage Dependent Rules Flows

For more information, see <u>Viewing the Current Data</u> in the *Virtuoso Electrically Aware Design Flow Guide*.

#### **Creating Datasets for the Voltage Data**

To reference the voltage data in the layout view, you must first save the information into voltage datasets that can be transferred to and referenced by Layout XL.

To save the voltage data in a dataset:

1. Specify a name for the dataset in the *DUT Dataset* field and click *Create*.



Virtuoso ADE creates a new dataset with the specified name and saves it in the constraint view for the design.

**Note:** If both current and voltage capture are enabled in the EAD Setup form, Virtuoso ADE creates two different datasets, one each for current measurements and voltage measurements. It appends " $_{\perp}$ " to the dataset that contains current data and " $_{\perp}$ " to the dataset that contains voltage data.

For more information on creating datasets, see <u>Creating Datasets for the Current Data</u> in the *Virtuoso Electrically Aware Design Flow Guide*.

Virtuoso Voltage Dependent Rules Flows

2. You can view the datasets for a design in the Dataset Table in the EAD results view, as shown below.



**3.** Expand the dataset to view details of the test name, corner name, voltages, temperature values, and more.

For more information, including alternative methods of viewing the contents of datasets, see <u>Viewing Datasets</u> in the *Virtuoso Electrically Aware Design Flow Guide*.

#### **Populating Voltages and Generating Labels or Markers**

To reference the datasets created during the simulation runs and generate corresponding voltage labels or markers for all the nets in the layout design, use the *Tools – Voltage Dependent Rules – Create Labels/Markers From Simulation Voltages* command.



Virtuoso Voltage Dependent Rules Flows

- Use the options in the *Simulation Datasets* and *Mode* group boxes to propagate the minimum and maximum voltages to the OpenAccess database for the layout design. This makes the voltage data available to layout editor tools such as design rule driven (DRD) editing, the interactive wire editor, and the Virtuoso space-based router, which help ensure that the minimum voltage spacing constraints defined in the technology file are honored. See Storing Voltages in the OpenAccess Database for more information.
- Use the options in the *Voltage Labels* group box to generate voltage labels for all nets in the layout design. the labels can then be used by DRC sign-off tools such as Pegasus or PVS to check that the minimum voltage spacing rules are met. See <u>Generating Voltage Labels from Simulation Data for All Nets</u> for more information.
  - Alternatively, if required by your process, you can use the options in the *Voltage Markers* group box to generate voltage markers for all nets in the layout design. See <u>Generating Voltage Markers from Simulation Data for All Nets</u> for more information.
- Use the common options at the bottom of the form to specify for which nets labels or markers are to be generated and how far down the hierarchy to search for those nets.

Virtuoso Voltage Dependent Rules Flows

#### **Storing Voltages in the OpenAccess Database**

To propagate the minimum and maximum voltage values from the datasets to the OpenAccess database for the layout design:

- 1. Open the layout design in Layout XL.
- **2.** Choose *Tools Voltage Dependent Rules Create Labels/Markers From Simulation Voltages* from the layout window menu bar.

The Voltage Dependent Rules form appears.



- (Optional) Click Update to transfer all the latest voltage dataset information from Virtuoso ADE. This is important if simulation data has changed since it was last referenced by Layout XL.
- **4.** Choose the datasets containing the data you want to use from the list.
- **5.** Choose the *Mode* you require:
  - Replace the minimum and maximum voltage values for the nets in the selected datasets. This is the default.

**Note:** Voltages are replaced only for the nets that are present in the selected datasets. All other nets are left unchanged.

Virtuoso Voltage Dependent Rules Flows

Update the minimum and maximum voltages for the nets in the selected datasets, but only if the minimum voltage value specified for the net is lower than the value currently in the design and the maximum value specified for the net is higher than the voltage currently in the design.

Use Override Manually Entered Voltages to override any voltage values that were entered manually on nets using the Property Editor assistant in VLS or VSE (and then propagated to the layout by using Generate All From Source).

**Note:** By default, the option is switched off and user-specified voltages are not overridden. The only exception is if you set both minimum and maximum voltages to 0 manually in the Property Editor assistant and then generate labels directly from the Navigator using these values. Those labels *will* be overwritten if you subsequently run the simulation-driven flow (provided the dataset you use contains values for the nets in question and even if *Override Manually Entered Voltages* is switched off).

**6.** Click *OK* to populate the minimum and maximum voltages on nets in the OpenAccess database.

You can view the voltages in the Property Editor assistant in Layout XL.



Observe that no labels or markers have been generated on the net in the layout canvas yet.

#### Generating Voltage Labels from Simulation Data for All Nets

To generate voltage labels from simulation data for all the nets in your design:

**1.** Choose *Tools – Voltage Dependent Rules – Create Labels/Markers From Simulation Voltages* to display the <u>Voltage Dependent Rules</u> form appears.

Virtuoso Voltage Dependent Rules Flows

**2.** Select the datasets and mode as described in <u>Storing Voltages in the OpenAccess</u> Database.



Virtuoso Voltage Dependent Rules Flows

- **3.** Check the *Generate Voltage Labels* box to enable the controls in the *Voltage Labels* group box.
- 4. Set the layer purposes on which the voltage labels are to be drawn.

Specify a *Special Voltage LPP File* if you require greater control over the purposes on which labels are drawn.

- **5.** Specify the nets for which labels are to be generated. Choose between:
  - External and Internal Nets to generate labels for all nets (the default).
  - □ External Nets Only to generate labels only for nets that are connected to the terminals of the cellview to which they belong.
  - ☐ Internal Nets Only to generate labels only for nets that are internal to the cellview in which they belong.
- **6.** Specify how many hierarchy levels to search for nets on which to generate labels.

The default is 0, which means that labels are generated only for top-level nets only; 1 means top-level nets and nets located one level below in the hierarchy; and so on.

**7.** Specify the size of the labels to be generated.

Type 0.0 to automatically size labels to match the height of the shape to which they are attached.

**8.** Click *OK* to generate the specified labels.

Virtuoso Voltage Dependent Rules Flows

The voltage labels for the specified nets are added in the layout canvas, with the maximum value above and the minimum value underneath it; for example:



Label generation depends on the *Mode* setting.

- □ In *Replace* mode, all voltage labels are replaced for the nets in the datasets.
- □ In *Update* mode:
  - O Minimum voltages are updated only if the existing label shows a higher voltage.
  - O Maximum voltages are updated only if the existing label shows a lower voltage.

#### Note:

- □ Labels are generated for a net only if geometry exists on that net. The software does not consider geometry inside parameterized cells.
- □ Labels are also generated for the individual bits of bus nets.

**Note:** Enable the <u>preserveImplicitNetVoltages</u> environment variable to ensure that voltage values on bus bits are preserved throughout the flow.

```
envSetVal("schematic" "preserveImplicitNetVoltages" 'boolean t)
```

Mosaics are not supported.

Virtuoso Voltage Dependent Rules Flows

#### Generating Voltage Labels from a Voltage Information File

As an alternative to using a simulation dataset, you can specify a text file with commaseparated values as an input for label generation. If the same net is listed multiple times in the file, the generated labels reflect the highest maximum and lowest minimum values specified for that net.

**Note:** This feature is available only through the <u>vdrCreateVoltageLabel</u> and <u>vdrCreateVoltageLabelEx</u> SKILL functions. There is no GUI equivalent.

The following command runs label generation in *Replace* mode for only the top-level nets in the current cellview. Voltage values are taken from a CSV file called <code>voltages.csv</code>, and labels are drawn on purpose <code>drawing</code>. The code then automatically executes a user-defined callback named <code>\_myPostVdrCB</code> to perform some post-processing tasks.

```
vdrCreateVoltageLabel(geGetEditCellView() nil "drawing" "drawing" 0.0 t nil
nil t nil 0 " myPostVdrCB" "./voltages.csv")
```

The format of the voltage information file is illustrated below.

```
#Net, minV, maxV
#All comments start with '#'
#Top-level Nets
AVDD, 1.0,
                     1.5
net15,
              -10,
                     10
net57,
             1.4,
#Wildcard * is supported,
V*, 0.4, 0.5
|I1/*,
              -1.0,
#Hierarchical Nets
#Full hierarchical path must be specified with '/' as delimiter.
A0/A1/net31, 0.7,
|I2/VDD,
             -2.0,
                      2.0
|IO/OUT,
              -3.0, 3.0
#Bus Nets
|I0/VSS<1:5>, -4.0,
                     4.0
#Bit Nets
|10/VSS1<10>, -4.0,
                      4.0
```

### Generating Voltage Markers from Simulation Data for All Nets

To generate voltage markers from simulation data for all the nets in your design:

1. Choose Tools – Voltage Dependent Rules – Create Labels/Markers From Simulation Voltages from the layout window menu bar (or type vdrGenerateLabelsGUI() in the CIW).

Virtuoso Voltage Dependent Rules Flows

The Voltage Dependent Rules form appears.

**2.** Select the datasets and mode as described in <u>Storing Voltages in the OpenAccess Database</u>.



- **3.** Check the *Generate Voltage Markers* box to enable the controls in the *Voltage Markers* group box.
- **4.** Specify the location of the *Voltage Purpose File*, which lists the layer-purpose pairs on which markers for different voltage values are to be created. See <u>Specifying Layers and Purposes for Voltage Markers</u> for more information.
- 5. Choose whether markers are to be created for maximum, minimum, or all voltage values.
- **6.** Choose the rounding rule to follow for voltage values.
  - roundOff rounds the voltage value to the nearest 0.01 (the default)
  - ceiling rounds up the voltage value to the nearest 0.01
  - floor rounds down the voltage value to the nearest 0.01
- **7.** Specify the nets for which markers are to be generated. Choose between:
  - □ External and Internal Nets to generate labels for all nets (the default)
  - □ External Nets Only to generate labels only for nets that are connected to the terminals of the cellview to which they belong

Virtuoso Voltage Dependent Rules Flows

- ☐ Internal Nets Only to generate labels only for nets that are completely internal to the cellview in which they belong
- 8. Specify how many hierarchy levels to search for nets on which to generate markers.
- **9.** Click *OK* to generate the specified markers.

The voltage markers for the specified nets are added in the layout canvas. See <u>Showing Voltage Information in Info Balloons</u> to learn how to view information about each marker.



Marker generation depends on the *Mode* setting.

- ☐ In *Replace* mode, all voltage markers are replaced for the nets in the datasets.
- □ In *Update* mode, minimum voltages are updated only if the existing marker shows a higher voltage; maximum voltages are updated only if the existing marker shows a lower voltage.

Virtuoso Voltage Dependent Rules Flows

## **Showing Voltage Information in Info Balloons**

You can use the layout editor's *Show Info Balloon* feature to see voltage information when you move the mouse pointer over nets in the layout canvas. To do this:

- **1.** From the layout window menu bar, choose *Options Dynamic Display* and enable *Show Info Balloon* at the top of the form.
- **2.** Make sure the *MinMaxVoltages* option is selected (this is the default) in the *Contents* pane and click *OK*.



Virtuoso Voltage Dependent Rules Flows

**3.** Move the mouse pointer over a net in your design to see an info balloon containing the voltage information for the highlighted net.



4. Move the pointer over a different net.

The original info balloon disappears and a new one opens containing information on the new net.

Virtuoso Voltage Dependent Rules Flows

## **Checking for Voltage Dependent Spacing Violations using DRD**

You can use Layout Editor features such as DRD editing to check for and report any minimum voltage spacing violations as you edit your design. To do this:

- Choose Options DRD Edit from the layout window menu bar.
   The DRD Options form appears.
- 2. Set *Notify* to display interactive notifications of violations as they occur.



If you violate the minimum voltage spacing rules during interactive editing, the system provides immediate visual feedback on the layout canvas.

Virtuoso Voltage Dependent Rules Flows

**3.** Set *Post-Edit* to see violation markers on the canvas and Annotation Browser assistant after you have finished editing.



For detailed information on design rule driven layout editing, see the <u>Virtuoso Design Rule Driven Editing User Guide</u>.

## **Customizing the Voltage Calculation**

Voltage values captured during a transient simulation can sometimes contain short pulses (spikes) that distort the final result. You can exclude these spikes from the final voltage calculation by writing your own custom SKILL procedures to perform the required filtering operations on the voltage waveforms before the minimum and maximum voltage values are extracted. To do this:

Virtuoso Voltage Dependent Rules Flows

**1.** Write two custom SKILL procedures, one for the calculation of Vmax and one for the calculation of Vmin, which define the filtering you need.

The basic structure of the procedures is as indicated below:

**2.** Assign the custom SKILL procedures to the environment variables indicated below by typing the following in the CIW:

```
envSetVal("elec.gui" "customVmaxCalc" 'string "My_VMax")
envSetVal("elec.gui" "customVminCalc" 'string "My VMin")
```

For details of these variables, see <u>customVmaxCalc</u> and <u>customVminCalc</u> in the *Virtuoso Electrically Aware Design Flow Guide*.

**3.** Switch on the custom voltage calculation feature by typing the following in the CIW:

```
envSetVal("elec.gui" "enableCustomVminVmaxCalc" 'boolean t)
```

For details of this variable, see <a href="mailto:enableCustomVminVmaxCalc">enableCustomVminVmaxCalc</a> in the Virtuoso Electrically Aware Design Flow Guide.

4. Run a transient simulation with voltage capture enabled in the EAD Setup form.

Virtuoso replaces the standard voltage calculation with the procedures defined in the custom SKILL procedures.

## **Schematic Driven VDR Flow**

You can also populate the OpenAccess database for your layout design with voltage data by manually entering the minimum and maximum voltages as properties on the nets in the schematic.

When you generate or update your layout view from the schematic, the voltage values are propagated to the layout design and made available to DRD editing, the interactive wire editor, and the Virtuoso space-based router, which you can use to ensure that the minimum voltage spacing constraints defined in the technology file are honored.

## **Propagating Voltage Values from Schematic to Layout**

To define voltage values in the schematic and propagate them to the layout view:

**1.** Launch Layout XL and open the schematic view in the Virtuoso Schematic Editor.



- **2.** Select the net you require in the Navigator assistant.
- **3.** Type the *Min Voltage* and *Max Voltage* values into the Property Editor assistant.
- **4.** Choose *File Save* to save the schematic the do one of the following,
  - To create a new layout, choose *Connectivity Generate All From Source* from the layout window menu bar.

Virtuoso Voltage Dependent Rules Flows

☐ To update an existing layout, see <u>Updating Voltage Values in the Layout to Match the</u> Schematic.

The layout view is created or updated and the new minimum and maximum voltage values are transferred from the schematic nets to the layout nets.



Layout editor tools such as DRD, the interactive wire editor, and VSR consider the voltages when checking that minimum voltage spacing constraints defined in the technology file are not being violated. See <u>Specifying a Minimum Voltage Spacing Constraint</u> for more information.

For information on how to generate labels or markers for these values, see

- Generating Voltage Labels for Manually Entered Voltages
- ☐ Generating Voltage Markers for Manually Entered Voltages

Virtuoso Voltage Dependent Rules Flows

#### Checking Voltage Values between Schematic and Layout

You can use the Layout XL *Check Against Source* command to ensure that the voltage values specified in the schematic match those in the corresponding layout:

- 1. In the layout window menu bar, select Connectivity Check Against Source.
- **2.** Make sure the *Connectivity* option is selected in the Check Against Source form and then click *OK*.



Layout XL checks the schematic against the layout and reports any mismatches found:



## **Updating Voltage Values in the Layout to Match the Schematic**

To update the values in the layout to match those in the schematic:

**1.** Choose *Connectivity – Update – Components And Nets* from the layout window menu bar.

Virtuoso Voltage Dependent Rules Flows

**2.** Ensure the *Update Net MinV/MaxV* option is selected, and click *OK*.



The layout view is updated with the minimum and maximum voltage values from the schematic nets and any existing voltage labels for that net in the layout canvas are updated automatically.

**Note:** The *Update Net MinV/MaxV* option is switched on by default. To switch it off by default, set the <u>updateNetMinMaxVoltage</u> environment variable to nil in your .cdsenv file.

#### **Backannotating Voltage Values from Layout to Schematic**

When working on the physical implementation of your design in Layout XL, it might be necessary to update the voltage values for certain nets to meet specific design requirements. To update the voltage values in the schematic to match those in the layout:

Choose Connectivity – Back Annotate – Net MinV/MaxV from the layout window menu bar.

Layout XL backannotates the minimum and maximum voltage values for all the top-level nets in the layout to the corresponding nets in the schematic.

**Note:** When backannotating voltage values for buses, provided you have set the same minV/ maxV value pair for all the bits of a given bus in the layout, backannotation will be performed to the corresponding schematic bus.

If you have set different minV/maxV value pairs on the different bits of a layout bus and the corresponding schematic bus is not expanded, then Layout XL takes the highest maximum voltage value and the lowest minimum voltage value across all the bits of the layout bus and backannotates that minV/maxV value pair to the corresponding unexpanded bus in the schematic.

#### Sanity Checking Voltage Values in Constrained Labels

You can use the VDR Sanity Checker to check constrained VDR voltage labels in the layout view against the values stored in the schematic or layout net properties and report any discrepancies between them. Missing labels, labels with value differences greater than a specified tolerance, and multiple labels with different values on a single net are reported either in a user-specified log file or printed in the CIW and listed in the Annotation Browser.

**Note:** In ICADVM20.1 Layout EXL, you can additionally check that vsync shapes in the layout canvas all have a corresponding *Voltage Synced Nets* constraint in the layout view. See Checking Synced Nets in the Layout View (ICADVM20.1 EXL Only) for more information.

The constrained VDR label sanity check flow is illustrated below.



Virtuoso Voltage Dependent Rules Flows

#### **Establishing the Net Association**

The label-net association for constrained labels is established by searching the design for a net shape that overlaps the label shape in question.

- If a net shape is found at the top level, Virtuoso reads the net name from that shape.
- If no net shape is found at the top level, Virtuoso traverses the hierarchy to establish if there is an underlying terminal or pin shape inside the instance and, if so, makes the association to the top-level net connected to that terminal or pin shape.
- If a non-terminal/non-pin net shape is found one level down the hierarchy, or any net shape is found at two or more levels down the hierarchy, the label is ignored on the assumption that it is intended for some hierarchical net.
- If no overlapping net shape is found in the design, including cases where the label is created on a via layer and does not overlap any net, the label is tagged as floating.

#### **Types of Violations**

| Туре                | Description                                                                                                                                                    | Notes                                                                                                                                                                                                                                     |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No Vmax label       | There is a maximum voltage defined for a net in the design but no corresponding label drawn on the canvas.                                                     | Although the sanity checker expects only one label each for Vmax and Vmin for each net, multiple Vmax or Vmin labels on a net are treated as a single label provided the values are the same. Markers are drawn on one of the net shapes. |
| No Vmin label       | There is a minimum voltage defined for a net in the design but no corresponding label drawn on the canvas.                                                     |                                                                                                                                                                                                                                           |
| Vmax label mismatch | The maximum voltage value in<br>the label is different from the<br>value specified in the design.                                                              | For both mismatch violations, the values are first rounded to two decimal places and the specified tolerance applied.  Markers are drawn on the label in question.                                                                        |
| Vmin label mismatch | The minimum voltage value in<br>the label is different from the<br>value specified in the design.                                                              |                                                                                                                                                                                                                                           |
| Floating label      | If a label does not overlap any net or instance or the instance terminal is missing and no net association is possible, the label is a <i>floating label</i> . | Markers for these violations are drawn on the label in question.                                                                                                                                                                          |

Virtuoso Voltage Dependent Rules Flows

#### Performing a Label Sanity Check

To perform a sanity check of constrained VDR labels:

- 1. Specify the <u>vdrConstraintGroupName</u> environment variable before you launch Virtuoso.
  - The specified constraint group must contain a valid voltageLabelMapping constraint to specify the layer-purpose pair on which labels are drawn.
- **2.** Choose *Tools Voltage Dependent Rule Sanity Checker* from the layout window menu bar.

The VDR Sanity Checker form appears.



- 3. Specify whether to check against the voltage values stored in the schematic or layout.
- 4. Specify a tolerance within which any differences are ignored.

You can also specify whether the tolerance value is absolute or relative to the voltage.

**5.** Specify whether the results are to be captured in a text file and click *OK* to perform the sanity check.

When you capture the results in a log file, only a summary message is printed in the CIW. If you do not specify a log file, discrepancies are reported in a table printed in the CIW. In both cases, the format is similar to that shown below. Values are rounded to two decimal places before comparison.

| NetName        | Net Voltage Values (Vmin) (Vmax) | Label Voltage Values (Vmin) (Vmax) |  |
|----------------|----------------------------------|------------------------------------|--|
| net15<br>net14 | (-0.05) (1.57)<br>(1.25) (2.56)  | (0.05) (1.75)<br>(1.15) (2.35)     |  |

Virtuoso Voltage Dependent Rules Flows

Corresponding markers are drawn on the canvas and entries displayed on the *Misc* tab in the Annotation Browser assistant. When you select a violation in the assistant, Virtuoso zooms to the marker in question on the canvas.





You can also run the sanity check procedurally using the <u>vdrRunSanityChecker</u> SKILL API.

When analyzing sanity checker output, keep the following in mind:

- Zero Voltage Nets specified by the user during label generation are ignored by the sanity checker provided there are either no labels at all on the specified net or both Vmin and Vmax values are set to 0. If one or both values is nonzero, or the number of labels is other than 0 or 2, the sanity checker reports an error.
- Where there is no geometry for a net on the canvas, and labels have been generated on all the Pcell and instance terminals connected to the net, there could be multiple discrepancies related to incorrect numbers of labels or label mismatches. The sanity checker reports such discrepancies in terms of both instance name and net name to allow them to be easily identified.

Virtuoso Voltage Dependent Rules Flows

#### Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Some processes feature the concept of *synced nets*, the voltages of which must always transition in phase with each other. The voltage difference that triggers a DRC violation for synced nets is much lower than in conventional processes. To support the enhanced voltage check, you can:

- 1. Define *Voltage Synced Nets* constraints in the schematic for the nets whose voltages must transition in phase.
- 2. Generate vsync shapes connecting these synced nets in the layout view.
- **3.** Use the VDR Sanity Checker to check that the vsync shapes match the constraints in the layout.

**Note:** This functionality is available only in Layout EXL when the <u>vdrConstraintGroupName</u> environment variable is set.

## Creating a Voltage Synced Nets Constraint By Using the Constraint Manager (ICADVM20.1 EXL Only)

To create a *Voltage Synced Nets* constraint using the Constraint Manager:

- **1.** Select the pair of nets to be tagged as synced in the schematic Navigator assistant.
- **2.** In the Constraint Manager assistant, choose *Voltage Synced Nets* from the toolbar:



Virtuoso Voltage Dependent Rules Flows

The *Voltage Synced Nets* constraint is created on the selected nets.



See <u>Voltage Synced Nets</u> in the *Virtuoso Unified Custom Constraints* for more information about the constraint.

#### Creating Voltage Synced Nets Constraints from a File (ICADVM20.1 EXL Only)

You can also create *Voltage Synced Nets* constraints from a comma-separated file capturing the nets to be constrained and the minimum and maximum voltages for those nets. Each line in the file creates a Voltage Synced Nets constraint with members as defined by the comma-separated nets captured in that line. To do this:

**1.** Choose *Tools – Voltage Dependent Rules – VSync Visualizer* from the layout window menu bar.

The VSync Constraints Visualizer form appears.



Virtuoso Voltage Dependent Rules Flows

- **2.** Browse to the location of the file you require and click *Create* to create constraints from the information in that file.
- **3.** (Optional) Click *Refresh* to update the list of voltage synced nets currently in the design.
- **4.** (Optional) Click *Delete* to remove the selected voltage synced nets from the design.



You can perform the same operation procedurally using the <a href="https://www.vdrCreateVSyncConstraintsFromFile">vdrCreateVSyncConstraintsFromFile</a> SKILL API.

#### Generating Vsync Shapes in the Layout View (ICADVM20.1 EXL Only)

To generate vsync shapes in the layout view:

→ Choose *Tools – Voltage Dependent Rules – Create VSync Shapes* from the layout window menu bar.



**Note:** If the <u>vdrConstraintGroupName</u> environment variable is not set, the menu item is grayed out.

Virtuoso removes all existing vsync shapes created by the tool and generates one vsync shape for each pair of nets tagged in a *Voltage Synced Nets* constraint in the layout view.

- □ For pairs of nets on the *same layer*, the vsync shapes are created on the layer and purpose defined in the <u>voltageLayerMarkerMapping</u> technology file constraint.
- For pairs of nets on different layers, the vsync shapes are created on the layers and purposes defined in the voltageLayerPairMarkerMapping technology file constraint.

Virtuoso Voltage Dependent Rules Flows

☐ If there are multiple possible layers on which the shapes could be created, the vsync shapes are created on the lowest layer to preserve routing resources on higher metal layers.

See Specifying Layers and Purposes for Synced Nets for more information.

#### Checking Synced Nets in the Layout View (ICADVM20.1 EXL Only)

You can use the VDR Sanity Checker to check that each vsync shape on the canvas corresponds to a *Voltage Synced Nets* constraint in the layout.

**Note:** The sanity checker checks vsync shapes against constraints in the layout view, not in the schematic, so you must first ensure that *Voltage Synced Nets* constraints defined in the schematic are current in the layout view.

#### To do this:

- **1.** In the layout window, choose *Connectivity Update Layout Constraints* to transfer the constraints from the schematic view to the layout view.
- 2. Choose *Tools Voltage Dependent Rules Sanity Checker* from the layout window menu bar.

The VDR Sanity Checker appears.



**3.** Select the *Check VSync Shapes* radio button and specify whether the results are to be captured in a text file.

**Note:** If the vdrConstraintGroupName environment variable is not set, the menu item is grayed out.

Virtuoso Voltage Dependent Rules Flows

When you capture the results in a log file, only a summary message is printed in the CIW. If you do not specify a log file, discrepancies are reported in a table printed in the CIW.

**4.** Click *OK* to check the vsync shapes in the design.

Two types of errors are reported:

- □ Vsync shapes with no corresponding *Voltage Synced Nets* constraint in the layout.

  Markers for this violation type are created on the vsync shape in the layout view. The text report prints the bounding box of the vsync shape.
- □ A *Voltage Synced Nets* constraint exists in the layout, but there is no corresponding vsync shape.

Markers for this violation type are created on the corresponding cell to reduce visual clutter on the canvas. The description in the Annotation Browser provides the names of the nets in the constraint. The text report captures the constraint name and its member nets.

## Layout-centric VDR Flow

You can also enter voltage values directly in the layout editor Property Editor assistant. The voltage values are made available to layout features such as DRD editing, the interactive wire editor, and the Virtuoso space-based router. You can then generate voltage labels or markers for all the nets at the current level of layout hierarchy, or for a set of nets selected in the Navigator assistant.

#### **Entering Voltage Values in the Property Editor Assistant**

To enter minimum and maximum voltage values for a net directly in the Property Editor assistant:

- Open the layout design in Layout XL and open the Navigator and Property Editor assistants.
- 2. Select the net you require in the Navigator assistant.
- **3.** Type the *Min Voltage* and *Max Voltage* values into the Property Editor assistant.



**Note:** If there are already voltage labels or markers for that net visible on the canvas, the values are automatically updated. If there are no labels or markers for that net, see <u>Generating Voltage Labels for Manually Entered Voltages</u> or <u>Generating Voltage Markers for Manually Entered Voltages</u> for information on how to create them.

**4.** Choose *File – Save* to save the layout view.

Virtuoso Voltage Dependent Rules Flows

Layout editor tools such as DRD, the interactive wire editor, and VSR consider the voltages when checking that minimum voltage spacing constraints defined in the technology file are not being violated.

See Specifying a Minimum Voltage Spacing Constraint for more information.

#### Generating Voltage Labels for Manually Entered Voltages

- Generating Labels on All Nets
- Generating Labels on Selected Nets

#### **Generating Labels on All Nets**

To generate labels for manually entered voltage values on all the nets at the current level of layout hierarchy:

**1.** Choose *Tools – Voltage Dependent Rules – Create Labels/Markers From Net Voltages* from the layout window menu bar.

The condensed <u>Voltage Dependent Rules</u> form appears containing only the options required for label and marker generation.



Virtuoso Voltage Dependent Rules Flows

2. Set the layer purpose and size options as required.

Specify a *Special Voltage LPP File* if you require greater control over the purposes on which labels are drawn.

**3.** List the *Zero Voltage Nets* for which labels should be generated.

By default, the field lists the nets in the design that have (0,0) voltage values and signal type ground.

**4.** Click *OK* to generate voltage labels for all the nets at the current level of layout hierarchy.

The labels are generated on the geometry of the net in question. Where there is no geometry for that net on the canvas, the labels are generated on all the Pcell and instance terminals connected to the net (where such connectivity information exists).

## **Important**

If you subsequently generate labels from simulation data, you must switch off the *Override Manually Entered Voltages* option to prevent these labels from being overwritten.

Note, however, that if you manually set both minimum and maximum voltages to 0 in the Property Editor assistant and then generate labels using these values, those labels *will* always be overwritten if you subsequently run the simulation-driven flow (provided the dataset you use contains values for the nets in question).

See <u>Populating Voltages and Generating Labels or Markers</u> for more information on the *Override Manually Entered Voltages* option.

Virtuoso Voltage Dependent Rules Flows

#### **Generating Labels on Selected Nets**

To generate labels for manually entered voltage values on selected nets in the design:

- 1. In the Navigator assistant, select the nets for which you want to generate voltage labels.
- **2.** Right-click, and choose *Create Voltage Labels/Markers*.



- **3.** The truncated version of the <u>Voltage Dependent Rules</u> form appears.
- **4.** Set the layer purpose and size options as required.

Specify a *Special Voltage LPP File* if you require greater control over the purposes on which labels are drawn.

**5.** List any *Zero Voltage Nets* for which labels should be generated.

By default, the field lists the nets in the selected set that have (0,0) voltage values and signal type ground.

Virtuoso Voltage Dependent Rules Flows

**6.** Click *OK* to create voltage labels for the selected nets in the layout canvas in line with the values shown in the Property Editor assistant.

The labels are generated on the geometry of the net in question. Where there is no geometry for that net on the canvas, the labels are generated on all the Pcell and instance terminals connected to the net (where such connectivity information exists).

## **Important**

If you subsequently generate labels from simulation data, you must switch off the *Override Manually Entered Voltages* option to prevent these labels from being overwritten.

Note, however, that if you manually set both minimum and maximum voltages to 0 in the Property Editor assistant and then generate labels using these values, those labels *will* always be overwritten if you subsequently run the simulation-driven flow (provided the dataset you use contains values for the nets in question).

See <u>Populating Voltages and Generating Labels or Markers</u> for more information on the *Override Manually Entered Voltages* option.

You can also perform the same task programmatically by using the <u>vdrCreateVoltageLabelOnNets</u> SKILL function.

Virtuoso Voltage Dependent Rules Flows

## Viewing Voltage Labels in the Layout View

To view the voltage labels on a top-level net:

**1.** In the Navigator assistant, right-click to select the net and choose *Zoom To Voltage Labels/Markers*.



Virtuoso Voltage Dependent Rules Flows

Layout XL zooms to the voltage labels on the selected net.



**Note:** Zoom to Voltage Labels/Markers works only for labels and markers on toplevel nets. You cannot zoom to labels that have been generated on Pcell or instance terminals further down the hierarchy.

## **Checking Voltage Labels in the Layout View**

You can use the <u>vdrCheckVoltageLabels</u> SKILL function to verify that all top-level nets in the specified layout cellview are correctly labeled on the canvas.

**Note:** There is no GUI equivalent for this function.

Virtuoso Voltage Dependent Rules Flows

#### Generating Voltage Markers for Manually Entered Voltages

Some processes, especially at advanced nodes, require voltage markers to be present on predefined layers in the design. You can use the VDR layout-centric flow to create markers for all the nets at the current level of layout hierarchy, or for a set of nets selected in the Navigator assistant.

- Generating Markers on All Nets
- Generating Markers on Selected Nets

#### **Generating Markers on All Nets**

To generate markers for manually entered voltage values on all the nets at the current level of layout hierarchy:

**1.** Choose *Tools – Voltage Dependent Rules – Create Labels/Markers From Net Voltages* from the layout window menu bar.

The truncated version of the Voltage Dependent Rules form appears.



Virtuoso Voltage Dependent Rules Flows

2. Check the *Generate Voltage Markers* box to enable the controls in the *Voltage Markers from Net Voltages* group box.

The *Voltage Labels* options are automatically disabled.

**3.** Specify the *Voltage Purpose File*, which lists the layer-purpose pairs on which markers for different voltage values are to be created.

See Specifying Layers and Purposes for Voltage Markers for more information.

- **4.** Choose whether markers are to be created for maximum, minimum, or all voltage values.
- **5.** Choose the rounding rule to follow for voltage values.
  - □ roundOff rounds the voltage value to the nearest 0.01 (the default)
  - ceiling rounds up the voltage value to the nearest 0.01
  - floor rounds down the voltage value to the nearest 0.01
- **6.** Change the *Size* setting if required.

**Note:** If you set the size to 0.0, no marker is generated.

**7.** List the *Zero Voltage Nets* for which markers should be generated.

By default, the field lists the nets in the design that have (0,0) voltage values and signal type ground.

**8.** Click *OK* to generate voltage markers for all the nets at the current level of layout hierarchy.

The markers are generated on the geometry of the net in question.

#### **Generating Markers on Selected Nets**

To generate markers for manually entered voltage values on selected nets in the design:

- 1. In the Navigator assistant, select the nets for which you want to generate voltage labels.
- 2. Right-click, and choose *Create Voltage Labels/Markers*.

The truncated version of the <u>Voltage Dependent Rules</u> form appears.

- **3.** Check the *Generate Voltage Markers* box to enable the controls in the *Voltage Markers from Net Voltages* group box.
- **4.** Specify the *Voltage Purpose File*, which lists the layer-purpose pairs on which markers for different voltage values are to be created. See <u>Specifying Layers and Purposes for Voltage Markers for more information</u>.

Virtuoso Voltage Dependent Rules Flows

- **5.** Choose whether markers are to be created for maximum, minimum, or all voltage values.
- **6.** Choose the rounding rule to follow for voltage values.
  - □ roundOff rounds the voltage value to the nearest 0.01 (the default)
  - ceiling rounds up the voltage value to the nearest 0.01
  - floor rounds down the voltage value to the nearest 0.01
- **7.** Change the *Size* setting if required.

**Note:** If you set the size to 0.0, no marker is generated.

**8.** List the *Zero Voltage Nets* for which markers should be generated.

By default, the field lists the nets in the design that have (0,0) voltage values and signal type ground.

**9.** Click *OK* to generate voltage markers for the selected nets at the current level of layout hierarchy.

The markers are generated on the geometry of the net in question.

You can also perform the same task programmatically by using the <u>vdrCreateVoltageMarkersOnNets</u> SKILL function.

## **Post-Processing Voltage Labels and Markers**

You can use the <u>vdrPostLabelCreationCallback</u> environment variable to specify a custom SKILL callback that can be set to perform any required post-processing tasks on VDR-generated labels. The specified callback must accept a cellview ID as an argument and is run automatically after label generation is complete.

For example, the callback shown below collects all the labels generated by the VDR flow in the specified cellview and creates a property to link them to a dataset called dataset1.

Virtuoso Voltage Dependent Rules Flows

To modify the callback to post-process marker objects instead of labels, change the objType to "rect".

You can also specify the callback function name as an optional argument when using the <u>vdrCreateVoltageLabel</u> and <u>vdrCreateVoltageMarkers</u> SKILL functions.

**Note:** There is no GUI equivalent for this feature.

## **Deleting Voltage Labels and Markers**

To delete all the labels and markers generated by the voltage dependent rules flows, do one of the following:

- Choose *Tools Voltage Dependent Rules Delete Labels/Markers* from the layout window menu bar
- Call the vdrDeleteLabels SKILL function

# Virtuoso Voltage Dependent Rules Flow Guide Virtuoso Voltage Dependent Rules Flows

A

# **Voltage Dependent Rules Forms**

The following forms are used in the voltage dependent rules flows.

- EAD Setup
- VDR Dataset
- VDR Sanity Checker
- Voltage Dependent Rules
- Voltage Dependent Rules (from net voltages)
- VSync Constraints Visualizer

Voltage Dependent Rules Forms

## **EAD Setup**

Use the **EAD Setup** form to enable EAD mode, specify the design under test, and enable voltage capture in Virtuoso ADE.

**Note:** The other controls on the form relate to the Virtuoso Electrically Aware Design flow. For more information, see <u>The EAD Setup Form</u> in the *Virtuoso Electrically Aware Design Flow Guide*.

#### **Related Topics**

Enabling Voltage Capture in Virtuoso ADE

Simulation Driven VDR Flow

Voltage Dependent Rules Forms

#### **VDR Dataset**

Use the **VDR Dataset** form to view, refresh, and delete voltage information derived from simulation datasets and CSV datasets. The form lists the nets in each dataset and the minimum and maximum voltages allowed for each net. You can also create a new CSV dataset from an existing CSV file.

For more information, see <u>Working with VDR Datasets</u> in the *Virtuoso Electrically Aware Design Flow Guide*.

## Related Topics

Simulation Driven VDR Flow

Voltage Dependent Rules Forms

## VDR Sanity Checker

Use the **VDR Sanity Checker** form to check constrained VDR voltage labels in the layout view and report any labels that are missing or which have values different from the values specified for the net in the schematic or layout design. In ICADVM20.1 Layout EXL, you can also check that vsync shapes in the layout canvas all have a corresponding *Voltage Synced Nets* constraint in the layout view.

**Note:** The form is available only if the <u>vdrConstraintGroupName</u> environment variable is set. This environment variable also enables the constrained VDR label flow.

**Check Labels** runs the sanity checker on voltage values printed as labels in the layout view. Environment variable: <a href="https://drsanityCheckerObjectType"><u>vdrSanityCheckerObjectType</u></a>

**Check VSync Shapes** runs the sanity check on vsync shapes in the layout view (ICADVM20.1 EXL Only).

Environment variable: <a href="https://www.vdr.sanityCheckerObjectType">vdrSanityCheckerObjectType</a>

Check Against Schematic or Check Against Layout specifies whether to check the voltage values against layout net properties or schematic net properties. Environment variable: <a href="https://dream.nitycheckerCheckAgainst"><u>vdrSanityCheckerCheckAgainst</u></a>

**Tolerance** specifies the threshold beyond which voltage mismatches are to be reported.

- *Absolute* specifies that the tolerance value is an absolute value
- *Relative* specifies that the value is a relative percentage based on the net voltage.

Environment variables: <u>vdrSanitvCheckerTolerance</u> and <u>vdrSanitvCheckerToleranceType</u>

#### Related Topics

Sanity Checking Voltage Values in Constrained Labels

Performing a Label Sanity Check

Voltage Dependent Rules Forms

### **Voltage Dependent Rules**

Use the **Voltage Dependent Rules** form to bring voltage data from Virtuoso ADE into the OpenAccess layout view and generate labels or markers for the minimum and maximum voltages in the layout canvas.

**Simulation Datasets** lets you choose one or more voltage datasets containing the maximum and minimum values you want to reference in your layout design. If required, click *Update* to retrieve the latest versions of the listed voltage datasets from Virtuoso ADE.

#### Mode

**Replace** specifies that the voltage values for the nets in the selected datasets are to be replaced in the layout design. This is the default. Voltages are replaced **only** for the nets listed in the selected datasets.

**Update** specifies that the voltage values for the nets in the selected datasets are to be updated in the layout design, but only if

- ☐ The minimum voltage value specified for a net is lower than the voltage value (database or label) currently in the layout design
- The maximum voltage value specified for a net is higher than the voltage value (database or label) currently in the layout design

**Override Manually Entered Voltages** specifies that any manually entered voltage values on nets are overridden by the values from the simulation datasets.

## **Important**

Manually-entered values are values entered on nets using the Property Editor assistant in VLS (or in VSE and then propagated to the layout using *Generate All From Source*). By default, these values are not overridden. The only exception is if you set both minimum and maximum voltages to 0 manually in the Property Editor assistant and then generate labels directly from the Navigator using these values. Those labels will be overwritten if you subsequently run the simulation-driven flow (provided the dataset you use contains values for the nets in question and even if *Override Manually Entered Voltages* is switched off).

#### **Voltage Labels**

**Generate Voltage Labels** creates labels on nets based on the settings specified in the group box at the bottom of the form. When you check the box, *Generate Voltage Markers* is automatically disabled.

Environment variable: vdrGenerateLabels

Voltage Dependent Rules Forms

In *Replace* mode, all voltage labels are replaced for the nets in the selected datasets. In *Update* mode:

- Minimum voltages are updated only if an existing label shows a higher voltage than the corresponding value in the selected datasets
- Maximum voltages are updated only if the existing label shows a lower voltage than the corresponding value in the selected datasets

Labels for lower-level cells are generated at the current level of hierarchy. Layout XL updates only system-generated labels; user-generated labels are left untouched.

**Low Voltage Purpose** specifies the layer purpose to use for minimum voltage labels. The default is v1o.

Environment variable: <a href="https://www.voltagePurpose">vdrLowVoltagePurpose</a>

**High Voltage Purpose** specifies the layer purpose to use for maximum voltage labels. The default is vhi.

Environment variable: vdrHighVoltagePurpose

**Special Voltage LPP File** is a text file that can be used to override the default *High Voltage Purpose* and *Low Voltage Purpose* settings if your process requires it. See <u>Specifying Layers and Purposes for Generic Voltage Labels</u> for more information. Environment variable: <u>vdrLayerPurposeFile</u>

#### **Voltage Markers**

**Generate Voltage Markers** creates markers on nets based on the settings specified in the group box at the bottom of the form. When you check the box, *Generate Voltage Labels* is automatically disabled.

Environment variable: vdrGenerateMarkers

The behavior in *Replace* and *Update* modes is the same as described in the Voltage Labels section.

**Voltage Purpose File** specifies the name of a voltage purpose file, which lists the layer-purpose pairs on which markers for different voltage values are to be created. Click *Browse* to locate the file in your file system.

Environment variable: vdrVoltagePurposeFile

**Net Voltage Mode** specifies whether markers are to be created for maximum, minimum, or all voltage values.

Environment variable: <a href="https://www.vdr.ncbe.nu/vdr.NetVoltageMode">vdr.NetVoltageMode</a>

- □ maxVoltage creates markers only for maximum voltage values (the default)
- □ *minVoltage* creates markers only for minimum voltage values

# Virtuoso Voltage Dependent Rules Flow Guide Voltage Dependent Rules Forms

|     |                                                                                                                                                                                                                                                                                                                       | bothVoltage creates markers for all voltage values                                                                                                                                                                                                                                                                                                                                 |  |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|     |                                                                                                                                                                                                                                                                                                                       | <b>Voltage Rounding</b> specifies the rounding rule to follow for voltage values. Environment variable: <a href="mailto:vdrVoltageRounding">vdrVoltageRounding</a>                                                                                                                                                                                                                 |  |
|     |                                                                                                                                                                                                                                                                                                                       | roundOff rounds the voltage value to the nearest 0.01 (the default)                                                                                                                                                                                                                                                                                                                |  |
|     |                                                                                                                                                                                                                                                                                                                       | ceiling rounds up the voltage value to the nearest 0.01                                                                                                                                                                                                                                                                                                                            |  |
|     |                                                                                                                                                                                                                                                                                                                       | floor rounds down the voltage value to the nearest 0.01                                                                                                                                                                                                                                                                                                                            |  |
| are | to be                                                                                                                                                                                                                                                                                                                 | mon options at the bottom of the form let you specify for which nets labels or markers generated and how far down the hierarchy to search for those nets. The <i>Size</i> option control the size of the labels and markers that are created.                                                                                                                                      |  |
|     | inte                                                                                                                                                                                                                                                                                                                  | <b>Selection</b> specifies whether labels or markers are to be generated for external nets, rnal nets, or all nets. ironment variable: <a href="mailto:vdrGenerateLabelsOn">vdrGenerateLabelsOn</a>                                                                                                                                                                                |  |
|     |                                                                                                                                                                                                                                                                                                                       | External and Internal Nets (the default) specifies that labels or markers are generated for all nets in the design.                                                                                                                                                                                                                                                                |  |
|     |                                                                                                                                                                                                                                                                                                                       | External Nets Only specifies that labels or markers are generated only for external nets. A net is considered external if it is connected to any of the terminals of the cellview to which it belongs. When the cell is instantiated at a higher level, these nets are propagated up the hierarchy, allowing you to make connections to the terminals to which they are connected. |  |
|     |                                                                                                                                                                                                                                                                                                                       | Internal Nets Only specifies that labels or markers are to be generated only for nets that are wholly internal to the cellview in which they belong. When the cellview is instantiated at a higher level, internal nets are not propagated up the hierarchy.                                                                                                                       |  |
|     | <b>Hierarchy Stop Level</b> specifies how many hierarchy levels the software searches to find nets on which to generate labels or markers.  Environment variable: <a href="mailto:vdrHierarchyStopLevel">vdrHierarchyStopLevel</a>                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                    |  |
|     | For example,                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                    |  |
|     |                                                                                                                                                                                                                                                                                                                       | 0 means that labels/markers are generated for top-level nets only (the default)                                                                                                                                                                                                                                                                                                    |  |
|     |                                                                                                                                                                                                                                                                                                                       | 1 means top-level nets and nets located one level below in the hierarchy                                                                                                                                                                                                                                                                                                           |  |
|     |                                                                                                                                                                                                                                                                                                                       | 2 means top-level nets and nets located one and two levels below in the hierarchy                                                                                                                                                                                                                                                                                                  |  |
|     | <b>Size</b> specifies the height of the labels or markers created. The default is 0.0. For labels, this means that the label is automatically sized to match the height of the shape with which it is associated. For markers, it prevents the marker from being created at all. Environment variable: vdrLabelHeight |                                                                                                                                                                                                                                                                                                                                                                                    |  |

All Rights Reserved.

Voltage Dependent Rules Forms

## **Related Topics**

Specifying Layers and Purposes for Generic Voltage Labels

Specifying Layers and Purposes for Voltage Markers

Storing Voltages in the OpenAccess Database

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Markers from Simulation Data for All Nets

Simulation Driven VDR Flow

Voltage Dependent Rules Forms

## **Voltage Dependent Rules (from net voltages)**

Use this form to generate voltage labels or markers for nets selected directly from the Navigator assistant.

#### Voltage Labels from Net Voltages

**Low Voltage Purpose** specifies the layer purpose to use for minimum voltage labels. The default is v1o.

Environment variable: vdrLowVoltagePurpose

**High Voltage Purpose** specifies the layer purpose to use for maximum voltage labels.

The default is vhi.

Environment variable: <a href="mailto:vdrHighVoltagePurpose">vdrHighVoltagePurpose</a>

**Special Voltage LPP File** is a text file that can be used to override the default *High Voltage Purpose* and *Low Voltage Purpose* settings if your process requires it. See <u>Specifying Layers and Purposes for Generic Voltage Labels</u> for more information.

Environment variable: vdrLaverPurposeFile

#### **Voltage Markers**

**Generate Voltage Markers** creates markers on nets based on the settings specified in the group box at the bottom of the form. When you check the box, the voltage purpose options above are automatically disabled.

Environment variable: vdrGenerateMarkers

**Voltage Purpose File** specifies the name of a voltage purpose file, which lists the layer-purpose pairs on which markers for different voltage values are to be created. Click *Browse* to locate the file in your file system.

Environment variable: vdrVoltagePurposeFile

**Net Voltage Mode** specifies whether markers are to be created for maximum, minimum, or all voltage values.

Environment variable: <a href="https://www.vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu/vdr.ncbe.nu

- maxVoltage creates markers only for maximum voltage values (the default)
   minVoltage creates markers only for minimum voltage values
- □ both Voltage creates markers for all voltage values

**Voltage Rounding** specifies the rounding rule to follow for voltage values. Environment variable: <a href="https://www.vdvoltageRounding">vdrVoltageRounding</a>

- □ roundOff rounds the voltage value to the nearest 0.01 (the default)
- ceiling rounds up the voltage value to the nearest 0.01

Voltage Dependent Rules Forms

floor rounds down the voltage value to the nearest 0.01

The options at the bottom of the form let you specify the size of the labels or markers that are created and enter a list of nets for which labels or markers are to be generated even if their voltage values are 0.

**Zero Voltage Nets** lists the nets which have voltage values of (0,0) but for which labels should be generated anyway.

Environment variable: vdrZeroVoltageNets

The field lists the net names specified by the environment variable. If the environment variable is set to its default value (an empty string), the field lists the nets that have voltage values of (0,0) and signal type ground.

**Note:** Zero voltage nets are ignored by the sanity checker provided there are either no labels at all on the specified net or both Vmin and Vmax values are set to 0. If one or both values is nonzero, or the number of labels is other than 0 or 2, the sanity checker reports an error.

#### Related Topics

Generating Voltage Labels for Manually Entered Voltages

Generating Voltage Markers for Manually Entered Voltages

Layout-centric VDR Flow

Voltage Dependent Rules Forms

## **VSync Constraints Visualizer**

(ICADVM20.1 EXL Only) Use this form to create *Voltage Synced Nets* (vsync) constraints from the contents of a CSV file, list the vsync constraints currently present in the layout view, and delete those that are no longer required.

Create Constraints From CSV File lets you choose a CSV file from your file system and use it as a source from which to create vsync constraints in your design.

Browse helps you locate the CSV file you require.

*Create* lets you generate vsync constraints in the layout view based on the entries in the selected file.

**Voltage Synced Nets** lists the vsync constraints currently present in the design.

*Refresh* lets you update the list to reflect any changes made since the last update.

*Delete* removes the selected constraints from the list and the design.

#### Related Topics

# Virtuoso Voltage Dependent Rules Flow Guide Voltage Dependent Rules Forms

В

## **Environment Variables**

The list below provides information on the names, descriptions, and graphical user interface equivalents for the Virtuoso<sup>®</sup> Layout Suite L layout editor environment variables used in the voltage dependent rules flows.



Only the environment variables listed below are supported for public use. All other environment variables, and undocumented aspects of the environment variables described below, are private and subject to change at any time.

#### **List of VDR-related Environment Variables**

<u>vdrConstraintGroupName</u>

**vdrGenerateLabels** 

vdrGenerateLabelsOn

vdrGenerateMarkers

<u>vdrHierarchyStopLevel</u>

vdrHighVoltagePurpose

<u>vdrLabelHeight</u>

<u>vdrLayerPurposeFile</u>

<u>vdrLowVoltagePurpose</u>

<u>vdrNetVoltageMode</u>

vdrPostLabelCreationCallback

vdrSanityCheckerCheckAgainst

**Environment Variables** 

vdrSanityCheckerGenLogFile

<u>vdrSanityCheckerLogFile</u>

<u>vdrSanityCheckerObjectType</u>

vdrSanityCheckerTolerance

<u>vdrSanityCheckerToleranceType</u>

<u>vdrVoltagePurposeFile</u>

vdrVoltageRounding

vdrVSyncCreateCheckLayer

vdrVSyncSanityCheckLayer

<u>vdrZeroVoltageNets</u>

**Environment Variables** 

## vdrConstraintGroupName

layout vdrConstraintGroupName string "cgName"

#### **Description**

Specifies the name of a constraint group that contains layer-purpose pair (LPP) information for VDR labels and markers. The specified constraint group must in turn contain voltageLabelMapping or voltageMarkerMapping constraints, which define the LPPs on which labels or markers will be drawn.

When set, the environment variable automatically enables the constrained label generation flow, which lets you create and edit labels manually in the layout view.

It also enables the Voltage Synced Nets flow in Layout EXL, which lets you mark and check the voltages of nets that must always transition in phase with each other.

The default is an empty string, meaning that LPP information is not read from the technology file and the constrained label flow is not enabled.

#### **GUI Equivalent**

None

#### **Examples**

```
envGetVal("layout" "vdrConstraintGroupName")
envSetVal("layout" "vdrConstraintGroupName" 'string "myVDRLppCg")
```

#### Related Topics

Types of VDR Labels

**Environment Variables** 

#### vdrGenerateLabels

```
layout vdrGenerateLabels boolean { t | nil }
```

#### **Description**

Specifies that the VDR flow is to be run in label generation mode. The default is nil.

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules -

- Create Labels/Markers From Simulation Voltages
- Create Labels/Markers From Net Voltages

Field: Generate Voltage Labels

#### **Examples**

```
envGetVal("layout" "vdrGenerateLabels")
envSetVal("layout" "vdrGenerateLabels" 'boolean t)
envSetVal("layout" "vdrGenerateLabels" 'boolean nil)
```

#### Related Topics

Voltage Dependent Rules (form)

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels for Manually Entered Voltages

**Environment Variables** 

#### vdrGenerateLabelsOn

layout vdrGenerateLabelsOn cyclic "netType"

#### **Description**

Specifies the scope of nets for which labels are to be generated.

- External and Internal Nets (the default) specifies that labels are generated for all nets in the design.
- External Nets Only specifies that labels are generated only for external nets. A net is considered external if it is connected to any of the terminals of the cellview to which it belongs. When the cell is instantiated at a higher level, these nets are propagated up the hierarchy, allowing you to make connections to the terminals to which they are connected.
- Internal Nets Only specifies that labels are to be generated only for nets that are wholly internal to the cellview in which they belong. When the cellview is instantiated at a higher level, internal nets are not propagated up the hierarchy.

#### **GUI Equivalent**

Command: Tools – Voltage Dependent Rules

Field: Generate Labels On

#### **Examples**

```
envGetVal("layout" "vdrGenerateLabelsOn")
envSetVal("layout" "vdrGenerateLabelsOn" 'cyclic "External Nets Only")
envSetVal("layout" "vdrGenerateLabelsOn" 'cyclic "Internal Nets Only")
```

#### Related Topics

Voltage Dependent Rules (form)

Specifying Layers and Purposes for Generic Voltage Labels

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels for Manually Entered Voltages

**Environment Variables** 

#### vdrGenerateMarkers

```
layout vdrGenerateMarkers boolean { t | nil }
```

#### **Description**

Specifies that the VDR flow is to be run in marker generation mode. The default is nil.

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules -

- Create Labels/Markers From Simulation Voltages
- Create Labels/Markers From Net Voltages

Field: Generate Voltage Markers

#### **Examples**

```
envGetVal("layout" "vdrGenerateMarkers")
envSetVal("layout" "vdrGenerateMarkers" 'boolean t)
envSetVal("layout" "vdrGenerateMarkers" 'boolean nil)
```

### Related Topics

Voltage Dependent Rules (form)

Generating Voltage Markers from Simulation Data for All Nets

Generating Voltage Markers for Manually Entered Voltages

**Environment Variables** 

## vdrHierarchyStopLevel

layout vdrHierarchyStopLevel int stopLevel

#### **Description**

Specifies how many hierarchy levels the software searches to find the nets on which to generate labels. Specify an integer value between 0 and 32, where for example:

- 0 means that labels are generated only for top-level nets (this is the default)
- 1 means top-level nets and nets located one level below in the hierarchy
- 2 means top-level nets and nets located one and two levels below in the hierarchy

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules

Field: Hierarchy Stop Level

#### **Examples**

```
envGetVal("layout" "vdrHierarchyStopLevel")
envSetVal("layout" "vdrHierarchyStopLevel" 'int 2)
```

#### Related Topics

Voltage Dependent Rules (form)

Specifying Layers and Purposes for Generic Voltage Labels

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels for Manually Entered Voltages

Generating Voltage Markers from Simulation Data for All Nets

Generating Voltage Markers for Manually Entered Voltages

**Environment Variables** 

## vdrHighVoltagePurpose

layout vdrHighVoltagePurpose string "purposeName"

#### **Description**

Specifies the layer purpose on which to draw the maximum voltage label for a net when generating labels using the VDR flow.

The default is "vhi".

#### **GUI Equivalent**

Command: Tools – Voltage Dependent Rules

Field: High Voltage Purpose

#### **Examples**

```
envGetVal("layout" "vdrHighVoltagePurpose")
envSetVal("layout" "vdrHighVoltagePurpose" 'string "vhi")
```

#### **Related Topics**

<u>vdrLowVoltagePurpose</u>

Voltage Dependent Rules (form)

Specifying Layers and Purposes for Generic Voltage Labels

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels for Manually Entered Voltages

**Environment Variables** 

## vdrLabelHeight

layout vdrLabelHeight float heightValue

#### **Description**

Specifies the default height for labels or markers generated by the VDR flow.

The default is 0.0.

- For labels, this means that the label is automatically sized to match the height of the shape with which it is associated.
- For markers, it prevents the marker from being created at all.

#### **GUI Equivalent**

Command: Tools – Voltage Dependent Rules

Field: Size

### **Examples**

```
envGetVal("layout" "vdrLabelHeight")
envSetVal("layout" "vdrLabelHeight" 'float 0.05)
```

#### Related Topics

Voltage Dependent Rules (form)

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels for Manually Entered Voltages

Generating Voltage Markers for Manually Entered Voltages

**Environment Variables** 

## vdrLayerPurposeFile

layout vdrLayerPurposeFile string "fileName"

#### **Description**

Specifies the name of a special layer purpose file, which lets you override the default <a href="https://www.vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.layer.gov/vdr.l

The default is "" (an empty string).

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules -

Create Labels/Markers From Simulation Voltages

Create Labels/Markers From Net Voltages

Field: Special Voltage LPP File

#### **Examples**

```
envGetVal("layout" "vdrLayerPurposeFile")
envSetVal("layout" "vdrLayerPurposeFile" 'string "vdrLayerPurpose.map")
```

#### Related Topics

Voltage Dependent Rules (form)

Specifying Layers and Purposes for Generic Voltage Labels

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels for Manually Entered Voltages

**Environment Variables** 

## vdrLowVoltagePurpose

layout vdrLowVoltagePurpose string "purposeName"

#### **Description**

Specifies the layer purpose on which to draw the minimum voltage label for a net when generating labels using the VDR flow.

The default is "vlo".

#### **GUI Equivalent**

Command: Tools – Voltage Dependent Rules

Field: Low Voltage Purpose

#### **Examples**

```
envGetVal("layout" "vdrLowVoltagePurpose")
envSetVal("layout" "vdrLowVoltagePurpose" 'string "vlo")
```

#### **Related Topics**

<u>vdrHighVoltagePurpose</u>

Voltage Dependent Rules (form)

Specifying Layers and Purposes for Generic Voltage Labels

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels for Manually Entered Voltages

**Environment Variables** 

## vdrNetVoltageMode

```
layout vdrNetVoltageMode cyclic { "maxVoltage" | "minVoltage" | "bothVoltage" }
```

#### **Description**

Specifies whether markers are to be created for maximum, minimum, or all voltage values.

- maxVoltage creates markers for maximum voltage values only
- minVoltage creates markers for minimum voltage values only
- bothVoltage creates markers for all voltage values

The default is "maxVoltage".

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules -

- Create Labels/Markers From Simulation Voltages
- Create Labels/Markers From Net Voltages

Field: Net Voltage Mode

#### **Examples**

```
envGetVal("layout" "vdrNetVoltageMode")
envSetVal("layout" "vdrNetVoltageMode" 'cyclic "maxVoltage")
```

#### Related Topics

Voltage Dependent Rules (form)

Generating Voltage Markers from Simulation Data for All Nets

Generating Voltage Markers for Manually Entered Voltages

**Environment Variables** 

#### vdrPostLabelCreationCallback

layout vdrPostLabelCreationCallback string "procedureName"

#### **Description**

Specifies a user-defined SKILL procedure that can be used to perform any required postprocessing tasks on the generated labels. The specified callback must accept a cellview ID as an argument and is run automatically after label generation is complete.

For example, the callback shown below collects all the labels generated by the VDR flow in the specified cellview and creates a property to link them to a dataset called dataset1.

To modify the callback to post-process marker objects instead of labels, change the objType to "rect".

You can also specify the callback function name as an optional argument when using the <a href="https://vdr.createVoltageLabel">vdr.createVoltageLabel</a> SKILL function.

#### **GUI Equivalent**

None

#### **Examples**

```
envGetVal("layout" "vdrPostLabelCreationCallback")
envSetVal("layout" "vdrPostLabelCreationCallback" 'string " myPostVdrCB")
```

#### Related Topics

Post-Processing Voltage Labels and Markers

**Environment Variables** 

## vdrSanityCheckerCheckAgainst

```
layout vdrSanityCheckerCheckAgainst cyclic { "Schematic" | "Layout" }
```

#### **Description**

Specifies whether voltage values in labels are checked against schematic net properties or layout net properties.

- Schematic checks values against schematic net properties (this is the default)
- Layout checks values against layout net properties

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules - Sanity Checker

Field: ■ Check Against Schematic

Check Against Layout

## **Examples**

```
envGetVal("layout" "vdrSanityCheckerCheckAgainst")
envSetVal("layout" "vdrSanityCheckerCheckAgainst" 'cyclic "Layout")
```

#### **Related Topics**

**VDR Sanity Checker** 

Sanity Checking Voltage Values in Constrained Labels

**Environment Variables** 

## vdrSanityCheckerGenLogFile

layout vdrSanityCheckerGenLogFile boolean { t | nil }

#### **Description**

Specifies that the sanity checker comparison report is to be captured in a log file. You specify the log filename and location using <u>vdrSanityCheckerLogFile</u>.

When you specify a filename, only a summary message is printed in the CIW. If you do not specify a filename, discrepancies are reported in a table printed in the CIW.

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules - Sanity Checker

Field: Generate report in text file

#### **Examples**

```
envGetVal("layout" "vdrSanityCheckerGenLogFile")
envSetVal("layout" "vdrSanityCheckerGenLogFile" 'boolean t)
```

#### Related Topics

**VDR Sanity Checker** 

Sanity Checking Voltage Values in Constrained Labels

**Environment Variables** 

## vdrSanityCheckerLogFile

layout vdrSanityCheckerLogFile string "fileName"

#### **Description**

Specifies the path and name of the sanity checker report log file.

When you specify a filename, only a summary message is printed in the CIW. If you do not specify a filename, discrepancies are reported in a table printed in the CIW.

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules - Sanity Checker

Field: File Name

#### **Examples**

```
envGetVal("layout" "vdrSanityCheckerLogFile")
envSetVal("layout" "vdrSanityCheckerLogFile" 'string "vdrReport.log")
```

#### Related Topics

**VDR Sanity Checker** 

Sanity Checking Voltage Values in Constrained Labels

**Environment Variables** 

## vdrSanityCheckerObjectType

```
layout vdrSanityCheckerObjectType cyclic { "Labels" | "VSync" }
```

#### **Description**

Specifies what is to be checked by the VDR Sanity Checker.

- Labels performs the sanity check on voltage values that are printed as labels in the layout (this is the default)
- VSync performs the sanity check on vsync shapes in the layout view (ICADVM20.1 EXL Only)

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules - Sanity Checker

Field: ■ Check Labels

■ Check VSync Shapes

#### **Examples**

```
envGetVal("layout" "vdrSanityCheckerObjectType")
envSetVal("layout" "vdrSanityCheckerObjectType" 'cyclic "Labels")
envSetVal("layout" "vdrSanityCheckerObjectType" 'cyclic "VSync")
```

#### Related Topics

**VDR Sanity Checker** 

Sanity Checking Voltage Values in Constrained Labels

**Environment Variables** 

## vdrSanityCheckerTolerance

layout vdrSanityCheckerTolerance float toleranceValue

## **Description**

Specifies a threshold beyond which voltage mismatches are to be reported by the sanity checker. The default is 0.00.

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules - Sanity Checker

Field: Tolerance

#### **Examples**

```
envGetVal("layout" "vdrSanityCheckerTolerance")
envSetVal("layout" "vdrSanityCheckerTolerance" 'float 0.05)
```

### **Related Topics**

**VDR Sanity Checker** 

Sanity Checking Voltage Values in Constrained Labels

**Environment Variables** 

## vdrSanityCheckerToleranceType

```
layout vdrSanityCheckerToleranceType cyclic { "Absolute" | "Relative" }
```

#### **Description**

Specifies whether the sanity checker tolerance value is considered an absolute value or a relative percentage based on the net voltage.

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules - Sanity Checker

Field: Absolute and Relative

#### **Examples**

```
envGetVal("layout" "vdrSanityCheckerToleranceType")
envSetVal("layout" "vdrSanityCheckerToleranceType" 'cyclic "Relative")
```

### **Related Topics**

**VDR Sanity Checker** 

Sanity Checking Voltage Values in Constrained Labels

**Environment Variables** 

## vdrVoltagePurposeFile

layout vdrVoltagePurposeFile string "fileName"

#### **Description**

Specifies the name of the voltage purpose file, which determines the layer-purpose pairs on which markers for different voltage values are to be created. The default is "" (an empty string).

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules -

- Create Labels/Markers From Simulation Voltages
- Create Labels/Markers From Net Voltages

Field: Voltage Purpose File

#### **Examples**

```
envGetVal("layout" "vdrVoltagePurposeFile")
envSetVal("layout" "vdrVoltagePurposeFile" 'string "volt LPP.map")
```

#### Related Topics

Voltage Dependent Rules (form)

Specifying Layers and Purposes for Voltage Markers

Generating Voltage Markers from Simulation Data for All Nets

Generating Voltage Markers for Manually Entered Voltages

**Environment Variables** 

## vdrVoltageRounding

```
layout vdrVoltageRounding cyclic { "roundOff" | "floor" | "ceiling" }
```

#### **Description**

Specifies the rounding rule to follow for voltage values in marker-based VDR flows.

- roundOff rounds the voltage value to the nearest 0.01
- ceiling rounds up the voltage value to the nearest 0.01
- floor rounds down the voltage value to the nearest 0.01

The default is "roundOff".

#### **GUI Equivalent**

Command: Tools - Voltage Dependent Rules -

- Create Labels/Markers From Simulation Voltages
- Create Labels/Markers From Net Voltages

Field: Voltage Rounding

#### **Examples**

```
envGetVal("layout" "vdrVoltageRounding")
envSetVal("layout" "vdrVoltageRounding" 'cyclic "floor")
```

#### Related Topics

Voltage Dependent Rules (form)

Generating Voltage Markers from Simulation Data for All Nets

Generating Voltage Markers for Manually Entered Voltages

**Environment Variables** 

## vdrVSyncCreateCheckLayer

layout vdrVSyncCreateCheckLayer string "vSyncSpec"

#### **Description**

Overrides the vsync shape creation specification defined in the process technology file to improve the routability of the design.

The vSyncSpec comprises a list of one or more strings, each separated by a space. Each string specifies one or two input layers and an output layer and purpose on which the vsync shape is to be drawn. The input and output layer specifications are separated by a comma.

```
t_inputLayer1[:t_inputLayer2],t_outputLayer:t_outputPurpose
```

#### For example,

■ "Metal1, Metal1:v\_sync"

Specifies a single layer check on layer Metall with the vsync shape created on LPP Metall vsync.

"Metal1:Metal2,Metal1:v\_sync"

Specifies a layer-pair check on layers Metall and Metall with the vsync shape created on LPP Metall vsync.

The default is " " (empty string), which means that the vsync layer specification in the technology file is used when creating vsync shapes.

#### **GUI Equivalent**

None

#### **Examples**

```
envGetVal("layout" "vdrVSyncCreateCheckLayer")
envSetVal("layout" "vdrVSyncCreateCheckLayer" 'string "Metal1, Metal1:v_sync
Metal2, Metal2:v sync Metal3, Metal3:v sync Metal1:Metal2, Metal1:v sync")
```

#### Related Topics

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Specifying Layers and Purposes for Synced Nets

**Environment Variables** 

## vdrVSyncSanityCheckLayer

layout vdrVSyncSanityCheckLayer string "vSyncSpec"

#### **Description**

Modifies the vsync layer definition in the process technology file to specify which vsync shapes are to be checked by the VDR Sanity Checker.

The vSyncSpec comprises a list of one or more strings, each separated by a space. Each string specifies one or two input layers and an output layer and purpose on which shapes are to be checked. The input and output layer specifications are separated by a comma.

```
t_inputLayer1[:t_inputLayer2],t_outputLayer:t_outputPurpose
```

#### For example,

■ "Metal1, Metal1:v\_sync"

Specifies a single layer check on layer Metall with the vsync shape created on LPP Metall vsync.

"Metal1:Metal2,Metal1:v\_sync"

Specifies a layer-pair check on layers Metall and Metall with the vsync shape created on LPP Metall vsync.

The default is " " (empty string), which means that the vsync layer specification in the technology file is used by the sanity checker.

#### **GUI Equivalent**

None

#### **Examples**

```
envGetVal("layout" "vdrVSyncSanityCheckLayer")
envSetVal("layout" "vdrVSyncSanityCheckLayer" 'string "Metal1, Metal1:v_sync
Metal2, Metal2:v sync Metal1:Metal2, Metal1:v sync")
```

#### Related Topics

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Specifying Layers and Purposes for Synced Nets

**Environment Variables** 

### vdrZeroVoltageNets

layout vdrZeroVoltageNets string "list\_of\_netNames"

#### **Description**

Lists the names of nets which have voltage values of (0,0) but for which labels or markers should be generated anyway.

List the net names, with each name separated by a space or a comma and the whole list enclosed by double quotes.

The default is "" (an empty string), which means that the corresponding form field is seeded with the names of nets that have (0,0) voltage values and signal type ground.

### **GUI Equivalent**

Command: Tools – Voltage Dependent Rules – Create Labels/Markers From

Net Voltages

Navigator - RMB Net Name - Create Voltage Labels/Markers

Field: Zero Voltage Nets

#### **Examples**

```
envGetVal("layout" "vdrZeroVoltageNets")
envSetVal("layout" "vdrZeroVoltageNets" 'string "VSS VSS1")
```

#### Related Topics

Voltage Dependent Rules (from net voltages) (form)

Voltage Dependent Rules (form)

Generating Voltage Labels for Manually Entered Voltages

Layout-centric VDR Flow

C

## **Voltage Dependent Rules Functions**

The list below lets you access information about syntax, descriptions, and examples for the Cadence<sup>®</sup> SKILL functions associated with the Virtuoso<sup>®</sup> voltage dependent rules flows. Only the functions listed here are supported for public use. Any other functions, and undocumented aspects of the functions described below, are private and subject to change or removal at any time.

#### **VDR-related SKILL Functions**

The functions listed below let you create and remove voltage labels for the nets in your design:

- vdrCheckVoltageLabels
- vdrCreateVoltageLabel
- vdrCreateVoltageLabelEx
- vdrCreateVoltageLabelOnNets
- vdrCreateVoltageMarkers
- vdrCreateVoltageMarkersOnNets
- vdrCreateVSyncConstraintsFromFile
- vdrDeleteLabels
- vdrGenerateLabelsGUI
- vdrGenerateVSvncShapes
- vdrGetValidLayers
- vdrRunSanityChecker
- vdrRunVSvncSanityChecker
- vdrSanityCheckerGUI

Voltage Dependent Rules Functions

- vdrSetNetVoltageRange
- vdrSetValidLayers
- vdrTransferVSyncConstraints
- vdrVsyncVisualizerGUI

Voltage Dependent Rules Functions

### **VDR-related Database Access SKILL Functions**

The functions listed below let you manipulate voltage values for nets directly in the design database.

| To set, get, and unset the minimum and maximum voltages for a net, use: |                                                                                      |  |  |
|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
|                                                                         | <u>dbGetNetVoltageRange</u>                                                          |  |  |
|                                                                         | <u>dbSetNetVoltageRange</u>                                                          |  |  |
|                                                                         | <u>dbUnsetNetVoltageRange</u>                                                        |  |  |
| То                                                                      | To set, get, and unset the voltage source for a net, use:                            |  |  |
|                                                                         | <u>dbGetNetVoltageRangeSource</u>                                                    |  |  |
|                                                                         | <u>dbSetNetVoltageRangeSource</u>                                                    |  |  |
|                                                                         | dbUnsetNetVoltageRangeSource                                                         |  |  |
| То                                                                      | To set and get the default minimum and maximum voltages for nets in a cellview, use: |  |  |
|                                                                         | <u>dbGetCellViewNetVoltageRange</u>                                                  |  |  |
|                                                                         | <u>dbSetCellViewNetVoltageRange</u>                                                  |  |  |
|                                                                         |                                                                                      |  |  |

For detailed information, click any of the links above or see <u>Chapter 2</u>, "<u>Database Access</u>," in the *Virtuoso Design Environment SKILL Reference*.

Voltage Dependent Rules Functions

# vdrCheckVoltageLabels

```
vdrCheckVoltageLabels(
    d_cellviewID
    [ t_reportFilename ]
    [ g_enablePopup ]
    )
    => t / nil
```

# **Description**

Verifies that all top-level nets in the specified layout cellview are correctly labeled on the canvas.

## **Arguments**

| d_cellviewID     | Database ID of the layout cellview in which labels are to be checked.                                                   |
|------------------|-------------------------------------------------------------------------------------------------------------------------|
| t_reportFilename | Name of the report file to which information about missing or incorrect labels is appended.                             |
|                  | Enclose the filename in double quotes. If you do not specify a filename, the information is printed to the CIW instead. |
| g_enablePopup    | Displays the messages issued by the command in a pop-up window when the command is run (the default).                   |
|                  | When set to $\ensuremath{\mathtt{nil}}$ , no pop-up window appears and the messages are printed to the CIW instead.     |

### **Value Returned**

| t   | All the top-level nets in the design are correctly labeled on the canvas.                                      |
|-----|----------------------------------------------------------------------------------------------------------------|
| nil | Some of the top-level nets in the design do not have correct labels. Check the report file or CIW for details. |

Voltage Dependent Rules Functions

# **Example**

```
returnVal = true
when(window = hiGetCurrentWindow()
   when(cellView = geGetEditCellView(window)
      when(instHeaders = cellView~>instHeaders
        if(vdrCheckVoltageLabels(instHeader~>master "vdrReport.log" nil) == nil)
        returnVal = nil
      )
    )
   )
  )
)
```

Checks that all the top-level nets in the current design are correctly labeled on the canvas and appends information to a file called vdrReport.log in the current working directory.

## **Related Topics**

Checking Voltage Labels in the Layout View

Voltage Dependent Rules Functions

# vdrCreateVoltageLabel

```
vdrCreateVoltageLabel(
    d cellviewID
    1t_datasetName
     t lowVPurposeName
     t highVPurposeName
     [ f_labelHeight ]
     [ g_externalNets ]
     [ g_internalNets ]
     [ g_update ]
     [ g_generateLabels ]
     [ g overrideMode ]
     [ x_hierStopLevel ]
     [ u customFunc ]
     [ u_postLabelCreationCB ]
     [ t voltageInfoFile ]
     [ t layerPurposeFile ]
     [ g_verbose ]
     [ t_logFile ]
     [ g_propagateNetVoltages ]
     [ lt_sourceName ]
    => t / nil
```

## **Description**

Creates labels on the nets in a layout design reflecting the minimum and maximum voltages from simulation data or a specified list of sources.

**Note:** The same functionality is provided by the <u>vdrCreateVoltageLabelEx</u> API, which features keyed optional arguments for added convenience.

### **Arguments**

d\_cellviewID Database ID of the layout cellview for which labels are to be created.

1t\_datasetName

One or more strings representing the names of the simulation datasets that contain the minimum and maximum voltage data for the nets in the specified design.

To specify a single dataset name, use this format:

```
"voltages_0"
```

To specify more than one dataset name, use this format:

```
("voltages_0" "voltages_1" "voltages_2")
```

Voltage Dependent Rules Functions

t\_lowVPurposeName

Name of the layer purpose on which to draw minimum voltage labels. This argument is mandatory; the function does not consider the setting of the <a href="mailto:vdrLowVoltagePurpose">vdrLowVoltagePurpose</a> environment variable.

t\_highVPurposeName

Name of the layer purpose on which to draw maximum voltage labels. This argument is mandatory; the function does not consider the setting of the <a href="mailto:vdrHighVoltagePurpose">vdrHighVoltagePurpose</a> environment variable.

*f\_labelHeight* Height of the labels created.

The default is 0.0 microns, which means that the label is automatically sized to match the height of the shape with which it is associated.

11 10 40000141

g\_externalNets Creates labels for external nets, that is, nets that are connected to the terminals of the cellview to which they

belong.

The default is t. To create labels only for internal nets, specify

nil for this argument.

*g\_internalNets* Creates labels for internal nets.

The default is t. To create labels only for external nets, specify

nil for this argument.

g\_update Runs label creation in *Update* mode.

The default is nil, which means that label creation runs in

Replace mode.

g\_generateLabels Specifies whether labels are to be created on the canvas or

not.

The default is t.

Use in conjunction with the propagateNetVoltages option to control whether only net properties, only labels, both properties and labels, or neither properties nor labels are

updated.

Voltage Dependent Rules Functions

g\_overrideMode

Specifies that any manually entered voltage values on nets are to be overridden by the values from the simulation datasets.

The default is nil, which means that manually entered values are not overridden.

x\_hierStopLevel

Number of hierarchy levels the software searches to find the nets on which to create labels. For example:

- means that labels are created only for top-level nets (this is the default)
- 1 means top-level nets and nets located one level below in the hierarchy
- 2 means top-level nets and nets located one and two levels below in the hierarchy

The default is 32.

u\_customFunc

User-defined SKILL procedure that can be called to create or instantiate objects other than regular text labels.

The default is nil, which means that no custom SKILL function is specified.

u\_postLabelCreationCB

User-defined SKILL procedure that can be used to perform any required post-processing tasks on the created labels.

The default is nil, which means that no user-defined post-processing is performed.

For more information, see <u>Post-Processing Voltage Labels and</u> Markers.

t\_voltageInfoFile

Specifies the name of a comma-separated value (CSV) file containing voltage information, which can be used as an input for the VDR flow instead of a simulation dataset. The CSV file specifies net names and corresponding minimum and maximum voltage values. The asterisk (\*) is supported as a wildcard character. The default is nil.

For more information, see <u>Generating Voltage Labels from a Voltage Information File</u>.

Voltage Dependent Rules Functions

t\_layerPurposeFile

Special layer purpose file that lets you override the default  $t\_highVPurposeName$  and  $t\_lowVPurposeName$  arguments when a process requires it.

The default is nil.

See <u>Specifying Layers and Purposes for Generic Voltage Labels</u> for more information.

g\_verbose Enables verbose mode when generating labels based on a voltage information file. The software prints one message per

entry in the file confirming the action taken for that entry.

The default is nil, which means that no messages are issued. When set to t, messages are printed in the CIW. Use  $t \log File$  to save the messages to a separate log file.

Name of a log file in which messages are saved when

generating labels from a voltage information file in verbose

mode.

g\_propagateNetVoltages

Specifies whether the voltage values are to be updated for the specified nets in the database. The default is t.

Use in conjunction with the <code>generateLabel</code> argument to control whether only properties, only labels, both properties and labels, or neither properties nor labels are updated.

1t\_sourceName

t\_logFile

Specifies a list of alternative sources from which voltages values are read and the order in which they are considered. Along with view names, the list may also reference a voltage information file specified by the voltageInfoFile argument. For example:

```
?source list("csv" "schematic" "layout")
?dataFile "csv")
```

The list of sources is considered only if you have not specified datasets as the source of voltage values. If no dataset, data file, or source list is specified, the voltages in the layout view are used to create labels.

Voltage Dependent Rules Functions

### **Value Returned**

t Labels were created with no errors.

nil Labels could not be created due to errors.

### **Example**

```
vdrCreateVoltageLabel(geGetEditCellView() "voltages_0" "drawing" "drawing" 0.0 t
nil nil t nil 0 ' myPostVdrCB)
```

Runs label creation in *Replace* mode for only the top-level nets in the current cellview. Voltage values are taken from a dataset called <code>voltages\_0</code>, and labels are drawn on layer purpose <code>drawing</code>. The code then automatically executes a user-defined callback named <code>\_myPostVdrCB</code> to perform some post-processing tasks.

```
vdrCreateVoltageLabel(geGetEditCellView() nil "drawing" "drawing" 0.0 t nil nil t
nil 0 ' myPostVdrCB "./voltages.csv")
```

Performs the same operation as above but uses the information in the file called voltages.csv instead of a dataset as input.

### Related Topics

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels from a Voltage Information File

Voltage Dependent Rules Functions

# vdrCreateVoltageLabelEx

```
vdrCreateVoltageLabelEx(
     d cellviewID
     1t_datasetName
     t lowVPurposeName
     t highVPurposeName
     [ ?labelHeight f_labelHeight ]
     [ ?externalNet { t | nil } ]
     [ ?internalNet { t | nil } ]
     [ ?update { t | nil } ]
     [ ?generateLabel { t | nil } ]
     [ ?overrideMode { t | nil } ]
     [ ?hierStopLevel x_hierStopLevel ]
     [ ?customFunc u customFunc ]
     [ ?postLabelCreationCB u_postLabelCreationCB ]
     [ ?dataFile t voltageInfoFile ]
     [ ?lppFile t_layerPurposeFile ]
     [ ?verbose { t | nil } ]
     [ ?logFile t_logFile ]
     [ ?propagateNetVoltages { t | nil } ]
     [ ?source lt_sourceName ]
    => t / nil
```

## **Description**

Creates labels on the nets in a layout design reflecting the minimum and maximum voltages from simulation data or a specified list of sources.

# **Arguments**

d\_cellviewID Database ID of the layout cellview for which labels are to be created.

1t\_datasetName

One or more strings representing the names of the simulation datasets that contain the minimum and maximum voltage data for the nets in the specified design.

To specify a single dataset name, use this format:

```
"voltages_0"
```

To specify more than one dataset name, use this format:

```
("voltages_0" "voltages_1" "voltages_2")
```

Voltage Dependent Rules Functions

t\_lowVPurposeName

Name of the layer purpose on which to draw minimum voltage labels. This argument is mandatory; the function does not consider the setting of the <a href="mailto:vdrLowVoltagePurpose">vdrLowVoltagePurpose</a> environment variable.

t\_highVPurposeName

Name of the layer purpose on which to draw maximum voltage labels. This argument is mandatory; the function does not consider the setting of the <a href="mailto:vdrHighVoltagePurpose">vdrHighVoltagePurpose</a> environment variable.

?labelHeight f\_labelHeight

Height of the labels created.

The default is 0.0 microns, which means that the label is automatically sized to match the height of the shape with which it is associated.

?externalNet { t | nil }

Creates labels for external nets, that is, nets that are connected to the terminals of the cellview to which they belong.

The default is t. To create labels only for internal nets, specify nil for this argument.

?internalNet { t | nil }

Creates labels for internal nets.

The default is t. To create labels only for external nets, specify nil for this argument.

?update { t | nil }

Runs label creation in *Update* mode.

The default is nil, which means that label creation runs in Replace mode.

Voltage Dependent Rules Functions

?generateLabel { t | nil }

Specifies whether labels are to be created on the canvas or not.

The default is t.

Use in conjunction with the <code>?propagateNetVoltages</code> option to control whether only net properties, only labels, both properties and labels, or neither properties nor labels are updated.

?overrideMode { t | nil }

Specifies that any manually entered voltage values on nets are to be overridden by the values from the simulation datasets.

The default is nil, which means that manually entered values are not overridden.

?hierStopLevel x\_hierStopLevel

Number of hierarchy levels the software searches to find the nets on which to create labels. For example:

- means that labels are created only for top-level nets (this is the default)
- 1 means top-level nets and nets located one level below in the hierarchy
- 2 means top-level nets and nets located one and two levels below in the hierarchy

The default is 32.

?customFunc  $u_customFunc$ 

User-defined SKILL procedure that can be called to create or instantiate objects other than regular text labels.

The default is nil, which means that no custom SKILL function is specified.

?postLabelCreationCB u\_postLabelCreationCB

User-defined SKILL procedure used to perform any required post-processing tasks on the created labels. The default is nil, which means that no post-processing is performed. For more information, see <u>Post-Processing Voltage Labels and Markers</u>.

Voltage Dependent Rules Functions

?dataFile t\_voltageInfoFile

Specifies the name of a comma-separated value (CSV) file containing voltage information, which can be used as an input for the VDR flow instead of a simulation dataset. The CSV file specifies net names and corresponding minimum and maximum voltage values. The asterisk (\*) is supported as a wildcard character.

The default is nil.

For more information, see <u>Generating Voltage Labels from a Voltage Information File</u>.

?lppFile t\_layerPurposeFile

Special layer purpose file that lets you override the default  $t\_highVPurposeName$  and  $t\_lowVPurposeName$  arguments when your process requires it.

The default is nil.

See <u>Specifying Layers and Purposes for Generic Voltage</u>
<u>Labels</u> for more information.

?verbose { t | nil }

Enables verbose mode when generating labels based on a voltage information file. The software prints one message per entry in the file confirming the action taken for that entry.

The default is nil, which means that no messages are issued. When set to t, messages are printed in the CIW. Use  $t_logFile$  to save the messages to a separate log file.

?logFile t\_logFile

Name of a log file in which messages are saved when generating labels from a voltage information file in verbose mode.

Voltage Dependent Rules Functions

?propagateNetVoltages { t | nil }

Specifies whether the voltage values are to be updated for the specified nets in the database. The default is t.

Use in conjunction with the <code>?generateLabel</code> option to control whether only net properties, only labels, both properties and labels, or neither properties nor labels are updated.

?source lt\_sourceName

Specifies a list of alternative sources from which voltages values are read and the order in which they are considered. Along with view names, the list may also reference a voltage information file specified by the <code>?dataFile</code> argument. For example:

```
?source list("csv" "schematic" "layout")
?dataFile "voltageInfoFile.csv"
```

The list of sources is considered only if you have not specified datasets as the source of voltage values. If no dataset, data file, or source list is specified, the voltages in the layout view are used to create labels.

#### Value Returned

t Labels were created with no errors.

nil Labels could not be created due to errors.

## Example

```
cv = geGetEditCellView()
vdrCreateVoltageLabelEx(cv "voltages_0" "drawing" "drawing" ?internalNet nil
?hierStopLevel 0)
```

Creates labels from the voltage values from dataset <code>voltages\_0</code> for the top-level external nets in *Replace* mode.

# Related Topics

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Labels from a Voltage Information File

Voltage Dependent Rules Functions

# vdrCreateVoltageLabelOnNets

```
vdrCreateVoltageLabelOnNets(
    d_cellviewID
    ld_netIDs
    t_lowVPurposeName
    t_highVPurposeName
    [ f_labelHeight ]
    [ u_customFunc ]
    [ lt_ignoreZeroVoltNets ]
    [ u_postLabelCreationCB ]
    [ t_layerPurposeFile ]
    )
    => t / nil
```

### **Description**

Creates labels from the voltage values entered manually in the Property Editor assistant for the specified top-level nets in the given cellview. The labels are created on the geometry of the net in question. Where there is no geometry, the labels are created on all the Pcell and instance terminals connected to the net. The command works only in Layout XL and higher tiers.

## **Arguments**

d\_cellviewID Database ID of the layout cellview containing the nets for which

labels are to be created.

1d\_netIDs
List of database IDs identifying the nets for which labels are to

be created.

t\_lowVPurposeName

Name of the layer purpose on which to draw minimum voltage labels. This argument is mandatory; the function does not consider the setting of the <a href="mailto:vdrLowVoltagePurpose">vdrLowVoltagePurpose</a>

environment variable.

t\_highVPurposeName

Name of the layer purpose on which to draw maximum voltage labels. This argument is mandatory; the function does not consider the setting of the <a href="mailto:vdrHighVoltagePurpose">vdrHighVoltagePurpose</a> environment variable.

Voltage Dependent Rules Functions

*f\_labelHeight* Height of the labels created.

The default is 0.0 microns, which means that the label is automatically sized to match the height of the shape with which

it is associated.

u\_customFunc

User-defined SKILL procedure that can be called to create or

instantiate objects other than regular text labels.

The default is nil, which means that no custom SKILL function

is specified.

lt\_ignoreZeroVoltNets

List of nets that have voltage values of (0,0) but for which

labels should be created anyway.

Names must each be enclosed in double quotes and

separated by a space.

t\_layerPurposeFile

Special layer purpose file that lets you override the default

t\_highVPurposeName and t\_lowVPurposeName

arguments when your process requires it.

See Specifying Layers and Purposes for Generic Voltage

Labels for more information.

#### **Value Returned**

t Label creation ran without any errors.

nil Label creation encountered errors.

### **Example**

vdrCreateVoltageLabelOnNets(geGetEditCellView() netIDs "vlo" "vhi" 0.2)
t

Creates labels for the list of netIDs in the currently edited cellview. The labels are 0.2 microns high with the minimum voltage label drawn on layer purpose vlo and the maximum voltage label on purpose vhi.

Voltage Dependent Rules Functions

# Related Topics

Generating Voltage Labels for Manually Entered Voltages

Voltage Dependent Rules Functions

# vdrCreateVoltageMarkers

```
vdrCreateVoltageMarkers(
    d_cellviewID
    t_voltagePurposeFile
    [ ?dataset t_datasetName ]
    [ ?update { t | nil } ]
    [ ?override_mode { t | nil } ]
    [ ?size f_markerHeight ]
    [ ?externalNet { t | nil } ]
    [ ?internalNet { t | nil } ]
    [ ?hierStopLevel x_hierStopLevel ]
    [ ?postMarkerCreationCB u_postMarkerCreationCB ]
    [ ?csvFile t_voltageInfoFile ]
    [ ?voltageRounding { roundOff | floor | ceiling } ]
    [ ?mode { maxVoltage | minVoltage | bothVoltage } ]
    )
    => t / nil
```

### **Description**

Creates markers for minimum and/or maximum voltages on the nets in the specified design. Voltage information can be taken from simulation datasets, from user-defined voltages on nets, or from a voltage information file. The voltage purpose file specifies on which layer-purpose pair a marker is created depending on the voltage value in question.

## **Arguments**

d cellviewID

Database ID of the layout cellview containing the nets for which markers are to be created.

t\_voltagePurposeFile

Lists the layer-purpose pairs on which markers for different voltage values are to be created.

?dataset lt\_datasetName

One or more strings representing the names of the simulation datasets containing minimum and maximum voltage data for the nets in the specified design.

For example, to specify a single dataset name, use this format: "voltages\_0". To specify more than one dataset name, type ("voltages\_0" "voltages\_1" "voltages\_2")

```
?update { t | nil }
```

Voltage Dependent Rules Functions

Runs marker creation in *Update* mode, which means that values are based on the last voltages set on net; that is

- The lower of the current minimum and the last minimum
- The higher of the current maximum and the last maximum

The default is nil, which means that marker creation is run in *Replace* mode.

```
?override mode { t | nil }
```

Specifies that any manually entered voltage values on nets are to be overridden by the values from the simulation datasets.

The default is nil, which means that manually entered values are not overridden.

?size f\_markerHeight

Height of the markers created.

The default is 0.0 microns, which means that no marker is created.

```
?externalNet { t | nil }
```

Creates markers for external nets; that is, nets that are connected to the terminals of the cellview to which they belong.

The default is t.

```
?internalNet { t | nil }
```

Creates markers for internal nets.

The default is t.

?hierStopLevel x\_hierStopLevel

Specifies how many hierarchy levels the software searches to find the nets on which to create markers. For example, 0 means that markers are created for top-level nets only; 1 means top-level nets and nets located one level below in the hierarchy; 2 means top-level nets and nets located one and two levels below in the hierarchy; and so on. The default is 32.

?postMarkerCreationCB u\_postMarkerCreationCB

Voltage Dependent Rules Functions

Specifies a user-defined SKILL procedure that can be used to perform any required post-processing tasks on the created labels. For more information, see <a href="Post-Processing Voltage">Post-Processing Voltage</a> Labels and Markers.

?csvFile t\_voltageInfoFile

Specifies the name of a comma-separated value (CSV) file containing voltage information, which can be used instead of a simulation dataset as an input for the VDR flow. The CSV file specifies net names and corresponding minimum and maximum voltage values. Wildcard (\*) is supported.

For more information, see <u>Generating Voltage Labels from a Voltage Information File</u>.

```
?voltageRounding { "roundOff" | "floor" | "ceiling" }
```

Specifies the rounding rule to follow for voltage values.

- roundOff rounds the voltage value to the nearest 0.01
- ceiling rounds up the voltage value to the nearest 0.01
- floor rounds down the voltage value to the nearest 0.01

The default is "roundOff".

```
?mode { "maxVoltage" | "minVoltage" | "bothVoltage" }
```

Specifies whether markers are to be created for maximum, minimum, or all voltage values.

The default is "maxVoltage".

#### **Value Returned**

t Marker creation ran without any errors.

nil Marker creation encountered errors.

## Example

```
when (cellView = geGetEditCellView(window)
    voltageLPPFile = "volt_LPP.map"
    dataset = "VDR_dataset_0"
    vdrCreateVoltageMarkers(cellview voltageLPPFile ?dataset dataset
        ?update nil ?override_mode nil ?size 0.01 ?externalNet t
        ?internalNet nil ?hierStopLevel 3 ?postMarkerCreationCB nil
```

Voltage Dependent Rules Functions

```
?csvFile nil ?voltageRounding "floor" ?mode "bothVoltage")
```

Creates markers for the minimum and maximum voltages on external nets in the specified dataset down to hierarchy level 3 of the specified cellview. The markers are 0.01 high. Voltage values are rounded down to the nearest 0.01.

## **Related Topics**

Generating Voltage Markers from Simulation Data for All Nets

Specifying Layers and Purposes for Voltage Markers

Voltage Dependent Rules Functions

# vdrCreateVoltageMarkersOnNets

```
vdrCreateVoltageMarkersOnNets(
    d_cellviewID
    ld_netIDs
    t_voltagePurposeFile
    [?size f_markerHeight]
    [?postMarkerCreationCB t_postMarkerCreationCB]
    [?voltageRounding { roundOff | floor | ceiling } ]
    [?voltageMode { maxVoltage | minVoltage | bothVoltage } ]
    [?ignoreZeroVoltNets lt_netNames]
)
    => t / nil
```

## Description

Creates markers from the voltage values entered manually in the Property Editor assistant for the specified top-level nets in the given cellview.

### **Arguments**

| d_cellviewID | Database ID of the layout cellview containing the nets for which |
|--------------|------------------------------------------------------------------|
|              | markers are to be created.                                       |

1d\_netIDs
List of database IDs identifying the nets for which markers are

to be created.

t voltagePurposeFile

Lists the layer-purpose pairs on which markers for different voltage values are to be created.

?size f\_markerHeight

Height of the markers created.

The default is 0.0 microns, which means that no marker is created.

?postMarkerCreationCB t\_postMarkerCreationCB

Specifies the name of a user-defined SKILL procedure that can be used to perform any required post-processing tasks on the generated markers. For more information, see <u>Post-Processing Voltage Labels and Markers</u>.

Voltage Dependent Rules Functions

```
?voltageRounding { "roundOff" | "floor" | "ceiling" }
```

Specifies the rounding rule to follow.

- roundOff rounds the voltage value to the nearest 0.01
- ceiling rounds up the voltage value to the nearest 0.01
- floor rounds down the voltage value to the nearest 0.01

The default is "roundOff".

```
?mode { "maxVoltage" | "minVoltage" | "bothVoltage" }
```

Specifies whether markers are to be created for maximum, minimum, or all voltage values.

The default is "maxVoltage".

?ignoreZeroVoltNets lt\_netNames

Lists the names of nets which have voltage values of (0,0) but for which markers should be created anyway.

Names must each be enclosed in double quotes and separated by a space.

#### Value Returned

t Marker creation ran without any errors.

nil Marker creation encountered errors.

### Example

```
cv = geGetEditCellView()
netIds = cv~>nets
callback = stringToSymbol("vdrMarkerCB")
vdrCreateVoltageMarkersOnNets(cv netIds "voltagePurpose.map"
    ?size 0.01 ?voltageRounding "floor" ?voltageMode "bothVoltage"
    ?ignoreZeroVoltNets list("AVSS" "AVDD") ?postMarkerCreationCB callback)
```

Creates markers for minimum and maximum voltage values for the list of netIDs in the currently edited cellview. The markers are 0.01 high and are generated for nets AVSS and AVDD even if their values are 0. Voltage values are rounded down to the nearest 0.01. The code automatically executes a user-defined callback named vdrMarkerCB to perform some post-processing tasks.

Voltage Dependent Rules Functions

# Related Topics

Generating Voltage Markers for Manually Entered Voltages

Voltage Dependent Rules Functions

# vdrCreateVSyncConstraintsFromFile

```
vdrCreateVSyncConstraintsFromFile(
    t_libName
    t_cellName
    t_viewName
    t_fileName
)
=> nil
```

## Description

(ICADVM20.1 Only) Creates Voltage Synced Net (vsync) constraints in the specified source schematic cellview based on information from the given CSV file. The schematic view is opened in read-only mode.

### **Arguments**

| t_libName  | Name of the library in which the schematic cellview resides.         |
|------------|----------------------------------------------------------------------|
| t_cellName | Name of the schematic cell in which constraints are to be created.   |
| t_viewName | Name of the view in which vsync constraints are to be created.       |
| t_fileName | Name of the CSV file specifying the vsync constraints to be created. |

#### Value Returned

None

#### **Example**

Voltage Dependent Rules Functions

Creates the vsync constraint specified in file Data.csv in cellview lib1/cell1/schematic and writes appropriate messages to the log file.

### Related Topics

VSync Constraints Visualizer

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Voltage Dependent Rules Functions

### vdrDeleteLabels

## **Description**

Deletes from the specified cellview all the labels and markers created using the VDR flows.

### **Arguments**

d cellviewID

Database ID of the top layout cellview from which labels and

markers are to be deleted.

### **Value Returned**

nil

All the VDR labels and markers in the cellview were deleted.

## **Example**

vdrDeleteLabels(topCvId)

Deletes all the VDR labels and markers in the cellview with the given database ID.

### **Related Topics**

**Deleting Voltage Labels and Markers** 

Voltage Dependent Rules Functions

### vdrGenerateLabelsGUI

```
vdrGenerateLabelsGUI(
    )
=> t / nil
```

### **Description**

Opens the Voltage Dependent Rules form, which you can use to create voltage labels or markers on nets. The command works only in Layout XL and higher tiers.

### **Arguments**

None

#### **Value Returned**

t The form was opened.

nil The form could not be opened, possibly because you are not

using Layout XL.

### **Example**

```
vdrGenerateLabelsGUI()
+
```

Opens the Voltage Dependent Rules form.

### **Related Topics**

Generating Voltage Labels from Simulation Data for All Nets

Generating Voltage Markers from Simulation Data for All Nets

Voltage Dependent Rules Functions

# vdrGenerateVSyncShapes

### **Description**

(ICADVM20.1 EXL Only) Creates voltage sync (vsync) shapes between nets that are constrained by a common voltage sync constraint.

### **Arguments**

d\_cellviewID

Database ID of the layout cellview in which the vsync shapes are to be created.

# Value Returned

The vsync shapes were created.

ni1

The vsync shapes could not be created.

## **Example**

```
when(window = hiGetCurrentWindow()
  when(cellview = geGetEditCellView(window)
    vdrGenerateVSyncShapes(cellview)
  )
)
```

Generates vsync shapes for the cellview being edited in the current session.

## Related Topics

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Voltage Dependent Rules Functions

# vdrGetValidLayers

```
vdrGetValidLayers(
    )
=> 1_layers / nil
```

## **Description**

Returns the list of valid layers on which labels or markers can be generated. The list was specified previously using the vdrSetValidLayers function.

## **Arguments**

None

#### Value Returned

1\_layersnilNo layer names have been registered.

## **Example**

```
cv = geGetEditCellView()
if(cv then
    layers = list("Metall" "Metal2" "Poly")
    vdrSetValidLayers(cv layers)
)

vdrGetValidLayers()
>("Metal1" "Metal2" "Poly")
```

Returns the list of layer names registered using the <u>vdrSetValidLayers</u> command.

# Related Topics

vdrSetValidLayers

Specifying Layers and Purposes for Generic Voltage Labels

Voltage Dependent Rules Functions

# vdrRunSanityChecker

```
vdrRunSanityChecker(
    d_cellviewID
    [ g_checkMarkers ]
    [ g_checkAgainstLayout ]
    [ f_tolerance ]
    [ g_isToleranceAbsolute ]
    [ t_logFile ]
)
    => t / nil
```

### Description

Checks constrained voltage labels in the layout against the voltage values stored in the schematic or layout net properties and reports any discrepancies between the values. You can optionally apply a threshold up to which mismatches are tolerated and not reported. You can also specify the location and name of a log file in which the report is captured.

### **Arguments**

| d_cellviewID       | Database ID of the layout cellview in which labels and markers are to be checked.                     |
|--------------------|-------------------------------------------------------------------------------------------------------|
| g_checkMarkers     | Specifies whether to check markers (t) or labels (nil) in the layout.                                 |
|                    | Environment variable: <a href="https://www.vdr.nubre-realization.com/">wdrSanityCheckerObjectType</a> |
| g_checkAgainstLayo | ut                                                                                                    |
|                    | Specifies whether to check the voltage values in labels or                                            |

markers against layout net properties (t) or schematic net properties (nil).

Environment variable: vdrSanityCheckerCheckAgainst

Threshold beyond which mismatches are to be reported.

Environment variable: <u>vdrSanityCheckerTolerance</u>

g\_isToleranceAbsolute

f\_tolerance

Specifies whether the tolerance value is considered an absolute value (t) or a relative percentage based on the net voltage (nil).

Environment variable: <a href="https://www.vdrSanityCheckerToleranceType">vdrSanityCheckerToleranceType</a>

Voltage Dependent Rules Functions

t\_logFile Path and name of a log file in which the discrepancy report is to be captured.

When you specify a log filename, only a summary message is

printed in the CIW. If you do not specify a log filename, discrepancies are reported in a table printed in the CIW.

Environment variable: <a href="https://www.vdr.anityCheckerLogFile">vdrSanityCheckerLogFile</a>

#### **Value Returned**

t The comparison report was generated.

nil The sanity check could not be run.

### **Example**

```
checkMarkers = t
checkAgainstLayout = nil
tolerance = 0.05
isToleranceAbsolute = nil
logFile = "vdrReport.log"
when(window = hiGetCurrentWindow()
    when(cellView = geGetEditCellView(window)
        vdrRunSanityChecker(cellView checkMarkers checkAgainstLayout tolerance \
        isToleranceAbsolute logFile)
    )
)
```

Checks the voltage markers in the currently edited layout cellview against the values stored in the layout net properties and captures the report in a file called vdrReport.log. Only discrepancies of more than 0.05V are reported.

### Related Topics

Sanity Checking Voltage Values in Constrained Labels

Voltage Dependent Rules Functions

# vdrRunVSyncSanityChecker

## Description

(ICADVM20.1 EXL Only) Checks whether there are valid voltage sync (vsync) shapes on nets that are constrained by a common vsync constraint. The checker reports any vsync shapes that are wrongly created and any nets that have a vsync constraint defined but no vsync shape between them.

### **Arguments**

 $d\_cellviewID$  Database ID of the layout cellview to be checked.

t\_logFile Path and name of a log file in which the report is to be

captured.

When you specify a log filename, only a summary message is printed in the CIW. If you do not specify a log filename, discrepancies are reported in a table printed in the CIW.

Environment variable: vdrSanityCheckerLogFile

#### Value Returned

t The sanity check was completed.

nil The sanity check could not be run.

# **Example**

```
when(window = hiGetCurrentWindow()
  when(cellView = geGetEditCellView(window)
    logFile = "report.log"
    vdrRunVSyncSanityChecker(cellView logFile)
  )
)
```

Checks vsync shapes in the currently edited layout cellview and saves the report in a file called report.log.

Voltage Dependent Rules Functions

# Related Topics

Sanity Checking Voltage Values in Constrained Labels

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Voltage Dependent Rules Functions

# vdrSanityCheckerGUI

```
vdrSanityCheckerGUI(
    )
    => t / nil
```

### **Description**

Opens the VDR Sanity Checker form, which you can use to check constrained VDR voltage labels in the layout view and report any labels that are missing or which have values different from the values specified for the net in the schematic or layout design.

### **Arguments**

None

#### **Value Returned**

t The form was opened.

nil The form was not opened.

#### **Example**

```
vdrSanityCheckerGUI()
+
```

Opens the VDR Sanity Checker form.

### Related Topics

**VDR Sanity Checker** 

Sanity Checking Voltage Values in Constrained Labels

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Voltage Dependent Rules Functions

# vdrSetNetVoltageRange

```
vdrSetNetVoltageRange(
    t_libName
    t_cellName
    l_viewList
    [ ?netVoltages l_netVoltages ]
    [ ?voltageDataFile t_voltageInfoFile ]
    [ ?verbose { t | nil } ]
    [ ?logFile t_logFile ]
    )
    => t / nil
```

## **Description**

(ICADVM20.1 Only) Sets net voltages in the specified list of cellviews. The voltages can either be specified directly as a list when the command is called or read from voltage information file.

### **Arguments**

t\_libName

Name of the library in which the cellviews to be updated reside.

t\_cellName

Name of the cell whose views are to be updated.

1\_viewList

List of view names for which net voltages are to be set.

?netVoltages l\_netVoltages

List of net names and corresponding minimum and maximum voltage values to be applied to the specified list of cellviews. The asterisk (\*) is supported as a wildcard character.

### Examples:

```
list("net15" 0.11 9.09)
list("net*" 0.11 1.09)
```

The ?netVoltages and ?voltageDateFile arguments are mutually exclusive.

Voltage Dependent Rules Functions

?voltageDataFile t\_voltageInfoFile

Name of a comma-separated value (CSV) file that contains voltage information, including net names and corresponding minimum and maximum voltage values. The asterisk (\*) is supported as a wildcard character.

The ?netVoltages and ?voltageDateFile arguments are mutually exclusive.

?verbose { t | nil }

Enables verbose mode when generating labels based on a voltage information file. The software prints one message per entry in the file confirming the action taken for that entry.

The default is nil, which means that no messages are issued. When set to t, messages are printed in the CIW. Use ?logFile to save the messages to a separate log file.

?logFile t\_logFile

Name of a log file in which messages are saved when generating labels from a voltage information file in verbose mode.

#### Value Returned

t The specified net voltages were set in the cellviews given.

nil The specified net voltages could not be set.

### **Examples**

```
vdrSetNetVoltageRange(cv~>libName cv~>cellName list(list("layout" "r"))
?voltageDataFile "data1.csv")
```

Sets the minimum and maximum net voltages specified in voltage information file data1.csv on the specified layout cellview in read mode.

```
vdrSetNetVoltageRange(cv~>libName cv~>cellName list("layout") ?voltageDataFile
"data1.csv")
```

Sets the minimum and maximum net voltages specified in voltage information file data1.csv on the specified layout cellview.

```
vdrSetNetVoltageRange(cv~>libName cv~>cellName list(list("layout" "r")
list("layout org" "r") ) ?netVoltages list("net*" 0.11 1.09))
```

Voltage Dependent Rules Functions

Sets the specified minimum and maximum voltages on all the nets in the layout and layout\_org views in the specified cell in read mode.

```
vdrSetNetVoltageRange(cv~>libName cv~>cellName list(list("layout" "r")
list("layout_org" "r") ) ?netVoltages list("net15" 0.11 9.09))
```

Sets the specified minimum and maximum voltages on net15 in the layout and layout\_org views in the specified cell in read mode.

### Related Topics

Generating Voltage Labels from a Voltage Information File

Voltage Dependent Rules Functions

# vdrSetValidLayers

### **Description**

Specifies a list of valid layers on which labels or markers can be generated. The software creates labels or markers only for nets on one of the listed layers. Each subsequent call to the function overrides all the previously set layers.

## **Arguments**

| d_cellviewID          | Database ID of the cellview for which the valid layers are to be set.               |
|-----------------------|-------------------------------------------------------------------------------------|
| <i>l_layers</i>   nil | List of valid layer names, each enclosed in double quotes and separated by a space. |
|                       | Type nil to unset all previously registered layer names.                            |

#### **Value Returned**

| t   | The specified list of layers has been successfully registered (or unset if you specified $nil$ ). |
|-----|---------------------------------------------------------------------------------------------------|
| nil | An error occurred while registering the list of layers.                                           |

### **Example**

```
cv = geGetEditCellView()
rValue = nil
if(cv then
    layers = list("Metal1" "Metal2" "Metal3" "Poly")
    rValue = vdrSetValidLayers(cv layers)
)
```

Registers Metall, Metall, Metall, and Poly as valid layers for use in the voltage dependent rules flow. Labels or markers are created only for nets on those layers.

```
cv = geGetEditCellView()
rValue = nil
if(cv then
    layers = nil
```

Voltage Dependent Rules Functions

```
rValue = vdrSetValidLayers(cv layers)
```

Removes the valid layers specification for the current cellview.

# Related Topics

vdrGetValidLayers

Specifying Layers and Purposes for Generic Voltage Labels

Voltage Dependent Rules Functions

# vdrTransferVSyncConstraints

## **Description**

Transfers Voltage Synced Net (vsync) constraints from a specified source cellview to the specified target cellviews without opening any of the cellviews involved. If there is no target cellview specified, then the constraints are transferred to all open cellviews.

### **Arguments**

| l_srcCellview  | The cellview containing the constraints to be transferred. For example:                    |
|----------------|--------------------------------------------------------------------------------------------|
|                | <pre>list("lib1" "cell1" "schematic")</pre>                                                |
| l_tgtCellviews | List of one or more cellviews to which the constraints are to be transferred. For example: |
|                | <pre>list(list("lib1" "cell1" "layout") list("lib2" "cell2" "layout_cv"))</pre>            |

#### Value Returned

None

#### **Example**

Voltage Dependent Rules Functions

Transfers voltage synced net constraints from source cellview lib1/cell1/schematic to target cellviews lib1/cell1/layout and lib2/cell2/layout\_cv.

## **Related Topics**

VSync Constraints Visualizer

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)

Voltage Dependent Rules Functions

# vdrVsyncVisualizerGUI

```
vdrVsyncVisualizerGUI(
    )
    => t / nil
```

### **Description**

(ICADVM20.1 EXL Only) Opens the VDR Constraints Visualizer form, which you can use to create *Voltage Synced Net* (vsync) constraints from the contents of a CSV file, list the vsync constraints currently present in the layout view, and delete those that are no longer required.

### **Arguments**

None

#### **Value Returned**

t The form was opened.

nil The form could not be opened.

#### **Example**

```
vdrVsyncVisualizerGUI()
+
```

Opens the VDR Constraints Visualizer form.

### Related Topics

VSync Constraints Visualizer

Defining and Checking Voltage Synced Nets (ICADVM20.1 EXL Only)