

# **IC Compiler**

## **Implementation**

## **User Guide**

---

Version F-2011.09-SP2, December 2011

**SYNOPSYS®**

# Copyright Notice and Proprietary Information

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

## Right to Copy Documentation

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

This document is duplicated with the permission of Synopsys, Inc., for the exclusive use of \_\_\_\_\_ and its employees. This is copy number \_\_\_\_\_.

## Destination Control Statement

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

## Disclaimer

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

## Registered Trademarks (®)

Synopsys, AEON, AMPS, ARC, Astro, Behavior Extracting Synthesis Technology, Cadabra, CATS, Certify, Chipidea, CHIPit, CODE V, CoMET, Confirma, CoWare, Design Compiler, DesignSphere, DesignWare, Eclypse, Formality, Galaxy Custom Designer, Global Synthesis, HAPS, HapsTrak, HDL Analyst, HSIM, HSPICE, Identify, Leda, LightTools, MAST, MaVeric, METeor, ModelTools, NanoSim, NOVeA, OpenVera, ORA, PathMill, Physical Compiler, PrimeTime, SCOPE, SIVL, SNUG, SolvNet, Sonic Focus, STAR Memory System, Syndicated, Synplicity, Synplify, Synplify Pro, Synthesis Constraints Optimization Environment, TetraMAX, the Synplicity logo, UMRBus, VCS, Vera, and YieldExplorer are registered trademarks of Synopsys, Inc.

## Trademarks (™)

AFGen, Apollo, ASAP, Astro-Rail, Astro-Xtalk, Aurora, AvanWaves, BEST, Columbia, Columbia-CE, Cosmos, CosmosLE, CosmosScope, CRITIC, CustomExplorer, CustomSim, DC Expert, DC Professional, DC Ultra, Design Analyzer, Design Vision, DesignerHDL, DesignPower, DFTMAX, Direct Silicon Access, Discovery, EMBED-IT!, Encore, EPIC, Galaxy, HANEX, HDL Compiler, Hercules, Hierarchical Optimization Technology, High-performance ASIC Prototyping System, plus HSIM<sup>plus</sup>, i-Virtual Stepper, IICE, in-Sync, iN-Tandem, Intelli, Jupiter, Jupiter-DP, JupiterXT, JupiterXT-ASIC, Liberty, Libra-Passport, Library Compiler, Macro-PLUS, Magellan, Mars, Mars-Rail, Mars-Xtalk, Milkyway, ModelSource, Module Compiler, MultiPoint, ORAengineering, Physical Analyst, Planet, Planet-PL, Polaris, Power Compiler, Raphael, RippledMixer, Saturn, Scirocco, Scirocco-i, SiWare, Star-RCXT, Star-SimXT, StarRC, System Compiler, System Designer, Taurus, TotalRecall, TSUPREM-4, VCSI, VHDL Compiler, VMC, and Worksheet Buffer are trademarks of Synopsys, Inc.

## Service Marks (SM)

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

SystemC is a trademark of the Open SystemC Initiative and is used under license.

ARM and AMBA are registered trademarks of ARM Limited.

Saber is a registered trademark of SabreMark Limited Partnership and is used under license.

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

## **Copyright Statement for the Command-Line Editing Feature**

Copyright © 1992, 1993 The Regents of the University of California. All rights reserved. This code is derived from software contributed to Berkeley by Christos Zoulas of Cornell University.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
3. All advertising materials mentioning features or use of this software must display the following acknowledgement: This product includes software developed by the University of California, Berkeley and its contributors.
4. Neither the name of the University nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

## **Copyright Statement for the Line-Editing Library**

Copyright © 1992 Simmule Turner and Rich Salz. All rights reserved.

This software is not subject to any license of the American Telephone and Telegraph Company or of the Regents of the University of California.

Permission is granted to anyone to use this software for any purpose on any computer system, and to alter it and redistribute it freely, subject to the following restrictions:

1. The authors are not responsible for the consequences of use of this software, no matter how awful, even if they arise from flaws in it.
2. The origin of this software must not be misrepresented, either by explicit claim or by omission. Since few users ever read sources, credits must appear in the documentation.
3. Altered versions must be plainly marked as such, and must not be misrepresented as being the original software. Since few users ever read sources, credits must appear in the documentation.
4. This notice may not be removed or altered.



# Contents

---

|                                                          |        |
|----------------------------------------------------------|--------|
| What's New in This Release . . . . .                     | xxxiv  |
| About This Guide . . . . .                               | xxxiv  |
| Customer Support . . . . .                               | xxxvii |
| <b>Part I: IC Compiler Implementation Flow</b>           |        |
| <b>1. Introduction to IC Compiler</b>                    |        |
| Supported Platforms . . . . .                            | 1-2    |
| IC Compiler Packages . . . . .                           | 1-2    |
| User Interfaces . . . . .                                | 1-5    |
| Methodology Overview . . . . .                           | 1-5    |
| Speeding Up the Basic Flow . . . . .                     | 1-8    |
| <b>2. Working With IC Compiler</b>                       |        |
| Getting Started . . . . .                                | 2-2    |
| Starting IC Compiler . . . . .                           | 2-2    |
| Entering <code>icc_shell</code> Commands . . . . .       | 2-4    |
| Choosing Menu Commands in GUI Windows . . . . .          | 2-5    |
| Interrupting or Terminating Command Processing . . . . . | 2-7    |
| Opening and Closing the GUI . . . . .                    | 2-7    |
| Using Tcl Scripts . . . . .                              | 2-8    |
| Using Setup Files . . . . .                              | 2-9    |

|                                                                  |      |
|------------------------------------------------------------------|------|
| Using Command Log Files .....                                    | 2-10 |
| Exiting IC Compiler .....                                        | 2-10 |
| Getting Help in IC Compiler .....                                | 2-11 |
| Getting Help on the Command Line .....                           | 2-12 |
| Finding Menu Commands and Dialog Boxes.....                      | 2-13 |
| Viewing Man Pages.....                                           | 2-14 |
| Displaying the List of Keyboard Shortcuts.....                   | 2-15 |
| Using Online Help .....                                          | 2-15 |
| Searching for Text.....                                          | 2-16 |
| Configuring the Help Browser.....                                | 2-17 |
| Using the IC Compiler Command-Line Interface .....               | 2-18 |
| Using Wildcard Characters .....                                  | 2-19 |
| Using Aliases.....                                               | 2-20 |
| Listing and Rerunning Previously Entered Commands.....           | 2-20 |
| Reporting Memory Usage and Runtime .....                         | 2-20 |
| Redirecting and Appending Command Output .....                   | 2-21 |
| Working With the GUI .....                                       | 2-22 |
| Using GUI Windows.....                                           | 2-22 |
| Menu Bar .....                                                   | 2-23 |
| Toolbars .....                                                   | 2-24 |
| Status Bar.....                                                  | 2-24 |
| View Windows .....                                               | 2-25 |
| Panels.....                                                      | 2-26 |
| Working in the Main Window.....                                  | 2-26 |
| Working With the Console .....                                   | 2-28 |
| Viewing the Session Log .....                                    | 2-29 |
| Viewing the History View .....                                   | 2-31 |
| Previewing <code>icc_shell</code> Commands in Dialog Boxes ..... | 2-32 |
| Viewing the Physical Layout .....                                | 2-33 |
| Setting the Current Task.....                                    | 2-34 |
| Setting the Primary Design.....                                  | 2-35 |
| Setting GUI Preferences .....                                    | 2-35 |
| Recording and Replaying a GUI Session .....                      | 2-36 |
| Checking the Syntax and Semantics of Your Scripts .....          | 2-37 |
| Installation Requirements .....                                  | 2-38 |
| Running the Synopsys Syntax Checker.....                         | 2-38 |
| Limitations of the Synopsys Syntax Checker.....                  | 2-39 |

|                                                     |      |
|-----------------------------------------------------|------|
| Bytecode-Compiled Files . . . . .                   | 2-40 |
| TclPro Limitations . . . . .                        | 2-40 |
| Working With Licenses . . . . .                     | 2-40 |
| Listing the Licenses in Use . . . . .               | 2-41 |
| Getting Licenses . . . . .                          | 2-41 |
| Enabling License Queuing . . . . .                  | 2-41 |
| Releasing Licenses . . . . .                        | 2-42 |
| Getting and Releasing Licenses in the GUI . . . . . | 2-43 |
| Enabling Multicore Processing . . . . .             | 2-43 |
| Configuring Multithreading . . . . .                | 2-44 |
| Configuring Distributed Processing . . . . .        | 2-45 |

### 3. Preparing the Design

|                                                       |      |
|-------------------------------------------------------|------|
| Setting Up the Libraries . . . . .                    | 3-3  |
| Setting Up the Logic Libraries . . . . .              | 3-3  |
| Setting Up the Physical Libraries . . . . .           | 3-4  |
| Creating a Milkyway Design Library . . . . .          | 3-5  |
| Specifying the Milkyway Reference Libraries . . . . . | 3-5  |
| Opening a Milkyway Design Library . . . . .           | 3-6  |
| Reporting a Milkyway Design Library . . . . .         | 3-7  |
| Changing Physical Library Information . . . . .       | 3-9  |
| Saving Physical Library Information . . . . .         | 3-10 |
| Verifying the Libraries . . . . .                     | 3-11 |
| Reading the Design . . . . .                          | 3-11 |
| Reading a Design in Milkyway Format . . . . .         | 3-12 |
| Reading a Design in .ddc Format . . . . .             | 3-13 |
| Reading a Design in ASCII Format . . . . .            | 3-13 |
| Setting the Working Design . . . . .                  | 3-14 |
| Setting the Current Design . . . . .                  | 3-14 |
| Opening Designs in a Hierarchical Stack . . . . .     | 3-14 |
| Traversing Multiple Levels . . . . .                  | 3-15 |
| Changing Between Different Stacks . . . . .           | 3-16 |
| Transforming Parent and Child Coordinates . . . . .   | 3-17 |
| Annotating the Physical Data . . . . .                | 3-17 |
| Reading DEF Files . . . . .                           | 3-18 |
| Reading Floorplan Files . . . . .                     | 3-18 |

|                                                                          |      |
|--------------------------------------------------------------------------|------|
| Copying Physical Data . . . . .                                          | 3-18 |
| Validating Physical Data . . . . .                                       | 3-19 |
| Specifying the Power Intent . . . . .                                    | 3-19 |
| Creating Logical Power and Ground Connections . . . . .                  | 3-20 |
| Creating the Connections for Single-Voltage Designs . . . . .            | 3-21 |
| Creating the Connections for Multivoltage Designs . . . . .              | 3-22 |
| Checking the Design Database . . . . .                                   | 3-23 |
| Using the GUI Partition Editor . . . . .                                 | 3-24 |
| Setting Up for Multicorner-Multimode Analysis and Optimization . . . . . | 3-29 |
| Defining Scenarios . . . . .                                             | 3-30 |
| Checking the Scenario Definitions . . . . .                              | 3-31 |
| Managing the Scenarios . . . . .                                         | 3-31 |
| Selecting the Scenarios to Use . . . . .                                 | 3-31 |
| Reporting the Scenarios . . . . .                                        | 3-34 |
| Removing Scenarios . . . . .                                             | 3-36 |
| Preparing for Timing Analysis and RC Calculation . . . . .               | 3-36 |
| Setting Up the TLUPlus Files . . . . .                                   | 3-36 |
| Specifying the Operating Conditions . . . . .                            | 3-38 |
| Selecting the Operating Condition Analysis Mode . . . . .                | 3-39 |
| Preparing for Minimum and Maximum Timing Analysis . . . . .              | 3-39 |
| Setting Voltage and Temperature Scaling Between Libraries . . . . .      | 3-42 |
| Setting Timing Constraints . . . . .                                     | 3-43 |
| Selecting the Delay Calculation Method . . . . .                         | 3-44 |
| Back-Annotating Delay or Parasitic Data . . . . .                        | 3-45 |
| Linking Designs . . . . .                                                | 3-45 |
| Linking Designs Without Multicorner-Multimode Scenarios . . . . .        | 3-46 |
| Linking Designs With Multicorner-Multimode Scenarios . . . . .           | 3-46 |
| Resolving References With Operating Condition Mismatches . . . . .       | 3-48 |
| Saving a Design . . . . .                                                | 3-50 |
| Saving the Design in Milkyway Format . . . . .                           | 3-51 |
| Saving the Design From the Command Line . . . . .                        | 3-51 |
| Saving the Design in the GUI . . . . .                                   | 3-51 |
| Saving the Design Settings in the Milkyway Design Library . . . . .      | 3-53 |
| Saving the Design in ASCII Format . . . . .                              | 3-54 |
| Writing GDSII and OASIS Layout Data Files . . . . .                      | 3-55 |

|                                                                     |      |
|---------------------------------------------------------------------|------|
| Closing Designs .....                                               | 3-56 |
| Closing a Milkyway Design Library .....                             | 3-57 |
| Archiving Designs .....                                             | 3-58 |
| <b>4. Design for Test</b>                                           |      |
| Overview of the DFT Flow .....                                      | 4-2  |
| Preparing for Physical DFT .....                                    | 4-3  |
| Performing Scan Synthesis and Generating a SCANDEF File .....       | 4-3  |
| Hierarchical Flow .....                                             | 4-4  |
| Loading the SCANDEF File .....                                      | 4-5  |
| Scan Chain Consistency Checking .....                               | 4-5  |
| Removing SCANDEF Data .....                                         | 4-6  |
| Optimizing Scan Chains .....                                        | 4-6  |
| Placement-Aware Scan Chain Reordering .....                         | 4-7  |
| Clock-Aware Scan Reordering .....                                   | 4-9  |
| Continuing the Optimization Flow Without SCANDEF Data .....         | 4-10 |
| DFT Optimization Flow .....                                         | 4-11 |
| Viewing Scan Chains .....                                           | 4-12 |
| <b>5. Power Optimization</b>                                        |      |
| Types of Power Optimization .....                                   | 5-2  |
| Annotating Switching Activity .....                                 | 5-2  |
| Reducing Leakage-Power Using Multiple Threshold-Voltage Cells ..... | 5-3  |
| Multiple Threshold-Voltage Libraries .....                          | 5-4  |
| Defining Multiple Threshold-Voltage Cells Using Attributes .....    | 5-5  |
| Adaptive Leakage-Power Optimization .....                           | 5-6  |
| Specifying the Multiple Threshold-Voltage Constraint .....          | 5-6  |
| Specifying the Scenarios for Leakage-Power Optimization .....       | 5-7  |
| Performing Leakage-Power Optimization .....                         | 5-7  |
| Power Optimization During Placement .....                           | 5-8  |
| Power Optimization During Clock Tree Synthesis .....                | 5-8  |
| Power Optimization During Routing .....                             | 5-9  |

|                                                                |      |
|----------------------------------------------------------------|------|
| Performing Final Stage Leakage-Power Recovery .....            | 5-10 |
| Leakage-Power Optimization Flow Example .....                  | 5-13 |
| <b>6. Placement</b>                                            |      |
| Defining Placement Blockages .....                             | 6-2  |
| Defining Keepout Margins .....                                 | 6-2  |
| Defining Global Keepout Margins .....                          | 6-3  |
| Defining Cell-Specific Keepout Margins .....                   | 6-4  |
| Defining Area-Based Placement Blockages .....                  | 6-5  |
| Creating Placement Blockages for Thin Channels .....           | 6-9  |
| Preventing Cell Placement in the Default Voltage Area .....    | 6-10 |
| Setting Placement Options .....                                | 6-11 |
| Setting the Congestion Options .....                           | 6-11 |
| Setting the Move Bounds .....                                  | 6-13 |
| Defining Intercell and Boundary Spacing Rules .....            | 6-14 |
| Defining the Buffer Strategy for Optimization .....            | 6-16 |
| Setting the Preferred Buffers for Hold Fixing .....            | 6-16 |
| Setting Up Multithreading .....                                | 6-16 |
| Enabling Tie Cell Insertion .....                              | 6-17 |
| Preserving dont_touch Nets During Optimization .....           | 6-18 |
| Setting Placement and Optimization Attributes .....            | 6-19 |
| Inserting Port Protection Diodes .....                         | 6-19 |
| Preparing for High-Fanout Net Synthesis .....                  | 6-20 |
| Generating Physical Data Reports .....                         | 6-20 |
| Analyzing Placement and Optimization Feasibility .....         | 6-22 |
| Analyzing Cell Displacement During Legalization .....          | 6-24 |
| Performing Clock Tree Synthesis During Placement .....         | 6-26 |
| Performing Placement and Optimization .....                    | 6-26 |
| Omitting Initial Placement .....                               | 6-28 |
| Using Physical Guidance From Design Compiler .....             | 6-29 |
| Saving Intermediate Results During Preroute Optimization ..... | 6-30 |
| Setting Up for Congestion-Driven Placement .....               | 6-31 |

|                                                                     |      |
|---------------------------------------------------------------------|------|
| Enabling Magnet Placement .....                                     | 6-31 |
| Pulling Cells in a Continuous Datapath Toward a Magnet Object ..... | 6-33 |
| Excluding Cells From Magnet Placement.....                          | 6-34 |
| Reporting Magnet Cells .....                                        | 6-35 |
| Using the Top-Level Buffering Technique for Optimization .....      | 6-35 |
| Using Physical Optimization .....                                   | 6-36 |
| Performing Layer Optimization.....                                  | 6-38 |
| Performing Preroute RC Estimation .....                             | 6-39 |
| Modifying the RC Coefficients .....                                 | 6-40 |
| Defining Net-Based Layer Constraints .....                          | 6-41 |
| Introducing Pessimism .....                                         | 6-41 |
| Enabling Via Resistance Estimation .....                            | 6-42 |
| Scaling the Via Resistance Values.....                              | 6-43 |
| Manually Specifying Via Resistance Values.....                      | 6-43 |
| Analyzing Placement .....                                           | 6-43 |
| Placement Area Utilization.....                                     | 6-44 |
| Timing Analysis .....                                               | 6-46 |
| Power Analysis .....                                                | 6-51 |
| Reporting Quality-of-Results .....                                  | 6-52 |
| create_qor_snapshot .....                                           | 6-53 |
| query_qor_snapshot.....                                             | 6-54 |
| Analyzing Timing Results in the GUI .....                           | 6-56 |
| Applying Filters.....                                               | 6-57 |
| Creating Subgroups .....                                            | 6-58 |
| Analyzing the Clock Tree Synthesis Results.....                     | 6-59 |
| Placement Analysis Tools in the GUI.....                            | 6-59 |
| Cell Density Map.....                                               | 6-61 |
| Congestion Maps .....                                               | 6-63 |
| Hierarchy Visual Mode .....                                         | 6-64 |
| Clock Tree Visual Mode .....                                        | 6-65 |
| Net Connections in Area Visual Mode .....                           | 6-65 |
| Refining Placement.....                                             | 6-69 |
| <b>7. Clock Tree Synthesis</b>                                      |      |
| Prerequisites for Clock Tree Synthesis .....                        | 7-3  |
| Design Prerequisites .....                                          | 7-3  |
| Library Prerequisites .....                                         | 7-4  |

|                                                                     |      |
|---------------------------------------------------------------------|------|
| Analyzing the Clock Trees.....                                      | 7-4  |
| Defining the Clock Trees.....                                       | 7-5  |
| Cascaded Clocks.....                                                | 7-5  |
| Cascaded Generated Clocks.....                                      | 7-6  |
| Identifying the Clock Tree Endpoints .....                          | 7-7  |
| Analyzing Clock Sink Groups .....                                   | 7-9  |
| Setting Sink Group Options .....                                    | 7-10 |
| Ignoring Clock Tree Exceptions .....                                | 7-11 |
| Ignoring Buffers and Inverters .....                                | 7-12 |
| Defining the Clock Root Attributes.....                             | 7-13 |
| Specifying Clock Tree Exceptions.....                               | 7-13 |
| Precedence of Clock Tree Exceptions.....                            | 7-17 |
| Specifying Nonstop Pins .....                                       | 7-18 |
| Specifying Exclude Pins .....                                       | 7-19 |
| Specifying Float Pins .....                                         | 7-20 |
| Specifying Float Pins for Multicorner Clock Tree Optimization ..... | 7-22 |
| Specifying Stop Pins .....                                          | 7-23 |
| Specifying Don't Touch Subtrees.....                                | 7-24 |
| Specifying Don't Buffer Nets .....                                  | 7-24 |
| Specifying Don't Size Cells .....                                   | 7-25 |
| Specifying Size-Only Cells.....                                     | 7-25 |
| Preserving the Clock Pins of Existing Hierarchies.....              | 7-26 |
| Specifying the Clock Tree References .....                          | 7-27 |
| Defining Clock Cell Spacing Rules .....                             | 7-29 |
| Specifying Clock Tree Synthesis Options .....                       | 7-31 |
| Specifying the Clock Tree Synthesis Goals .....                     | 7-34 |
| Setting Clock Tree Design Rule Constraints.....                     | 7-35 |
| Setting the Maximum Transition Time Constraints .....               | 7-36 |
| Setting Clock Tree Timing Goals .....                               | 7-37 |
| Setting Clock Tree Routing Options .....                            | 7-38 |
| Specifying Routing Rules .....                                      | 7-39 |
| Shielding Clock Nets.....                                           | 7-40 |
| Specifying Routing Layers .....                                     | 7-42 |
| Association of Nondefault Routing Rules With Reference Cells.....   | 7-43 |
| Inserting Boundary Cells .....                                      | 7-45 |

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| Selecting the Clock Tree Clustering . . . . .                             | 7-45 |
| Enabling On-Chip-Variation-Aware Clustering . . . . .                     | 7-46 |
| Enabling Logic-Level Balancing . . . . .                                  | 7-46 |
| Enabling Region-Aware Clock Tree Synthesis . . . . .                      | 7-49 |
| Specifying Clock Tree Optimization Options . . . . .                      | 7-50 |
| Controlling Embedded Clock Tree Optimization . . . . .                    | 7-50 |
| Controlling Preroute Clock Tree Optimization . . . . .                    | 7-51 |
| Controlling Postroute Clock Tree Optimization . . . . .                   | 7-52 |
| Saving Intermediate Results During Preroute Optimization . . . . .        | 7-52 |
| Inserting User-Specified Clock Trees . . . . .                            | 7-53 |
| Reading a Clock Configuration File . . . . .                              | 7-53 |
| Reducing Skew Variation by Using RC Constraint-Based Clustering . . . . . | 7-53 |
| Saving a Clock Configuration File . . . . .                               | 7-54 |
| Defining the Clock Tree Structure . . . . .                               | 7-54 |
| Handling Specific Design Characteristics . . . . .                        | 7-58 |
| Multicorner-Multimode Designs . . . . .                                   | 7-59 |
| Handling Hard Macro Cells . . . . .                                       | 7-60 |
| Handling Existing Clock Trees . . . . .                                   | 7-60 |
| Identifying Existing Clock Trees . . . . .                                | 7-61 |
| Preserving Portions of an Existing Clock Tree . . . . .                   | 7-61 |
| Removing Clock Trees . . . . .                                            | 7-61 |
| Handling Non-Unate Gated Clocks . . . . .                                 | 7-63 |
| Handling Integrated Clock-Gating Cells . . . . .                          | 7-64 |
| Using XOR Self-Gating to Save Dynamic Power . . . . .                     | 7-64 |
| Optimizing for Clock Tree QoR . . . . .                                   | 7-67 |
| Optimizing for Power . . . . .                                            | 7-69 |
| Optimizing for Timing on Enable Signals . . . . .                         | 7-71 |
| Balancing Multiple Clocks . . . . .                                       | 7-72 |
| Defining the Delay Balancing Buffers . . . . .                            | 7-73 |
| Defining a Clock Balance Group . . . . .                                  | 7-73 |
| Defining the Interclock Delay Requirements . . . . .                      | 7-74 |
| Removing the Interclock Delay Settings . . . . .                          | 7-76 |
| Hierarchical Designs . . . . .                                            | 7-77 |
| Handling Extracted Timing Models . . . . .                                | 7-78 |
| Multivoltage Designs . . . . .                                            | 7-78 |
| Verifying the Clock Trees . . . . .                                       | 7-79 |

|                                                                      |       |
|----------------------------------------------------------------------|-------|
| Implementing the Clock Trees.....                                    | 7-81  |
| Optimizing Clock Tree Synthesis Only and                             |       |
| Clock Tree Synthesis Hold Only Scenarios .....                       | 7-87  |
| Analyzing Optimization Feasibility After Clock Tree Synthesis .....  | 7-88  |
| Standalone Clock Tree Synthesis Capabilities.....                    | 7-89  |
| Performing Clock Tree Power Optimization.....                        | 7-89  |
| Performing Clock Tree Synthesis .....                                | 7-90  |
| High-Fanout Net Synthesis.....                                       | 7-92  |
| Performing Clock Tree Optimization .....                             | 7-93  |
| Performing Clock Routing .....                                       | 7-98  |
| Implementing Clock Meshes.....                                       | 7-99  |
| Prerequisites for Creating Clock Meshes.....                         | 7-100 |
| The Clock Mesh Flow .....                                            | 7-101 |
| Flattening the Logic of Integrated Clock-Gating Cells .....          | 7-102 |
| Splitting Clock Nets .....                                           | 7-103 |
| Creating Clock Meshes .....                                          | 7-103 |
| Adding Clock Mesh Drivers .....                                      | 7-105 |
| Routing Mesh Nets .....                                              | 7-107 |
| Performing Quick Mesh Analysis.....                                  | 7-107 |
| Prerequisites for Clock Mesh Analysis .....                          | 7-107 |
| Quick Mesh Analysis .....                                            | 7-108 |
| Compiling Premesh Trees .....                                        | 7-108 |
| Creating H-, T-, or I-Shape Routes for Premesh Trees.....            | 7-110 |
| Routing Clock Nets .....                                             | 7-112 |
| Analyzing Clock Mesh Circuits .....                                  | 7-112 |
| Optimizing Meshes With Macros .....                                  | 7-114 |
| Implementing Hierarchical Clock Meshes .....                         | 7-115 |
| Prerequisites for the Hierarchical Clock Mesh Flow .....             | 7-115 |
| Procedures to Create Hierarchical Clock Mesh .....                   | 7-115 |
| Using Batch Mode to Reduce Runtime.....                              | 7-118 |
| Analyzing the Clock Tree Results .....                               | 7-119 |
| Generating Clock Tree Reports .....                                  | 7-120 |
| Generating Reports for Multicorner Clock Tree Optimization .....     | 7-123 |
| Analyzing Clock Timing .....                                         | 7-123 |
| Generating Categorized Timing Reports for Clock Tree Synthesis ..... | 7-124 |
| create_qor_snapshot .....                                            | 7-124 |
| query_qor_snapshot.....                                              | 7-125 |

|                                                                  |       |
|------------------------------------------------------------------|-------|
| Analyzing Clock Trees in the GUI . . . . .                       | 7-127 |
| Viewing Clock Trees in the Layout Window . . . . .               | 7-128 |
| Using the Interactive Clock Tree Synthesis Window . . . . .      | 7-130 |
| Using the Clock Tree Option Viewer . . . . .                     | 7-131 |
| Viewing the Clock Tree Hierarchy . . . . .                       | 7-131 |
| Viewing the Clock Tree Arrival Time Histogram . . . . .          | 7-132 |
| Viewing Clock Latency and Skew in the Clock Graph View . . . . . | 7-133 |
| Using the Clock Tree Levelized Graph View . . . . .              | 7-134 |
| Viewing the Fanout or Fanin Schematic . . . . .                  | 7-136 |
| Fine-Tuning the Clock Tree Synthesis Results . . . . .           | 7-136 |
| Using the Useful Skew Technique . . . . .                        | 7-137 |
| skew_opt Details . . . . .                                       | 7-137 |
| skew_opt Flow . . . . .                                          | 7-138 |
| Balancing the Skew Using Skew Groups . . . . .                   | 7-140 |
| Guidelines for Defining Skew Groups . . . . .                    | 7-140 |
| Validating and Committing Skew Groups . . . . .                  | 7-142 |
| Limitations of Using Skew Groups . . . . .                       | 7-142 |
| Resynthesizing the Clock Trees . . . . .                         | 7-143 |
| Validating the Setup . . . . .                                   | 7-143 |
| Resynthesizing the Clock Trees . . . . .                         | 7-144 |
| Modifying the Nondefault Routing Rule . . . . .                  | 7-144 |
| Modifying Clock Trees in the GUI . . . . .                       | 7-144 |
| Inserting a Buffer . . . . .                                     | 7-146 |
| Removing a Buffer . . . . .                                      | 7-146 |
| Moving a Buffer or Gate . . . . .                                | 7-147 |
| Reparenting a Subtree . . . . .                                  | 7-147 |
| Sizing a Buffer or Gate . . . . .                                | 7-148 |
| Analyzing and Refining the Design . . . . .                      | 7-148 |
| <b>8. Routing Using Zroute</b>                                   |       |
| Zroute Features . . . . .                                        | 8-3   |
| Basic Zroute Flow . . . . .                                      | 8-3   |
| Prerequisites for Routing . . . . .                              | 8-5   |
| Checking Routability . . . . .                                   | 8-6   |

|                                                               |      |
|---------------------------------------------------------------|------|
| Setting Up for Routing . . . . .                              | 8-6  |
| Enabling Multicore Processing . . . . .                       | 8-7  |
| Defining Route Guides . . . . .                               | 8-8  |
| Using Route Guides to Prevent Routing . . . . .               | 8-9  |
| Using Route Guides to Control the Routing Direction . . . . . | 8-9  |
| Using Route Guides to Control the Routing Density . . . . .   | 8-10 |
| Using Route Guides to Prioritize Routing Regions . . . . .    | 8-10 |
| Using Route Guides to Encourage River Routing . . . . .       | 8-11 |
| Using Route Guides to Fix Violations . . . . .                | 8-11 |
| Querying Route Guides . . . . .                               | 8-11 |
| Removing Route Guides . . . . .                               | 8-12 |
| Defining Routing Corridors . . . . .                          | 8-12 |
| Reporting Routing Corridors . . . . .                         | 8-13 |
| Modifying Routing Corridors . . . . .                         | 8-14 |
| Removing Routing Corridors . . . . .                          | 8-15 |
| Defining Routing Blockages . . . . .                          | 8-15 |
| Setting the Preferred Routing Direction . . . . .             | 8-16 |
| Controlling Pin Connections . . . . .                         | 8-17 |
| Creating Design-Specific Via Masters . . . . .                | 8-20 |
| Creating Parameter-Based Via Masters . . . . .                | 8-21 |
| Creating Rectangle-Based Via Masters . . . . .                | 8-21 |
| Using Nondefault Routing Rules . . . . .                      | 8-22 |
| Defining Nondefault Routing Rules . . . . .                   | 8-22 |
| Applying Nondefault Routing Rules . . . . .                   | 8-31 |
| Reporting Nondefault Routing Rules . . . . .                  | 8-33 |
| Removing Nondefault Routing Rules . . . . .                   | 8-33 |
| Specifying the Routing Layers . . . . .                       | 8-33 |
| Specifying the Ignored Layers . . . . .                       | 8-34 |
| Specifying Routing Layers for Specific Nets . . . . .         | 8-34 |
| Setting Zroute Options . . . . .                              | 8-35 |
| Setting Common Route Options . . . . .                        | 8-35 |
| Setting Global Route Options . . . . .                        | 8-42 |
| Setting Track Assignment Options . . . . .                    | 8-45 |
| Setting Detail Route Options . . . . .                        | 8-45 |
| Setting Signal Integrity Options . . . . .                    | 8-52 |
| Setting Multivoltage Options . . . . .                        | 8-53 |
| Routing Clock Nets . . . . .                                  | 8-55 |
| Clock Net Routing . . . . .                                   | 8-55 |
| Clock Net Redundant Via Insertion . . . . .                   | 8-56 |

|                                                                       |       |
|-----------------------------------------------------------------------|-------|
| Clock Net Shielding .....                                             | 8-57  |
| Postroute Clock Tree Optimization .....                               | 8-57  |
| Routing Critical Nets .....                                           | 8-57  |
| Routing Signal Nets .....                                             | 8-59  |
| Routing Signal Nets by Using Individual Routing Commands .....        | 8-60  |
| Global Routing .....                                                  | 8-60  |
| Track Assignment .....                                                | 8-65  |
| Detail Routing .....                                                  | 8-66  |
| Routing Signal Nets by Using Automatic Routing .....                  | 8-70  |
| Routing Signal Nets by Using the <code>route_opt</code> Command ..... | 8-72  |
| Setting the Routing and Optimization Strategy .....                   | 8-72  |
| Enabling Fixing of Hold Time Violations .....                         | 8-73  |
| Setting the Crosstalk Reduction Options .....                         | 8-74  |
| Running the <code>route_opt</code> Command .....                      | 8-77  |
| Performing Focal Optimization .....                                   | 8-83  |
| Performing ECO Routing .....                                          | 8-85  |
| Cleaning Up Routed Nets .....                                         | 8-87  |
| Saving the Routing Information .....                                  | 8-88  |
| Analyzing the Routing Results .....                                   | 8-89  |
| Reporting Cell Placement and Routing Statistics .....                 | 8-89  |
| Analyzing Congestion .....                                            | 8-90  |
| Generating a Congestion Report .....                                  | 8-90  |
| Generating a Congestion Map .....                                     | 8-92  |
| Performing Design Rule Checking Using IC Compiler .....               | 8-95  |
| Performing Signoff Design Rule Checking .....                         | 8-98  |
| Setting Up the Validation Tool Environment .....                      | 8-98  |
| Setting Up The Physical Signoff Options .....                         | 8-99  |
| Running the <code>signoff_drc</code> Command .....                    | 8-102 |
| Automatically Fixing Signoff DRC Violations .....                     | 8-105 |
| Verifying the Routing in an External Tool .....                       | 8-107 |
| Analyzing DRC Violations .....                                        | 8-108 |
| Using the DRC Query Commands .....                                    | 8-108 |
| Using the Error Browser .....                                         | 8-109 |

|                                                              |       |
|--------------------------------------------------------------|-------|
| Routing Nets and Buses in the GUI . . . . .                  | 8-109 |
| Routing Single Nets . . . . .                                | 8-110 |
| Creating Physical Buses . . . . .                            | 8-111 |
| Manual Bus Creation . . . . .                                | 8-112 |
| Automatic Bus Creation . . . . .                             | 8-113 |
| Modifying Buses . . . . .                                    | 8-114 |
| Routing Buses or Multiple Nets . . . . .                     | 8-115 |
| Modifying Routed Nets . . . . .                              | 8-117 |
| Creating Custom Wires . . . . .                              | 8-119 |
| Postroute RC Extraction . . . . .                            | 8-121 |
| <b>9. Chip Finishing and Design for Manufacturing</b>        |       |
| Overview . . . . .                                           | 9-2   |
| Inserting Tap Cells . . . . .                                | 9-3   |
| Adding Tap Cell Arrays . . . . .                             | 9-3   |
| Fixing Tap Spacing Violations . . . . .                      | 9-5   |
| Removing Tap Cells . . . . .                                 | 9-6   |
| Finding and Fixing Antenna Violations . . . . .              | 9-6   |
| Defining Metal Layer Antenna Rules . . . . .                 | 9-7   |
| Defining the Global Metal Layer Antenna Rules . . . . .      | 9-8   |
| Defining Layer-Specific Antenna Rules . . . . .              | 9-13  |
| Reporting Antenna Rules . . . . .                            | 9-18  |
| Removing Antenna Rules . . . . .                             | 9-19  |
| Specifying Antenna Properties . . . . .                      | 9-19  |
| Analyzing and Fixing Antenna Violations . . . . .            | 9-20  |
| Inserting Diodes During Detail Routing . . . . .             | 9-22  |
| Inserting Diodes After Detail Routing . . . . .              | 9-23  |
| Removing Diodes . . . . .                                    | 9-24  |
| Inserting Redundant Vias . . . . .                           | 9-24  |
| Inserting Redundant Vias on Clock Nets . . . . .             | 9-25  |
| Inserting Redundant Vias on Signal Nets . . . . .            | 9-26  |
| Viewing the Default Via Mapping Table . . . . .              | 9-26  |
| Defining a Customized Via Mapping Table . . . . .            | 9-27  |
| Postroute Redundant Via Insertion . . . . .                  | 9-29  |
| Concurrent Soft-Rule-Based Redundant Via Insertion . . . . . | 9-30  |
| Near 100 Percent Redundant Via Insertion . . . . .           | 9-31  |

|                                                                  |      |
|------------------------------------------------------------------|------|
| Preserving Timing During Redundant Via Insertion . . . . .       | 9-32 |
| Maximizing the Redundant Via Rate . . . . .                      | 9-33 |
| Reporting Redundant Via Rates . . . . .                          | 9-34 |
| Optimizing Wire Length and Via Count. . . . .                    | 9-35 |
| Reducing Critical Areas . . . . .                                | 9-36 |
| Reporting Critical Areas. . . . .                                | 9-36 |
| Displaying Critical Area Maps . . . . .                          | 9-38 |
| Performing Wire Spreading . . . . .                              | 9-39 |
| Performing Wire Widening. . . . .                                | 9-40 |
| Shielding Nets. . . . .                                          | 9-41 |
| Defining the Shielding Rules . . . . .                           | 9-42 |
| Performing Preroute Shielding. . . . .                           | 9-43 |
| Soft Shielding Rules During Signal Routing . . . . .             | 9-45 |
| Performing Postroute Shielding . . . . .                         | 9-45 |
| Shielding Example . . . . .                                      | 9-46 |
| Performing Incremental Shielding . . . . .                       | 9-46 |
| Reporting Shielding Information . . . . .                        | 9-47 |
| Inserting Filler Cells . . . . .                                 | 9-49 |
| Inserting Standard Cell Fillers . . . . .                        | 9-49 |
| Connecting Multiple Power and Ground Pins . . . . .              | 9-51 |
| Avoiding One-Unit-Tile Violations for Overlapping Rows . . . . . | 9-52 |
| Defining the Filler Rules . . . . .                              | 9-53 |
| Reporting Filler Cells . . . . .                                 | 9-53 |
| Removing Filler Cells . . . . .                                  | 9-53 |
| Inserting End Caps . . . . .                                     | 9-54 |
| Inserting Well Fillers . . . . .                                 | 9-55 |
| Inserting Pad Fillers. . . . .                                   | 9-57 |
| Inserting Metal Fill. . . . .                                    | 9-58 |
| Setting Up the Validation Tool Environment. . . . .              | 9-59 |
| Setting Up the IC Validator Environment . . . . .                | 9-59 |
| Setting Up the Hercules Environment. . . . .                     | 9-59 |
| Setting Up the Physical Signoff Options . . . . .                | 9-60 |
| Setting Up Distributed Processing. . . . .                       | 9-60 |
| Running the signoff_metal_fill Command . . . . .                 | 9-61 |
| Standard Metal Fill Insertion. . . . .                           | 9-62 |
| Timing-Driven Metal Fill Insertion. . . . .                      | 9-64 |

|                                       |      |
|---------------------------------------|------|
| Metal Fill Removal . . . . .          | 9-65 |
| Post-ECO Metal Fill Cleanup . . . . . | 9-65 |

## Part II: Advanced IC Compiler Features

### 10. Signal Integrity

|                                                            |       |
|------------------------------------------------------------|-------|
| Analyzing and Reducing Crosstalk . . . . .                 | 10-3  |
| Setting the Signal Integrity Options . . . . .             | 10-4  |
| Preventing Crosstalk During Placement . . . . .            | 10-5  |
| Preventing Crosstalk During Clock Tree Synthesis . . . . . | 10-6  |
| Preventing and Fixing Crosstalk During Routing . . . . .   | 10-6  |
| Preventing Crosstalk . . . . .                             | 10-7  |
| Fixing Crosstalk Violations . . . . .                      | 10-7  |
| Analyzing Crosstalk . . . . .                              | 10-9  |
| Preparing for Crosstalk Analysis . . . . .                 | 10-9  |
| Running Crosstalk Analysis . . . . .                       | 10-13 |
| Preventing Crosstalk During Signoff Optimization . . . . . | 10-15 |
| Example Scripts . . . . .                                  | 10-16 |
| Analyzing and Reducing Signal Electromigration . . . . .   | 10-16 |
| Loading Signal Electromigration Constraints . . . . .      | 10-18 |
| Verifying the Electromigration Constraints . . . . .       | 10-19 |
| Verifying the Current Unit . . . . .                       | 10-19 |
| Validating the Design . . . . .                            | 10-19 |
| Loading the Net Switching Information . . . . .            | 10-20 |
| Reading a SAIF File . . . . .                              | 10-20 |
| Annotating the Switching Activity . . . . .                | 10-21 |
| Performing Signal Electromigration Analysis . . . . .      | 10-21 |
| Identifying Unfixable Violations . . . . .                 | 10-24 |
| Electromigration Fixing . . . . .                          | 10-26 |

### 11. Physical Datapath With Relative Placement

|                                                                     |      |
|---------------------------------------------------------------------|------|
| Introduction to Physical Datapath With Relative Placement . . . . . | 11-3 |
| Benefits of Relative Placement . . . . .                            | 11-4 |

|                                                                               |       |
|-------------------------------------------------------------------------------|-------|
| Flow for Relative Placement . . . . .                                         | 11-5  |
| Methodology for the Relative Placement Flow . . . . .                         | 11-6  |
| Script for a Relative Placement Flow . . . . .                                | 11-7  |
| Relative Placement Flow in Design Compiler Topographical Mode . . . . .       | 11-8  |
| Considerations for Using Relative Placement . . . . .                         | 11-9  |
| Creating Relative Placement Groups . . . . .                                  | 11-10 |
| Anchoring Relative Placement Groups . . . . .                                 | 11-13 |
| Specifying a Corner for an Anchored Relative Placement Group . . . . .        | 11-16 |
| Aligning Relative Placement Rows With the Site Row . . . . .                  | 11-16 |
| Applying Compression to Relative Placement Groups . . . . .                   | 11-17 |
| Supporting Compression With Mixed Alignment . . . . .                         | 11-19 |
| Adding Objects to a Group . . . . .                                           | 11-19 |
| Adding Leaf Cells . . . . .                                                   | 11-20 |
| Specifying Orientation for Leaf Cells . . . . .                               | 11-21 |
| Aligning Leaf Cells Within a Column . . . . .                                 | 11-21 |
| Orientation of Relative Placement Groups . . . . .                            | 11-27 |
| Relative Placement Group Orientations . . . . .                               | 11-27 |
| Relative Placement Cell Orientations . . . . .                                | 11-29 |
| Controlling Relative Placement Cell Orientations . . . . .                    | 11-30 |
| Adding Relative Placement Groups . . . . .                                    | 11-31 |
| Benefits of Hierarchical Relative Placement Groups . . . . .                  | 11-32 |
| Including Relative Placement Groups . . . . .                                 | 11-32 |
| Instantiating Relative Placement Groups . . . . .                             | 11-34 |
| Setting the Orientation of an Instantiated Relative Placement Group . . . . . | 11-36 |
| Changing the Structures of Relative Placement Groups . . . . .                | 11-37 |
| Using Hierarchical Relative Placement for Straddling . . . . .                | 11-39 |
| Using Hierarchical Relative Placement for Compression . . . . .               | 11-40 |
| Effect of Ungrouping on Hierarchical Relative Placement . . . . .             | 11-42 |
| Effect of Uniquifying on Hierarchical Relative Placement . . . . .            | 11-44 |
| Adding Keepouts . . . . .                                                     | 11-45 |
| Placement of Relative Placement Groups . . . . .                              | 11-47 |
| Performing Relative Placement in a Design Containing Obstructions . . . . .   | 11-47 |
| Performing Relative Placement in a Design Containing Tap Cells . . . . .      | 11-48 |
| Handling Fixed Cells During Relative Placement . . . . .                      | 11-49 |
| Handling Physical-Only Cells During Relative Placement . . . . .              | 11-50 |
| Using Move Bounds to Constrain Relative Placement . . . . .                   | 11-50 |

|                                                                          |       |
|--------------------------------------------------------------------------|-------|
| Supporting Relative Placement Groups in Virtual Flat Placement .....     | 11-51 |
| Propagating Relative Placement Groups in Physical Hierarchy .....        | 11-52 |
| Postplacement for Relative Placement Groups .....                        | 11-54 |
| Adding Incremental Relative Placement Groups.....                        | 11-54 |
| Controlling Movement When Legalizing Relative Placement Groups .....     | 11-55 |
| Legalizing Relative Placement Groups in a Placed Design.....             | 11-55 |
| Exposing Unused Space in Relative Placement Groups.....                  | 11-57 |
| Postplacement Optimization of Relative Placement Groups.....             | 11-58 |
| Preserving Relative Placement Structures .....                           | 11-58 |
| Optimizing Relative Placement Cells.....                                 | 11-60 |
| Buffering Strategy for Relative Placement Groups .....                   | 11-60 |
| Analyzing the Relative Placement Results .....                           | 11-61 |
| Checking Relative Placement Constraints.....                             | 11-61 |
| Locating a Relative Placement Group .....                                | 11-63 |
| Analyzing Relative Placement Groups in the GUI .....                     | 11-64 |
| Working With Relative Placement Groups in the GUI.....                   | 11-64 |
| Using the Relative Placement Hierarchy Browser.....                      | 11-65 |
| Viewing Relative Placement Groups .....                                  | 11-65 |
| Viewing Relative Placement Group Net Connections .....                   | 11-66 |
| Viewing Net Connectivity Between Relative Placement Groups .....         | 11-68 |
| Moving Relative Placement Groups. ....                                   | 11-69 |
| Editing and Creating Relative Placement Groups .....                     | 11-69 |
| Using the Relative Placement Window .....                                | 11-71 |
| Viewing the Hierarchy of Relative Placement Groups .....                 | 11-72 |
| Viewing Logical Connections in a Relative Placement Group .....          | 11-73 |
| Editing Relative Placement Groups in a Relative Placement View Window .. | 11-76 |
| Editing the Structures of Relative Placement Groups .....                | 11-77 |
| Querying Relative Placement Groups and Objects .....                     | 11-79 |
| Displaying Relative Placement Group Attributes .....                     | 11-80 |
| Displaying Relative Placement Cell Attributes .....                      | 11-81 |
| Displaying Relative Placement Keepout Attributes .....                   | 11-82 |
| Reporting the Total Net Lengths of Relative Placement Groups .....       | 11-82 |
| Querying Relative Placement Groups .....                                 | 11-83 |
| Querying Objects in Relative Placement Groups .....                      | 11-83 |
| Query Commands for Relative Placement Groups and Objects .....           | 11-85 |

|                                                                  |        |
|------------------------------------------------------------------|--------|
| Saving Relative Placement Information . . . . .                  | 11-86  |
| Ignoring Relative Placement Constraints . . . . .                | 11-87  |
| Removing Relative Placement Groups . . . . .                     | 11-88  |
| Changing Relative Placement Information . . . . .                | 11-89  |
| Reporting the Attributes of a Relative Placement Group . . . . . | 11-89  |
| Changing the Options of a Relative Placement Group . . . . .     | 11-89  |
| Setting Relative Placement Group Attributes . . . . .            | 11-90  |
| Removing Relative Placement Group Attributes . . . . .           | 11-93  |
| Renaming a Group . . . . .                                       | 11-95  |
| Removing Objects From a Group . . . . .                          | 11-95  |
| Changing Specific Objects Within a Group . . . . .               | 11-96  |
| Changing the Attributes of Relative Placement Cells . . . . .    | 11-96  |
| Changing the Dimensions of Relative Placement Keepouts . . . . . | 11-96  |
| Deriving Relative Placement Groups . . . . .                     | 11-97  |
| Extracting a Relative Placement Group . . . . .                  | 11-97  |
| Ordering Extracted Relative Placement Groups . . . . .           | 11-98  |
| Summary of Relative Placement Commands . . . . .                 | 11-99  |
| Limitations of Relative Placement . . . . .                      | 11-100 |

## 12. Using Hierarchical Models

|                                                                                     |       |
|-------------------------------------------------------------------------------------|-------|
| Overview of Hierarchical Models . . . . .                                           | 12-2  |
| Interface Logic Models . . . . .                                                    | 12-4  |
| Information Stored in Interface Logic Models . . . . .                              | 12-4  |
| Creating ILMs . . . . .                                                             | 12-6  |
| Creating ILMs for Multiple Blocks . . . . .                                         | 12-8  |
| Creating ILMs for Multicorner-Multimode Usage . . . . .                             | 12-8  |
| Creating ILMs for Rotated and Mirrored Instances . . . . .                          | 12-9  |
| Creating ILMs for Blocks With Nested ILMs . . . . .                                 | 12-9  |
| Controlling the Logic Included in an ILM . . . . .                                  | 12-10 |
| Storing Parasitic Information in the ILM . . . . .                                  | 12-17 |
| Storing Signal Integrity Information in the ILM . . . . .                           | 12-18 |
| Milkyway Database Compatibility . . . . .                                           | 12-18 |
| Validating ILMs . . . . .                                                           | 12-19 |
| Debugging Differences Reported by<br>the compare_interface_timing Command . . . . . | 12-22 |
| Reporting Information About ILMs . . . . .                                          | 12-23 |

|                                                                                              |       |
|----------------------------------------------------------------------------------------------|-------|
| Using ILMs .....                                                                             | 12-27 |
| Using ILMs in the Top-Level Design .....                                                     | 12-27 |
| Linking ILMs to the Top-Level Design .....                                                   | 12-29 |
| Applying Top-Level Constraints .....                                                         | 12-29 |
| Checking ILMs .....                                                                          | 12-31 |
| Running the place_opt Command on the Top-Level Design .....                                  | 12-32 |
| Running the clock_opt Command on the Top-Level Design .....                                  | 12-32 |
| Running the route_opt Command on the Top-Level Design .....                                  | 12-33 |
| Block Abstraction Models .....                                                               | 12-33 |
| Creating a Block Abstraction .....                                                           | 12-33 |
| Creating a Block Abstraction Model for Multicorner-Multimode Usage .....                     | 12-34 |
| Linking to Block Abstraction Models .....                                                    | 12-35 |
| Reporting Block Abstraction Models .....                                                     | 12-35 |
| Checking Block Abstraction Models .....                                                      | 12-36 |
| Viewing Hierarchical Models in the GUI .....                                                 | 12-37 |
| Using Hierarchical Models in a Multicorner-Multimode Flow .....                              | 12-37 |
| Transparent Interface Optimization .....                                                     | 12-38 |
| Enabling Interface Optimization .....                                                        | 12-38 |
| Specifying Block-Specific Size-Only Settings .....                                           | 12-40 |
| Reporting Implementation Options .....                                                       | 12-41 |
| Example Scripts .....                                                                        | 12-41 |
| Creating Block Abstraction Models .....                                                      | 12-41 |
| Top-Level Flow With Block Abstraction Models .....                                           | 12-41 |
| Top-Level Flow With Block Abstraction Models and<br>Transparent Interface Optimization ..... | 12-42 |
| <b>13. In-Design Rail Analysis</b>                                                           |       |
| Overview .....                                                                               | 13-2  |
| Preparing for In-Design Rail Analysis .....                                                  | 13-5  |
| Checking the Library Robustness .....                                                        | 13-5  |
| Checking the Power Network Robustness .....                                                  | 13-5  |
| Checking the Voltage Settings .....                                                          | 13-6  |
| Setting Up the Environment .....                                                             | 13-6  |
| Performing Power Network Integrity Analysis .....                                            | 13-7  |
| Performing Voltage Drop Analysis .....                                                       | 13-8  |

|                                                                    |       |
|--------------------------------------------------------------------|-------|
| Performing Electromigration Analysis . . . . .                     | 13-10 |
| Performing Inrush Current Analysis . . . . .                       | 13-12 |
| Performing Decoupling Capacitance Analysis and Insertion . . . . . | 13-15 |
| Preparing for Decoupling Capacitance Analysis . . . . .            | 13-16 |
| Performing Decoupling Capacitance Analysis . . . . .               | 13-17 |
| Performing Decoupling Capacitor Insertion . . . . .                | 13-18 |
| Loading and Deleting PrimeRail Analysis Maps . . . . .             | 13-19 |

## 14. Multivoltage Design Flow

|                                                                    |       |
|--------------------------------------------------------------------|-------|
| Multivoltage Designs . . . . .                                     | 14-2  |
| Power Domains . . . . .                                            | 14-2  |
| Defining Power Domains . . . . .                                   | 14-3  |
| Voltage Areas . . . . .                                            | 14-4  |
| Associating Power Domains and Voltage Areas . . . . .              | 14-4  |
| Level-Shifter and Isolation Cells . . . . .                        | 14-4  |
| Basic Library Requirements for Multivoltage Designs . . . . .      | 14-5  |
| Using a Target Library Subset . . . . .                            | 14-6  |
| Converting Libraries to PG Pin Library Format . . . . .            | 14-7  |
| Physical Synthesis . . . . .                                       | 14-9  |
| High-Level Design Flow for Multivoltage Designs . . . . .          | 14-10 |
| UPF Flow for Multivoltage Designs . . . . .                        | 14-11 |
| Defining Power Domains and Supply Networks . . . . .               | 14-14 |
| Power Domains . . . . .                                            | 14-14 |
| Hierarchy and Scope . . . . .                                      | 14-15 |
| Supply Sets . . . . .                                              | 14-15 |
| Creating Power Domains . . . . .                                   | 14-16 |
| Creating the Supply Network . . . . .                              | 14-18 |
| Creating Supply Ports . . . . .                                    | 14-18 |
| Creating Supply Nets . . . . .                                     | 14-20 |
| Connecting Supply Nets . . . . .                                   | 14-20 |
| Specifying the Primary Supply Nets for a Power Domain . . . . .    | 14-21 |
| Creating Supply Sets . . . . .                                     | 14-22 |
| Defining Power States for the Components of a Supply Set . . . . . | 14-23 |
| Creating Power Domains Using Supply Sets . . . . .                 | 14-24 |
| Restricting Supply Sets to a Power Domain . . . . .                | 14-24 |
| Updating a Supply Set . . . . .                                    | 14-25 |

|                                                                              |       |
|------------------------------------------------------------------------------|-------|
| Creating Supply Set Handles . . . . .                                        | 14-27 |
| Assigning Supply Nets to Supply Set Handles . . . . .                        | 14-27 |
| Creating Power Switches . . . . .                                            | 14-29 |
| Connecting Power Switches . . . . .                                          | 14-30 |
| Macro Cells with Fine-Grained Switches . . . . .                             | 14-32 |
| Defining State Information for the Supply Ports . . . . .                    | 14-33 |
| Creating a Power State Table . . . . .                                       | 14-34 |
| Defining the States of the Supply Nets . . . . .                             | 14-34 |
| Connecting Power and Ground Nets . . . . .                                   | 14-35 |
| Specifying the Operating Voltage . . . . .                                   | 14-36 |
| Defining and Using Voltage Areas . . . . .                                   | 14-37 |
| Creating Voltage Areas . . . . .                                             | 14-39 |
| Updating Voltage Areas in a Design . . . . .                                 | 14-40 |
| Default Voltage Area . . . . .                                               | 14-41 |
| Including Guard Bands With Voltage Areas . . . . .                           | 14-41 |
| Handling Nested Voltage Areas . . . . .                                      | 14-43 |
| Voltage Area Support for Macros . . . . .                                    | 14-44 |
| Defining Always-On Power Wells Within Voltage Areas . . . . .                | 14-44 |
| Removing Voltage Areas From the Design . . . . .                             | 14-45 |
| Reporting on the Voltage Areas of a Design . . . . .                         | 14-45 |
| Power Management Cells and UPF Strategies . . . . .                          | 14-45 |
| Library Requirements of Level-Shifter and Isolation Cells . . . . .          | 14-46 |
| Managing the Level-Shifter Cells . . . . .                                   | 14-46 |
| Inserting the Buffer-Type Level Shifters . . . . .                           | 14-47 |
| Setting the Threshold Voltage for Level Shifters . . . . .                   | 14-49 |
| Defining the Level-Shifter Strategy . . . . .                                | 14-51 |
| Associating Specific Library Cells With the Level-Shifter Strategy . . . . . | 14-52 |
| Checking Level-Shifter Violations . . . . .                                  | 14-52 |
| Placing Level Shifters . . . . .                                             | 14-53 |
| Removing Level Shifters . . . . .                                            | 14-53 |
| Managing Isolation and Enable-Type Level-Shifter Cells . . . . .             | 14-53 |
| Inserting Isolation Cells and Enable-Type Level Shifters . . . . .           | 14-54 |
| Defining the Isolation Strategy . . . . .                                    | 14-54 |
| Connecting the Isolation and Level-Shifter Cells Back-to-Back . . . . .      | 14-61 |

|                                                                                         |       |
|-----------------------------------------------------------------------------------------|-------|
| Retention Registers .....                                                               | 14-62 |
| Library Specification of Retention Register .....                                       | 14-62 |
| Defining the Retention Strategy .....                                                   | 14-63 |
| Mapping the Retention Registers .....                                                   | 14-65 |
| Handling Always-On Logic. ....                                                          | 14-66 |
| Marking Always-On Library Cells .....                                                   | 14-67 |
| Marking Always-On Pins. ....                                                            | 14-67 |
| Supply-Net-Aware Always-On Synthesis .....                                              | 14-68 |
| Marking Pass-Gate Library Pins .....                                                    | 14-68 |
| Power Management Cells and the ASCII UPF Flow .....                                     | 14-69 |
| Inserting Power Management Cells .....                                                  | 14-69 |
| Associating of Power Management Cells With UPF Strategies .....                         | 14-70 |
| Example IC Compiler Script for the UPF Flow .....                                       | 14-70 |
| Voltage-Area-Aware Capabilities .....                                                   | 14-72 |
| Automatic High-Fanout Synthesis .....                                                   | 14-73 |
| Virtual Hierarchy Routing. ....                                                         | 14-73 |
| Maximum Net Length Optimization .....                                                   | 14-73 |
| Voltage-Area-Based Optimization .....                                                   | 14-74 |
| Voltage-Area-Based Clock Tree Synthesis and Optimization .....                          | 14-74 |
| Voltage-Area-Based Global Routing .....                                                 | 14-74 |
| Voltage Area Feedthrough Flow .....                                                     | 14-75 |
| Voltage-Area-Aware Always-On Synthesis .....                                            | 14-75 |
| Controlling the Dummy Hierarchy.....                                                    | 14-76 |
| Voltage-Area-Based Power and Ground Net Associations .....                              | 14-77 |
| Voltage-Area-Based Standard-Cell Filler Cell Insertion .....                            | 14-77 |
| Interface Logic Model Hierarchical Flow .....                                           | 14-78 |
| Multivoltage Relative Placement Capability.....                                         | 14-79 |
| Hierarchical Signal Integrity Flow .....                                                | 14-79 |
| Placing and Optimizing the Design.....                                                  | 14-79 |
| Handling Isolation Cells and Always-On Clock Paths During<br>Clock Tree Synthesis ..... | 14-80 |
| Multivoltage Specific Queries, Checks, and Reports .....                                | 14-81 |
| Multivoltage Specific dont_touch Attributes - Query and Report.....                     | 14-82 |
| Multivoltage-Specific Checks.....                                                       | 14-82 |
| Multivoltage-Specific Reports .....                                                     | 14-83 |

|                                                                                  |       |
|----------------------------------------------------------------------------------|-------|
| Hierarchical UPF Flow .....                                                      | 14-85 |
| Design Compiler to IC Compiler Interface .....                                   | 14-86 |
| Guidelines for the Hierarchical UPF Flow .....                                   | 14-86 |
| Methodology Guidelines.....                                                      | 14-87 |
| Interface Guidelines .....                                                       | 14-87 |
| Implementation Guidelines.....                                                   | 14-87 |
| Known Limitations.....                                                           | 14-89 |
| Full-Chip Design Planning .....                                                  | 14-89 |
| Block-Level Place and Route.....                                                 | 14-92 |
| Top-Level Place and Route .....                                                  | 14-93 |
| <b>15. ECO Flow</b>                                                              |       |
| ECO Flow Overview .....                                                          | 15-2  |
| ECO Flow Features .....                                                          | 15-3  |
| Hierarchical Design Support .....                                                | 15-3  |
| Multivoltage and UPF Design Support.....                                         | 15-3  |
| Programmable Spare Cell Support .....                                            | 15-4  |
| ECO Limitations .....                                                            | 15-5  |
| ECO Recommended Flows .....                                                      | 15-6  |
| Unconstrained ECO Flow .....                                                     | 15-7  |
| Creating ECO Changes and Updating the Design .....                               | 15-7  |
| Updating With a Verilog Netlist.....                                             | 15-8  |
| Updating With Tcl Commands .....                                                 | 15-9  |
| Updating Placement .....                                                         | 15-12 |
| Updating Routing.....                                                            | 15-14 |
| Freeze Silicon ECO Flow .....                                                    | 15-15 |
| Inserting Spare Cells .....                                                      | 15-16 |
| Inserting Spare Cells Using a Verilog Netlist .....                              | 15-17 |
| Inserting Spare Cells by Using the <code>insert_spare_cells</code> Command ..... | 15-21 |
| Creating ECO Changes and Updating the Design .....                               | 15-21 |
| Updating with a Verilog File .....                                               | 15-22 |
| Updating with a Tcl File .....                                                   | 15-23 |
| Finalizing the Freeze Silicon Flow .....                                         | 15-24 |
| Updating Routing.....                                                            | 15-24 |

|                                                                  |       |
|------------------------------------------------------------------|-------|
| Freeze Layer ECO Flow . . . . .                                  | 15-25 |
| Preparing Net Shapes and Vias . . . . .                          | 15-25 |
| Selected Net Routing . . . . .                                   | 15-26 |
| Hierarchical Placement Area Reservation Flow . . . . .           | 15-27 |
| Removing Tie Cells. . . . .                                      | 15-34 |
| Comparing Designs . . . . .                                      | 15-35 |
| <b>16. Signoff-Driven Design Closure</b>                         |       |
| Signoff-Driven Design Closure Overview . . . . .                 | 16-3  |
| Key Features. . . . .                                            | 16-4  |
| Signoff-Driven Design Closure Methodology . . . . .              | 16-6  |
| Automatic IC Compiler Signoff-Driven Design Closure . . . . .    | 16-6  |
| Manual IC Compiler Signoff-Driven Design Closure . . . . .       | 16-9  |
| Usage Guidelines . . . . .                                       | 16-12 |
| Entry Requirements. . . . .                                      | 16-12 |
| General Guidelines . . . . .                                     | 16-13 |
| PrimeTime and StarRC Guidelines . . . . .                        | 16-18 |
| PrimeTime and StarRC Version Requirements . . . . .              | 16-18 |
| Automatic Generation of PrimeTime and StarRC Settings. . . . .   | 16-18 |
| PrimeTime and StarRC Customization Options . . . . .             | 16-21 |
| PrimeTime and StarRC Correlation . . . . .                       | 16-25 |
| Multicorner-Multimode Guidelines . . . . .                       | 16-26 |
| Scenario Differences Between IC Compiler and PrimeTime . . . . . | 16-30 |
| Rail Voltage Information Update . . . . .                        | 16-31 |
| Troubleshooting and Problem Solving . . . . .                    | 16-32 |
| <b>Appendix A. Using GUI Tools</b>                               |       |
| Viewing a Design . . . . .                                       | A-2   |
| Selecting a Mouse Tool . . . . .                                 | A-3   |
| Previewing Objects in a Layout View. . . . .                     | A-5   |
| Selecting Objects. . . . .                                       | A-7   |
| Highlighting Objects. . . . .                                    | A-9   |
| Selecting Only the Highlighted Objects . . . . .                 | A-12  |
| Selecting or Highlighting Objects by Name . . . . .              | A-12  |
| Viewing Object Information . . . . .                             | A-13  |

|                                                            |      |
|------------------------------------------------------------|------|
| Magnifying and Traversing the Design . . . . .             | A-15 |
| Following Selected Objects . . . . .                       | A-17 |
| Reusing Zoom and Pan Settings . . . . .                    | A-18 |
| Redrawing the Active View . . . . .                        | A-19 |
| Examining Design and Object Information . . . . .          | A-19 |
| Viewing and Editing Object Properties . . . . .            | A-20 |
| Exploring the Design Hierarchy . . . . .                   | A-21 |
| Examining Hierarchical Cells . . . . .                     | A-22 |
| Examining Hierarchical Cell Placement . . . . .            | A-23 |
| Exploring the Virtual Hierarchy of a Flat Design . . . . . | A-23 |
| Examining Virtual Hierarchical Cells . . . . .             | A-25 |
| Examining Virtual Hierarchical Cell Placement . . . . .    | A-26 |
| Managing Attribute Groups . . . . .                        | A-27 |
| Searching for Objects by Name . . . . .                    | A-29 |
| Selecting and Viewing Timing Paths . . . . .               | A-31 |
| Viewing Reports . . . . .                                  | A-32 |
| Saving an Image of a Window or View . . . . .              | A-33 |
| Visualizing the Physical Design . . . . .                  | A-34 |
| Navigating Through Layout Views . . . . .                  | A-35 |
| Displaying Grid Lines . . . . .                            | A-36 |
| Drawing Rulers . . . . .                                   | A-36 |
| Adjusting the Color Brightness . . . . .                   | A-38 |
| Displaying Cell Orientations . . . . .                     | A-38 |
| Examining ILMs and Blocks with Abstraction . . . . .       | A-39 |
| Viewing Design Overlays . . . . .                          | A-40 |
| Setting and Saving View Properties . . . . .               | A-41 |
| Using Stroke Activated Commands . . . . .                  | A-46 |
| Analyzing the Physical Design . . . . .                    | A-48 |
| Using Visual Analysis Modes . . . . .                      | A-48 |
| Displaying Flylines . . . . .                              | A-49 |
| Displaying Net Connectivity . . . . .                      | A-50 |
| Using Visual Modes . . . . .                               | A-51 |
| Using Map Modes . . . . .                                  | A-53 |
| Examining and Editing Relative Placement Groups . . . . .  | A-55 |
| Analyzing Signal Integrity . . . . .                       | A-56 |

|                                                                   |       |
|-------------------------------------------------------------------|-------|
| Analyzing Clock Trees . . . . .                                   | A-57  |
| Opening an Interactive Clock Tree Synthesis Window . . . . .      | A-58  |
| Exploring Clock Tree Structures . . . . .                         | A-59  |
| Highlighting the Critical Paths . . . . .                         | A-61  |
| Examining Clock Tree Timing . . . . .                             | A-61  |
| Examining Clock Tree Overlaps . . . . .                           | A-65  |
| Analyzing Timing Paths . . . . .                                  | A-66  |
| Opening a Timing Analysis Window . . . . .                        | A-67  |
| Viewing Timing Path Details . . . . .                             | A-67  |
| Using Timing Analysis Views . . . . .                             | A-68  |
| Viewing Histograms . . . . .                                      | A-69  |
| Examining Path Profiles . . . . .                                 | A-70  |
| Viewing Path and Design Schematics . . . . .                      | A-71  |
| Inspecting a Timing Path . . . . .                                | A-73  |
| Examining Routing and Verification Errors . . . . .               | A-75  |
| Viewing and Fixing Errors . . . . .                               | A-77  |
| Filtering Errors in the Error List . . . . .                      | A-79  |
| Selecting Errors in the Layout View . . . . .                     | A-81  |
| Examining Nets Associated With Detail Routing Errors . . . . .    | A-81  |
| Examining Net Nodes Associated With Open Locator Errors . . . . . | A-82  |
| Examining Errors in an Area . . . . .                             | A-82  |
| Saving the Error List in an Error Report File . . . . .           | A-83  |
| Saving Error Updates in an Error View . . . . .                   | A-83  |
| Saving a Copy of the Editor DRC Error View . . . . .              | A-84  |
| Editing the Physical Layout . . . . .                             | A-85  |
| Editing Objects Interactively . . . . .                           | A-87  |
| Moving, Resizing, Modifying, and Removing Objects . . . . .       | A-89  |
| Routing Nets and Physical Buses . . . . .                         | A-92  |
| Expanding and Rotating Objects . . . . .                          | A-93  |
| Creating Floorplan Objects . . . . .                              | A-94  |
| Working in the Editing Environment . . . . .                      | A-94  |
| Reversing and Reapplying Edit Changes . . . . .                   | A-96  |
| Fixing and Unfixing Objects for Edits . . . . .                   | A-97  |
| Changing the Way Objects Snap to a Grid . . . . .                 | A-98  |
| Setting Editing Options . . . . .                                 | A-100 |
| Editing Groups of Objects . . . . .                               | A-102 |

|                                                    |       |
|----------------------------------------------------|-------|
| Finding and Fixing Editor DRC Violations . . . . . | A-103 |
| Verifying Route Edits Interactively . . . . .      | A-105 |
| Verifying Edited Nets . . . . .                    | A-105 |
| Setting Editor DRC Options . . . . .               | A-107 |
| Examining Editor DRC Errors . . . . .              | A-108 |
| Editing Hierarchical Cells in Place . . . . .      | A-108 |

## **Index**

# Preface

---

This preface includes the following sections:

- [What's New in This Release](#)
- [About This Guide](#)
- [Customer Support](#)

---

## What's New in This Release

Information about new features, enhancements, and changes, along with known problems and limitations and resolved Synopsys Technical Action Requests (STARs), is available in the *IC Compiler Release Notes* in SolvNet.

To see the *IC Compiler Release Notes*,

1. Go to the Download Center on SolvNet located at the following address:

<https://solvnet.synopsys.com/DownloadCenter>

If prompted, enter your user name and password. If you do not have a Synopsys user name and password, follow the instructions to register with SolvNet.

2. Select IC Compiler, and then select a release in the list that appears.
- 

## About This Guide

The IC Compiler tool provides a complete netlist-to-GDSII or netlist-to-clock-tree-synthesis design solution, which combines proprietary design planning, physical synthesis, clock tree synthesis, and routing for logical and physical design implementations throughout the design flow.

This guide describes the IC Compiler implementation and integration flow; the companion volume, *IC Compiler Design Planning User Guide*, describes the design planning flow.

---

## Audience

This user guide is for design engineers who use IC Compiler to implement designs.

To use IC Compiler, you need to be skilled in physical design and design synthesis and be familiar with the following:

- Physical design principles
- The Linux or UNIX operating system
- The tool command language (Tcl)

---

## Related Publications

For additional information about IC Compiler, see the documentation on SolvNet at the following address:

<https://solvnet.synopsys.com/DocsOnWeb>

You might also want to see the documentation for the following related Synopsys products:

- Design Compiler
- Milkyway Environment

---

## Conventions

The following conventions are used in Synopsys documentation.

| Convention            | Description                                                                                                  |
|-----------------------|--------------------------------------------------------------------------------------------------------------|
| Courier               | Indicates syntax, such as <code>write_file</code> .                                                          |
| <i>Courier italic</i> | Indicates a user-defined value in syntax, such as <code>write_file design_list</code> .                      |
| <b>Courier bold</b>   | Indicates user input—text you type verbatim—in examples, such as<br><code>prompt&gt; write_file top</code>   |
| [ ]                   | Denotes optional arguments in syntax, such as <code>write_file [-format fmt]</code>                          |
| ...                   | Indicates that arguments can be repeated as many times as needed, such as<br><code>pin1 pin2 ... pinN</code> |
|                       | Indicates a choice among alternatives, such as<br><code>low   medium   high</code>                           |
| Ctrl-c                | Indicates a keyboard combination, such as holding down the Ctrl key and pressing c.                          |
| \                     | Indicates a continuation of a command line.                                                                  |
| /                     | Indicates levels of directory structure.                                                                     |
| Edit > Copy           | Indicates a path to a menu command, such as opening the Edit menu and choosing Copy.                         |

---

---

## Customer Support

Customer support is available through SolvNet online customer support and through contacting the Synopsys Technical Support Center.

---

### Accessing SolvNet

SolvNet includes a knowledge base of technical articles and answers to frequently asked questions about Synopsys tools. SolvNet also gives you access to a wide range of Synopsys online services including software downloads, documentation, and technical support.

To access SolvNet, go to the following address:

<https://solvnet.synopsys.com>

If prompted, enter your user name and password. If you do not have a Synopsys user name and password, follow the instructions to register with SolvNet.

If you need help using SolvNet, click HELP in the top-right menu bar.

---

### Contacting the Synopsys Technical Support Center

If you have problems, questions, or suggestions, you can contact the Synopsys Technical Support Center in the following ways:

- Open a support case to your local support center online by signing in to SolvNet at <https://solvnet.synopsys.com>, clicking Support, and then clicking “Open A Support Case.”
- Send an e-mail message to your local support center.
  - E-mail support\_center@synopsys.com from within North America.
  - Find other local support center e-mail addresses at <http://www.synopsys.com/Support/GlobalSupportCenters/Pages>
- Telephone your local support center.
  - Call (800) 245-8005 from within North America.
  - Find other local support center telephone numbers at <http://www.synopsys.com/Support/GlobalSupportCenters/Pages>



## **Part I: IC Compiler Implementation Flow**

---

---



# 1

## Introduction to IC Compiler

---

IC Compiler is a single, convergent netlist-to-GDSII or netlist-to-clock-tree-synthesis design tool for chip designers developing very deep submicron designs. It takes as input a gate-level netlist, a detailed floorplan, timing constraints, physical and timing libraries, and foundry-process data, and it generates as output either a GDSII-format file of the layout or a Design Exchange Format (DEF) file of placed netlist data ready for a third-party router. IC Compiler can also output the design at any time as a binary Synopsys Milkyway database for use with other Synopsys tools based on Milkyway or as ASCII files (Verilog, DEF, and timing constraints) for use with tools not from Synopsys.

This chapter contains the following sections:

- [Supported Platforms](#)
- [IC Compiler Packages](#)
- [User Interfaces](#)
- [Methodology Overview](#)

---

## Supported Platforms

You can use IC Compiler on the platforms and operating systems shown in [Table 1-1](#).

*Table 1-1 Supported Platforms, Operating Systems, and Keywords*

| Compute platform | Operating system                            | Synopsys platform keyword                               | Desktop windowing environment |
|------------------|---------------------------------------------|---------------------------------------------------------|-------------------------------|
| x86_64           | Red Hat Enterprise Linux v4, 5 <sup>1</sup> | amd64 (64-bit mode)<br>linux (32-bit mode) <sup>2</sup> | GNOME                         |
| x86_64           | SUSE Enterprise Linux v9, 10 <sup>1</sup>   | suse64 (64-bit mode)<br>suse32 (32-bit mode)            | KDE                           |
| x86_64           | Solaris 10                                  | x86sol64 (64-bit mode)                                  | CDE                           |
| x86              | Red Hat Enterprise Linux v4, 5 <sup>1</sup> | linux (32-bit mode) <sup>2</sup>                        | GNOME                         |
| x86              | SUSE Enterprise Linux v9,10 <sup>1</sup>    | suse32 (32-bit mode)                                    | KDE                           |
| Sun SPARC        | Solaris 9, 10 <sup>1</sup>                  | sparc64 (64-bit mode)                                   | CDE                           |

1. Binary-compatible hardware platform or operating system. Note, however, that binary compatibility is not guaranteed. See <http://www.synopsys.com/Support/Licensing/SupportPlatform/ReleaseSupport/Pages/default.aspx> for the latest on supported platforms, including required OS patches.

2. The 32-bit (x86) and 64-bit (x86\_64) Linux software is binary compatible with the Intel EM64T or AMD Opteron processors running Red Hat Enterprise Linux.

---

## IC Compiler Packages

IC Compiler has four packages: IC Compiler, IC Compiler-XP, IC Compiler-PC, and IC Compiler-DP.

- If you are using IC Compiler for a netlist-to-clock-tree-synthesis design flow and will perform routing with another tool, you need the IC Compiler-PC package.
- If you are also performing routing (netlist-to-GDSII flow), you need the IC Compiler package.
- If you are designing at process nodes of 130 nm and above and need a complete netlist-to-GDSII flow, you might consider the IC Compiler-XP package.

- If you are using IC Compiler only to perform design planning, use the IC Compiler-DP package.
- If you are using IC Compiler for both design planning and implementation, including routing, for process nodes below 130 nm, use the IC Compiler package, which contains all of the IC Compiler functionality.

Note:

The design planning functionality is described in the *IC Compiler Design Planning User Guide*.

The IC Compiler, IC Compiler-PC, and IC Compiler-DP packages support both Zroute and the classic router. For these packages, Zroute is the default router. The IC Compiler-XP package supports only the classic router. This document assumes the use of Zroute for routing and chip finishing. For information about using the classic router, see the *IC Compiler Classic Router User Guide*.

Basic power optimization capabilities, including multithreshold leakage optimization, are available in the IC Compiler and IC Compiler-XP packages. Advanced power optimization capabilities, including power-aware placement and low-power clock tree synthesis, are available only in the IC Compiler package. You can enable both the basic and advanced power optimization capabilities in the IC Compiler-PC package by adding the optional Power Compiler license.

Multivoltage and multithreshold-CMOS (MTCMOS) related low-power design capabilities are available only in the IC Compiler, IC Compiler-PC, and IC Compiler-DP packages. These capabilities are standard in the IC Compiler-PC package and do not require a Power Compiler license.

The following advanced features are available only in the IC Compiler and IC Compiler-PC packages: relative placement, clock-sink clustering based on on-chip variation (OCV) analysis, and concurrent multicorner-multimode (MCMM) optimization.

The following advanced features are available only in the IC Compiler package: signoff-driven closure with incremental PrimeTime and StarRC, advanced design rule support for process nodes below 130 nm, and advanced design-for-yield (DFY) capabilities.

Each package offers a different set of licenses. Each license allows you to perform specific tasks within the IC Compiler product. [Table 1-2](#) lists the licenses provided with each package.

*Table 1-2 Licenses Required for Each IC Compiler Package*

| Licenses                       | IC Compiler package | IC Compiler-XP package | IC Compiler-PC package | IC Compiler-DP package |
|--------------------------------|---------------------|------------------------|------------------------|------------------------|
| Galaxy-ICC                     | X                   | X                      | X                      | X                      |
| Galaxy-Common                  | X                   | X                      | X                      | X                      |
| Milkyway-Interface             | X                   | X                      | X                      | X                      |
| Galaxy-FP                      | X                   | X                      | X                      | X                      |
| Galaxy-FP-MV <sup>1</sup>      |                     |                        |                        | X                      |
| Galaxy-FP-AdvCTS <sup>2</sup>  |                     |                        |                        | X                      |
| Galaxy-FP-AdvTech <sup>3</sup> |                     |                        |                        | X                      |
| Galaxy-Power                   | X                   | X                      |                        | X                      |
| Galaxy-PSYN                    | X                   | X                      | X                      |                        |
| Galaxy-MultiRoute4             | X <sup>4</sup>      | X <sup>4</sup>         |                        |                        |
| Galaxy-MultiRoute8             | X <sup>5</sup>      | X <sup>5</sup>         |                        |                        |
| Galaxy-PNR                     | X                   | X                      |                        |                        |
| Galaxy-AdvCTS                  | X                   |                        | X                      |                        |
| Galaxy-AdvTech                 | X                   |                        | X                      |                        |
| Galaxy-MV                      | X                   |                        | X                      |                        |
| Galaxy-Prototype               | X                   |                        | X                      |                        |
| Galaxy-DFT                     | X                   |                        |                        |                        |
| Galaxy-DFY                     | X                   |                        |                        |                        |
| Galaxy-IU                      | X                   |                        |                        |                        |
| Power Compiler                 |                     |                        | X <sup>6</sup>         |                        |

1. This license enables the design planning subset of the functionality enabled by the Galaxy-MV license.  
 2. This license enables the design planning subset of the functionality enabled by the Galaxy-AdvCTS license.

3. This license enables the design planning subset of the functionality enabled by the Galaxy-AdvTech license.
  4. This optional license is required for the classic router to perform distributed routing with three or four CPUs.
  5. This optional license is required for the classic router to perform distributed routing with more than four CPUs.
  6. This optional license is required to use power optimization features.
- 

## User Interfaces

IC Compiler provides two user interfaces:

- Shell interface (icc\_shell) – The IC Compiler command-line interface is used for scripts, batch mode, and push-button operations.
- Graphical user interface (GUI) – The IC Compiler graphical user interface is an advanced analysis and physical editing tool. IC Compiler can perform certain tasks, such as very accurately displaying the design and providing visual analysis tools, only from the GUI. The look and feel of the IC Compiler GUI is consistent with the look and feel of other Synopsys GUIs.

Help is available for both interfaces (see “[Viewing Man Pages](#)” on page 2-14 and “[Getting Help in IC Compiler](#)” on page 2-11).

IC Compiler uses the tool command language (Tcl), which is used in many applications in the EDA industry. Using Tcl, you can extend the IC Compiler command language by writing reusable procedures and scripts (see the *Using Tcl With Synopsys Tools* manual).

---

## Methodology Overview

The IC Compiler design flow is an easy-to-use, single-pass flow that provides convergent timing closure. [Figure 1-1](#) shows the basic IC Compiler design flow, which is centered around three core commands that perform placement and optimization (`place_opt`), clock tree synthesis and optimization (`clock_opt`), and routing and postroute optimization (`route_opt`).

**Note:**

If you have the IC Compiler-PC package, you cannot perform routing and postroute optimization or chip finishing and design for manufacturing tasks in IC Compiler.

Figure 1-1 IC Compiler Design Flow



For most designs, the `place_opt`, `clock_opt`, and `route_opt` steps are preset for optimal results. IC Compiler also provides additional placement, clock tree synthesis, and routing technologies, as well as extended physical synthesis tools, that you can use to further improve the quality of results for your design.

To run the IC Compiler design flow,

1. Set up the libraries and prepare the design data, as described in [Chapter 3, “Preparing the Design”](#).
2. Perform design planning and power planning.

When you perform design planning and power planning, you create a floorplan to determine the size of the design, create the boundary and core area, create site rows for the placement of standard cells, set up the I/O pads, and create a power plan.

For more information about design planning and power planning, see the *IC Compiler Design Planning User Guide*.

### 3. Perform placement and optimization.

To perform placement and optimization, use the `place_opt` core command (or choose Placement > Core Placement and Optimization in the GUI).

The `place_opt` core command addresses and resolves timing closure for your design. This iterative process uses enhanced placement and synthesis technologies to generate legalized placement for leaf cells and an optimized design. You can supplement this functionality by optimizing for power, recovering area for placement, minimizing congestion, and minimizing timing and design rule violations.

For more information about placement and optimization, see [Chapter 6, “Placement.”](#)

### 4. Perform clock tree synthesis and optimization.

To perform clock tree synthesis and optimization, use the `clock_opt` core command (or choose Clock > Core CTS and Optimization in the GUI).

IC Compiler clock tree synthesis and embedded optimization solve complicated clock tree synthesis problems, such as blockage avoidance and the correlation between preroute and postroute data. Clock tree optimization improves both clock skew and clock insertion delay by performing buffer sizing, buffer relocation, gate sizing, gate relocation, level adjustment, reconfiguration, delay insertion, dummy load insertion, and balancing of interclock delays.

For more information about clock tree synthesis and optimization, see [Chapter 7, “Clock Tree Synthesis.”](#)

### 5. Perform routing and postroute optimization.

To perform routing and postroute optimization, use the `route_opt` core command (or choose Route > Core Routing and Optimization in the GUI).

As part of routing and postroute optimization, IC Compiler performs global routing, track assignment, detail routing, topological optimization, and engineering change order (ECO) routing. For most designs, the default routing and postroute optimization setup produces optimal results. If necessary, you can supplement this functionality by optimizing routing patterns and reducing crosstalk or by customizing the routing and postroute optimization functions for special needs.

For more information about routing and postroute optimization, see [Chapter 8, “Routing Using Zroute.”](#)

### 6. Perform chip finishing and design for manufacturing tasks, as described in [Chapter 9, “Chip Finishing and Design for Manufacturing.”](#)

IC Compiler provides chip finishing and design for manufacturing and design for yield capabilities that you can apply throughout the various stages of the design flow to address process design issues encountered during chip manufacturing.

## 7. Save the design.

Save your design in the Milkyway format. This format is the internal database format used by IC Compiler to store all the logical and physical information about a design. For more information, see “[Saving the Design in Milkyway Format](#)” on page 3-51.

The IC Compiler reference methodology (<https://solvnet.synopsys.com/rmgen>) provides scripts that implement this flow.

---

## Speeding Up the Basic Flow

If runtime is a concern and a slight degradation in quality of results is acceptable, you can run a low-effort quick flow that uses a low effort for placement and optimization and a low effort for routing and postroute optimization. This quick flow can save 30 to 50 percent in runtime, but it can also slightly degrade the quality of results.

To run a quick flow, run the `set_fast_mode true` command before running the core commands. When you enable fast mode,

- The `place_opt` command uses low effort (and ignores the `-effort` option) and invokes congestion removal.

To further reduce runtime, you can disable congestion removal by specifying the `-no_congestion` option.

**Note:**

The quality of results after running the `place_opt` command with low effort can be disappointing, but it should improve after running clock tree synthesis.

- There is no impact on the `clock_opt` command.
- The `route_opt` command uses low effort (and ignores the `-effort` option).

# 2

## Working With IC Compiler

---

IC Compiler provides a flexible working environment with both a shell command-line interface and a graphical user interface. The shell command-line interface, `icc_shell`, is always available during an IC Compiler session. You can start or exit a session in either the GUI or `icc_shell`, and you can open or close the GUI at any time during a session. This chapter describes standard tasks for working in the IC Compiler environment.

This chapter contains the following sections:

- [Getting Started](#)
- [Getting Help in IC Compiler](#)
- [Using the IC Compiler Command-Line Interface](#)
- [Working With the GUI](#)
- [Checking the Syntax and Semantics of Your Scripts](#)
- [Working With Licenses](#)
- [Enabling Multicore Processing](#)

---

## Getting Started

The `icc_shell` command-line interface is a text-only environment in which you enter commands at the command-line prompt. The IC Compiler GUI provides both menu commands and a command-line interface. The GUI also provides tools you can use to visualize design data and analyze results. You can perform any task in the GUI that you can perform in `icc_shell`. You can use menus and dialog boxes to preview or run `icc_shell` commands.

For information about using `icc_shell` and the IC Compiler GUI, see the following sections:

- [Starting IC Compiler](#)
  - [Entering `icc\_shell` Commands](#)
  - [Choosing Menu Commands in GUI Windows](#)
  - [Interrupting or Terminating Command Processing](#)
  - [Opening and Closing the GUI](#)
  - [Using Tcl Scripts](#)
  - [Using Setup Files](#)
  - [Using Command Log Files](#)
  - [Exiting IC Compiler](#)
- 

## Starting IC Compiler

IC Compiler operates in the X Windows environment on UNIX or Linux. Before starting IC Compiler, make sure the path to the bin directory is included in your \$PATH variable. Before starting the GUI, make sure your \$DISPLAY environment variable is set to the name of your UNIX or Linux system display.

Note:

When you start IC Compiler, it automatically executes commands in the IC Compiler setup files. Setup commands perform basic tasks, such as initializing options and variables, declaring design libraries, and setting GUI options. For more details, see “[Using Setup Files](#)” on page 2-9.

You start IC Compiler by entering the `icc_shell` command in a UNIX or Linux shell:

```
% icc_shell
```

By default, this command starts the tool in the command-line interface (`icc_shell`).

You can start the tool in the GUI by specifying the `-gui` option.

```
% icc_shell -gui
```

When you start the tool in a package other than the IC Compiler package, you must indicate which package you are using. [Table 2-1](#) shows the commands for starting the various versions of IC Compiler. For more information about these IC Compiler packages, see [“IC Compiler Packages” on page 1-2](#).

*Table 2-1 Commands for Starting IC Compiler*

| IC Compiler package | IC Compiler startup command              |
|---------------------|------------------------------------------|
| IC Compiler         | <code>icc_shell [-gui]</code>            |
| IC Compiler-XP      | <code>icc_shell -xp_mode [-gui]</code>   |
| IC Compiler-PC      | <code>icc_shell -psyn_mode [-gui]</code> |
| IC Compiler-DP      | <code>icc_shell -dp_mode [-gui]</code>   |

When you start the command-line interface, the `icc_shell>` prompt appears in the UNIX or Linux shell. If you need to use the GUI after starting the command-line interface, enter the `gui_start` command at the `icc_shell>` prompt.

When you start the GUI, the `icc_shell>` prompt appears in the UNIX or Linux shell, and the IC Compiler main window opens. By default, the console appears attached (docked) to the main window above the status bar.

You can include other options on the command line when you start IC Compiler. For example, you can use

- `-f script_file_name` to execute a script
- `-x command` to execute an IC Compiler shell command
- `-display terminal_name` to display the GUI on a different terminal from the one you set with the `DISPLAY` environment variable
- `-h` to display a list of the available options (without starting IC Compiler)

For a complete list of startup options, see the *IC Compiler Quick Reference*.

At startup, IC Compiler performs the following tasks:

1. Creates a command log file
2. Reads and executes the setup files
3. Executes any script files or commands specified by the `-f` and `-x` options, respectively, on the command line
4. Displays the program header and `icc_shell>` prompt in the shell in which you started `icc_shell`

The program header lists all IC Compiler packages for which your site is licensed.

---

## Entering `icc_shell` Commands

You interact with IC Compiler by using `icc_shell` commands, which are based on the tool command language (Tcl) and include certain command extensions needed to implement specific IC Compiler functionality. The IC Compiler command language provides capabilities similar to UNIX command shells, including variables, conditional execution of commands, and control flow commands. You can

- Enter individual commands interactively at the `icc_shell>` prompt in `icc_shell`
- Enter individual commands interactively on the console command line in the GUI
- Run one or more Tcl command scripts, which are text files containing `icc_shell` commands

You enter commands in `icc_shell` the same way you enter commands in a standard UNIX or Linux shell. When the GUI is open, you can enter commands on the console command line to supplement the IC Compiler commands available through the menu interface. For details about running Tcl scripts, see [“Using Tcl Scripts” on page 2-8](#).

To enter a command in `icc_shell`,

1. Type the command on the command line.
2. Press Return.

To enter a command on the console command line,

1. Click anywhere on the console to make sure the command line is active.
2. Type the command.
3. Click the `icc_shell>` prompt button or press Return.

IC Compiler echoes the command output (including processing messages and any warnings or error messages) in both `icc_shell` and the console log view.

You can display the options used with an `icc_shell` command by entering the command name and `-help` on the `icc_shell` command line. For example, to see the options used with the `place_opt` command, enter the following command:

```
icc_shell> place_opt -help
```

For more details, see “[Getting Help on the Command Line](#)” on page 2-12.

When entering a command, an option, or a file name, you can minimize your typing by pressing the Tab key when you have typed enough characters to specify a unique name; IC Compiler completes the remaining characters. If the characters you typed could be used for more than one name, IC Compiler lists the qualifying names, from which you can select by using the arrow keys and the Enter key.

If you need to reuse a command from the output for a command-line interface, you can copy and paste the portion by selecting it, moving the pointer to the `icc_shell` command line, and clicking with the middle mouse button.

For more details about entering `icc_shell` commands, see “[Using the IC Compiler Command-Line Interface](#)” on page 2-18.

---

## Choosing Menu Commands in GUI Windows

The IC Compiler GUI provides menu commands and dialog boxes for most graphic features, such as viewing, selecting, and highlighting objects in layout views. In addition, the GUI provides menu and dialog box equivalents for many `icc_shell` commands. Menu commands are grouped by function on the menus in each GUI window. You can add commands to these menus and even create new menus.

To choose a command on a menu bar menu,

- Click the menu name to open the menu, and click the command name on the menu.

Some frequently used menu commands are also available on pop-up menus for individual views.

To choose a command on a pop-up menu,

- Move the pointer over the object of interest, right-click to display the menu, and click the command name.

A menu command can perform an immediate operation, display a submenu, or display a dialog box.

- Menu commands that display a submenu are followed by a right-pointing arrow.
- Menu commands that open a dialog box that requires a response before performing an operation are followed by an ellipsis (...). These commands open a dialog box to prompt you for the information.

Dialog boxes that require a response before performing an operation contain OK and Cancel buttons and sometimes an Apply button. After selecting options or entering information in the dialog box, you respond by clicking OK or Apply.

- Menu commands without an arrow or ellipsis either perform an immediate operation or open a dialog box that performs immediate operations.

Dialog boxes that perform immediate operations usually display options and contain a Close button. You select options that perform operations and click Close to close the dialog box.

When you choose a command or select a dialog box option that performs an immediate action, or when you click OK or Apply in a dialog box that requires a response, IC Compiler displays command output (including processing messages and any warnings or error messages) in both `icc_shell` and the console log view.

This manual identifies commands with their menus in the following formats:

- *Menu > Command*
- *Menu > Submenu > Command*

where

- *Menu* represents a menu title on the menu bar.
- *Submenu* represents a menu command that displays a submenu. Some submenus contain commands that open other submenus.
- *Command* represents a command that performs an operation or displays a dialog box.

Each menu command can also be activated by a shortcut key, which is indicated on the menu by an underscore (\_) below a letter in the command and, if needed, the name of the modifier key (Shift or Ctrl) to the right of the command name. You can view a list of shortcut keys by choosing Help > Report Hotkey Bindings. For details, see “[Displaying the List of Keyboard Shortcuts](#)” on page 2-15.

---

## Interrupting or Terminating Command Processing

If you enter the wrong options for a command or enter the wrong command, you can interrupt command processing and remain in `icc_shell`. To interrupt or terminate a command, press `Ctrl-c`.

Some commands and processes, such as `update_timing`, cannot be interrupted. To stop these commands or processes, you must terminate `icc_shell` at the system level. When you terminate a process or the shell, no data is saved.

When you use `Ctrl-c`, keep the following points in mind:

- If a script file is being processed and you interrupt one of its commands, the script processing is interrupted and no further script commands are processed.
- If you press `Ctrl-c` three times before a command responds to your interrupt, `icc_shell` is interrupted and exits with this message:

Information: Process terminated by interrupt.

This behavior has a few exceptions, which are documented in the man pages for the applicable commands.

---

## Opening and Closing the GUI

If you start `icc_shell` without the GUI, you can open the GUI by entering the `gui_start` command at the `icc_shell>` prompt.

To open the GUI,

- Enter the `gui_start` command.

```
icc_shell> gui_start
```

Alternatively, you can enter the `start_gui` command.

If you want to run a setup script before opening the GUI, use the `-file` option. For example,

```
icc_shell> gui_start -file my_gui_setup.tcl
```

If you open a design in `icc_shell` and then open the GUI, IC Compiler automatically opens a layout window and displays the design in the layout view. This is the primary design in the window. If you have multiple designs open when you open the GUI, IC Compiler opens a separate layout window for each design. The active window (the window that has the mouse focus) is the window with the current design.

When you open the GUI, it builds query data by default if a design cell is already open. This query data ensures consistent, fast interactive query operations. If you open the GUI before opening a design cell, the GUI builds the query data the first time you open a design.

If you prefer not to wait for the tool to build the query data when you open the GUI or open a design in the GUI, you can disable the build by setting the following variable:

```
icc_shell> set_app_var gui_build_query_data_table 0
```

You can build the query data manually at any time by choosing Edit > Build Query Data in a layout window.

You can open or close the GUI at any time during the session. For example, if you need to conserve system resources, you can close the GUI and continue the session in `icc_shell`.

To close the GUI, do one of the following:

- Choose File > Close GUI in the main window or layout window.
- Enter the `gui_stop` command.

```
icc_shell> gui_stop
```

Alternatively, you can close the GUI by choosing Window > Close All Windows in any GUI window or by entering `stop_gui` or `stop`.

When you are ready to use the GUI again, enter the `gui_start` command on the command line.

---

## Using Tcl Scripts

You can use Tcl scripts to accomplish routine, repetitive, or complex tasks. To run a script from the `icc_shell` command line, enter the `source file_name` command, where `file_name` is the name of the script file.

You can create a command script file by placing a sequence of `icc_shell` commands in a text file. Any `icc_shell` command can be executed within a script file.

In Tcl, a “#” at the beginning of a line denotes a comment. For example,

```
# This is a comment
```

For more information about writing scripts and script files, see the *Using Tcl With Synopsys Tools* manual. For information about using the Synopsys Syntax Checker to find syntax and semantic errors in your Tcl scripts, see “[Checking the Syntax and Semantics of Your Scripts](#)” on page 2-37.

To run a script in the GUI,

1. Choose File > Execute Scripts.

The Execute Script File dialog box is a standard file browser.

2. Navigate to the directory that contains the script file you want to run.

3. If you need to display file names that do not have a script file extension, select “All Files (\*)” in the “File type” list.

4. Double-click the file name, or select the file name and click Open.

IC Compiler executes the script and displays status messages in the console log view.

You can also run scripts when you start IC Compiler. For details about using startup scripts, see [“Starting IC Compiler” on page 2-2](#).

---

## Using Setup Files

When you start IC Compiler, it automatically executes commands in three synthesis setup files, named .synopsys\_dc.setup, and three icc\_shell setup files, named .synopsys\_icc.tcl. When you open the GUI, it automatically executes commands in three GUI setup files named .synopsys\_icc\_gui.tcl. These files reside in the installation (Synopsys root) directory, your home directory, and the project directory (the current working directory in which you start IC Compiler). For more information about the .synopsys\_dc.setup files, see the *Design Compiler User Guide*.

The setup files can contain commands that perform basic tasks, such as initializing options and variables, declaring logic libraries, and setting GUI options. You can add commands and Tcl procedures to the setup files in your home and project directories. For example,

- To set variables that define your IC Compiler working environment, create setup files in your home directory.
- To set project- or design-specific variables that affect the optimizations or analysis of a design, create a setup file in the design directory.

The default setup files in the installation directory contain system variables defined by Synopsys and general IC Compiler setup information for all users at your site. You should not edit these files.

If settings conflict between files with the same name, IC Compiler gives precedence to settings in your project directory first, then in your home directory, and finally in the installation directory. This order of precedence allows you to define your general personal settings in your home directory and the design-related settings in each project directory.

**Note:**

In addition to executing setup files when you open the GUI, IC Compiler loads application preferences from a file named `.synopsys_icc_prefs.tcl`. For details, see “[Setting GUI Preferences](#)” on page 2-35.

For more information about using IC Compiler setup files, see the “Using Setup Files” topic in IC Compiler Help.

---

## Using Command Log Files

The command log file records the `icc_shell` commands processed by IC Compiler, including setup file commands and variable assignments. By default, IC Compiler writes the command log to a file named `command.log` in the directory from which you invoked `icc_shell`.

You can change the name of the command log file by setting the `sh_command_log_file` variable in your `.synopsys_dc.setup` or `.synopsys_icc.tcl` file. You should make any changes to these variables before you start IC Compiler. If your user-defined or project-specific setup file does not contain this variable, IC Compiler automatically creates the `command.log` file.

Each IC Compiler session overwrites the command log file. To save a command log file, move it or rename it. You can use the command log file to

- Produce a script for a particular implementation strategy
- Record the physical implementation process
- Document any problems you are having

For information about using the command log file to replay a GUI session, see “[Recording and Replaying a GUI Session](#)” on page 2-36.

IC Compiler also creates a file named `icc_output.txt` that contains a log of the text shown in `icc_shell` during the session. This text file is not executable.

---

## Exiting IC Compiler

You can end the session and exit IC Compiler at any time. To exit IC Compiler, use the `exit` or `quit` command (or choose File > Exit).

When you exit IC Compiler by using the `exit` or `quit` command, IC Compiler does not save the open designs. If you enter the command on the console command-line in the GUI, an IC Compiler message box appears; click OK to exit.

When you exit IC Compiler by choosing File > Exit in the GUI and there are unsaved changes in any open designs, the Exit IC Compiler dialog box appears, which allows you to save the changes to the modified designs. By default, you can either save or discard all changes. If you select “Show advanced options,” you can

- Specify a list of scenarios with constraints that you need to save with the designs.
- Select from the following options for each modified design,
  - Save a new CEL version of the design
  - Save a copy of a design with a new name
  - Save the design hierarchy (a modified top-level design together with all its subdesigns and attached files) into the same CEL version
  - Close the design after saving or discarding changes

For more information about using the advanced options to save or discard changes, see [“Saving the Design in the GUI” on page 3-51](#).

If you do not have unsaved design changes, an IC Compiler message box appears instead of the Exit IC Compiler dialog box. If you see this message box, click OK to exit.

IC Compiler does not save view settings when you exit. If you have changed view settings for layout or schematic views and want to save them, do so before exiting the tool, as explained in [“Setting and Saving View Properties” on page A-41](#).

---

## Getting Help in IC Compiler

IC Compiler provides a variety of user-assistance tools. You can view command-line Help and man pages for `icc_shell` commands and variables, find equivalent GUI menu commands and dialog boxes for `icc_shell` commands, display a list of keyboard shortcuts that you can use in the GUI, view contextual Help pages for interactive editing and visualization tools, and view a Help system with information about using IC Compiler with the GUI.

For information about these tools, see the following sections:

- [Getting Help on the Command Line](#)
- [Finding Menu Commands and Dialog Boxes](#)
- [Viewing Man Pages](#)
- [Displaying the List of Keyboard Shortcuts](#)
- [Using Online Help](#)

---

## Getting Help on the Command Line

The following online information resources are available while you are using the IC Compiler tool:

- Command help, which is a list of options and arguments used with a specified `icc_shell` command, displayed in the IC Compiler shell and in the console log view when the GUI is open
- Man pages displayed in the IC Compiler shell and in the console log view when the GUI is open
- A man page viewer that displays command, variable, and error message man pages that you request while using the GUI

To display a brief description of an `icc_shell` command,

- Enter `help` followed by the command name:

```
icc_shell> help command_name
```

To display a list of command options and arguments,

- Enter the command name followed by the `-help` option:

```
icc_shell> command_name -help
```

To display a man page in `icc_shell` and in the console log view if the GUI is open,

- Enter `man` followed by the command or variable name in `icc_shell`:

```
icc_shell> man command_or_variable_name
```

To display a man page in the GUI man page viewer, do either of the following:

- Enter `man` followed by the command or variable name on the console command-line in the GUI:

```
icc_shell> man command_or_variable_name
```

- Enter `gui_show_man_page` followed by the command or variable name in `icc_shell` or on the console command-line in the GUI:

```
icc_shell> gui_show_man_page command_or_variable_name
```

Note:

If you enter the `gui_show_man_page` command in `icc_shell` when the GUI is closed, the tool automatically opens the GUI and displays the man page in the man page viewer.

To view man pages interactively in the GUI man page viewer,

1. Choose Help > Man Pages.

The man page viewer opens.

2. Select the type of man pages to view: Commands, Variables, or Messages.

A list of man pages appears.

3. Select the man page to view.

For more information about using the man page viewer, see “[Viewing Man Pages](#)” on [page 2-14](#).

---

## Finding Menu Commands and Dialog Boxes

You can quickly find the equivalent menu command and open the dialog box for any `icc_shell` command by using the `gui_show_form` command. You can specify a single `icc_shell` command or use wildcard characters (?) or (\*) to specify commands with similar names. The `gui_show_form` command has the following syntax:

```
gui_show_form command_name_or_name_pattern
```

When you specify a command that is used by only one dialog box, the GUI displays the menu command and the application task in the console log view and opens the dialog box.

```
icc_shell> gui_show_form open_mw_cel
Info: GUI access for open_mw_cel
      Menu : File->Open Design...
      Task : all
```

Task indicates the application tasks in which the menu command is available. For menu commands in the layout window, you can set the current application task to block implementation, design planning, or all tasks. For menu commands in other windows, the current application task is always all tasks. To learn more about application tasks in the layout window, see “[Setting the Current Task](#)” on [page 2-34](#).

When you specify an `icc_shell` command that is used by more than one dialog box or specify a name pattern that matches more than one `icc_shell` command name, the GUI displays an information table in the man page viewer. For each `icc_shell` command, the table displays information in the following columns:

- Command – displays the `icc_shell` command names with keywords for additional menu commands
- Menu – displays the equivalent menu command names
- Window – displays the names of the windows in which the menu commands can be found

- Task – displays the application tasks in which the menu commands are available
- You can click links in the man page viewer to open dialog boxes and view man pages.

To open the dialog box for a menu command,

- Click the link on the menu command name in the man page viewer.

To display the man page for an `icc_shell` command,

- Click the link on the `icc_shell` command name in the man page viewer.

If you specify an `icc_shell` command used by a menu command that performs an immediate action without opening a dialog box, the GUI displays the command information in the man page viewer. If you enter a name for an `icc_shell` command that does not exist, the GUI displays an error message in the console log view.

---

## Viewing Man Pages

You can use the man page viewer to view, search, and print man pages for commands, variables, and error messages.

To view a man page in the man page viewer,

1. Choose Help > Man Pages.

The man page viewer appears and displays a list of links for the different man page categories.

2. Click the category link for the type of man page you want to view: Commands, Variables, or Messages.

The contents page for the category displays a list of title links for the man pages in that category.

3. Click the title link for the man page you want to view.

You can also display man pages in the man page viewer by using the `man` command (or the `gui_show_man_page` command) on the console command line. For more information about using the man page viewer, see the “Viewing Man Pages” topic in IC Compiler Help.

---

## Displaying the List of Keyboard Shortcuts

You can view a report of the keyboard shortcuts for Tcl commands and commands on menus in the active window. IC Compiler displays the hotkeys report in a report view.

To display the report of keyboard shortcuts for the active window,

- Choose Help > Report Hotkey Bindings.

The report consists of three columns:

- Hot Key lists the shortcut keys or key combinations.
  - Type indicates whether the key is a shortcut for a menu command or a Tcl command.
  - Function lists the commands that the shortcut keys launch.
- 

## Using Online Help

The IC Compiler GUI provides the following types of online Help:

- Contextual Help pages that display information about the current interactive editing or visualization tool in GUI
- A Web browser-based Help system that explains how to use IC Compiler with the GUI

Contextual Help pages are available for most of the interactive mouse tools and for certain other tools, such as the error browser. These Help pages provide usage information for the tool, explanations of the tool's options, and descriptions of the Tcl command options used to log the tool operations.

To view the Help page for the tool you are currently using,

- If the tool displays options on the Mouse Tool Options toolbar, click the  button.
- If the tool displays options on a panel or in a dialog box, click the Help button.

IC Compiler Help is a browser-based HTML Help system that provides detailed information and instructions for using the IC Compiler GUI. You can use it to

- Learn about tool features, including windows, views, toolbars, panels, menus, and dialog boxes
- Learn how to use the interactive visualization and editing tools
- Learn how to use IC Compiler to perform design tasks

To open IC Compiler Help in your Web browser,

1. Choose Help > IC Compiler Online Help.

The Help system appears in a Web browser window and displays the Welcome topic for IC Compiler Help.

2. Use the navigation frame (leftmost frame) to find the information you need in one of the following ways:

- Browse for the topic in the hierarchical table of contents by clicking Contents and expanding the appropriate books until you find the information you need.
- Find the topic by its subject by clicking Index and looking for the subject in the alphabetical listing.
- Search for text found in topics by clicking Search and entering the text.

If more than one topic has the words you are searching for, you must select the appropriate topic from a list of topics.

For more information, see the following sections:

- [Searching for Text](#)
- [Configuring the Help Browser](#)

## Searching for Text

IC Compiler Help lets you search for text in any Help topic. By default, the Search mechanism in the navigation frame performs a Boolean AND search for one or more text strings separated by spaces. To search for an exact phrase containing two or more words, enclose the words within double quotation marks ("").

A legal search string has the following characteristics:

- Contains letters and numbers
- Can begin with a period (.) or hyphen (-)
- Can contain underscores (\_), but only in a string that begins with a hyphen  
However, you can find a string that contains underscores by replacing them with blank spaces and enclosing the string in double quotation marks.
- Can contain a slash (/), backslash (\), or colon (:), but only when preceded and followed by whole words or in a string that begins with a hyphen
- Cannot contain a comma (,) or semicolon (;) in any position

- Cannot contain quotation marks (" , ' ) or any other special characters in any position
- Is three or more characters long

Searches are not case-sensitive. Search results are ranked according to the location of the matched term and the number of matches. Matches in headings always rank near the top. To locate the search string in a Help topic, you can use the quick search box on the button bar above the topic frame or the Find command in your Web browser.

## Configuring the Help Browser

You can use the following Web browsers to view IC Compiler Help:

- Firefox version 1.5 or 2.0
- Mozilla 1.7

The default Help browser is Firefox. You can use the `gui_online_browser` variable to control which browser IC Compiler uses to display the Help system.

To set the browser for the current GUI session,

- Enter the following command after you start the IC Compiler GUI:

```
set gui_online_browser "browser-name"
```

The *browser-name* must be one of the following:

```
firefox  
mozilla
```

Alternatively, you can set the default Help browser for any GUI session by including the `gui_online_browser` variable in the `.synopsys_icc_gui.tcl` file in your home directory.

You can open IC Compiler Help from within the IC Compiler GUI (choose Help > IC Compiler Online Help) or standalone in your Web browser. To open the Help system from within the GUI, the browser executable file must be specified in your UNIX or Linux path variable.

IC Compiler Help makes extensive use of JavaScript and style sheets. If your browser encounters problems displaying the Help system, open the browser preferences and make sure that JavaScript and style sheets are enabled and that JavaScript is not blocked by your security preferences.

Note:

Although IC Compiler Help might work on a standalone basis in Internet Explorer versions 6.0 and later, it is not tested in this browser.

---

## Using the IC Compiler Command-Line Interface

The IC Compiler command language provides capabilities similar to UNIX command shells, including variables, conditional execution of commands, and control flow commands. The syntax for an `icc_shell` command is

`command_name [-option [argument]] [command_argument]`

`command_name`

The name of the command.

`-option`

Modifies the command and passes information to the tool. Options specify how the command should run. A hyphen (-) precedes option names. Options that do not take an argument are called switches.

`argument`

The argument to an option. Some options require values, keywords, or other information. If you omit a required argument, an error message and a usage statement appear.

`command_argument`

Some IC Compiler commands require command arguments that do not begin with a hyphen (-). These are positional arguments that must be entered in a specific order relative to each other. Named arguments (that begin with a hyphen) can be entered in any order and can be intermingled with positional arguments.

Command names and variable names are case-sensitive, as are other values, such as file names, design object names, and strings.

You can abbreviate command names and options to the shortest unambiguous (unique) string. For example, you can abbreviate the `get_attribute` command to `get_attr` or the `create_clock` command's `-period` option to `-p`. However, you cannot abbreviate most built-in commands. If you enter an ambiguous command, `icc_shell` attempts to help you find the correct command.

Note:

Command abbreviation is meant as an interactive convenience. Do not use command or option abbreviation in script files because script files are susceptible to command changes in subsequent versions of the tool. Such changes can cause abbreviations to become ambiguous.

If you enter a long command with many options and arguments, you can split it across more than one line by using the continuation character, the backslash (\). There is no limit to the number of characters in an `icc_shell` command line.

If you want to put more than one command on a line, separate the commands with a semicolon. If you want to include a comment in a command, begin the comment with the “#” character. The comment can start anywhere on a line. It ends with the end of the line.

Every `icc_shell` command returns a value, either a status code or design-specific information. The command status codes in `icc_shell` are

- 1 for successful completion
- 0 or { } (null list) for unsuccessful execution

The IC Compiler command language also supports wildcard characters and aliases. In addition, you can rerun commands and redirect or append command output. For details, see the following sections:

- [Using Wildcard Characters](#)
- [Using Aliases](#)
- [Listing and Rerunning Previously Entered Commands](#)
- [Reporting Memory Usage and Runtime](#)
- [Redirecting and Appending Command Output](#)

For additional information about Tcl commands and the IC Compiler command language, see the *Using Tcl With Synopsys Tools* manual and the *Design Compiler Command-Line Interface Guide*.

---

## Using Wildcard Characters

The IC Compiler command language has two wildcard characters:

- The wildcard character “\*” matches one or more characters in a name.  
For example, `u*` indicates all object names that begin with the letter u, and `u*z` indicates all object names that begin with the letter u and end in the letter z.
- The wildcard character “?” matches a single character in a name.  
For example, `u?` indicates all object names exactly two characters in length that begin with the letter u.

---

## Using Aliases

You can use aliases to create short forms for the commands you commonly use. When you use aliases, keep the following points in mind:

- The `icc_shell` interface recognizes aliases only when they are the first word of a command.
- An alias definition takes effect immediately but lasts only until you exit the IC Compiler session. To save commonly used alias definitions, store them in the `.synopsys_dc.setup` file.
- You cannot use an existing command name as an alias name; however, aliases can refer to other aliases.

The following example shows how you can use the `alias` command to create a shortcut for the `report_timing` command:

```
icc_shell> alias rt100 {report_timing -max_paths 100}
```

Use the `unalias` command removes alias definitions created with the `alias` command. For example, to remove all aliases beginning with `f*` and the `rt100` alias, enter

```
icc_shell> unalias f* rt100
```

---

## Listing and Rerunning Previously Entered Commands

You can use the `history` command to list the commands used in an `icc_shell` session. It prints an ordered list of previously executed commands. You can control the number of commands printed. The default number printed is 20. The `history` command is complex and can generate various forms of output. For detailed information about this command, see the man page.

You can rerun and recall previously entered commands by using the exclamation point (!) operator. For more information, see the *Design Compiler Command-Line Interface Guide*.

---

## Reporting Memory Usage and Runtime

By default, IC Compiler does not provide statistics for memory usage or runtime. To enable the reporting of CPU time, elapsed time, and peak memory usage before and after each major command, set the `monitor_cpu_memory` variable to `true`. For more information about this variable, see the man page.

---

## Redirecting and Appending Command Output

If you run `icc_shell` scripts overnight to compile a design, you cannot see warnings or error messages echoed to the command window while your scripts are running. You can direct the output of a command, procedure, or script to a specified file in two ways:

- By using the traditional UNIX redirection operators (`>` and `>>`)
- By using the `redirect` command

You can use the UNIX redirection operators (`>` and `>>`) in the following ways:

- Divert command output to a file by using the redirection operator (`>`).
- Append command output to a file by using the append operator (`>>`).

Note:

Unlike UNIX, IC Compiler treats `>` and `>>` as arguments to a command. Therefore, you must use white space to separate these arguments from the command and the redirected file name. The pipe character (`|`) has no meaning in the `icc_shell` interface.

You cannot use the UNIX style redirection operators with built-in commands because the UNIX redirection operators are not part of Tcl. Always use the `redirect` command when using built-in commands. The Tcl built-in command `puts` does not respond to redirection of any kind. Instead, use the `echo` command, which does respond to redirection.

The `redirect` command performs the same function as the traditional UNIX redirection operators (`>` and `>>`); however, the `redirect` command is more flexible. Also, the UNIX redirection operators are not part of Tcl and cannot be used with built-in commands. You must use the `redirect` command with built-in commands.

- The result of a redirected command that does not generate a Tcl error is an empty string.
- Screen output from a redirected command occurs only when there is an error.
- You can redirect multiple commands or an entire script.

Although the result of a successful `redirect` command is an empty string, you can get and use the result of the command you redirected. You do this by constructing a `set` command in which you set a variable to the result of your command, and then redirecting the `set` command. The variable holds the result of your command. You can then use that variable in a conditional expression.

You can direct command output to the standard output device as well as a redirect target by using the `-tee` option.

---

## Working With the GUI

The IC Compiler GUI provides a flexible working environment with multiple windows for performing different tasks. The GUI windows operate independently in your X Windows environment, but they all share the design and global selection data in the tool.

For information about how to get started working with the IC Compiler GUI, see the following sections:

- [Using GUI Windows](#)
  - [Working in the Main Window](#)
  - [Working With the Console](#)
  - [Viewing the Physical Layout](#)
  - [Setting GUI Preferences](#)
  - [Recording and Replaying a GUI Session](#)
- 

## Using GUI Windows

Each top-level GUI window displays design information in view windows and provides menus and dialog boxes (with keyboard shortcuts), toolbars and panels, interactive mouse button tools, a command console (with a command-line interface), and a status bar. View windows are child windows that appear in the workspace area between the toolbars and the status bar.

The IC Compiler GUI provides the following types of windows:

- IC Compiler main window
- Layout window
- Timing analysis window
- Interactive clock tree synthesis (CTS) window
- Relative placement (RP) window
- Partition editor window

Each top-level GUI window is independent of other GUI windows. The title bar displays the product name (IC Compiler), the window name (MainWindow.1 for the window that appears when you start the GUI) and the name of the active view (the view window that has the mouse focus). Design objects you select in one window are automatically selected in the other windows.

You can open and close GUI windows, and you can open multiple instances of each window to work with different design settings. Each window instance has a unique name that includes an incremented number.

To open a new instance of a GUI window,

- Choose Window > *window-type*.

To close a GUI window,

- In the window you want to close, choose Window > Close Window.

Note:

If you close all the open GUI windows, you end the GUI session but you remain in the `icc_shell` and your designs remain open. You can reopen the GUI by using the `gui_start` command.

You can move, resize, minimize, or maximize GUI windows by using the window management tools on your UNIX or Linux desktop.

For more information about the top-level GUI windows, see the following sections:

- [Menu Bar](#)
- [Toolbars](#)
- [Status Bar](#)
- [View Windows](#)
- [Panels](#)

## Menu Bar

The menu bar at the top of a GUI window contains menus with the commands you need to work in the window. You can display a brief message in the status bar about the action that a menu command performs by holding the pointer over the command. For menu commands that can also be used by clicking a toolbar button or pressing a keyboard shortcut, the menus show representations of those alternatives.

Note:

If a window is not wide enough to display all the menu names on the menu bar, the window displays all the menu names that fit, from left to right, followed by an overflow button (»). To access the other menus, click the overflow button.

## Toolbars

Each top-level IC Compiler window provides toolbars with buttons you can use to quickly perform frequently used operations or tasks. To determine the function of a toolbar button, hold the pointer over the button. A ToolTip displays the name of the button, and the status bar displays a brief description of its use. You cannot disable these messages.

Toolbars are always attached to a window edge. If a window edge is not long enough to display all of the toolbars attached to it, the GUI displays the full toolbars that fit and shortened versions of the other toolbars. A shortened toolbar displays an overflow button (). To access the other buttons on a shortened toolbar, click the overflow button.

You can move a toolbar to another location by dragging the double bars on one of its sides. You can also disable a toolbar, hiding it from view.

To display or hide a toolbar or panel,

- Choose View > Toolbars > *toolbar\_name*.

A check mark beside the name of a toolbar on the Toolbars menu indicates that the toolbar is visible.

## Status Bar

Each GUI window displays a status bar at the bottom of the window. The status bar displays the following information:

- Status information such as the number and type of selected objects
  - Information about the action performed by the toolbar button, menu command, or workspace tab under the pointer
- If you hold the pointer over a menu command, a toolbar button, or a tab in the workspace, the status bar displays a brief message about the action that the command, button, or tab performs.
- The relative coordinates of the pointer position over an active layout view (layout windows only)

To quickly display the list of selected objects in the Selection List dialog box, click the  button at the right end of the status bar.

You can control the visibility of the status bar in each GUI window.

To display or hide the status bar,

- Choose View > Status Bar.

A check mark next to the Status Bar command on the View menu indicates that the status bar is visible.

## View Windows

IC Compiler displays design information in view windows, which are child windows that open within the workspace area of a GUI window. View windows display specific graphic or textual design information.

Most menu commands and toolbar buttons in a GUI window operate in the active view, which is the view window that has the mouse focus. Some view windows contain two or more panes, with a view in each pane. You can drag the split bars between two panes to adjust their relative sizes within the window.

You can resize a view window or move it to another location inside the workspace area of its parent window.

To change the size of a view window,

1. Hold the pointer over an edge or corner of the window until the pointer changes shape.
2. Drag the edge or corner to resize the window.

To move a view window,

1. Move the pointer over the title bar.
2. Drag the window to a different location.

You can organize view windows by tiling or cascading them within the workspace area.

To tile the view windows in the workspace area,

- Choose Window > Tile.

To cascade the view windows in the workspace area,

- Choose Window > Cascade.

You can also minimize individual view windows, or maximize a view window to fill the workspace area.

The GUI displays a tab at the bottom of the workspace area for each open view window. When you click a tab, the view window appears on top of the other view windows in the workspace area and becomes the active view.

**Note:**

If a view window and a panel overlap on the screen, the panel appears on top of the view window.

In most views, you can use navigation keys (the arrow keys, Page Up, Page Down, Home, and End) to scroll through and navigate the view.

## Panels

Panels are enhanced toolbars that open within the workspace area of a top-level window to provide tools or views for performing particular tasks. Most panels are associated with a particular view window and operate on the active view (the view window that has the mouse focus). An exception is the console, which contains a command line and its own views.

Some panels contain tabs that you can click to access different tools or views. The first time that you open a panel during a session, it displays the tools or view for its default tab.

You can move a panel to another location on or off the parent window by dragging the double bars on one of its sides. You can also dock a panel (attach it to a window edge) or let it float where you leave it.

You can also disable a panel, hiding it from view. (A panel that is associated with a particular view is automatically hidden when you close the view window.)

To display or hide a toolbar or panel,

- Choose View > Toolbar > *panel\_name*.

A check mark beside the name of a panel on the Toolbars menu indicates that the panel is visible.

---

## Working in the Main Window

When you start IC Compiler and open the GUI, the IC Compiler main window appears.

[Figure 2-1](#) identifies the major features of the main window. For information about these features, see the “IC Compiler Main Window” topic in IC Compiler Help.

Figure 2-1 IC Compiler Main Window Features



In the main window, the console is docked above the status bar by default. Although the other top-level GUI windows also provide consoles, they are hidden by default.

Typically, you use the main window to

- Run Tcl scripts
- Enter `icc_shell` commands, monitor command processing, and view messages in the console
- Read in and save (or close) designs
- Set variables and setup options
- Open other GUI windows
- Close the GUI or exit IC Compiler

In addition, you can open view windows (in the workspace area below the toolbars), explore the logic design in the hierarchy browser, examine the logic design in design schematics, and examine design object and timing information in object list views.

---

## Working With the Console

The console provides a command-line interface and two views, a log view that displays the session transcript (the default) and a history view that displays the command list.

You can use the console to

- Enter IC Compiler Tcl commands on the console command line
- View either the session transcript (log view) or the command history list (history view) by clicking the tabs above the command line
- Display an error message man page in the man page viewer by clicking the message number in the console log view
- Copy and edit or reuse commands
- Search for, select, and save commands or messages in the log view or the history view

You can enter any IC Compiler shell command on the console command line. For example, if you enter `get_selection`, the console log view displays a list of the names of all selected objects. When you enter a command on the console command line, make sure the console has the mouse focus.

To enter a command on the console command line,

1. Type the command.
2. Click the `icc_shell>` prompt button or press Return.

You can open (or close) one console in each top-level window. When the console is open, you can dock it to the bottom or top of its parent window, or move it over or away from the window.

For more information about the console, see the following sections:

- [Viewing the Session Log](#)
- [Viewing the History View](#)
- [Previewing `icc\_shell` Commands in Dialog Boxes](#)

## Viewing the Session Log

The console log view displays a transcript of session information that includes the commands you entered and the IC Compiler output and messages resulting from your commands. You can use this information to check on tool status after performing functions, to troubleshoot problems you encounter, and to look up information about past functions. You can even reenter commands you have already used by copying them from the log to the `icc_shell` command line.

To view the session transcript,

- Click the Log tab in the console.

The console changes to the log view, which is displayed by default whenever the console is opened.

The log view displays the commands you enter next to a boldfaced `icc_shell>` prompt. Warnings and error messages are noted with “Warning” or “Error” as the first word. If you need to see information not currently displayed in the display area of the log view, use the scroll bars to scroll through the session information.

You can use commands on the Options menu (on the right side of the console above the command line) to

- Find text in the transcript
- Select and copy text in the transcript
- Search the transcript for commands or messages
- Save text from the transcript in a text file

To find text in the transcript,

1. Choose Options > Find.

The Find Text in Console dialog box appears.

2. Type the text you want to find in the Find box.

You must type the text exactly as it appears in the transcript, including uppercase and lowercase letters and blank spaces.

3. Search the transcript forward, by clicking Next, or backward, by clicking Previous.

The console highlights the next or previous instance of the text. Repeat this step as needed to find additional instances of the text.

To copy a used command from the log view to the command line,

1. Select the command or portion of the command that you want to copy in the log view.
2. Middle-click the console command line.

If you already have text on the command line, middle-click where you want to paste the selected information.

You can copy text in the transcript that you want to paste somewhere else, such as in a file.

To copy text in the transcript,

1. Drag the pointer over the text to select it.

You can select all of the text in the transcript by choosing Options > Select All.

2. Choose Options > Copy.

You can search the transcript for commands or messages, and you can set the types of text that you want the search mechanism to find.

To search the transcript,

1. (Optional) Set up the search criteria to include or exclude certain types of information by choosing commands on the Options menu.

You can include or exclude commands, error messages, warnings, or information messages. Check marks appear on the Options menu next to the commands for the types of text included in the search.

2. Search forward or backward by choosing Options > Find Next or Options > Find Previous.

The console highlights the next or previous instance of any text type you included in the search.

3. Repeat step 2 as needed to find the command or message you need.

You can save all the text in the transcript, save selected text, or save just the error and warning messages.

To save text from the transcript in a text file,

1. Do one of the following:

- To save the transcript, choose Options > Save Contents As.
- To save selected text, drag the pointer over the text to select it, and choose Options > Save Selection As.
- To save error and warning messages, choose Options > Save Errors/Warnings As.

2. In the dialog box that appears, navigate to the directory where you want to save the file.
3. Enter the file name in the “File name” box.
4. Click Save.

## Viewing the History View

The console history view lists shell, menu, and stroke commands you have used in the current session. You can do the following with this list:

- See which commands you have used
- Find and reuse commands already used
- Copy commands in the list
- Save the list for later use

To view the command history for the current session,

- Click the History tab in the command console.

The console displays the list of commands, each with a number showing the order in which you used it.

If you need to see information not currently displayed in the display area of the history view, use the scroll bars to scroll through the list of commands. Alternatively, you can enter the `history` command on the command line. This displays the list of commands in the log view.

To reuse a command listed in the history view, you can do any of the following:

- Double-click the command in the history view.
- Select the command in the view and click either Execute (to immediately rerun the command) or Edit (to paste the command on the command line where you can edit it).
- Enter an exclamation point character followed by the number of the command on the `icc_shell` command line.

For example, to reuse the fifth command, enter the following:

```
icc_shell> !5
```

You can copy commands in the list that you want to paste somewhere else, such as in a file.

To copy commands in the history list,

1. Drag the pointer over the text to select it.

You can select all of the text in the transcript by choosing Options > Select All.

2. Choose Options > Copy.

To save the command history list (or a portion of the list) in a text file,

1. (Optional) To save a portion of the list, select the commands you want to save.

2. Do one of the following:

- If you are saving the entire list, click the Save Contents As button or choose Options > Save Contents As.

The Save Contents As dialog box appears.

- If you are saving just a portion of the list, choose Options > Save Selection As.

The Save Selection As dialog box appears.

3. If necessary, navigate to the directory where you want to save the file.

4. Enter the file name in the “File name” box.

5. Click Save.

You can set options in the Application Preferences dialog box to control which types of GUI commands are included in the history list. For details, see “[Setting GUI Preferences](#)” on page 2-35.

## Previewing `icc_shell` Commands in Dialog Boxes

Many IC Compiler dialog boxes support a preview mechanism that you can use to view the commands without running them. You can view the command equivalents for various dialog box options, or combinations of options, or generate an `icc_shell` command that you want to copy into a script. When you enable the preview mechanism, it remains on for all dialog boxes that support the feature until you disable it.

When you click OK or Apply in a dialog box that supports the preview mechanism while the mechanism is enabled, the `icc_shell` command equivalents appear in the console history log preceded by a pound sign (#), but IC Compiler does not execute the commands and they do not appear in the console log view or the shell transcript.

To enable or disable the dialog box command preview mechanism,

- Click the  menu button in the bottom right corner of a dialog box, and choose Preview command only.

A check mark next to “Preview command only” on the menu indicates that the preview mechanism is enabled.

---

## Viewing the Physical Layout

When you read in a design, a new layout window appears and displays the design in the layout view. This is the primary design in the window. Each layout view you open in a layout window displays the primary design. [Figure 2-2](#) identifies the major layout window features.

*Figure 2-2 IC Compiler Layout Window Features*



The layout window provides the physical design working environment for the GUI. Layout views provide the focal points for viewing, analyzing, and editing the physical design.

You can use the layout window for each major stage in the physical design process, including the floorplan, the power network, placement, preroute, routing, finishing, and verification.

The layout window provides the following layout analysis tools:

- Visually customizable layout views
- A hierarchy browser you can use to explore the design hierarchy and highlight hierarchical cells and subblocks in the layout view
- A relative placement hierarchy view you can use to examine relative placement groups and hierarchy levels in the design
- An error browser you can use to examine routing and verification errors and highlight their locations in the layout view

## Setting the Current Task

You can configure the IC Compiler GUI for the design task you are performing by setting the current application task to block implementation, design planning, or all tasks. The block implementation and design planning tasks simplify the menus you use and provide better layout view rendering performance for large designs.

The current task applies to all open layout windows. It controls the types of menus and menu commands that appear in the layout window menu bar and the visibility of some object types in the layout view.

To set the current task,

- Choose File > Task > *task\_type*, where *task\_type* is Design Planning, Block Implementation, or All Tasks.

Alternatively, you can use the `gui_set_current_task` command. You can also change the default task by setting the current task in one of the IC Compiler setup files, `.synopsys_icc.tcl` or `.synopsys_icc_gui.tcl`, in the design directory or in your home directory.

When you set the current task to design planning, the tool automatically hides standard cells and cell contents in the layout view and displays the following message in the console log view:

```
Visibility is turned OFF for cells and cell contents because the task  
is set to Design Planning (GUI-026)
```

When you set the current task to either block implementation or all tasks, the tool automatically displays standard cells and cell contents in the layout view and displays an appropriate message in the console log view.

You can disable this automatic behavior by setting the `setVisibilityByTask` preference to `false`. For example, to set the preference, enter

```
icc_shell> gui_set_pref_value -category layout \
-key setVisibilityByTask -value false
```

In addition, you can manually control the visibility of cells and cell contents by setting options on the View Settings panel. For details, see the “Setting the Current Task” topic in IC Compiler Help.

## Setting the Primary Design

If you open a new layout window when multiple designs are open, you must select the primary design for the window.

To open a new layout window,

- Choose Window > New Layout Window.

If you have more than one design open, the Choose Design dialog box appears and displays a list of the open designs.

- a. Select the name of the design you want to make the primary design for layout views in the new layout window.
- b. Click OK.

Note:

The GUI provides special windows for timing path analysis and clock tree synthesis. For details, see “[Analyzing Timing Paths](#)” on page A-66 and “[Analyzing Clock Trees](#)” on page A-57.

---

## Setting GUI Preferences

At the beginning of a GUI session, IC Compiler loads GUI preferences and layout view settings from the preferences file, `.synopsys_icc_prefs.tcl`, in your home directory. You can change global preferences for GUI tools and the window environment by setting options in the Application Preferences dialog box. If you change preference settings during a GUI session, the new settings are automatically saved in your preferences file when you click OK in the Application Preferences dialog box.

The preferences you can set include

- Font options
- GUI command logging options
- Global tool default options
- Global layout view options
- Global schematic view options

For details about setting these preferences, see the “Setting GUI Preferences” topic in IC Compiler Help.

---

## Recording and Replaying a GUI Session

You can use the command log file as a replay script to reproduce a GUI session in IC Compiler. The command log file records the `icc_shell` commands processed by IC Compiler, including setup file commands and variable assignments. Before you record a GUI session, make sure that the preferences for logging selection operations and interactive GUI operations are enabled in the Application Preferences dialog box.

**Important:**

You must replay the entire command log file as is, with no modifications, to reproduce the exact state of the design in the GUI.

To set GUI command logging preferences,

1. Choose View > Preferences.

The Application Preferences dialog box appears.

2. Select Global Settings in the Categories tree.

3. Select the optional output logging options as needed.

- To enable logging of interactive selection operations, select the “Selection commands” option.
- To enable logging of other interactive GUI operations, select the “GUI commands” option.

4. Click OK or Apply.

For more information about the command log file, see “[Using Command Log Files](#)” on page 2-10.

---

## Checking the Syntax and Semantics of Your Scripts

The Synopsys Syntax Checker, which is based on the TclPro Checker (`procheck`), helps you find syntax and semantic errors in your Tcl scripts. Everything that you need for syntax and semantic checking is shipped with IC Compiler. In this environment, the following items are checked:

- Unknown options
- Ambiguous option abbreviation
- Use of exclusive options
- Missing required options
- Validation of literal option values for numerical range (range, `<=`, `>=`)
- Validation of one-of-string (keyword) options
- Recursion into constructs that have script arguments, such as the `redirect` and `foreach_in_collection` commands
- Warning of duplicate options that override previous values

The open-source TclPro toolkit also includes the following tools, which are not included in the IC Compiler distribution, but which can be downloaded separately:

- TclPro Compiler (`procomp`), which is a standalone bytecode compiler
- TclPro Debugger (`prodebug`), which is a Tcl debugger

For more information about the TclPro tools, see the following Web address:

<http://tcl.sourceforge.net>

The following sections discuss how to use these tools in the Synopsys environment:

- [Installation Requirements](#)
- [Running the Synopsys Syntax Checker](#)
- [Limitations of the Synopsys Syntax Checker](#)
- [Bytecode-Compiled Files](#)
- [TclPro Limitations](#)

---

## Installation Requirements

To access only the syntax checker, you do not need to download the TclPro tools. To use any TclPro tools other than the syntax checker, you must install TclPro on your system. After you have installed TclPro on your system, you must define the `SNPS_TCLPRO_HOME` environment variable to define where the TclPro installation exists.

For example, if you installed TclPro version 1.5 at `/u/tclpro1.5`, you must set the `SNPS_TCLPRO_HOME` variable to point to that directory. IC Compiler uses this variable as a base for launching some of the TclPro tools. In addition, other Synopsys applications use this variable to link to the TclPro tools.

---

## Running the Synopsys Syntax Checker

The Synopsys Syntax Checker for IC Compiler is a standalone executable called `iccprocheck`. This executable is located at `$root/bin/iccprocheck`

[Example 2-1](#) shows a script that is being run through `iccprocheck`. [Example 2-2](#) shows the resulting output from `iccprocheck`. Each line in the output shows where a syntax or semantic error was detected. The offending command is shown with a caret (^) below the character that begins the offending token.

*Example 2-1 Example Script*

```
create_clock [get_port CLK] -p
create_clock [get_ports CLK] -p -12.2

sort_collection
set paths [get_timing_paths -nworst 10 -delay_type mx_fall -r]
my_report -from [sort_collection [sort_collection $a b] {b c d} -x]
foreach_in_collection x $objects {
    query_objects $x
    report_timing -through $x -thr $y -from a -from b -to z > r.out
}
all_fanout -from X -clock_tree
```

*Example 2-2 iccprocheck Output*

Synopsys Tcl Syntax Checker - Version 1.0

```
Loading snps_tcl.pcx...
Loading icc.pcx...
scanning: /disk/scripts/ex1.tcl
checking: /disk/scripts/ex1.tcl
/disk/scripts/ex1.tcl:1 (warnUndefProc) undefined procedure: get_port
get_port CLK
^
/disk/scripts/ex1.tcl:1 (SnpsE-MisVal) Value not specified for
'create_clock -period'
create_clock [get_port CLK] -p
```

```

^
/disk/scripts/ex1.tcl:2 (SnpsE-BadRange) Value -12.2 for 'create_clock
-period' must be >= 0.000000
create_clock [get_ports CLK] -p -12.2
^
/disk/scripts/ex1.tcl:3 (SnpsE-MisReq) Missing required positional
options for sort_collection: collection criteria
sort_collection
^
/disk/scripts/ex1.tcl:4 (badKey) invalid keyword "mx_fall" must be:
max min min_max max_rise max_fall min_rise min_fall
get_timing_paths -nworst 10 -delay_type mx_fall -r
^
/disk/scripts/ex1.tcl:4 (SnpsE-AmbOpt) Ambiguous option
'get_timing_paths -r'
get_timing_paths -nworst 10 -delay_type mx_fall -r
^
/disk/scripts/ex1.tcl:5 (warnUndefProc) undefined procedure: my_report
my_report -from [sort_collection \
^
/disk/scripts/ex1.tcl:5 (SnpsE-UnkOpt) Unknown option
'sort_collection -x'
sort_collection [sort_collection $a b] {b c d} -x
^
/disk/scripts/ex1.tcl:9 (SnpsW-DupOver) Duplicate option
'report_timing -from' overrides previous value
report_timing -through $x -thr $y -from a -from b -to z > r.out
^
/disk/scripts/ex1.tcl:11 (SnpsE-Excl) Can only specify one of
these options for all_fanout: -from -clock_tree
all_fanout -from X -clock_tree
^

```

## Limitations of the Synopsys Syntax Checker

The following limitations apply to the Synopsys Syntax Checker:

- Command abbreviations are not checked. Use of abbreviated commands show up as undefined procedures.
- Aliases created with the `alias` command are not expanded and show up as undefined procedures.
- A few checks done when the application is running might not be checked using the `snps_checker` environment. For example, some cases where one option requires another option are not checked.
- Script size is an issue with `snps_checker` and `TclPro 1.3` and `1.5`. Scripts of up to a few thousand lines can be reasonably checked, but beyond that, CPU time becomes a factor. Do not try to check extremely large scripts using `snps_checker`.

- IC Compiler allows you to specify Verilog-style bus names on the command line without rigid quotation. An example of this is A[0]. This format with indexes from 0 to 255 is checked. The wildcard characters “\*” and “%” are also checked. Other forms, including ranges such as A[15:0], show up as undefined procedures, unless represented as {A[15:0]}.
- User-defined procedures enhanced with the `define_proc_attributes` command are not checked. Because such procedures are declared with the `args` argument, no semantic errors are reported.

---

## Bytecode-Compiled Files

Bytecode-compiled files are created using the TclPro Compiler, procomp, and have the following advantages over ASCII scripts:

- They are efficient to load.
- They are secure because the content is not readable.
- The body of the compiled Tcl procedures is hidden.

IC Compiler can load bytecode-compiled scripts. To load a bytecode-compiled file, you source it like you do other scripts. You do not need any files other than the application to load bytecode-compiled files.

---

## TclPro Limitations

TclPro is not supported on RS/6000. However, bytecode-compiled files can be loaded into this application on all platforms, including RS/6000, and snps\_checker is supported on all UNIX platforms.

---

## Working With Licenses

You can view a list of the licenses you are currently using and a list of all licenses that are currently checked out. You can also check out additional licenses, queue licenses that are not currently available, and release licenses you no longer need. To learn how to determine what licenses are in use and know how to obtain and release licenses, see the following sections:

- [Listing the Licenses in Use](#)
- [Getting Licenses](#)
- [Enabling License Queuing](#)

- [Releasing Licenses](#)
  - [Getting and Releasing Licenses in the GUI](#)
- 

## **Listing the Licenses in Use**

To view the licenses that you currently have checked out, use the `list_licenses` command. For example,

```
icc_shell> list_licenses
```

```
Licenses in use:  
    Galaxy-Common  
    Galaxy-ICC  
1
```

To determine which licenses are already checked out, use the `license_users` command. For example,

```
icc_shell> license_users  
bill@eng1 Galaxy-Common, Galaxy-FP, Galaxy-ICC  
matt@eng2 Galaxy-Common, Galaxy-ICC, Milkyway-Interface  
2 users listed.  
1
```

---

## **Getting Licenses**

When you invoke IC Compiler, the Synopsys Common Licensing software automatically checks out the appropriate license. For example, if you open a Milkyway design library, Synopsys Common Licensing checks out the Milkyway-Interface license.

If you know the tools and interfaces you need, you can use the `get_license` command to check out those licenses. This ensures that each license is available when you are ready to use it. For example,

```
icc_shell> get_license Milkyway-Interface
```

After a license is checked out, it remains checked out until you release it or exit `icc_shell`.

---

## **Enabling License Queuing**

IC Compiler has a license queuing functionality that allows your application to wait for licenses to become available if all licenses are in use. To enable this functionality, set the `SNPSLMD_QUEUE` environment variable to `true`. The following message is displayed:

Information: License queuing is enabled. (ICCSH-001)

When you have enabled the license queuing functionality, you might run into a situation where two processes are waiting indefinitely for a license that the other process owns. To prevent such situations, set the SNPS\_MAX\_WAITTIME environment variable and the SNPS\_MAX\_QUEUEUTIME environment variable. You can use these variables only if the SNPSLMD\_QUEUE environment variable is set to `true`.

The `SNPS_MAX_WAITTIME` variable specifies the maximum wait time for the first key license that you require, such as the license for starting `icc_shell`. Consider the following scenario:

You have two IC Compiler packages, both of which are in use, and you are attempting to start a third `icc_shell` process. The queuing functionality places this last job in the queue for the specified wait time. The default wait time is 259,200 seconds (or 72 hours). If the license is still not available after the predefined time, you might see a message similar to the following:

```
Information: Timeout while waiting for feature 'Galaxy-ICC' (ICCSH-005)
```

The `SNPS_MAX_QUEUEUTIME` variable specifies the maximum wait time for checking out subsequent licenses within the same `icc_shell` process. You use this variable after you have successfully checked out the first license to start `icc_shell`. Consider the following scenario:

You have already started IC Compiler and are running a command that requires a Galaxy-FP license. The queuing functionality attempts to check out the license within the specified wait time. The default is 28,800 seconds (or eight hours). If the license is still not available after the predefined time, you might see a message similar to the following:

```
Information: Timeout while waiting for feature 'Galaxy-FP'. (ICCSH-005)
```

As you take your design through the synthesis flow, the queuing functionality might display other status messages, such as the following:

```
Information: Successfully checked out feature 'Galaxy-FP'. (ICCSH-002)
```

```
Information: Started queuing for feature 'Galaxy-FP'. (ICCSH-003)
```

```
Information: Still waiting for feature 'Galaxy-FP'. (ICCSH-004)
```

---

## Releasing Licenses

To release a license that is checked out to you, use the `remove_license` command. For example,

```
icc_shell> remove_license Milkyway-Interface
```

---

## Getting and Releasing Licenses in the GUI

You can view a list of the licenses you are currently using and a list of additional licenses, check out additional licenses, or release licenses you no longer need.

To display current license information,

- Choose File > Licenses.

The Application Licenses dialog box appears. The Allocated Licenses list shows the licenses you are currently using. The Available Licenses list shows other licenses you can use. When you finish viewing the license information, click Close to close the dialog box.

To check out an additional license,

1. Choose File > Licenses.
2. Select a license in the Available Licenses list.
3. Click Allocate.

IC Compiler checks out a copy of the license if one is available or displays an error message if all the licenses are already taken.

To release a license,

1. Choose File > Licenses.
2. Select a license in the Allocated Licenses list.
3. Click Release.

IC Compiler releases the selected license.

---

## Enabling Multicore Processing

Several IC Compiler functions support multicore processing, whether through distributed processing or multithreading. Multicore processing improves turnaround time by performing tasks in parallel much more quickly than if they were run in serial on a single core.

Note:

A single machine has one or more CPUs and each CPU has one or more cores. The total number of cores available for processing on a machine is the number of CPUs multiplied by the number of cores in each CPU.

When using multicore processing, you need one IC Compiler license for every four parallel tasks. For example, to run eight parallel tasks, you need two IC Compiler licenses.

The `set_host_options` command configures multicore processing in IC Compiler.

To report the values set by the `set_host_options` command, use the `report_host_options` command. To remove the values set by the `set_host_options` command, use the `remove_host_options` command.

For more information about these commands, see the man pages.

The following sections describe how to use the `set_host_options` command to configure both multithreading and distributed processing.

- [Configuring Multithreading](#)
- [Configuring Distributed Processing](#)

---

## Configuring Multithreading

Multithreading performs tasks in parallel by using multiple cores on the same machine, using a single process memory image. When using multithreading, each parallel task is called a thread. For the best performance during multithreading, you should limit the number of threads to the number of available cores, which is the number of CPUs in the machine times the number of cores per CPU.

To enable multithreading for those commands that support it, set the `set_host_options -max_cores` option to a value greater than one and less than or equal to the number of cores available on your machine. You can assign a name to the configuration by using the `-name` option; if you do not use this option, IC Compiler assigns a name to the configuration.

When you enable multithreading, multithreaded commands create and use the specified number of threads, even if the number is more than the number of available cores. You must set an appropriate number of threads, so that the command does not try to use more resources than it has. Overthreading can reduce performance because the extra threads compete for resources. For best performance, do not run more than one thread per available core.

For example, if your machine has two CPUs and each CPU has three cores, specify six as the maximum number of threads:

```
icc_shell> set_host_options -max_cores 6
```

By default, the number of cores specified by the `-max_cores` option applies to all commands that support multithreading. You can use the variables shown in [Table 2-2](#) to limit the number of cores used for a specific function.

*Table 2-2 Variables to Control Multicore Processing for Specific Functionality*

| Variable                                        | Functionality                  |
|-------------------------------------------------|--------------------------------|
| <code>extract_max_parallel_computations</code>  | Extraction engine              |
| <code>placer_max_parallel_computations</code>   | Placement engine               |
| <code>routeopt_max_parallel_computations</code> | <code>route_opt</code> command |
| <code>si_max_parallel_computations</code>       | Signal integrity engine        |
| <code>timing_max_parallel_computations</code>   | Timing analysis engine         |
| <code>zrt_max_parallel_computations</code>      | Zroute                         |

When you set these variables to a positive integer value, IC Compiler limits the number of cores used for the associated function to the smaller of the value specified in the variable and the value specified in the `-max_cores` option of the `set_host_options` command.

**Note:**

For the signal integrity engine, the `si_max_parallel_computations` variable can only enable or disable multicore processing; it cannot modify the maximum number of cores. When this variable has a value of 0, multicore processing is enabled based on the `set_host_options` settings. When this variable has a value of 1, multicore processing is disabled and the signal integrity engine uses a single core regardless of the `set_host_options` settings.

---

## Configuring Distributed Processing

Distributed processing performs tasks in parallel by using multiple machines; each process uses its own process memory image. When using distributed processing, each parallel task is called a process. For the best performance during distributed processing, you should limit the number of processes to the number of available cores, which is the sum of the number CPUs times the number of cores per CPU for each host machine.

The `set_host_options` command provides many options that can be used to configure distributed processing. At a minimum, you must specify the list of host machines (*list\_of\_hosts* argument); however, for the best performance, you should also specify the `-num_processes` option to limit the number of processes based on the number of available cores.

For example, to specify a distributed processing configuration that enables a maximum of four processes, with a maximum of two processes each on machineA and machineB, enter the following command:

```
icc_shell> set_host_options -name dp4 -num_processes 2 \
{machineA machineB}
```

To specify a distributed processing configuration that enables a maximum of four processes using the Load Sharing Facility (LSF), enter the following command:

```
icc_shell> set_host_options -name lsf4 -pool lsf -num_processes 4
```

To specify a distributed processing configuration that enables a maximum of four processes using the Oracle Grid Engine, enter the following command:

```
icc_shell> set_host_options -name grd4 -pool grd -num_processes 4
```

[Table 2-3](#) shows the command options for the `set_host_options` command.

*Table 2-3 set\_host\_options Command Options*

| Command options                   | Description                                                                                                                                                                       |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-name name</code>           | Specifies a name for this configuration.<br>You can use this name to modify, report, or remove this configuration. If you do not specify this option, IC Compiler assigns a name. |
| <code>-max_cores count</code>     | Specifies the maximum number of cores that can be used for multithreading.<br>By default, a single core is used.                                                                  |
| <code>-num_processes count</code> | Specifies the maximum number of processes that can be used on each host machine for distributed processing.<br>By default, there is no limit on the number of processes.          |

*Table 2-3 set\_host\_options Command Options (Continued)*

| <b>Command options</b>                      | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-timeout <i>timeout</i></code>        | <p>Specifies the job submission timeout value in seconds.</p> <p>If the jobs you submit do not become running jobs within the specified time, they are terminated to prevent them from hanging in the queuing system.</p> <p><b>Note:</b></p> <ul style="list-style-type: none"> <li>• If you do not specify this option, the queuing system waits as long as needed for the jobs to start.</li> </ul> |
| <code>-submit_command <i>cmd</i></code>     | <p>Specifies the full path name of the LSF, Oracle Grid Engine, or custom job submission program.</p> <p>If you do not specify this option, <code>rsh</code> is used.</p>                                                                                                                                                                                                                              |
| <code>-submit_options <i>options</i></code> | Specifies options to be passed to the LSF, Oracle Grid Engine, <code>rsh</code> , or custom job submission program.                                                                                                                                                                                                                                                                                    |
| <code>-32bit</code>                         | <p>Indicates that the program used by the distributed commands for executing their slave jobs is run in 32-bit mode.</p> <p>If you do not specify this option, 64-bit mode is used.</p>                                                                                                                                                                                                                |
| <code>-pool lsf   grd</code>                | Used by some commands to optimize their behavior for the specified type of queuing system.                                                                                                                                                                                                                                                                                                             |
| <code><i>list_of_hosts</i></code>           | Specifies the hosts used for distributed processing.                                                                                                                                                                                                                                                                                                                                                   |



# 3

## Preparing the Design

---

IC Compiler uses a Milkyway design library to store your design and its associated library information. This chapter describes how to set up the libraries, create a Milkyway design library, read your design, and save the design in Milkyway format.

These steps are explained in the following sections:

- [Setting Up the Libraries](#)
- [Reading the Design](#)
- [Setting the Working Design](#)
- [Annotating the Physical Data](#)
- [Specifying the Power Intent](#)
- [Creating Logical Power and Ground Connections](#)
- [Checking the Design Database](#)
- [Using the GUI Partition Editor](#)
- [Setting Up for Multicorner-Multimode Analysis and Optimization](#)
- [Preparing for Timing Analysis and RC Calculation](#)
- [Linking Designs](#)
- [Saving a Design](#)

- [Closing Designs](#)
- [Closing a Milkyway Design Library](#)
- [Archiving Designs](#)

---

## Setting Up the Libraries

IC Compiler requires both logic libraries and physical libraries. The following sections describe how to set up and validate these libraries:

- [Setting Up the Logic Libraries](#)
  - [Setting Up the Physical Libraries](#)
  - [Verifying the Libraries](#)
- 

### Setting Up the Logic Libraries

IC Compiler uses logic libraries to provide timing and functionality information for all standard cells. In addition, logic libraries can provide timing information for hard macros, such as RAMs.

IC Compiler supports logic libraries that use nonlinear delay models (NLDMs) and Composite Current Source (CCS) models. IC Compiler automatically selects the timing models to use, based on the contents of the logic libraries. If the logic libraries contain a mixture of both NLDM and CCS models, by default, IC Compiler uses the CCS capacitance and timing data; you can control this by setting the `lib_pin_using_cap_from_ccs` and `lib_cell_using_delay_from_ccs` variables before loading the libraries.

**Note:**

When using CCS models, the tool might not use all of the available CCS data in some instances, such as during preroute optimization or on non-Arnoldi nets during postroute delay calculations. This is done to balance runtime against the required accuracy.

In each session, you must set the following variables to define the logic library settings so that IC Compiler can find the libraries:

- `search_path`  
Lists the paths where IC Compiler can find the logic libraries. When IC Compiler resolves cell references, it searches the libraries in the order they are listed in the `search_path` variable.
- `target_library`  
Lists the logic libraries that IC Compiler can use to perform physical optimization.
- `link_library`  
Lists the logic libraries that IC Compiler can search to resolve hierarchical references.

The first library in the `link_library` path is the main library. If you are using an existing Milkyway design library, ensure that the main library you specify is the same one that was used when the Milkyway design was saved.

The units used for time, voltage, current, resistance, capacitance, and power in the main library are used as the default units for the design. If your design or SDC file does not have unit settings, IC Compiler uses these default settings.

For more information about logic libraries, see the Library Compiler documentation.

---

## Setting Up the Physical Libraries

IC Compiler uses Milkyway reference libraries and technology files to obtain physical library information. The Milkyway reference libraries contain physical information about the standard cells and macro cells in your technology library. In addition, these reference libraries define the placement unit tile. The technology file provides technology-specific information, such as the name and characteristics of each metal layer.

The physical library information is stored in the Milkyway design library. For each cell, the Milkyway design library contains several views of the cell, which are used for different physical design tasks. Commonly used views include

- The layout (CEL) view
- The place and route (FRAM) view
- The interface logic model (ILM) view
- The metal fill (FILL) view
- The power and ground connectivity (CONN) view
- The error (ERR) view

If a Milkyway library does not already exist for your design, you need to create one and open it. If you already have a Milkyway design library, you must open it before working on your design.

This section describes the following tasks:

- [Creating a Milkyway Design Library](#)
- [Specifying the Milkyway Reference Libraries](#)
- [Opening a Milkyway Design Library](#)
- [Reporting a Milkyway Design Library](#)

- [Changing Physical Library Information](#)
- [Saving Physical Library Information](#)

For more information about Milkyway libraries, see the *Library Data Preparation for IC Compiler User Guide* and the *Milkyway Database Application Note*.

## Creating a Milkyway Design Library

To create a Milkyway design library, use the `create_mw_lib` command (or choose File > Create Library).

At a minimum, you must specify the technology file that is used for the design, as well as the name of the Milkyway design library. For information about the technology file, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

For example, to create a Milkyway design library named `my_design` in the current working directory and associate it with the `mytechfile.tf` technology file located in the `/usr/lib/tech` directory, enter the following command:

```
icc_shell> create_mw_lib my_design  
-technology /usr/lib/tech/mytechfile.tf
```

## Specifying the Milkyway Reference Libraries

Before working with the design, you must specify the Milkyway reference libraries used for the design. You can do this when you create the Milkyway design library with the `create_mw_lib` command or you can do it later by using the `set_mw_lib_reference` command.

You can specify the reference libraries on the command line or in a separate text file called a reference control file.

- To specify the reference libraries on the command line, use the `-mw_reference_library` option with the `create_mw_lib` or `set_mw_lib_reference` command.
- To specify the reference libraries in a reference control file, use the `-reference_control_file` option with the `create_mw_lib` or `set_mw_lib_reference` command.

When you specify the reference libraries, you can use either a relative or an absolute path to the library location. When IC Compiler resolves cell references, it searches the libraries in the order they are specified, either on the command line or in the reference control file.

**Note:**

You can use the `set_mw_lib_reference` command to define the Milkyway reference libraries associated with a Milkyway design library only when the Milkyway design library is closed. If the design library is open, close it with the `close_mw_lib` command before defining the reference libraries.

For example, assume that the mydesign design library uses the refA and refB Milkyway libraries as reference libraries. The mydesign design library is in the current working directory and the reference libraries are in the /usr/lib/mw\_lib directory. To specify this relationship on the command line, use the following commands:

```
icc_shell> close_mw_lib
icc_shell> set_mw_lib_reference my_design \
-mw_reference_library {/usr/lib/mw_lib/refA /usr/lib/mw_lib/refB}
```

You can also represent this relationship in a reference control file with the following content:

```
LIBRARY my_design
REFERENCE /usr/lib/mw_lib/refA
REFERENCE /usr/lib/mw_lib/refB
```

To specify this relationship using the reference control file, use the following commands:

```
icc_shell> close_mw_lib
icc_shell> set_mw_lib_reference my_design \
-reference_control_file my_refs
```

If the my\_design library contains cell A, IC Compiler resolves this cell reference by first searching the refA library for the cell; if the cell is not found, it searches the refB library.

For more information about specifying the reference libraries, see the *Library Data Preparation for IC Compiler User Guide*.

## Opening a Milkyway Design Library

To open an existing Milkyway design library, use the `open_mw_lib` command (or choose File > Open Library). When you open a Milkyway design library, IC Compiler locks the library, which prevents other copies of it from being used and updated while you are working in it. You can open only one Milkyway design library at a time.

**Note:**

If you want to use the same Milkyway CEL version for multiple runs, copy the design by using the Copy Design dialog box (choose File > Copy Design) or the `copy_mw_cel` command.

To report the currently open Milkyway design library, use the `current_mw_lib` command.

If the Milkyway design library uses an older Milkyway database version (schema) and a database update is needed, the `open_mw_lib` command automatically updates the library data and issues a message about the conversion. For more information about Milkyway database versions and database updates, see the *Library Data Preparation for IC Compiler User Guide*.

If you specify the TLUPlus files before you open the Milkyway design library, IC Compiler performs consistency checking between the library files in the Milkyway design library and the TLUPlus files to ensure that you have a valid library setup. If you specify the TLUPlus files later, you must manually perform this validation by running the `check_tlu_plus_files` command. For more information, see “[Setting Up the TLUPlus Files](#)” on page 3-36.

## Reporting a Milkyway Design Library

To report the reference libraries defined for the current Milkyway design library, use the `report_mw_lib` command with the `-mw_reference_library` option. [Example 3-1](#) shows a report on the reference libraries for the current Milkyway design library.

*Example 3-1 Example of the report\_mw\_lib -mw\_reference\_library Command*

```
icc_shell> open_mw_lib my_design
{my_design}
icc_shell> report_mw_lib -mw_reference_library
/usr/lib/mw_lib/refA
/usr/lib/mw_lib/refB
```

To report the information defined in the technology file associated with the current design library, use the `report_mw_lib` command with the `-unit_range` option. Note that you must specify the name of the design library to run this command. [Example 3-2](#) shows a report on the technology file for the `my_design` Milkyway design library.

*Example 3-2 Example of the report\_mw\_lib -unit\_range Command*

```
icc_shell> report_mw_lib -unit_range my_design
Library: my_design
Tech. Attr.    Unit      Resolution   Min. Value   Max. Value
=====  =====  =====  =====  =====
length      micron      1000        0.001       2147483.647
time         ns          1000        0.001       2147483.647
capacitance  pf          10000000  0.0000001  214.7483647
resistance   kohm        10000000  0.0000001  214.7483647
inductance   nh          100          0.01        21474836.47
current      uA          1000        0.001       2147483.647
voltage       V           1000        0.001       2147483.647
power        pw          1000        0.001       2147483.647
```

```

Layer: CP
Mask name: poly
Attribute           Minimum      Maximum
=====
thickness          1.8e-01    1.8e-01
unit resistance   0.0e+00    0.0e+00
unit capacitance  0.0e+00    0.0e+00
unit channel cap.. 0.0e+00    0.0e+00
unit sidewall cap. 0.0e+00    0.0e+00
unit channel side cap. 0.0e+00    0.0e+00
unit inductance   0.0e+00    0.0e+00
height from substrate 0.0e+00    0.0e+00
delta width       0.0e+00    0.0e+00
min. area dimension 0.0e+00
min. object width  1.3e-01
min. object spacing 2.0e-01
max. wire length   0.0e+00
max. RC seg. length 0.0e+00
max. current density 0.0e+00
intracap. dist. ratio 0.0e+00
...

```

To report the units used in the current design library, use the `report_units` command. [Example 3-3](#) shows a report on the units for the current Milkyway design library.

*Example 3-3 Example of the report\_units Command*

```

icc_shell> open_mw_lib my_design
{my_design}
icc_shell> report_units

*****
Report : units
Design : my_design
Version: F-2011.09
Date   : Fri Jun 10 09:41:22 2011

*****
Units
-----
Time_unit      : 1.0e-09 Second(ns)
Capacitive_load_unit : 1.0e-12 Farad(pF)
Resistance_unit : 1000 Ohm(kOhm)
Voltage_unit   : 1 Volt
Power_unit     : N/A
Current_unit   : 1.0e-06 Amp(uA)
1

```

To report the Milkyway database version (schema) and the revision information for a specific cell or for all cells, use the `report_milkyway_version` command:

```
icc_shell> report_milkyway_version -cell cell_name
```

or

```
icc_shell> report_milkyway_version -all
```

Note:

All cells must be closed when running this command.

[Example 3-4](#) shows a report on the version information for the top cell in the current Milkyway design library.

*Example 3-4 Example of the report\_milkyway\_version -cell Command*

```
icc_shell> open_mw_lib my_design
{my_design}
...
icc_shell> report_milkyway_version -cell top

Cell Name          top.CEL;2
Data Model         6.0
Compatible Product E-2010.12 and F-2011.09
Creator            C-2009.06-ICC
Creation Time     Fri Sep 11 12:13:57 2009
Modifier           F-2011.09
Modification Time Tue Jun  7 16:48:29 2011
1
```

## Changing Physical Library Information

You can change the technology file and Milkyway reference libraries associated with your design library.

Note:

You can change the physical library information only when the Milkyway design library is closed. If the design library is open, close it with the `close_mw_lib` command before changing the physical library information.

## Changing the Technology File

To change the technology file associated with a design library, use the `set_mw_technology_file` command (or choose File > Set Technology File).

For example, to change the technology file associated with the `my_design` design library to `new_tech.tf`, enter the following command:

```
icc_shell> set_mw_technology_file -technology new_tech.tf my_design
```

## Changing the Milkyway Reference Libraries

To change the Milkyway reference libraries associated with a design library, use the `set_mw_lib_reference` command (or choose File > Set Library Reference). In the same way as when you create a Milkyway design library, you can specify the Milkyway reference libraries either on the command line by using the `-mw_reference_library` option or in a reference control file by using the `-reference_control_file` option. For more information about specifying the reference libraries, see “[Specifying the Milkyway Reference Libraries](#)” on page 3-5.

For example, to change the Milkyway reference library associated with the `my_design` design library to `new_mw_ref`, enter the following command:

```
icc_shell> set_mw_lib_reference \
    -mw_reference_library {/usr/lib/mw_lib/new_mw_ref} my_design
```

## Saving Physical Library Information

To save the technology file or reference control information in a file for later use, use the `write_mw_lib_files` command (or choose File > Export > Write Library File).

Note:

In a single invocation of the command, you can output only one type of file. To output both a technology file and a reference control file, you must run the command twice.

### Writing the Technology File

To write out the technology file from an existing Milkyway design library, use the `write_mw_lib_files` command with the following syntax:

```
write_mw_lib_files
  -technology
  -output tech_file design_lib_file
```

For example, to save the technology file for the `my_design` design library in a file named `my_tech.tf` in the current working directory, enter the following command:

For example,

```
icc_shell> write_mw_lib_files -technology \
    -output my_tech.tf my_design
```

### Writing the Reference Control File

To write out a reference control file from an existing Milkyway design library, use the `write_mw_lib_files` command with the following syntax:

```
write_mw_lib_files
  -reference_control_file
  -output reference_control_file design_lib_file
```

For example, to save the reference control file for the my\_design design library in a file named my\_refs in the current working directory, enter the following command:

```
icc_shell> write_mw_lib_files -reference_control_file \
           -output my_refs my_design
```

---

## Verifying the Libraries

To achieve good results, you must have high-quality libraries. Before you process your design, you should use the `check_library` command to ensure that the logic libraries and physical libraries are correct and consistent.

By default, the `check_library` command performs consistency checking between the logic libraries specified in the `link_library` variable and the physical libraries referenced in the current Milkyway design library. If the `check_library` command reports any inconsistencies, you must fix them before you process your design.

For more information about performing library checking, see the *Library Data Preparation for IC Compiler User Guide*.

---

## Reading the Design

IC Compiler can read designs in Milkyway, .ddc, or ASCII (Verilog) format.

Regardless of the design format, you must perform the following tasks before reading in the design:

1. Set up the logic libraries, as described in “[Setting Up the Logic Libraries](#)” on page 3-3.

```
icc_shell> set_app_var search_path my_search_path
icc_shell> set_app_var target_library my_library_list
icc_shell> set_app_var link_library "* my_link_library_list"
```

2. Open the Milkyway design library associated with the design, as described in “[Opening a Milkyway Design Library](#)” on page 3-6.

```
icc_shell> open_mw_lib design_library_name
```

Note:

If you do not have a Milkyway design library, see “[Creating a Milkyway Design Library](#)” on page 3-5.

The following sections explain how to open designs:

- [Reading a Design in Milkyway Format](#)
- [Reading a Design in .ddc Format](#)
- [Reading a Design in ASCII Format](#)

---

## Reading a Design in Milkyway Format

To open a design in Milkyway format,

1. Verify that you have defined the correct main library.

The unit settings in the Milkyway design must be consistent with the unit settings in the main library (the first library in the `link_library` definition). To see the main library unit settings, use the `report_lib` command. To see the Milkyway design library unit settings, use the `report_units` command.

To prevent problems with opening the Milkyway design, ensure that the main library is the same one that was used when the Milkyway design was saved.

2. Open the design by using the `open_mw_cel` command (or by clicking the  button on the File toolbar or choosing File > Open Design).

```
icc_shell> open_mw_cel design_name
```

Note:

If you use the GUI to open the design, you can open both the design library and the design from the Open Design dialog box.

If you get unit inconsistency errors when you try to open the Milkyway design, go back to step one and ensure that the main library is correctly defined.

When you open a Milkyway design, IC Compiler

- Checks the database model (schema) version and automatically updates the database, if necessary

For more information about converting the database model, see the *Library Data Preparation for IC Compiler User Guide*.

- Checks the correctness and consistency of the netlist-related objects in the Milkyway design

To reduce runtime, IC Compiler determines whether the design has previously passed these checks; if it has passed, the checks are skipped.

- Sets the design as the current design
- If the GUI is open, opens a new layout window and displays the design in the layout view

This is the primary design in the layout window; if you open multiple layout views in the same layout window, they all display the primary design. However, you can display other designs as overlays on the primary design.

---

## Reading a Design in .ddc Format

To read a .ddc-format design into IC Compiler,

1. Read the .ddc file for the design by using the `import_designs` command (or by choosing File > Import Designs in the GUI and selecting ddc as the input format).

```
icc_shell> import_designs -format ddc design.ddc
```

Note:

If you are using a bottom-up flow, you must have FRAM views for all blocks in the top-level design.

2. Annotate the physical data on the design.

For information about annotating the physical data, see “[Annotating the Physical Data](#)” on page 3-17.

After you read in the design, IC Compiler stores the design in Milkyway format for use in future sessions.

---

## Reading a Design in ASCII Format

To read an ASCII-format design into IC Compiler,

1. Read the Verilog netlist file for the design by using the `read_verilog` command (or by choosing File > Import > Read Verilog).

The Verilog netlist file is a structural or gate-level design in one file. For best results, the Verilog netlist should contain either a full power and ground network or no power and ground network.

```
icc_shell> read_verilog design.v
```

Note:

If you are using a bottom-up flow, you must have FRAM views for all blocks in the top-level design.

## 2. Uniquify the design by using the `uniquify_fp_mw_cel` command.

The Milkyway format does not support multiply instantiated designs. Before saving the design in Milkyway format, you must uniquify the design to remove multiple instances.

```
icc_shell> uniquify_fp_mw_cel
```

## 3. Read the timing constraints for the design by using the `read_sdc` command (or by choosing File > Import > Read SDC).

For information about setting timing constraints, see “[Setting Timing Constraints](#)” on [page 3-43](#).

## 4. Annotate the physical data on the design.

For information about annotating the physical data, see “[Annotating the Physical Data](#)” on [page 3-17](#).

After you read in the design, IC Compiler stores the design in Milkyway format for use in future sessions.

---

## Setting the Working Design

When you open a Milkyway design library, IC Compiler sets it as the current design (the design you are actively working on). Most IC Compiler commands operate within the context of the current design. For example, if you use the `save_mw_cel` command without specifying the name of the design you want to save, IC Compiler saves the current design.

---

## Setting the Current Design

When multiple designs are open, you can reset the current design to a different design by using the `current_mw_cel` command (or by selecting a design name in the list on the Cells List toolbar in the main window).

Note:

If you open a design by using the View Settings panel to display it as an overlay on a layout view, it is not set as the current design.

---

## Opening Designs in a Hierarchical Stack

Many large chip designs are organized as a hierarchy of physical designs. As you open and edit the various designs in a physical design hierarchy, you can use the `change_working_design` command to keep track of the parent-child relationships. This command also helps synchronize parent designs to edited child designs.

From a parent design, use the following command to open a child design:

```
icc_shell> change_working_design -push child_instance_name
```

This command has the same effect as opening the child design with the `open_mw_cel` command, but in addition, the parent-child relationship is maintained in a last-in, first out stack. By default, the child design is opened in write mode. To open the child design in read-only mode, use the `-readonly` option with the `change_working_design -push` command.

After you view or edit the child design, you can return to editing the parent design by using the following command:

```
icc_shell> change_working_design -pop
```

By default, this command synchronizes the changes made to the current design to its parent design, pops the current design out of the stack, and makes the parent design the current design. To discard the changes to the child design without synchronizing them to the parent design, use the `-discard` option with the `change_working_design -pop` command. Note that a pop operation does not save or close the child design. You can save all the parent and child changes from the level of the parent design by using the `save_mw_cel -hierarchy` command.

Note:

If you open a design by using the `read_verilog` command, the top-level design is not set. Before you can use the `change_working_design -push` command, you need to set the current design by using the `current_mw_cel` command.

## Traversing Multiple Levels

You can traverse the hierarchy multiple levels downward by using the `change_working_design -push` command multiple times. You can traverse the hierarchy back upward by using the `-pop` option multiple times. Each push operation causes the stack to grow by one entry and each pop operation causes the stack to shrink by one entry.

You can query the stack by using the `get_working_design_stack` command, as shown in the following example:

```
icc_shell> open_mw_cel Top
{Top}
icc_shell> change_working_design -push inst_celA
{Top celA}
icc_shell> change_working_design -push inst_celB
{Top celA celB}
...
icc_shell> get_working_design_stack
{Top celA celB}
...
```

```
icc_shell> change_working_design -pop  
{Top celA}  
icc_shell> change_working_design -pop  
{Top}
```

## Changing Between Different Stacks

When you open a design with the `open_mw_cel` command, it creates a new stack that contains the name of the design. If you use the `open_mw_cel` command to open multiple designs, it creates multiple stacks in memory. For example, consider the following sequence of commands:

```
icc_shell> open_mw_cel Top  
{Top}  
icc_shell> change_working_design -push inst_celA  
{Top celA}  
icc_shell> change_working_design -push inst_celB  
{Top celA celB}  
...  
icc_shell> open_mw_cel inst_celX  
{celX}  
icc_shell> change_working_design -push inst_celY  
{celX celY}
```

Now you have two stacks in memory. The current stack contains {celX celY}; the other stack contains {Top celA celB}.

You can switch the current working design back to the other stack by using the `change_working_design_stack` command.

```
icc_shell> change_working_design_stack Top  
{Top celA celB}
```

In the `change_working_design_stack` command, you must reference the desired stack by the oldest, highest-level design name in the stack (`Top` in this example), but the command opens the newest, lowest-level design name in the stack (`celB` in this example).

## Transforming Parent and Child Coordinates

The child and parent designs usually do not fall on the same coordinate system. In other words, the origin of a child design usually does not coincide with the origin of the parent design. To find out the coordinates of a location in a child design in terms of the parent design, or vice versa, use the `transform_coordinates` command.

For example, suppose you are editing a child design named celA that is instantiated in a parent design named Top, and you are editing an object at location (100.0, 200.0), which is the location in terms of the child design. To compute the coordinates of this location in the parent design, use the following commands:

```
icc_shell> change_working_design -pop  
{Top}  
icc_shell> transform_coordinates -from_child celA {100.0 200.0}  
{350.000 275.000}
```

The `transform_coordinates` command returns the coordinates of the location in the parent cell. You can similarly use the `-from_parent` option to transform the coordinates in a parent cell in terms of a child cell.

To use the `transform_coordinates` command, the parent and child designs must be contained within a stack created by a previous `change_working_design` command. A transform operation works only in a parent-child relationship and cannot span multiple levels of hierarchy. To transform coordinates between grandchild and grandparent cells, you need to use two separate transform operations with a `change_working_design` command between them.

---

## Annotating the Physical Data

IC Compiler provides several methods of annotating physical data on the design:

- Reading the physical data from a DEF file
- Reading the physical data from a floorplan file
- Copying the physical data from another design

If a floorplan does not yet exist for your design, see the *IC Compiler Design Planning User Guide* for information about design planning.

After annotating (or creating) the physical data, validate the physical data before performing physical synthesis.

---

## Reading DEF Files

To read a DEF file, use the `read_def` command (or choose File > Import > Read DEF).

```
icc_shell> read_def design_name.def
```

By default, the `read_def` command is additive; it adds the physical data in the DEF file to the existing physical data in the design. To replace rather than add to existing data, use the `-no_incremental` option on the command line (or deselect Incremental in the GUI).

To analyze the input DEF files before annotating the objects on the design, enable check-only mode by using the `-check_only` option. The check-only mode provides diagnostic information about the correctness and integrity of the DEF file. The check-only mode does not annotate any DEF information into the Milkyway database.

```
icc_shell> read_def -check_only design_name.def
```

---

## Reading Floorplan Files

A floorplan file is a file that you previously created by using the `write_floorplan` command (or by choosing Floorplan > Write Floorplan). This file is a script that contains information about the floorplan.

Note:

Before reading the floorplan file, create the logical power and ground connections by using the `derive_pg_connection` command as described in “[Creating Logical Power and Ground Connections](#)” on page 3-20.

To read a floorplan file, use the `read_floorplan` command.

```
icc_shell> read_floorplan floorplan_file_name
```

For more information about creating and reading floorplan files, see the *IC Compiler Design Planning User Guide*.

---

## Copying Physical Data

To copy physical data from the layout (CEL) view of one design in the current Milkyway design library to another, use the `copy_floorplan` command (or choose Floorplan > Copy Floorplan). Specify the design from which to copy the physical data by using the `-from` option (or in the “From cell” box in the GUI).

```
icc_shell> copy_floorplan -from design1
```

For more information about copying physical data from another design, see the *IC Compiler Design Planning User Guide*.

---

## Validating Physical Data

To validate the physical data in your design, run the `check_physical_design` command:

```
check_physical_design  
-stage pre_place_opt | pre_clock_opt | pre_route_opt
```

Specify the stage at which you are performing the check: before the `place_opt` command, before the `clock_opt` command, or before the `route_opt` command. This setting determines the types of physical design checks performed by the command. For more information, see the man page for the command.

---

## Specifying the Power Intent

The IEEE™ 1801 Unified Power Format (UPF) Standard establishes a set of commands used to specify the low-power design intent for electronic systems. Using UPF commands, you can specify the supply network, switches, isolation, retention, and other aspects relevant to power management of a chip design. The same set of low-power design specification commands is to be used throughout the design, analysis, verification, and implementation flow. Synopsys tools are designed to follow the official UPF standard.

The IEEE 1801™ (UPF) language provides a way to specify the power requirements of a design, but without specifying explicitly how those requirements are implemented. The language specifies how to create a power supply network for each design element, the behavior of supply nets with respect to each other, and how the logic functionality is extended to support dynamic power switching to design elements. It does not contain any placement or routing information.

In the UPF language, a *power domain* is a defined group of elements in the logic hierarchy that share a common set of power supply needs. By default, all logic elements in a power domain use the same primary supply and primary ground. Other power supplies can optionally be defined for a power domain as well. A power domain is typically implemented as a contiguous *voltage area* in the physical chip layout, although this is not a requirement of the language.

Each power domain has a *scope* and an *extent*. The *scope* is the level of logic hierarchy where the power domain exists. The *extent* is the set of logic elements that belong to the power domain and share the same power supply needs. In other words, the scope is the hierarchical level where the power domain exists, whereas the extent is what is contained within the power domain.

Each scope or hierarchical level in the design has *supply nets* and *supply ports*. A *supply net* is a conductor that carries a supply voltage or ground throughout a given power domain. A supply net that spans more than one power domain is said to be “reused” in multiple domains. A *supply port* is a power supply connection point between two adjacent levels of the design hierarchy, between parent and child blocks of the hierarchy. A supply net that crosses from one level of the design hierarchy to the next must pass through a supply port.

A *power switch* (or simply *switch*) is a device that turns on and turns off power for a supply net. A switch has an input supply net, an output supply net that can be switched on or off, and at least one input signal to control switching. The switch can optionally have multiple input control signals and one or more output acknowledge signals. A *power state table* lists the allowed combinations of voltage values and states of the power switches for all power domains in the design.

Where a logic signal leaves one power domain and enters another at a substantially different supply voltage, a *level-shifter* cell must be present to convert the signal from the voltage swing of the first domain to that of the second domain.

Where a logic signal leaves a power domain and enters a different power domain, an *isolation* cell must be present to generate a known logic value during shutdown. If the voltage levels of the two domains are substantially different, the interface cell must perform both level shifting when the domain is powered up and isolation when the domain is powered down. A cell that can perform both functions is called an *enable level shifter*.

In a power domain that has power switching, any registers that are to retain data during shutdown must be implemented as *retention registers*. A retention register has a separate, always-on supply net, sometimes called the backup supply, which keeps the data stable in while the primary supply of the domain is shut down.

For details about specifying the power intent, see [Chapter 14, “Multivoltage Design Flow”](#) and the “Power Intent Specification” chapter in the *Synopsys Low-Power Flow User Guide*.

---

## Creating Logical Power and Ground Connections

After you read in the design, you must ensure that there are logical connections between the power and ground nets and the power, ground, and tie-off pins on the cells in your design. If your design does not already have these connections, use the `derive_pg_connection` command (or Preroute > Derive PG Connection in the GUI) to create them. This command creates the logical power and ground connections for leaf cells, hierarchical cells, and physical-only cells in both single-voltage and multivoltage designs.

To show the logical power and ground connections made by the `derive_pg_connection` command, use the `report_cell_physical -connection` command.

You should rerun the `derive_pg_connection` command whenever the power and ground connections have changed, such as

- After design planning
- After using logic ECO to modify the design
- After chip-finishing tasks

To ensure correct power and ground information in the Verilog netlist, you should also run the `derive_pg_connection` command before writing a Verilog netlist.

For detailed information about the `derive_pg_connection` command, see the man page.

---

## Creating the Connections for Single-Voltage Designs

To create or update the logical power and ground connections for a single-voltage design,

1. Connect the power and ground pins to the power and ground nets.

To connect all power and ground pins for a single-voltage design, specify the power and ground net names when you run the `derive_pg_connection` command.

```
icc_shell> derive_pg_connection -power_net VDD -ground_net VSS
```

To connect specific power and ground pins for a single-voltage design, you must also specify the power and ground net and pin names when you run the `derive_pg_connection` command.

```
icc_shell> derive_pg_connection -power_net VDD -power_pin vdd \  
      -ground_net VSS -ground_pin vss
```

If the design does not yet have power and ground ports, use the `-create_ports top` option to create these ports.

If the design already has logical power and ground connections but you want to regenerate these connections, use the `remove_pg_network -top` command to remove the existing power and ground network before you run the `derive_pg_connection` command.

By default, the `derive_pg_connection` command does not change existing power and ground pin connections. To reconnect the power and ground pins, use the `-reconnect` option when you run the `derive_pg_connection` command.

2. Connect the tie-off pins to the power and ground nets.

If the design uses tie-off cells for tie-off connections, you do not need to perform this step; the `place_opt` or `psynopt` command performs tie-cell insertion and connects the tie-off cells to the tie-off pins.

If the design does not use tie-off cells, use the `derive_pg_connection` command with the `-tie` option to connect the tie-off pins.

```
icc_shell> derive_pg_connection -power_net VDD -ground_net VSS -tie
```

In a hierarchical design, the tie-off connections are mapped to actual power and ground nets in the same hierarchy.

By default, the `derive_pg_connection -tie` command does not change any existing tie-off connections; it only incrementally connects unconnected tie-off pins. To change existing tie-off connections, use the `recover_tie_connection` command and then use the `derive_pg_connection -tie` command with the proper options to remap the tie-off nets to power or ground nets. Note that the `-reconnect` option of the `derive_pg_connection` command does not reconnect tie-off nets.

---

## Creating the Connections for Multivoltage Designs

This section describes how to create the logical power and ground connections for multivoltage designs with UPF specifications. If the power intent for your multivoltage design is not specified using UPF, see [SolvNet article 031133](#) for information about using the `derive_pg_connection` command in non-UPF mode.

To create or update the logical power and ground connections for a multivoltage design,

1. Create the supply nets, if they do not already exist.

To create the supply nets based on the UPF specification, run the `derive_pg_connection` command with the `-create_nets` option.

```
icc_shell> derive_pg_connection -create_nets
```

When you use the `-create_nets` option, the `derive_pg_connection` command checks for the following conflicts and potential problems in the power and ground network:

- Incomplete power and ground network with a UPF conflict
- Signal tie-net name that is inconsistent with the UPF supply net name
- Signal net with a power or ground name but without a power or ground source
- Signal net with a power or ground name at a middle hierarchy level connected to a signal at the top level

The `derive_pg_connection -create_nets` command does not create the supply nets for the design unless all conflicts are resolved. To report the network changes necessary to make the power and ground network compatible with the UPF power intent, run the `derive_pg_network -resolve_conflict` command.

## 2. Connect the power and ground pins to the power and ground nets

To connect the power and ground pins for a multivoltage design, run the `derive_pg_connection` command.

```
icc_shell> derive_pg_connection
```

The `derive_pg_connection` command derives all power and ground nets, power and ground ports, and connections from the UPF specification.

By default, the `derive_pg_connection` command does not change existing power and ground pin connections. To override the existing power connections and use the power intent defined in the UPF file, use the `-reconnect` option when you run the `derive_pg_connection` command.

## 3. Connect the tie-off pins to the power and ground nets

If the design uses tie-off cells for tie-off connections, you do not need to perform this step; the `place_opt` or `psynopt` command performs tie-cell insertion and connects the tie-off cells to the tie-off pins.

If the design does not use tie-off cells, use the `derive_pg_connection` command with the `-tie` option to connect the tie-off pins.

```
icc_shell> derive_pg_connection -tie
```

By default, the `derive_pg_connection -tie` command does not change any existing tie-off connections; it only incrementally connects unconnected tie-off pins. To change existing tie-off connections, use the `recover_tie_connection` command and then use the `derive_pg_connection -tie` command to remap the tie-off nets to power and ground nets.

## Checking the Design Database

Validate the integrity of the infrastructure of a Milkyway design database by using the `check_database` command. You can indicate whether to perform logical checks, physical checks, or both, and you can specify the verbosity of the messages. The syntax of the `check_database` command is

```
check_database
  [-verbosity low | medium | high]
  [-physical]
  [-netlist]
  [mw_lib]
```

`-verbosity low | medium | high`

Specifies the level of verbosity of the messages. The default is `low`.

`-physical`

Specifies that the physical information is to be checked.

`-netlist`

Specifies that the logic netlist information is to be checked.

`mw_lib`

Specifies the name of the design library on which to perform the checks.

The `check_database` command verifies that

- The power and ground network is consistent.
- There are no logical connections to physical-only cells.
- The UPF data is consistent, if it exists.
- The design has been uniquified and contains hierarchy preservation data.

You should run the `check_database` command

- After reading a design in ASCII format using the `read_def` command.
- Before running application commands, such as `change_names`, `create_ilm`, `place_opt`, `clock_opt`, and `route_opt`. This can help save runtime in the case of a data error.
- Before using the `write_verilog` command. For information about the `write_verilog` command, see “[Saving the Design in ASCII Format](#)” on page 3-54.

---

## Using the GUI Partition Editor

For very large designs that exceed 10 million instances and might not fit entirely in memory, a high-capacity partitioning system called the partition editor allows you to create and edit partitions interactively through the GUI. By partitioning the design, you can get a good sense of how to implement the top-level floorplan.

The partition editor displays information about the top-level and block designs in a Partition Editor view. You can examine the design information and select the design modules that you want to operate on when you choose commands on the Edit menu in the Partition Editor window. You can

- Label a block as either a physical partition or a logic block in the design hierarchy
- Set optional overrides to adjust the utilization or physical area for a block
- Set optional external and internal keepout margins on a block

You can balance the partitions by equalizing either the number of instances or the area. When you are satisfied with the partition setup, you can create the partitions and save the partitioned designs in Verilog files. You can also save the partitioned designs in your Milkyway design library and generate a basic top-level floorplan.

To invoke the Partition Editor window,

- Choose Window > New Partition Editor window.

A new top-level window with an empty Partition Editor view appears. The top-level window has File, Edit, View, Partition, Window, and Help menus.

Before you can begin partitioning the design, you must open the Verilog files for the top-level design and each of the physical subblocks in the design.

Note:

You must open the Milkyway design library before you can open the Verilog files.

To load the Verilog design data into the Partition Editor,

1. Choose File > Create Partition Editor.

The Create Partition Editor dialog box appears.

2. Enter the names of the input Verilog files in the “Input Verilog files” text box.

3. Click OK.

Alternatively, you can use the `read_partition` command.

The tool loads the Verilog data for the top-level design and each physical subblock into memory and displays information about the blocks and leaf cells in the Partition Editor view. The Partition Editor view displays the design information in a list with a column for each type of design information and a row for each module, as shown in [Figure 3-1](#). A module can be a Verilog logic hierarchy module (a block) or a leaf cell. The module names appear in an instance tree in the first column. You can use the arrow keys to navigate the instance tree and to expand or collapse modules. You can also sort and resize the columns. [Table 3-1](#) describes the columns in the Partition Editor view.

*Figure 3-1 Partition Editor Window**Table 3-1 Partition Editor View Columns*

| Column        | Description                                                                                                                                                                                                     |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module Name   | A Verilog module (logic hierarchy module) or a leaf cell reference name, such as a standard cell, hard macro, black box, or I/O cell.                                                                           |
| Utilization   | The targeted utilization for a module. For a leaf cell module, the value is 1.                                                                                                                                  |
| Physical Area | The physical area of the block, calculated as the value in the Area column multiplied by the value in the Utilization column, and adjusted further by any internal or external keepouts defined for the module. |
| Area          | The area in square microns occupied by a module. It is the sum of the areas of the leaf cells inside the Verilog modules. It is also the area itself of a leaf cell module.                                     |
| Port          | The number of terminals (pins) on a module. It includes both power and ground terminals.                                                                                                                        |
| All           | Lists the number of standard cells, hard macros, black boxes, and I/O cells inside the module.                                                                                                                  |

**Table 3-1 Partition Editor View Columns (Continued)**

| <b>Column</b>    | <b>Description</b>                                                                      |
|------------------|-----------------------------------------------------------------------------------------|
| Std Cell         | Lists the number of standard cells inside the module.                                   |
| Hard Macro       | Lists the number of hard macros inside the module.                                      |
| I/O              | Lists the number of I/O cells inside the module.                                        |
| Black Box        | Lists the number of black boxes inside the module.                                      |
| Missing          | Lists the number of black boxes that have no estimated area inside the module.          |
| External Keepout | The external keepout distance in microns, which adds to the area of the parent modules. |
| Internal Keepout | The internal keepout distance in microns, which adds to the area of the module.         |

**Note:**

If you want to delete the Partition Editor and return to an empty view, you can choose File > Delete Partition Editor. The tool removes the design data from memory and clears the Partition Editor view. Alternatively, you can use the `remove_partition` command.

When you load the Verilog design data, each block in the design is labeled as a block in the logic hierarchy. By definition, the top-level block in the design is both a logic hierarchy block and a physical block. To designate the physical partitions for the design, you label blocks as physical partitions. You can also remove the physical partition labels from blocks that you want to designate as logic-only blocks in the hierarchy.

To make changes to a block, select the block in the Partition Editor list and then use one of the following editing commands from the Edit menu.

- Choose Edit > Set Module Logical to remove the block as physical partition and label it as an internal logic-only block in the hierarchy.  
Alternatively, you can use the `set_partition_data -logical` command.
- Choose Edit > Set Module Physical to label the block as a physical partition.  
Alternatively, you can use the `set_partition_data -physical` command.
- Choose Edit > Partition by Instance Count to create partitions that typically represent between 5 and 10 percent of the design, as measured by instance count. Partitions are balanced by equalizing the number of instances in each partition. This results in a very fast partitioning for designs that have few macro cells and well-structured RTL.

- Choose Edit > Partition by Area to create partitions that typically represent between 5 and 10 percent of the design, as measured by area. Partitions are balanced based on the area. This results in a very fast partitioning for designs with many macro cells and well-structured RTL.

Alternatively, you can use the `set_partition_data -auto_partition` command.

- Choose Edit > Set Overrides to invoke the Set Overrides dialog box. You can use this dialog box to adjust the utilization and physical area for the selected block.

- In the “Utilization” text box, specify the block utilization. The set utilization is used along with the leaf cell areas to compute the total required area for the physical blocks. The default utilization is 0.6.

Alternatively, you can use the `set_partition_data -utilization` command.

- In the “Physical Area” text box, specify the area for a given block within the hierarchy. Use this option in a top-down design flow when one or more, presumably large, blocks are missing but their estimated area is known.

Alternatively, you can use the `set_partition_data -area` command.

- Choose Edit > Set Keepouts to invoke the Set Keepouts dialog box. You can use this dialog box to specify external and internal keepout margins on the blocks.

- In the “External Keepout” text box, specify an external keepout margin. The default is 0. This keepout is added to the area outside of the partition blocks but it does not cause the partitioned physical blocks to become larger.

Alternatively, you can use the `set_partition_data -external_keepout` command.

- In the “Internal Keepout” text box, specify an internal keepout margin. The default is 0. This keepout is added to the area inside the partition blocks. If those blocks are partitioned into physical blocks, it causes the physical blocks to become larger.

Alternatively, you can use the `set_partition_data -internal_keepout` command.

- Choose Edit > Reset Partition Data to invoke the Reset dialog box. You can use this dialog box to reset some or all of the parameters in the Partition Editor view: Partitions, Overrides, Keepouts, or All.

Alternatively, you can use the `set_partition_data -reset` command.

To create another view for the Partition Editor,

- Choose View > New Partition Editor window.

A new view appears. For example, “PartitionEditorView.2.”

You can tile or cascade these views and compare different hierarchies in different views.

To create the partitions and save the partitioned designs,

1. Choose Partition > Create.  
The Create dialog box appears.
2. Type the name of the directory where you want to save the Verilog files in the “Output directory” box, or click the Browse button and select or create the directory in file browser that appears. The default directory name is ./sub\_blocks.
3. (Optional) To save the partitioned design in the Milkyway design library, select the “Import Verilog and open Milkyway cell” option.
4. If you want the tool to generate a basic top-level floorplan after the design is read into the Milkyway database, select the “Initialize floorplan for the Milkyway cell” option.

---

## Setting Up for Multicorner-Multimode Analysis and Optimization

Designs are often required to operate under multiple operating conditions (“corners”) and in multiple modes. Such designs are referred to as multicorner, multimode, or multicorner-multimode designs. These designs can involve numerous operating condition corners and many modes. IC Compiler uses a truly concurrent, multi-scenario method to analyze and optimize these designs across all design corners and modes of operation.

A *scenario* is a combination of modal constraints and corner specifications. In multicorner-multimode designs, IC Compiler uses a scenario or a set of scenarios as the unit for analysis and optimization. The *current scenario* is the focus scenario; when you set modal constraints or corner specifications, these typically apply to the current scenario. The *active scenarios* are the set of scenarios used for timing analysis and optimization.

The constraints, such as the clock specifications and false paths, describe the different modes of operation of the design. The operating conditions, extraction specifications, timing derates, and so on, form the corner specification of the multicorner-multimode design. Some timing constraints can be part of both the mode specification and the corner specification.

Timing analysis is carried out on all scenarios concurrently, and cost is measured across all scenarios for timing and design rule constraints. As a result, the timing and constraint reports show worst-case timing across all scenarios.

Concurrent multicorner-multimode optimization works on the worst violations across all scenarios, eliminating the convergence problems observed in sequential approaches. Optimization is performed for design rule constraints, setup, and hold, and is supported for both preroute and postroute designs.

The following topics describe how to prepare a multicorner-multimode design for analysis and optimization:

- [Defining Scenarios](#)
  - [Checking the Scenario Definitions](#)
  - [Managing the Scenarios](#)
- 

## Defining Scenarios

To define a scenario,

1. Create the scenario.

Use the `create_scenario` command to create a scenario. When you create a scenario, that scenario becomes the current scenario and is considered an active scenario.

You can create scenarios either before or after reading the design. If you create scenarios before reading the design, all the scenario definitions are applied to the design being read. If you create scenarios after reading the design, when you create the first scenario, all previous scenario-specific constraints are removed from the design and this warning is issued:

```
icc_shell> create_scenario s1
Warning: Any existing scenario-specific constraints are
discarded. (MV-020)
Current scenario is: s1
```

2. Specify the TLUPlus libraries, operating conditions, and constraints that apply to the scenario.

In general, when you specify these items, they apply to the current scenario. To determine the current scenario, use the `current_scenario` command without an argument. To change the current scenario, use the `current_scenario` command to specify the name of the current scenario. For example,

```
icc_shell> current_scenario
Current scenario is: s2
icc_shell> current_scenario s1
Current scenario is: s1
```

For more information about specifying the TLUPlus libraries, operating conditions, and constraints for a scenario, see “[Preparing for Timing Analysis and RC Calculation](#)” on page 3-36.

---

## Checking the Scenario Definitions

To perform consistency checks between scenarios, use the `check_scenarios` command. This command checks for scenario-specific information such as specifications of TLUPlus files, operating conditions, libraries, and clocks. By default, the output is saved in the current directory in HTML format. Use the `-output` option to specify a different location for the output file. Use the `-display` option to see the output in a Web browser. When you use this option, the tool displays the output in the browser defined by the `gui_online_browser` variable.

---

## Managing the Scenarios

The following sections describe how to manage scenarios:

- [Selecting the Scenarios to Use](#)
- [Reporting the Scenarios](#)
- [Removing Scenarios](#)

### Selecting the Scenarios to Use

By default, all scenarios that are applied to the current design are used for analysis and optimization. To reduce memory and runtime, you can modify the scenarios used for analysis and optimization by

- Setting the active scenarios
- Using scenario reduction
- Enabling and disabling scenarios for specific optimizations

#### Setting the Active Scenarios

By default, all scenarios are active scenarios; however, some scenarios might not be relevant for a specific optimization context. To specify the set of scenarios to use for analysis and optimization, use the `set_active_scenarios` command.

#### Using Scenario Reduction

During concurrent analysis and optimization, you can significantly reduce memory usage and runtime by limiting the number of active scenarios to those that are essential or dominant. A dominant scenario has the worst slack among all the scenarios for at least one of its constrained objects. Constrained objects can include delay constraints associated with a pin, the design rule constraints for a net, leakage power, and so on. Any scenario for which none of its constrained objects has the worst slack value is not a dominant scenario. The process of determining the dominant scenarios is called *scenario reduction*.

Scenario reduction analysis is always based on the current state of the design—that is, the design's current placement, routing, and clock tree state. In general, restricting concurrent analysis and optimization to a subset of dominant scenarios does not lead to significant QoR degradation.

To determine the dominant scenarios, use the `get_dominant_scenarios` command. By default, the `get_dominant_scenarios` command analyzes all active scenarios. Use the `get_dominant_scenarios -scenarios` command to restrict the set of scenarios considered during reduction. The list of scenarios you specify can include both active and inactive scenarios. The command identifies the dominant set from the list of specified scenarios. When you use the `get_dominant_scenarios -apply` command, the dominant scenarios become active and all other scenarios are inactive. The `-apply` option improves runtime if the current scenario before running this command is not in the scenario list returned by the `get_dominant_scenarios` command.

Note:

The `get_dominant_scenarios` command only supports designs that are already placed.

To improve turnaround time without adversely affecting QoR, you can run the `get_dominant_scenarios` command across multiple cores.

- To run the `get_dominant_scenarios` command in parallel on multiple cores on the same machine, use the `set_host_options -max_cores` command to specify the number of cores available on your machine.
- To run the `get_dominant_scenarios` command in parallel across several machines,
  1. Use the `set_host_options` command to configure the distributed processing.
  2. Use the `-distributed` option of the `get_dominant_scenarios` command to run the command in distributed mode.

For more information about configuring multicore processing, see “[Enabling Multicore Processing](#)” on page [2-43](#).

## Enabling and Disabling Scenarios for Specific Optimizations

Some optimizations, such as leakage-power optimization and clock tree synthesis, use only those scenarios enabled for that optimization, rather than using all active scenarios. To enable a scenario for specific optimizations, use the `set_scenario_options` command. By default, the options are applied to the current scenario. To apply the options to specific scenarios, use the `-scenarios` option.

- To enable a scenario for leakage-power optimization, set the `-leakage_power` option to `true`.

By default, leakage-power optimization is disabled on all scenarios. To enable the current scenario for leakage-power optimization, enter the following command:

```
icc_shell> set_scenario_options -leakage_power true
```

To enable the s1 and s2 scenarios for leakage-power optimization, enter the following command:

```
icc_shell> set_scenario_options -leakage_power true -scenarios {s1 s2}
```

Note:

In general, you can enable multiple scenarios for leakage-power optimization; however, final stage leakage recovery, which is invoked by running the `focal_opt -power` command, requires a single scenario enabled for leakage-power optimization. For more information about final stage leakage recovery, see “[Performing Final Stage Leakage-Power Recovery](#)” on page 5-10.

- To disable a scenario for maximum delay optimization, set the `-setup` option to `false`.

By default, maximum delay optimization is enabled on all scenarios. To disable the current scenario for maximum delay optimization, enter the following command:

```
icc_shell> set_scenario_options -setup false
```

To disable the s1 and s2 scenarios for maximum delay optimization, enter the following command:

```
icc_shell> set_scenario_options -setup false -scenarios {s1 s2}
```

- To disable a scenario for minimum delay optimization, set the `-hold` option to `false`.

By default, minimum delay optimization is enabled on all scenarios. To disable the current scenario for minimum delay optimization, enter the following command:

```
icc_shell> set_scenario_options -hold false
```

To disable the s1 and s2 scenarios for minimum delay optimization, enter the following command:

```
icc_shell> set_scenario_options -hold false -scenarios {s1 s2}
```

- To enable a scenario for clock tree synthesis, set the `-cts_mode` option to `true`.

By default, clock tree synthesis is disabled on all scenarios. To enable the current scenario for clock tree synthesis, enter the following command:

```
icc_shell> set_scenario_options -cts_mode true
```

To enable the s1 and s2 scenarios for clock tree synthesis, enter the following command:

```
icc_shell> set_scenario_options -cts_mode true -scenarios {s1 s2}
```

- To enable a specific corner of a scenario for clock tree optimization, using the `optimize_clock_tree` command, use the `-cts_corner` option.

The values you can specify with the `-cts_corner` option are `min`, `max`, `min_max`, or `none`. The default for the `-cts_corner` option is `none`. When you specify `-cts_corner min`, the minimum corner of the scenario is considered for clock tree optimization. When you specify `-cts_corner max`, the maximum corner of the scenario is considered for clock tree optimization. When you specify `-cts_corner min_max`, both the minimum and maximum corners of the scenario are considered for clock tree optimization. To enable the maximum corner of the current scenario for clock tree optimization, enter the following command:

```
icc_shell> set_scenario_options -cts_corner max
```

To enable both the minimum and maximum corners of the s1 and s2 scenarios for clock tree optimization, enter the following command:

```
icc_shell> set_scenario_options -cts_corner min_max -scenarios {s1 s2}
```

For more information about setting up multicorner-multimode designs for clock tree synthesis, see “[Performing Multimode Clock Tree Synthesis](#)” on page 7-91 and “[Performing Multicorner Clock Tree Optimization](#)” on page 7-95.

To report the scenario options, use the `report_scenario_options` command.

## Reporting the Scenarios

The following sections describe the IC Compiler commands used to check and report scenarios.

To display all the defined scenarios, use the `all_scenarios` command.

```
icc_shell> all_scenarios
s1 s2
```

To report all the defined scenarios, use the `report_scenarios` command.

```
icc_shell> report_scenarios
```

The following example shows a report generated by the `report_scenarios` command:

```
*****
Report : scenarios
Design : DESIGN1
scenario(s) : SCN1
Version: A-2007.12
Date   : Thu Nov 08 20:55:59 2007
*****  
  
All scenarios (Total=4): SCN1 SCN2 SCN3 SCN4
All Active scenarios (Total=1): SCN1
Current scenario      : SCN1
CTS Scenario         : SCN3  
  
Scenario #0: SCN1 is active.
Scenario options:
Has timing derate: No
Library(s) Used:
  technology library name (File: library.db)  
  
Operating condition(s) Used:
  Analysis Type      : bc_wc
  Max Operating Condition: library:WCCOM
  Max Process        : 1.00
  Max Voltage        : 1.08
  Max Temperature: 125.00
  Min Operating Condition: library:BCCOM
  Min Process        : 1.00
  Min Voltage        : 1.32
  Min Temperature: 0.00  
  
Tlu Plus Files Used:
  Max TLU+ file: tlu_plus_file.tf
  Tech2ITF mapping file: tf2itf.map  
  
Number of leakage-only scenario(s): 0
```

To display the current scenario, use the `current_scenario` command without an argument.

```
icc_shell> current_scenario
Current scenario is: s2
```

To display the currently active scenarios, use the `all_active_scenarios` command.

```
icc_shell> all_active_scenarios
s1 s2
```

## Removing Scenarios

Use the `remove_scenario` command to remove the specified scenarios from memory. To remove all scenarios use the `-all` option. You can use this command to control the scenarios applied to, or saved with a design.

---

## Preparing for Timing Analysis and RC Calculation

IC Compiler provides RC calculation technology and timing analysis capabilities for both preroute and postroute data. The following sections describe the tasks you should complete before you perform RC calculation and timing analysis:

- [Setting Up the TLUPlus Files](#)
  - [Specifying the Operating Conditions](#)
  - [Setting Timing Constraints](#)
  - [Selecting the Delay Calculation Method \(optional\)](#)
  - [Back-Annotating Delay or Parasitic Data \(optional\)](#)
- 

## Setting Up the TLUPlus Files

TLUPlus is a binary table format that stores the RC coefficients. The TLUPlus models enable accurate RC extraction results by including the effects of width, space, density, and temperature on the resistance coefficients. For details about modeling these effects in the Interconnect Technology Format (ITF) file, see the StarRC documentation.

To use TLUPlus models for RC estimation and extraction, you specify the following files:

- The map file, which matches the layer and via names in the Milkyway technology file with the names in the ITF file.
- The maximum TLUPlus model file.
- The minimum TLUPlus model file (optional). Specifying the minimum TLUPlus file is necessary if the minimum and maximum operating conditions are different and the TLUPlus models have derating coefficients. In that case, the minimum file must be specified even if it is the same as the maximum file.

You specify these files by using the `set_tlu_plus_files` command (or by choosing File > Set TLU+ in the GUI). You can specify TLUPlus file names with or without their full paths. If you do not include the paths, IC Compiler uses the search paths defined with the `search_path` variable.

Here is an example:

```
icc_shell> set_tlu_plus_files \
    -tech2itf_map ./path/map_file_name.map \
    -max_tluplus ./path/worst_settings.tlup \
    -min_tluplus ./path/best_settings.tlup
```

For multicorner-multimode designs, use the `set_tlu_plus_files` command to specify the TLUPlus files for each scenario. The `set_tlu_plus_files` command only applies to the current scenario. For information about setting the current scenario see “[Defining Scenarios](#)” on page 3-30. IC Compiler support up to one hundred TLUPlus files per design.

If a TLUPlus file is not specified for each scenario, an error similar to the following is issued:

```
Error: tlu_plus files are not set in this scenario s1.  
RC values will be 0.
```

To allow for temperature scaling, the TLUPlus files specified must contain the `GLOBAL_TEMPERATURE`, `CRT1`, and (optionally) `CRT2` variables. The following example is an excerpt from a TLUPlus file:

```
TECHNOLOGY = 90nm_1lib  
GLOBAL_TEMPERATURE = 105.0  
CONDUCTOR metal18 {THICKNESS= 0.8000  
    CRT1=4.39e-3 CRT2=4.39e-7  
...}
```

After specifying the TLUPlus files, you should validate them by running the `check_tlu_plus_files` command. An invalid TLUPlus setup can cause errors when you process your design. When you validate the TLUPlus files, IC Compiler checks the consistency of conducting layer names and via layer names across the ITF file, Milkyway file, and mapping files. It also verifies that the minimum width and minimum spacing rules for metal layers are consistent between the ITF file and the Milkyway technology file, but it does not check minimum width and minimum spacing for via layers. IC Compiler uses the technology file as the reference for these checks. The consistency check compares the parameters in the TLUPlus files with the corresponding fields in the technology file.

Note:

IC Compiler does not save the TLUPlus settings in the Milkyway design unless the design has a valid floorplan. For information about annotating a floorplan on the design, see “[Annotating the Physical Data](#)” on page 3-17. For information about creating a floorplan, see the *IC Compiler Design Planning User Guide*.

IC Compiler provides several commands for working with the TLUPlus file settings. [Table 3-2](#) lists these commands and their functions.

*Table 3-2 Commands for Working With the TLUPlus File Settings*

| Task                               | Command               | GUI             |
|------------------------------------|-----------------------|-----------------|
| Define the TLUPlus file settings   | set_tlu_plus_files    | File > Set TLU+ |
| Validate the TLUPlus file settings | check_tlu_plus_files  | N/A             |
| Report the TLUPlus file settings   | report_tlu_plus_files | N/A             |

## Specifying the Operating Conditions

The operating conditions of a design include the process, voltage, and temperature parameters under which the chip is intended to operate. IC Compiler analyzes and optimizes the design under the conditions you specify.

The technology library can specify multiple sets of chip operating conditions (process, voltage, and temperature). To get a list of the operating conditions available in a particular library and to view their characteristics, use either the `report_operating_conditions` or `report_lib -operating_condition` command.

To set the operating conditions for timing analysis and optimization, use the `set_operating_conditions` command. When you run this command, you can specify either a maximum operating condition only or both a minimum and a maximum operating condition (`-min` and `-max` options).

For multicorner-multimode designs, specify an operating condition for each scenario in the design. If an operating condition is not specified, MV-20 and MV-21 warning messages are issued as shown in the following example:

```
icc_shell> set_operating_conditions SLOW_95 -library max_v95_t125
icc_shell> create_scenario s1
Warning: Any existing scenario-specific constraints are discarded.
(MV-020)
icc_shell> report_timing
Warning: No operating condition was set in scenario s1 (MV-021)
```

Note:

Multicorner-multimode design libraries do not support the use of k-factor scaling. Therefore, the operating conditions that you specify for each scenario must match the nominal operating conditions of one of the libraries in the link library.

## Selecting the Operating Condition Analysis Mode

IC Compiler offers three analysis modes with respect to operating conditions:

- Single operating condition (default)

In the single operating condition mode, IC Compiler uses a single set of delay parameters for the whole circuit, based on one set of process, temperature, and voltage conditions.

- Best-case and worst-case (-analysis\_type bc\_wc option)

In the best-case and worst-case mode, IC Compiler simultaneously checks the circuit for the two extreme operating conditions: minimum and maximum. For setup checks, it uses maximum delays for all paths. For hold checks, it uses minimum delays for all paths. This mode lets you check both extremes in a single analysis run, thereby reducing overall runtime for a full analysis.

- On-chip variation (-analysis\_type on\_chip\_variation option)

In the on-chip variation mode, IC Compiler performs a conservative analysis that allows both minimum and maximum delays to apply to different paths at the same time. For a setup check, it uses maximum delays for the launch clock path and datapath and minimum delays for the capture clock path. For a hold check, it uses minimum delays for the launch clock path and datapath and maximum delays for the capture clock path. This mode models the effects of variation in operating conditions across the chip.

## Preparing for Minimum and Maximum Timing Analysis

By default, when you perform simultaneous minimum and maximum timing analysis, IC Compiler uses the logic libraries specified by the `link_library` variable for both maximum and minimum timing information.

IC Compiler also supports the following methods for determining the minimum and maximum timing information:

- Using two libraries
- Using derating factors
- Using advanced on-chip variation

### Using Two Libraries

You specify separate minimum timing libraries by using the `set_min_library` command. The `set_min_library` command associates minimum timing libraries with the maximum timing libraries specified in the `link_library` variable. For example,

```
icc_shell> set_app_var link_library "* maxlib.db"
icc_shell> set_min_library maxlib.db -min_version minlib.db
```

**Note:**

The link path should contain only the maximum library, as shown in the previous example.

The `set_min_library` command is not scenario-specific. So, if you use this command to associate a minimum library to a specific maximum library, that relationship applies to all scenarios.

A minimum library can be associated with a single maximum library. Similarly, a maximum library can be associated with a single minimum library. As shown in the example in [Table 3-3](#), the minimum library `Fast_0yr.db` is associated with the maximum library, `Slow.db` of scenario s1. The minimum library `Fast_10yr.db` is associated with the maximum library, `SlowHV.db` of scenario s2.

*Table 3-3 Supported Minimum-Maximum Library Configuration*

| Scenarios       |                          |
|-----------------|--------------------------|
| s1              | s2                       |
| Maximum library | <code>Slow.db</code>     |
| Minimum library | <code>Fast_0yr.db</code> |

IC Compiler does not support associating a single minimum library with multiple maximum libraries or associating a single maximum library with multiple minimum libraries. If you use multiple `set_min_library` commands to associate a single minimum (or maximum) library with multiple maximum (or minimum) libraries, the tool uses the values specified in the last `set_min_library` command, overriding the values specified in the previous `set_min_library` command.

Consider the example shown in [Table 3-4](#), where the maximum library, `Slow.db` is associated with two minimum libraries, `Fast_0yr.db` and `Fast_10yr.db`, in scenarios s1 and s2 respectively. IC Compiler does not support this type of association.

*Table 3-4 Unsupported Multiple Minimum Library Configuration*

| Scenarios       |                          |
|-----------------|--------------------------|
| s1              | s2                       |
| Maximum library | <code>Slow.db</code>     |
| Minimum library | <code>Fast_0yr.db</code> |

**Example 3-5 Unsupported Multiple Minimum Library Configuration Script**

```
create_scenario S1
set_min_library -min_version Fast_0yr.db Slow.db
...
create_scenario S2
set_min_library -min_version Fast_10yr.db Slow.db
...
```

In [Example 3-5](#), multiple `set_min_library` commands are used to associate a single maximum library with multiple minimum libraries. The tool overrides the value set by the first `set_min_library` command and issues the following warning message:

```
Warning: overriding result from previous set_min_library command on
library 'Fast_0yr.db'.
```

For more information, see “Using Two Libraries for Min-Max Analysis” in the *Synopsis Timing Constraints and Optimization User Guide*.

To find out which libraries are defined as the maximum and minimum libraries, use the `list_libs` command. In the generated report, the uppercase letter “M” appears next to the maximum library, and the lowercase letter “m” appears next to the minimum library.

## Using Derating Factors

If your timing libraries do not include both minimum and maximum timing data, you can perform simultaneous minimum and maximum timing analysis by specifying derating factors for your timing library.

Use the `set_timing_derate` command to specify the derating factors. For example, to specify that for the maximum operating condition, all early (shortest-path) delays should be decreased by 10 percent and all late (longest-path) delays should be increased by 20 percent, enter the following commands:

```
icc_shell> set_timing_derate -max -early 0.9
icc_shell> set_timing_derate -max -late 1.2
```

By default, the `set_timing_derate` command applies derating to the whole design. You can optionally specify a list of leaf-level cells or library cells, which restricts the scope of the command to only the listed cells.

In multi-scenario timing analysis, the command applies only to the scenario in which it is used, so you can set different derate factors for each scenario, except when you apply the command to library cells. By default, derating set on library cells affects the usage of those cells in all scenarios. To have this derating apply to only the current scenario, set the `timing_library_derate_is_scenario_specific` variable to `true`.

To report the derating factors, use the `report_timing_derate` command. To reset the derating factors to 1.0, use the `reset_timing_derate` command.

For more information, see “Setting Derating Factors” in the *Synopsys Timing Constraints and Optimization User Guide*.

### Using Advanced On-Chip Variation

Advanced on-chip variation (advanced OCV) is an optional method of accuracy improvement that determines varying derating factors for different clock paths based on the path lengths. To use the feature, you create tables of derating values to be applied to clock paths in the design. For details, see “Advanced On-Chip Variation Analysis” in the *Synopsys Timing Constraints and Optimization User Guide*.

## Setting Voltage and Temperature Scaling Between Libraries

IC Compiler can use “scaling library groups” to implement voltage and temperature scaling. To get the cell delays at intermediate voltage and temperature conditions, IC Compiler interpolates between the data in separate libraries that have been characterized at different nominal voltage and temperature values.

To use this feature, the libraries in the scaling group must contain CCS timing models or mixed CCS and NLDM timing models. The cell data must be consistent with respect to cell names, the number and names of pins, and the number and names of timing arcs.

Use the `define_scaling_lib_group` command to create a scaling library group and specify which libraries belong to the group. To apply a defined scaling library group to the whole design or to selected objects in the design, use the `set_scaling_lib_group` command. To create an intermediate operating condition, use the `create_operating_conditions` command.

For example,

```
icc_shell> define_scaling_lib_group -name group1 \
    { max_v70_t125.db max_v108_t125.db }
icc_shell> set_scaling_lib_group group1
icc_shell> set_operating_conditions SLOW_108 -library max_v108_t125
icc_shell> create_operating_conditions -name SLOW_95 \
    -library max_v70_t125 -process 1 -voltage 0.95 -temperature 125
icc_shell> set_operating_conditions SLOW_95 \
    -object_list { mid1/bot1 top_i }
```

This example creates a one-dimensional scaling group consisting of two libraries characterized at two extreme voltages, 0.70 and 1.25 volts. It applies this scaling group to the design and selects the 1.25-volt library as the default operating condition for the design. Then it creates a new operating condition at 0.95 volts and applies it to two objects in the

design. The tool performs interpolation between the 0.70-volt and 1.25-volt libraries to obtain the timing characteristics at 0.95 volts and uses that information for timing analysis of the two objects.

To perform both voltage and temperature scaling at the same time, you would use four libraries in the scaling group rather than two, representing the four possible combinations of voltage and temperature extremes: high voltage and high temperature, high voltage and low temperature, low voltage and high temperature, and low voltage and low temperature.

To remove the scaling library group from a set of ports or cells, use the `remove_scaling_lib_group` command.

**Note:**

The `check_library` command does not check for consistency among the libraries in the scaling library group.

---

## Setting Timing Constraints

At a minimum, the timing constraints must contain a clock definition for each clock signal, as well as input delay or output delay for each I/O port. This requirement ensures that all signal paths are constrained for timing.

To model the clock tree effects for placement before running clock tree synthesis, you should also define the uncertainty, latency, and transition constraints for each clock by using the `set_clock_uncertainty`, `set_clock_latency`, and `set_clock_transition` commands.

You can use a file of Synopsys Design Constraints (SDC) commands or use individual SDC commands. For details about the SDC commands, see the *Using the Synopsys Design Constraints Format Application Note*.

To read a timing constraints file, use the `read_sdc` command (or choose File > Import > Read SDC).

```
icc_shell> read_sdc -version 1.7 design_name.sdc
```

**Important:**

If the SDC file does not contain unit settings, they are derived from the main library (see “[Setting Up the Logic Libraries](#)” on page 3-3). If the SDC file does contain unit settings, they must be consistent with those in the main library.

IC Compiler does not optimize paths that are not constrained for timing. Before proceeding, use the `check_timing` command to verify that all paths are constrained. If the `check_timing` command reports unconstrained paths, run the `report_timing_requirements` command to verify that the unconstrained paths are false paths (the `check_timing` command considers false paths unconstrained).

To remove the timing constraints, use one of the following commands:

- `remove_sdc`

This command removes the timing constraints set by SDC commands.

**Note:**

If you have run extraction on your design, you can prevent removal of the extracted RC network by using the `-keep_parasitics` option when you run the `remove_sdc` command. Keeping the RC network saves runtime because IC Compiler does not need to redo the extraction.

- `remove_ideal_network -all`

This command removes `ideal_network` attributes, latencies, and transition times.

- `reset_design`

This command removes all attributes from the design, including timing constraints, optimization attributes, and physical information.

For multicorner-multimode designs, you must define timing constraints for each scenario. In general, when you set a timing constraint, it only applies to the current scenario. For information about setting the current scenario see “[Defining Scenarios](#)” on page 3-30.

---

## Selecting the Delay Calculation Method

By default, IC Compiler uses the Elmore delay model for both preroute and postroute delay calculation. For postroute delay calculations, you can optionally choose to use the Arnoldi delay model, either for clock nets only or for all nets. The Elmore delay model is faster, but its results do not always correlate with the PrimeTime and PrimeTime SI results. The Arnoldi model is better for designs with smaller geometries and highly resistive nets, but it requires more runtime and memory.

If you are not sure of which calculation method to use, you can use the `compare_delay_calculation` command to compare the results of sample delay calculations for your design. If the results are similar for both methods, use the faster Elmore method. Otherwise, use the Arnoldi method.

To enable Arnoldi delay calculation for clock nets only, enter the following command:

```
icc_shell> set_delay_calculation -clock_arnoldi
```

**Note:**

This delay model should be used only for signal path optimization after clock routing is complete. Using this delay model for postroute clock tree optimization can result in reduced clock tree QoR.

To enable Arnoldi delay calculation, enter the following command:

```
icc_shell> set_delay_calculation -arnoldi
```

Note:

Using the Arnoldi delay model removes existing back-annotation stored in the database (unlike using the Elmore delay model). In addition, if you save a design with Arnoldi settings (`set_delay_calculation -clock_arnoldi` or `set_delay_calculation -arnoldi`), the delay information is not saved in the Milkyway design.

By default, IC Compiler does not include crosstalk delta delays in the delay calculations. To extract coupling capacitances and include crosstalk delta delays in the postroute delay calculations, enter the following command:

```
icc_shell> set_si_options -delta_delay true
```

---

## Back-Annotating Delay or Parasitic Data

If you have existing delay or parasitic data, you can back-annotate the design with this data instead of using the IC Compiler extraction capability to calculate the data.

To back-annotate the design with delay information provided in a Standard Delay Format (SDF) file, use the `read_sdf` command (or choose File > Import > Read SDF). To back-annotate the design with parasitic capacitance and resistance information, use the `read_parasitics` command. IC Compiler accepts parasitic data in Synopsys Binary Parasitic Format (SBPF) or Standard Parasitic Exchange Format (SPEF).

Note:

If you read the parasitic data in SPEF format, IC Compiler uses this data for analysis only. If you read the data in SBPF format, IC Compiler can use the data for both analysis and on-route optimization.

To remove annotated data from your design, use the `remove_annotations` command.

---

## Linking Designs

When IC Compiler performs timing analysis, each cell instance in the design must be linked to a cell in the link libraries, which provides its timing information. For information about defining the link libraries, see “[Setting Up the Logic Libraries](#)” on page 3-3. In general, IC Compiler automatically links the design before performing timing analysis. If you want to explicitly link your design, use the `link -force` command.

---

## Linking Designs Without Multicorner-Multimode Scenarios

If your design does not contain multicorner-multimode scenarios, IC Compiler links each cell instance to the first reference cell it locates in the link libraries. If it locates additional reference cells with the same name, it generates a warning message identifying the ignored, duplicate reference cells. If IC Compiler does not find the reference cell, a warning appears advising that the reference cell cannot be resolved.

---

## Linking Designs With Multicorner-Multimode Scenarios

If your design contains multicorner-multimode scenarios, IC Compiler groups the link libraries into sets by using their nominal process, voltage, and temperature (PVT) values. Libraries with the same nominal PVT values are grouped into the same set. This grouping scheme allows you to use logic libraries that do not have operating condition definitions. It also provides the flexibility of having multiple library files (for example, one for standard cells, another for macros, and so forth).

When you use multiple libraries,

- If library cells with the same name are not functionally identical or do not have identical sets of library pins with the same name and order, a warning is issued, stating that the libraries are inconsistent.
- If library cells with the same name have the same nominal PVT, a warning is issued, stating that the libraries are ambiguous. The warning also states which libraries are being used and which are being ignored.

When you set the operating conditions for a scenario, IC Compiler uses the PVT values of the maximum operating condition to select the link library set associated with that scenario. For each scenario, IC Compiler links the cell instances in the design with the first matching reference cell in its associated link library set. Note that using the `-library` option with the `set_operating_conditions` command merely helps the tool identify the PVT for the operating conditions; it does not specify the library to link.

Note:

Because the grouping is done by nominal PVT values, you must ensure that these values are distinct for the maximum libraries associated with each corner; otherwise, they are grouped into the same set. Because IC Compiler links cell instances to the first matching library cell in a set, the cells are not linked correctly, which results in incorrect timing values.

For example, assume that you have two sets of libraries, one for each corner, as shown in [Table 3-5](#). Each corner has three libraries: one for combinational cells, one for sequential cells, and one for macros.

*Table 3-5 Link Libraries With Distinct PVT Values*

| Link library (in order) | Nominal PVT | Operating conditions in library (PVT) |
|-------------------------|-------------|---------------------------------------|
| Combo_cells_slow.db     | 1/0.85/130  | WORST (1/0.85/130)                    |
| Sequentials_fast.db     | 1/1.30/100  | None                                  |
| Macros_fast.db          | 1/1.30/100  | None                                  |
| Macros_slow.db          | 1/0.85/130  | None                                  |
| Combo_cells_fast.db     | 1/1.30/100  | BEST (1/1.3/100)                      |
| Sequentials_slow.db     | 1/0.85/130  | None                                  |

In this case, the libraries are grouped as

- `Combo_cells_slow`, `Macros_slow`, and `Sequentials_slow` with PVT values of 1, 0.85, and 130, respectively.
- `Combo_cells_fast`, `Macros_fast`, and `Sequentials_fast` with PVT values of 1, 1.30, and 100, respectively.

To create a scenario named `s1` with the cell instances linked to the `Combo_cells_slow`, `Macros_slow`, and `Sequentials_slow` libraries, enter the following command:

```
icc_shell> create_scenario s1
icc_shell> set_operating_conditions -max WORST -library Combo_cells_slow
```

In the following example, the link library contains four libraries, one for each corner, with each library containing the same library cells; however, the nominal PVT values are not distinct between these libraries, as shown in [Table 3-6](#).

*Table 3-6 Link Libraries That Do Not Have Distinct PVT Values*

| Link library (in order) | Nominal PVT | Operating conditions in library (PVT) |
|-------------------------|-------------|---------------------------------------|
| Ftyp.db                 | 1/1.30/100  | WORST (1/1.30/100)                    |
| Typ.db                  | 1/0.85/100  | WORST (1/0.85/100)                    |

*Table 3-6 Link Libraries That Do Not Have Distinct PVT Values (Continued)*

| Link library (in order) | Nominal PVT | Operating conditions in library (PVT) |
|-------------------------|-------------|---------------------------------------|
| TypHV.db                | 1/1.30/100  | WORST (1/1.30/100)                    |
| Holdtyp.db              | 1/0.85/100  | BEST (1/0.85/100)                     |

In this case, the libraries are grouped as

- Ftyp and TypHV with PVT values of 1, 1.30, and 100, respectively.
- Typ and Holdtyp with PVT values of 1, 0.85, and 100, respectively.

When you run the following commands, the cell instances in scenario s2 are not linked to the library cells in the TypHV.db library, as intended. Instead, they are linked to the library cells in the Ftyp.db library, which is the first logic library in its link set.

```
icc_shell> create_scenario s1
icc_shell> set_operating_conditions WORST -library Typ.db
icc_shell> create_scenario s2
icc_shell> set_operating_conditions WORST -library TypHV.db
icc_shell> create_scenario s3
icc_shell> set_operating_conditions WORST -library Ftyp.db
icc_shell> create_scenario s4
icc_shell> set_operating_conditions \
    -max WORST -max_library Typ.db -min BEST -min_library HoldTyp.db
```

## Resolving References With Operating Condition Mismatches

Before doing timing analysis, you can check whether your design contains any cells for which the link libraries do not have cells characterized with the correct operating conditions by running the `check_mv_design -opcond_mismatches` command.

By default, when IC Compiler cannot find an exact match for the reference cell name and operating conditions, it tries to match the reference cell with the same name and the closest operating conditions using the following process:

1. Find the set of library cells with the same name as the reference cell.

Note:

If the cell instance is connected to a power net, reference cells whose rail voltages do not match the explicit power connection rails are not included in this set.

2. Identify the library cells in this set that match each of the following criteria, in order.
  - a. The PVT values of the library cell match the PVT values of the design.
  - b. The process, temperature, and voltage values from one of the rails of the library cell match the PVT values of the design.
  - c. The temperature and voltage values of the library cell match the temperature and voltage values of the design.
  - d. The process and voltage values of the library cell match the process and voltage values of the design.
  - e. The voltage value of the library cell matches the voltage value of the design.
  - f. The voltage value from one of the rails of the library cell matches the voltage value of the design.
  - g. The process and temperature values of the library cell match the process and temperature values of the design.
  - h. None of the process, voltage, and temperature values of the library cell match the process, voltage, and temperature values of the design.

The process stops at the first criteria where either a single library cell matches or multiple library cells match.

If a single library cell matches, IC Compiler links that library cell to the cell instance, uses its PVT values as the operating conditions of the cell instance, and issues the warning following message:

```
Warning: cell top/macrol(mac1) was constrained to operate under the
operating condition (voltage = 1.110000V, process = 1.000000,
temperature = 125.000000), but the library cell mac1 matching this
characterization cannot be found in the link libraries. Instead,
library cell mac1 from mac1_1.00v_125c.db:mac1_1.00v_125c (voltage =
1.000000V, process = 1.000000, temperature = 125.000000) has been used.
(LIBSETUP-001)
```

If multiple library cells match, an error occurs and the cell instance remains unresolved.

If none of the criteria result in a single matching library cell, an error occurs and the cell instance remains unresolved.

For a macro-cell, pad-cell, or switch-cell instance, if you do not want to use this default resolution, use the `set_opcond_inference` command to control the degree to which the inferred operating condition can deviate from the operating condition of the design. A higher degree of deviation results in a lower likelihood of unresolved references; however, it can result in reduced timing accuracy.

You can reduce the degree of deviation by

- Requiring the process and temperature values of the library cell to match the process and temperature values of the design.

Set the `-match_process_temperature` option to `true` to enable this requirement.

- Requiring a single name-based match within the link libraries

Set the `-level` option to `unique_resolved` to enable this requirement. Note that if the cell instance is connected to a power net, a rail voltage of the library cell must match the explicit power connection rail voltage.

- Requiring an exact match of both name and operating conditions

Set the `-level` option to `exact` to enable this requirement.

To increase the degree of deviation, set the `-level` option to `closest_unresolved`. With this setting, the library cell matching process is the same as the default process (`-level closest_resolved`); however, when multiple library cells match a criteria, the first matching library cell is selected.

By default, the settings of the `set_opcond_inference` command apply to all macro-cell, pad-cell, and switch-cell instances. You can restrict the types of cells to which the settings apply by using the `-applies_to` option. You can apply the settings to specific cell instances by using the `-object_list` option.

Note:

The `set_opcond_inference` command applies only to macro-cell, pad-cell, and switch-cell instances. It does not apply to any other type of leaf-cell instance in your design.

---

## Saving a Design

You can save a design for use with Milkyway design tools, for use with other tools, and for manufacturing. If you are planning to work further with the design in IC Compiler or another design tool based on Milkyway, save the design as explained in “[Saving the Design in Milkyway Format](#)” on page 3-51. If you are going to use a tool that does not use Milkyway, export the design to ASCII format (which includes Verilog, DEF, SDC, and parasitic files), as explained in “[Saving the Design in ASCII Format](#)” on page 3-54. If you have completed the design and are ready for manufacturing, save it in GDSII or Oasis format, as explained in “[Writing GDSII and OASIS Layout Data Files](#)” on page 3-55.

---

## Saving the Design in Milkyway Format

To save the design in Milkyway format, use the `save_mw_cel` command (or click the  button on the File toolbar or choose File > Save Design).

When you save a design, IC Compiler automatically updates the Milkyway database. If your design does not have unit settings, IC Compiler applies the default settings from the main library and saves them with the design. For more information about the main library and its default settings, see “[Setting Up the Logic Libraries](#)” on page 3-3.

## Saving the Design From the Command Line

When you enter the `save_mw_cel` command on the shell command line, if you do not specify a design, IC Compiler saves the current Milkyway design. To save another design, specify the design name on the command line.

```
icc_shell> save_mw_cel design_name
```

By default, the top-level design is saved with the same name and CEL version.

To increment the CEL version, use the `-increase_version` option.

```
icc_shell> save_mw_cel design_name -increase_version
```

To save a copy of the design with a different name, use the `-as` option.

```
icc_shell> save_mw_cel design_name -as new_name
```

To save the top-level design together with its subdesigns and attached files in a single CEL view, use the `-hierarchy` option.

```
icc_shell> save_mw_cel design_name -hierarchy
```

By default, the `save_mw_cel` command saves all scenarios with a multicorner-multimode design. To save specific scenarios with the design, use the `-scenarios` option.

```
icc_shell> save_mw_cel design_name -scenarios scenario_names
```

## Saving the Design in the GUI

When you choose File > Save Design in the GUI, the Save Design dialog box appears.

- To save the top-level design for all modified designs with the same name and CEL version, click Save All.
- To save the designs using other options, select “Show advanced options,” which displays additional options and additional columns in the list of designs.

- (Optional) To display only the names of designs with unsaved changes, select the “All modified cells” option.

The “All open cells” option is selected by default.

- (Optional) To specify a list of the scenarios with constraints that you need to save with the design, type the scenario names in the Scenarios box.

Alternatively, you can click the browse button and select the scenarios in the Scenarios Chooser dialog box.

- Set options to save or discard design changes as needed.

You can select which designs you want to save and which methods to use to save them by setting options in the design list.

- To save the design, select the Save option.

By default, this option is selected for designs that have unsaved changes and deselected for designs that do not have unsaved changes. If you do not want to save the changes for a design, deselect its Save option.

- To increment the CEL version, select the “New version” option.
- To save a modified top-level design together with all its subdesigns and attached files in the same CEL version, select the Save Hierarchy option.

The subdesigns must be in the same design library as the top-level design. Subdesigns that are instantiated from the reference libraries are not included.

This option is not available when the “New version” or Save As option is selected.

- To save a copy of a design, select the Save As option and type a new design name in the Save As Name box.

Do not include a period (.) in the name unless you want to include the CEL view name. In Milkyway, the period is a special character used to separate design names from view names. A period followed by an invalid view name causes an error.

- To close a design after saving it, select the Close option.

If you need to close a design and discard the changes, select the Close option and deselect the Save option.

You can select or deselect options for all designs by using the buttons below the list.

- To select the Save options for all designs, click the Select Save All button.
- To deselect the Save options for all designs, click the Discard All Changes button.

- To select the Save Hierarchy options for all designs, click the Select Hierarchy All button.
- To deselect the Save Hierarchy options for all designs, click the Clear Hierarchy All button.
- Click OK or Apply.

Note:

When you use the GUI to close designs, close the design library, or exit the tool, IC Compiler opens a dialog box similar to the Save Design dialog box and gives you the option of automatically saving the open designs in Milkyway format.

---

## Saving the Design Settings in the Milkyway Design Library

Design settings, which are controlled by setting variables such as `search_path` and `link_library`, can be saved in the Milkyway design library rather than in a separate script file, helping to ensure that the correct settings are used in subsequent sessions. These are the commands for saving, reporting, and restoring design settings:

```
save_design_settings
  -library
  [-input tcl_file]

write_design_settings
  -library
  [-output tcl_file]

restore_design_settings
  -library
```

In each of these commands, using the `-library` option is mandatory, which causes the design settings to be saved to or restored from the Milkyway design library that is currently open.

The `save_design_settings -library` command saves the design settings into the Milkyway design library that is currently open. By default, the command saves all the variable settings that have been changed from their defaults. It saves them as a sequence of `set_app_var` commands. However, if you use the `-input tcl_file` option, it saves the sequence of commands contained in the specified text file into the design library, without considering whether these commands change default variable values. The file can contain any commands, not just `set` or `set_app_var` commands.

The `write_design_settings -library` command reports the commands that have been saved into the design library by the `save_design_settings` command. You can optionally write this command sequence into a text file by using the `-output tcl_file` option.

The `restore_design_settings -library` command restores the design settings previously stored into the design library with the `save_design_settings` command. It reads the previously saved commands from the library and executes them.

---

## Saving the Design in ASCII Format

To save the design in ASCII format,

1. Update the power and ground connections by using the `derive_pg_connection` command. This is a required step when writing a Verilog netlist. For more information, see “[Creating Logical Power and Ground Connections](#)” on page 3-20.
2. Ensure that the object names in the design are Verilog-compliant by using the `change_names` command. This is a required step when writing a Verilog netlist.

```
icc_shell> change_names -hierarchy -rules verilog
```

3. Write Verilog data for the design by using the `write_verilog` command.

```
icc_shell> write_verilog design_name.v
```

By default, the generated Verilog netlist does not include the power and ground nets. To include the power and ground nets, use the `-pg` and `-output_net_name_for_tie` options when you run the `write_verilog` command.

Note:

Before you run the `write_verilog` command, use the `check_database` command to validate the infrastructure integrity of the Milkyway design database. For more information, see “[Checking the Design Database](#)” on page 3-23.

4. Write the physical data to DEF files by using the `write_def` command (or by choosing File > Export > Write DEF).

```
icc_shell> write_def -output design_name.def
```

5. Write the design constraints to SDC files by using the `write_sdc` command.

```
icc_shell> write_sdc design_name.sdc
```

If the SDC file does not have unit settings, IC Compiler uses the default settings from the main library and saves them when you save the SDC file. For more information about the main library and its default settings, see “[Setting Up the Logic Libraries](#)” on page 3-3.

6. Write the RC extraction data to the parasitic netlist by using the `write_parasitics` command (or by choosing File > Export > Write Parasitics).

IC Compiler can write parasitic netlists in the SPEF and SBPF formats. Specify the format by using the `-format` option (or the “Net format in file” box in the GUI). You can also compress the output in gzip format by using the `-compress` option (or by selecting “Write in gzip format” in the GUI).

```
icc_shell> write_parasitics -format SPEF -output design_name.spef
```

---

## Writing GDSII and OASIS Layout Data Files

After you have completely finished and checked the chip design, you can write out the design in GDSII or OASIS format for delivery to the fabrication facility. You set the options for layout file generation by using the `set_write_stream_options` command and generate the layout data file with the `write_stream` command.

The `set_write_stream_options` command lets you set many file generation options such as naming conventions, name mapping, hierarchical depth, via flattening, and file compression. You can use the command multiple times to set individual options incrementally. For full details, see the man page for the `set_write_stream_options` command.

After you set the options, you use the `write_stream` command to write out the design in GDSII or OASIS format. This is the syntax of the command:

```
write_stream
  [-lib_name lib_name]
  [-format gds | oasis]
  [-cells list_of_cells]
  [-cell_file cell_name_file]
  stream_file_name
```

You must specify at least the output file name. The default format is GDSII, so to write the design in OASIS format, you must use the `-format oasis` option. For example,

```
icc_shell> write_stream -format oasis my_design.oasis
```

By default, the command writes out all cells in the currently opened library. To restrict the output to a specified library or specified cells, use the `-lib_name`, `-cells` or `-cell_file` option. For more information, see the man page for the `write_stream` command.

IC Compiler also supports the reading of GDSII and OASIS layout data for library cell preparation tasks. This is the syntax of the `read_stream` command:

```
read_stream
  [-lib_name lib_name]
  [-format gds | oasis]
  stream_file_name
```

The behavior of this command is affected by the option settings made with the `set_read_stream_options` command. You can report these option settings with the `report_read_stream_options` command. For more information, see the man pages for the applicable commands.

---

## Closing Designs

You can close designs at any time during an IC Compiler session. If you have unsaved changes in one or more designs, you can save or discard the changes before closing the designs.

To close Milkyway designs, use the `close_mw_cel` command (or choose File > Close Design).

```
icc_shell> close_mw_cel list_of_designs
```

By default, when you close Milkyway designs by using the `close_mw_cel` command, IC Compiler does not save the designs. To save a new CEL version for each specified design, use the `-save` option with the `close_mw_cel` command.

When you close Milkyway designs by choosing File > Close Design in the GUI and there are unsaved changes in any open designs, the Close Design dialog box appears, which enables you to save the changes to the modified designs. By default, you can either save or discard all changes. If you select “Show advanced options,” you can

- Specify a list of scenarios with constraints that you need to save with the designs.
- Select from the following options for each modified design,
  - Save a new CEL version of the design
  - Save a copy of a design with a new name
  - Save the design hierarchy (a modified top-level design together with all its subdesigns and attached files) into the same CEL version

Note:

If there are no open designs with unsaved changes, the current Milkyway design is closed without displaying the Close Design dialog box.

For more information about using the advanced options to save or discard changes, see [“Saving the Design in the GUI” on page 3-51](#).

---

## Closing a Milkyway Design Library

To close a Milkyway design library, use the `close_mw_lib` command (or choose File > Close Library).

By default, when you close a Milkyway design library by using the `close_mw_lib` command, IC Compiler does not save the open designs. To save new CEL versions for all open designs, use the `-save` option with the `close_mw_lib` command.

When you close a Milkyway design library by choosing File > Close Library in the GUI and there are unsaved changes in any open designs, the Close Library dialog box appears, which enables you to save the changes to the modified designs. By default, you can either save or discard all changes. If you select “Show advanced options,” you can

- Specify a list of scenarios with constraints that you need to save with the designs.
- Select from the following options for each modified design,
  - Save a new CEL version of the design
  - Save a copy of a design with a new name
  - Save the design hierarchy (a modified top-level design together with all its subdesigns and attached files) into the same CEL version
  - Close the design after saving or discarding changes

**Note:**

If there are no open designs with unsaved changes, the Milkyway design library is closed without displaying the Close Library dialog box.

For more information about using the advanced options to save or discard changes, see [“Saving the Design in the GUI” on page 3-51](#).

---

## Archiving Designs

IC Compiler provides the `archive_design` command to easily archive one or more designs from a Milkyway library. This capability can be useful for saving designs in various stages of implementation.

At a minimum, you must specify the source Milkyway design library (`-source` option), the designs to archive (`-design` option), and the archive directory (`-archive` option).

**Note:**

The specified Milkyway design library must not be open when you run the `archive_design` command. If the specified library is open, the command aborts.

By default, the `archive_design` command creates a new design archive by copying the following files to the specified archive directory:

- The designs specified in the `-design` option and the cells in the source Milkyway design library that are referenced by the specified designs

Use one of the following naming conventions to specify the designs you want to archive:

*design\_name*

*design\_name;version\_number*

If you do not specify a version, the `archive_design` command copies the latest version of the design.

By default, IC Compiler copies the design files for all views of the specified designs and their referenced cells from the source Milkyway design library to the `mw_lib` subdirectory of the archive directory. You can control which views are saved in the archive by using the `-include` and `-exclude` options.

If the specified archive directory already exists, the default behavior is to recopy all of the design files to the archive, overwriting the existing design files. To reduce runtime, you can use the `-update_archive` option to copy only those design files that have changed since the archive was created.

- The cells in the Milkyway reference libraries that are referenced by the specified designs

The cells from the reference libraries are saved in their own library. The library references in the copied designs are updated to reflect the new location of the reference libraries in the archive directory.

To copy the entire contents of all reference libraries used by the specified designs, instead of just the referenced cells, use the `-complete` option. This option is recommended if you intend to perform optimization after restoring the archived design.

- The TLUPlus files

The `archive_design` command copies the minimum, maximum, and map files set by the `set_tlu_plus_files` command with the `-max_tluplus`, `-min_tluplus`, and `-tech2itf_map` options. If the values are not set, the TLUPlus files are not copied. The TLUPlus files are copied to the `tlu_plus` subdirectory of the archive directory.

- The logic libraries for the specified designs

When archiving logic libraries, the `archive_design` command checks the `target_library` and `link_library` variables to identify the logic libraries to archive. These two variables contain file names that might or might not be absolute paths. If the file names are not absolute paths, the `archive_design` command checks if the file is found in the list of paths specified by the `search_path` variable. All files that match the files in the search paths are copied. The hierarchy of the directories is preserved to prevent file name conflicts. If the file name is an absolute path, only that file is copied. The logic library files are copied to the `logic_db` subdirectory of the archive directory.

In addition, the `archive_design` command writes a Tcl script called `design_setup.tcl` to the archive directory. This Tcl script contains the application variable initialization to help you set up the design. It contains the values of application variables from the current session similar to the output of the `write_app_var` command. The `search_path`, `target_library`, and `link_library` variables are modified to accommodate the new archive location.

For more information about the `archive_design` command, see the man page.



# 4

## Design for Test

---

This chapter describes the IC Compiler physical design-for-test (DFT) features.

During logic synthesis, sequential elements are replaced with scan cells that can be configured as serial chain-of-state elements to aid in testability. By setting certain test signals, the scan cells can either capture values from the functional combinational logic or the test data.

The order of the scan cells can be changed under some constraints without affecting the testability of the device. However, the scan chain order from logic synthesis is generally not based on physical proximity of the scan cells. For higher quality of results (QoR) in physical design, you can use IC Compiler to reorder scan cells based on physical data.

This chapter contains the following sections:

- [Overview of the DFT Flow](#)
- [Preparing for Physical DFT](#)
- [Scan Chain Consistency Checking](#)
- [Removing SCANDEF Data](#)
- [Optimizing Scan Chains](#)
- [Viewing Scan Chains](#)

## Overview of the DFT Flow

Physical DFT relies on the identification of scan chain components. In IC Compiler, this defined scan chain data is referred to as SCANDEF. SCANDEF specifies the scan chain components and their pins used for the scan path, along with constraints on how they can be reordered. The view of scan chains in the SCANDEF data is different from that in DFT Compiler or TetraMAX (see [Figure 4-1](#)). SCANDEF can specify chain stubs that are contiguous subsets of scan cells of a logical scan chain.

*Figure 4-1 Comparing Views of Scan Chains*



Physical DFT optimization in IC Compiler uses the SCANDEF flow. This flow accepts SCANDEF data (a subset of DEF) generated by DFT Compiler. Scan chain repartitioning and reordering are supported.

Note that you can use SCANDEF data generated from third-party flows. However, this data must conform to similar rules as DFT Compiler. For example, all combinational cell instances present in the SCANDEF must be in ORDERED lists. All multi-input components along a scan path of a specified chain stub must be included in the SCANDEF. All START (STOP) points should be input (output) ports of the current design or output (input) pins of cell instances.

You can check the consistency of the SCANDEF data against the netlist by using the `check_scan_chain` command.

[Figure 4-2](#) shows the overall physical DFT flow in IC Compiler.

*Figure 4-2 Overview of Physical DFT Flow in IC Compiler*



## Preparing for Physical DFT

Synopsys recommends that you use DFT Compiler for DFT insertion and Design Compiler topographical mode to generate SCANDEF data. This flow carries out the following primary steps:

1. Performs scan synthesis and generates SCANDEF data in Design Compiler. Creates an ASCII SCANDEF file or embeds the SCANDEF data in a .ddc file.
2. Loads in the SCANDEF data in IC Compiler.

## Performing Scan Synthesis and Generating a SCANDEF File

Scan synthesis is performed first in Design Compiler. You then use the `write_scan_def` command to generate the SCANDEF data. This can be transferred to IC Compiler in either an ASCII SCANDEF file or a .ddc file with embedded SCANDEF data.

The following example shows a typical command sequence for scan insertion and for generating SCANDEF data in Design Compiler. Both the ASCII SCANDEF file and a .ddc file with embedded SCANDEF data is generated, but you only need to load the .ddc file in IC Compiler, because it encapsulates both design and SCANDEF data.

```
insert_dft
dft_drc
change_names -hierarchy -rules verilog
write_scan_def -output ./myscan.def
write -format -out ./design_with_scandef.ddc
```

The output SCANDEF file is an ASCII file that specifies a list of stub chains that is reordered by IC Compiler without requiring additional test design rule checking. Each stub chain defines a scan chain segment whose endpoints are an I/O port or pins of a lockup latch, or a multiplexer.

The following example shows a section of a SCANDEF file.

```
DESIGN my_design
SCANCHAINS 2;
-1
+ START PIN test_si1
+ FLOATING A ( IN SI ) ( OUT Q )
  B ( IN SI ) ( OUT Q )
  C ( IN SI ) ( OUT Q )
  D ( IN SI ) ( OUT Q )
+ PARTITION CLK_45_45
+ STOP PIN test_so1
```

The SCANDEF data embedded in the .ddc file can be loaded into IC Compiler.

## Hierarchical Flow

If you are working with a hierarchical design, there are two possible flows you can use.

In the first flow, you match the DFT-inserted logic hierarchy in Design Compiler with the physical hierarchy in IC Compiler. This means that in DFT Compiler, after reading the block-level test models, you must generate SCANDEF data for each block, as well as for the top level. Then, in IC Compiler, you later need to perform DFT optimization at the block level, and create a hierarchical model, such as a block abstraction model or an interface logic model (ILM). At the top level, you need to read the top-level SCANDEF and block-level hierarchical models.

In the second flow, you use the full-chip SCANDEF file and the design planning capability of IC Compiler. IC Compiler can optimize scan chain connections based on the plan groups and can update the SCANDEF file for the top-level and block-level modules based on the physical hierarchy. Details of this flow are documented in the *IC Compiler Design Planning User Guide*.

Ensure that you propagate the placement, keepout, and delay data to the top-level blocks before performing the `place_opt` and `clock_opt` DFT optimizations. For details about the hierarchical flow, see [Chapter 12, “Using Hierarchical Models”](#) and the “SCANDEF-Based Reordering Flow” section of the “Exporting to Other Tools” chapter of the *DFT Compiler Scan User Guide*.

---

## Loading the SCANDEF File

You should load SCANDEF data from either the ASCII SCANDEF file or the .ddc file with embedded SCANDEF data, before performing physical DFT.

The ASCII SCANDEF file can be loaded using the `read_def` command. To generate detailed information about errors and warnings that occur when reading the SCANDEF file, use the `-verbose` option.

```
read_def ./myscan.def
```

The SCANDEF data from the .ddc file can be loaded by using the `read_file -format ddc`, `read_ddc`, or `import_designs` command, as shown in the following example.

```
read_ddc ./design_with_scandef.ddc
check_scan_chain
report_scan_chain
place_opt -optimize_dft
```

Loading SCANDEF data from the .ddc file ensures that the netlist and the SCANDEF data are consistent. It also simplifies file management.

After reading in the SCANDEF file, you are ready to run consistency checking. For details about this process, see [“Scan Chain Consistency Checking” on page 4-5](#).

---

## Scan Chain Consistency Checking

IC Compiler maintains the SCANDEF data that describes scan chain characteristics and constraints, as well as the scan-stitched netlist. The netlist and SCANDEF data must be consistent with each other. To validate their consistency, you can use the `check_scan_chain` command. By default, a summary of the consistency of all the chains is displayed. It includes the number of scan cells (sequential depth) in each chain. Upon failure, the `-chain` option can be used to debug the inconsistency.

Consistency checking is done on elements between the START and STOP points of the chain stubs. The check starts at the STOP point and proceeds backward. Each scan chain stub is given a status after the checks are complete. The `check_scan_chain` and `report_scan_chain` commands report the following status:

- NOT YET VALIDATED: `check_scan_chain` has not been run
- FAILED (F): SCANDEF and netlist are inconsistent for this chain
- VALIDATED (V): SCANDEF and netlist are consistent for this chain

Only VALIDATED scan chain stubs are optimized. If there are failures, the SCANDEF or the netlist must be fixed to have them optimized.

The following items are not checked during `check_scan_chain`:

- MAXBITS and scan chain lengths
- PARTITION labels

Further validation can be done using the Formality equivalency checker to ensure the pre-layout netlist is equivalent to the post-layout netlist, with test signals de-asserted or not compared.

---

## Removing SCANDEF Data

You can use the `remove_scan_def` command to remove all SCANDEF data that was previously loaded from a .ddc file or an ASCII SCANDEF file. Note, however, that physical DFT optimizations cannot be done without SCANDEF data.

If either the .ddc file with embedded SCANDEF or the ASCII SCANDEF file contains a chain with the same name as an existing scan chain loaded previously, the existing chain definition is preserved. If you want to overwrite the existing chain definitions, you must first remove the SCANDEF data.

---

## Optimizing Scan Chains

After performing consistency checking, there are two, non-exclusive physical DFT methods you can use to optimize scan chains with the validated status:

- [Placement-Aware Scan Chain Reordering](#) — The scan chains are repartitioned and reordered, based on scan cell locations.
- [Clock-Aware Scan Reordering](#) — The scan chains are reordered to minimize the number of clock buffer crossings in the scan chain.

## Placement-Aware Scan Chain Reordering

To repartition and reorder the scan chains based on scan cell locations, specify the `-optimize_dft` option with the `place_opt` or `place_opt_feasibility` command. Repartitioning involves swapping scan chain components across scan chains so that the scan chains contain components that are near each other. Using the placement information to optimize the scan chains provides the following benefits:

- Reduces scan chain wire length
- Minimizes congestion and improves routability

[Figure 4-3](#) shows the wiring diagram for a design containing scan chains that were synthesized by Design Compiler. Because these scan chains are not optimally ordered with respect to actual placement and clock trees, they can cause congestion and increased net delays.

*Figure 4-3 Scan Chains Before Physically Aware Optimizations*



IC Compiler gets the scan chain information from the SCANDEF data and improves the quality of results by ignoring nets connected to the scan-in pin of scan cells during initial placement and by performing physically aware scan chain optimizations during the `place_opt` and `place_opt_feasibility` commands. To consider the scan chain information during placement, specify the `-consider_scan` option with the `place_opt` or `place_opt_feasibility` command.

To repartition and reorder the scan chains using placement information, specify the `-optimize_dft` option with the `place_opt` or `place_opt_feasibility` command. You can also choose Placement > Core Placement and Optimization and select the “Reorder scan during placement” check box in the Core Placement and Optimization dialog box in the GUI. Alternatively, you can use the `optimize_dft` standalone command to perform scan chain optimization.

After repartitioning, the scan chains should consist of scan cells that are physically near each other, as shown in [Figure 4-4](#). This represents a design with many scan chains.

*Figure 4-4 Repartitioned Scan Chains*



For designs with a small number of scan chains, horizontal or vertical partitioning is done as shown in [Figure 4-5](#). If partitioning the scan chains horizontally significantly increases congestion, use the `set_optimize_dft_options -single_dir_option vertical` command to select vertical partitioning, and rerun the `place_opt` command. You can force a particular repartitioning method by using the `set_optimize_dft_options -repartitioning_method` command. You can also view the current setting by using the `report_optimize_dft_options` command. The output during DFT optimizations indicate if repartitioning was done, and, if so, what kind.

Figure 4-5 Horizontally Repartitioned Scan Chains



Following the optimizations, approximate wire lengths of the scan path wires that can be reordered are displayed. (Scan path nets in ORDERED lists cannot be reordered and therefore are not counted.) These lengths are in Milkyway database units and meant only for comparing wire lengths before and after scan chain optimizations, as shown in the following example.

```
Wire Length Before Ordering 1377917  
Wire Length After Ordering 604876
```

---

## Clock-Aware Scan Reordering

You can use the `clock_opt` or `clock_opt_feasibility` command to reorder the scan chains to minimize the number of clock buffer crossings in the scan chains. Minimizing the number of buffer crossings can reduce hold time violations in the scan chains, but it can also increase the wire lengths within the scan chains.

To reorder the scan chains using clock information, specify the `-optimize_dft` option with the `clock_opt` or `clock_opt_feasibility` command. You can also use the `optimize_dft -clock_buffer` standalone command. Alternatively, you can choose Clock > Core CTS and Optimization and then select the “Clock-aware scan reordering” check box in the Core CTS and Optimization dialog box in the GUI.

By default, the `clock_opt` and `clock_opt_feasibility` commands consider scan data nets, also known as scan nets. To ignore scan chain connections during the congestion optimization stage of these commands, specify the `-ignore_scan` option. After running the `clock_opt` command with the `-ignore_scan` option, you should run the standalone `optimize_dft` command to perform scan-chain optimization.

---

## Continuing the Optimization Flow Without SCANDEF Data

Placement and clock tree synthesis exit with an error if your design contains scan chains without corresponding SCANDEF data. You can force the placement or clock tree synthesis to ignore the error and continue by specifying the `-continue_on_missing_scandef` option. Using this option might impact the QoR because scan nets affect the placement. [Table 4-1](#) lists each command that invokes the placer and its default behavior.

*Table 4-1 Default Behavior and Options for Commands Invoking the Placer*

| Command                            | Default behavior with SCANDEF                   | Option (GUI option)                                                                                                                                                                                                                                                |
|------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>create_placement</code>      | Ignores scan nets                               | <ul style="list-style-type: none"> <li><code>-consider_scan</code></li> <li>(“Consider scan connections during placement” check box)</li> <li><code>-continue_on_missing_scandef</code></li> <li>(“Continue with missing scan definitions” check box)</li> </ul>   |
| <code>place_opt</code>             | Ignores scan nets and disables DFT optimization | <ul style="list-style-type: none"> <li><code>-consider_scan</code></li> <li>(“Consider scan connections during placement” check box)</li> <li><code>-continue_on_missing_scandef</code></li> <li>(“Continue with missing scan definitions” check box)</li> </ul>   |
| <code>place_opt_feasibility</code> | Ignores scan nets and disables DFT optimization | <ul style="list-style-type: none"> <li><code>-consider_scan</code></li> <li><code>-continue_on_missing_scandef</code></li> </ul>                                                                                                                                   |
| <code>refine_placement</code>      | Considers scan nets                             | <ul style="list-style-type: none"> <li><code>-ignore_scan</code></li> <li>(“Ignore scan-chain connections during placement” check box)</li> <li><code>-continue_on_missing_scandef</code></li> <li>(“Continue with missing scan definitions” check box)</li> </ul> |

*Table 4-1 Default Behavior and Options for Commands Invoking the Placer (Continued)*

| <b>Command</b>                    | <b>Default behavior<br/>with SCANDEF</b>          | <b>Option (GUI option)</b>                                                                                                        |
|-----------------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| psynopt -congestion               | Considers scan nets                               | -ignore_scan<br>-continue_on_missing_scandef                                                                                      |
| clock_opt                         | Considers scan nets and disables DFT optimization | -ignore_scan<br>("Ignore scan" check box)<br>-continue_on_missing_scandef<br>("Continue with missing scan definitions" check box) |
| clock_opt_feasibility -congestion | Considers scan nets and disables DFT optimization | -ignore_scan<br>-continue_on_missing_scandef                                                                                      |

---

## DFT Optimization Flow

The following example shows a typical physical DFT optimization flow:

```
# following read_def or read_ddc

check_scan_chain
place_opt -optimize_dft
check_scan_chain

clock_opt -optimize_dft

# check_scan_chain must be run before report_scan_chain

check_scan_chain
report_scan_chain

route_opt
save_mw_cel
```

---

## Viewing Scan Chains

You can view scan chains either by generating a scan chain report or by viewing the scan chains in the GUI.

To generate a scan chain report, use the `report_scan_chain` command. The scan chain report lists the current scan chain connections. The `report_scan_chain` command displays the chain stub connectivity as it exists in the netlist after a chain has been validated following `check_scan_chain`. All cells in the scan chain are reported, not just scan cells. Note that a SCANDEF file does not necessarily follow the order of connectivity defined in the netlist. Components inside a floating list are considered unordered, and ordered lists are also unordered among the other lists.

To view the scan chains in the GUI,

1. Choose Placement > Color By Scan Chain.

The Visual Mode panel opens.

2. Load the scan chain information by clicking Reload in the Visual Mode panel.

The number it displays next to each scan chain is the total number of cells in each scan chain plus two additional cells for the start and stop points.

3. Select the scan chains that should be highlighted in the layout window.

The layout window displays the scan chains. If you hover the pointer over a scan chain component, a tooltip box pops up and displays the object's properties, including the scan chain to which it belongs.

# 5

## Power Optimization

---

This chapter describes the IC Compiler power optimization capabilities.

Power optimization is an additional step performed by IC Compiler to reduce power consumption during various stages in the flow, such as placement, clock tree synthesis, routing. The following sections describe in detail the types of power optimizations that are supported, the setup that is required, and how you can perform power optimization at each stage in the IC Compiler flow.

- [Types of Power Optimization](#)
- [Annotating Switching Activity](#)
- [Reducing Leakage-Power Using Multiple Threshold-Voltage Cells](#)
- [Specifying the Multiple Threshold-Voltage Constraint](#)
- [Specifying the Scenarios for Leakage-Power Optimization](#)
- [Performing Leakage-Power Optimization](#)
- [Performing Final Stage Leakage-Power Recovery](#)
- [Leakage-Power Optimization Flow Example](#)

---

## Types of Power Optimization

There are two types of power consumption in a design: dynamic and static. IC Compiler can optimize both dynamic and static power.

- Dynamic power

This is the energy consumed because of the voltage or logic transitions in the design objects, such as cells, pins, and nets. The dynamic power consumption is directly proportional to the number and frequency of transitions in the design.

To reduce dynamic power, IC Compiler supports power-aware clock tree synthesis. For more details see [“Power Optimization During Clock Tree Synthesis” on page 5-8](#).

- Static power or leakage-power

This is the energy dissipated even when there are no transitions in the circuit. This is also known as leakage power and depends on the device characteristics. The main contributor to static power is the sub-threshold voltage leakage in the device. At lower technology nodes, leakage power consumption contributes significantly to the total power consumption of the circuit.

When you enable power optimization, IC Compiler, by default, performs leakage-power optimization.

IC Compiler supports power reduction at each step of the optimization flow. For more details, see [“Performing Leakage-Power Optimization” on page 5-7](#). The tool also supports cells with different threshold voltages on different paths. Based on the area, timing, and power constraints specified, the tool chooses the appropriate cells from the library that reduce the leakage without violating the other constraints. For more details, see [“Adaptive Leakage-Power Optimization” on page 5-6](#).

---

## Annotating Switching Activity

You obtain better power savings if you annotate switching activity on the design before you perform power optimization. You can annotate the switching activity in the following ways:

- Reading the switching activity file

You use the `read_saif` command to read the switching activity file. The `read_saif` command has the following syntax

```
read_saif -input saif_file -instance_name path
```

- Specifying the switching activity

You can specify the switching activity by using the `set_switching_activity` command.

If you do not specify the switching activity, IC Compiler applies the default toggle rate to the primary inputs and black box outputs and then propagates it throughout the design.

---

## Reducing Leakage-Power Using Multiple Threshold-Voltage Cells

Leakage-power consumption is a function of the threshold voltage and is related to other important characteristics such as the drive strength, delay, and area. However, the device characteristics such as the drive strength, delay, area, and leakage power are interrelated. Leakage dissipation is low when the threshold voltage is high and vice versa. Moreover, switching delay is increased when threshold voltage is high. So, using lower-threshold cells to reduce the leakage can violate the timing constraints of the design. If the technology library supports cells with multiple threshold-voltages, using cells with a lower threshold-voltage for timing-critical paths and cells with a higher threshold voltage for other paths can reduce the leakage power without violating the delay.

[Figure 5-1](#) shows the relationships between the various characteristics of a cell for a specific threshold voltage. For more information about how IC Compiler chooses cells of a specific threshold-voltage to obtain maximum power reduction during various stages of optimization, see “[Adaptive Leakage-Power Optimization](#)” on page 5-6.

One of the techniques to reduce the leakage power is to use lower-threshold voltage cells in the timing-critical path and higher-threshold voltage cells in the other paths. However, this requires that your target library supports multiple threshold-voltage cells. Alternatively, you can set attributes to associate the cells in your library with a specific threshold voltage.

*Figure 5-1 Tradeoffs of Various Characteristics of a Cell*

## Multiple Threshold-Voltage Libraries

Multiple threshold-voltage libraries support two or more different threshold-voltage groups for each logic gate. The threshold voltage determines the delay and leakage characteristics of the logic gate or cell. Cells with a lower threshold-voltage value can switch quickly between logic values but have a higher leakage current. Cells with a higher threshold-voltage value have a lower leakage current, but have longer switching delay.

Liberty library syntax supports cells of different threshold-voltages in the same library using the `default_threshold_voltage_group` attribute. This attribute is defined at the library level and specifies the name of the category to which a cell belongs, based on the voltage characteristics of the cell. This attribute has the following syntax:

```
default_threshold_voltage_group : "group_name";
```

The following example shows the usage of the `default_threshold_voltage_group` attribute.

```
default_threshold_voltage_group : "high_vt_cell";
```

Liberty library syntax also supports an optional cell-level `threshold_voltage_group` attribute that you can use to associate a cell with one or more threshold-voltage categories, as shown in the following example:

```
cell (AND1_H) {
    ...
    threshold_voltage_group "high_vt_cell";
    ...
}
cell (AND1_L) {
    ...
    threshold_voltage_group "low_vt_cell";
    ...
}
```

## Defining Multiple Threshold-Voltage Cells Using Attributes

If your target library does not support multiple threshold-voltage cells and the associated attributes, you can use the `set_attribute` command to define multiple threshold-voltage cells.

The following example shows how you set the library-level

`default_threshold_voltage_group` attribute on the `high_vt_library` and `low_vt_library` library files, which contain cells of the high and low threshold-voltage groups respectively in separate library files.

```
set HVT_lib "high_vt_library"
set LVT_lib "low_vt_library"
set_attribute [get_libs $HVT_lib] default_threshold_voltage_group HVT
set_attribute [get_libs $LVT_lib] default_threshold_voltage_group LVT
```

If you have multiple threshold-voltage cells in the same library file, you can set the `default_threshold_voltage_group` and `threshold_voltage_group` attributes as shown in the following example:

```
set all_vt_lib "multiple_vt_lib"
set_attribute [get_libs ${all_vt_lib}] default_threshold_voltage_group HVT
set_attribute [get_lib_cells ${all_vt_lib}/FAST*] \
    threshold_voltage_group LVT
set_attribute [get_lib_cells ${all_vt_lib}/MEM*] \
    threshold_voltage_group MEM
```

---

## Adaptive Leakage-Power Optimization

During leakage-power optimization using multiple threshold-voltage cells, improving leakage power by using higher threshold-voltage cells can violate timing and area. A good combination of different threshold-voltage cells can result in optimum leakage, timing, and area.

The adaptive leakage-power optimization feature in IC Compiler uses high threshold-voltage cells during the initial stages of optimization and gradually increases the use of lower threshold-voltage cells during the later stages. This feature chooses the appropriate threshold-voltage cells that simultaneously optimize for power, timing, area, and congestion.

The adaptive leakage-power optimization feature is enabled by default when you use the `-power` option with the `place_opt`, `clock_opt`, and `route_opt` commands. For more details about how to perform leakage-power optimization during various stages of the IC Compiler flow, see “[Performing Leakage-Power Optimization](#)” on page 5-7.

---

## Specifying the Multiple Threshold-Voltage Constraint

When you have multiple threshold-voltage cells, supported either in the technology library or by setting appropriate attributes on the library cells, IC Compiler chooses cells belonging to the appropriate threshold-voltage groups to minimize the leakage power, without violating the timing and design rule constraints. IC Compiler supports the `set_multi_vth_constraint` command to set the multiple threshold-voltage constraint. This command also allows you to specify whether this constraint should have higher or lower priority than the timing constraint.

Use the `-lvth_percentage` option to specify the percentage value. The value can be a floating-point number between 0 and 100. This number represents the maximum percentage of the low threshold-voltage cells in the synthesized design.

The `-type` option specifies whether the constraint is hard or soft. When you specify `-type hard`, the tool tries to meet this constraint even if this results in timing degradation. If you specify `-type soft`, the tool tries to meet this constraint only if that does not degrade the timing QoR.

While calculating the percentage of low threshold-voltage cells in the design, the tool does not consider the black box cells. To let the tool consider the black box cells in the percentage calculation, use the `-include_blackboxes` option.

When you specify the multiple threshold-voltage constraint, the power optimizations during the core commands, `place_opt -power`, `clock_opt -power`, and `route_opt -power`, optimize for leakage power to meet the specified threshold voltage constraint. When you do not specify this constraint, these commands optimize for leakage power based on the leakage value of the library cells.

In the following example, the maximum percentage of low threshold-voltage cells in the design is set to 15 percent. While trying to meet this constraint, the timing constraint is not compromised.

```
icc_shell> set_multi_vth_constraint -lvth_groups {lvt svt} \
    -lvth_percentage 15 -include_blackboxes
```

To see the percentage of cells for each threshold-voltage group in the design, use the `report_threshold_voltage_group` command.

---

## Specifying the Scenarios for Leakage-Power Optimization

Typically, in a multicorner-multimode design, leakage-power optimization and timing optimization are done on different corners. Therefore, the worst case leakage corner can be different from the worst case timing corner. To specify the scenarios for leakage-power optimization, use the `set_scenario_options` command.

When you enable leakage-power optimization for a scenario, the scenario is referred to as a leakage scenario. To enable leakage-power optimization, set the `-leakage_power` option to true. The default for this option is false.

When you specify `-leakage_power false` for all active scenarios, IC Compiler does not enable leakage-power optimization and issues the PWR-809 warning message.

Warning: No power optimization is performed because the leakage power optimization is not enabled for any active scenarios. (PWR-809)

Use the `report_scenario_options` command to report the scenario options set on the various scenarios of the design.

---

## Performing Leakage-Power Optimization

To perform leakage-power optimization, use the `-power` option with the `place_opt`, `psynopt`, `clock_opt`, and `route_opt` commands. For multicorner-multimode designs, you must first specify the leakage scenarios, as described in the previous section, “[Specifying the Scenarios for Leakage-Power Optimization](#).”

The following sections describe how to perform leakage-power optimization at various stages of the IC Compiler flow.

---

## Power Optimization During Placement

To perform power optimization during the `place_opt` command,

1. For a multicorner-multimode design, use the `set_scenario_options` command to select the leakage scenarios.

For more information about selecting the leakage scenarios, see “[Enabling and Disabling Scenarios for Specific Optimizations](#)” on page 3-33.

2. Run the `place_opt` command with the `-power` option.

When you use the `-power` option, the `place_opt` command performs power-aware placement and leakage-power optimization. The `place_opt` command uses the adaptive leakage-power optimization feature to optimize for leakage power. For more information about adaptive leakage-power optimization, see “[Adaptive Leakage-Power Optimization](#)” on page 5-6.

Alternatively, you can choose Placement > Core Placement and Optimization in the GUI, and then select Power Optimization.

To perform leakage-power optimization during incremental placement, use the `-power` option with the `psynopt` command. To perform only leakage-power optimization during incremental placement, use the `-only_power` option.

```
icc_shell> psynopt -only_power
```

---

## Power Optimization During Clock Tree Synthesis

To perform power optimization during the `clock_opt` command,

1. Use the `set_scenario_options` command to select the clock tree synthesis scenarios.

For more information about selecting the clock tree synthesis scenarios, see “[Enabling and Disabling Scenarios for Specific Optimizations](#)” on page 3-33.

2. For a multicorner-multimode design, use the `set_scenario_options` command to select the leakage scenarios.

For more information about selecting the leakage scenarios, see “[Enabling and Disabling Scenarios for Specific Optimizations](#)” on page 3-33.

3. (Optional) Enable power-aware placement by setting the `-low_power_placement` option of the `set_optimize_pre_cts_power_options` command to `true`.

4. (Optional) Enable clock-gate restructuring during power optimization by setting the `-merge_clock_gates` of the `set_optimize_pre_cts_power_options` command to true.
5. Run the `clock_opt` command with the `-power` option.

The `clock_opt` command uses the adaptive leakage-power optimization feature to optimize for leakage power. For more information about adaptive leakage-power optimization, see “[Adaptive Leakage-Power Optimization](#)” on page 5-6. It also performs power-aware placement and clock-gate restructuring, if you have enabled these features.

Alternatively, you can choose Clock > Core CTS and Optimization in the GUI, and then select “Power optimization.”

To perform standalone clock tree power optimization, run the `optimize_pre_cts_power` command or choose Clock > Optimize Pre-CTS Power in the GUI. Note that this command does not perform leakage-power optimization. For more information about clock tree power optimization, see “[Optimizing for Power](#)” on page 7-69.

---

## Power Optimization During Routing

To perform power optimization during routing,

1. For a multicorner-multimode design, use the `set_scenario_options` command to select the leakage scenarios.  
For more information about selecting the leakage scenarios, see “[Enabling and Disabling Scenarios for Specific Optimizations](#)” on page 3-33.
2. (Optional) Enable power-aware postroute optimization by setting the `-power_aware_optimization` option of the `set_route_opt_strategy` command to true.
3. Run the `route_opt` command with the `-power` option.

The `route_opt` command uses the adaptive leakage-power optimization feature to optimize for leakage power. For more information about adaptive leakage-power optimization, see “[Adaptive Leakage-Power Optimization](#)” on page 5-6. It also performs power-aware postroute optimization, if you have enabled this feature.

Alternatively, you can choose Route > Core Routing and Optimization in the GUI, and then select Perform Power Optimization.

To perform only leakage-power optimization during incremental routing, use the `-only_power_recovery` option with the `route_opt` command.

For more information about the `route_opt` command, see “[Running the route\\_opt Command](#)” on page 8-77.

---

## Performing Final Stage Leakage-Power Recovery

Final stage leakage-power recovery optimizes the leakage power based on the `cell_footprint` attribute of the library cells. Ensuring that your design is close to timing closure is a prerequisite for final stage leakage-power recovery.

The final stage leakage-power recovery step considers library cells to have the same footprint if the cells have

- The same operating conditions (P, V, and T)
- Logical equivalence
- The same physical boundary, width, and height, as defined in the FRAM view
- The same `cell_footprint` attribute

IC Compiler issues an FOPT-28 information message, to indicate that the tool is optimizing for leakage-power with multiple threshold-voltage library cells.

Information: Optimizing leakage power with 3 voltage thresholds  
(FOPT-028).

### Preparing the Libraries for Final Stage Leakage-Power Recovery

For the tool to complete final stage leakage-power recovery, the cell footprint attributes of the library cells must be consistent with the number of threshold voltages reported by the FOPT-028 message. You must also ensure that

- For all the threshold voltage cells in the design, you have the target libraries defined for each process, voltage, and temperature condition
- The `cell_footprint` attribute is present on the library cells

If the `cell_footprint` attribute is not present, create the attribute accordingly. The following is an example Tcl script:

```
foreach _lib [get_libs *] {  
    foreach_in_collection lib_cel [get_lib_cells $_lib/*] {  
        set footprint_name \  
            [string replace [get_attribute $lib_cel name] 0 3]  
        set_attribute -quiet \  
            -class lib_cell $lib_cel cell_footprint $footprint_name  
    }  
}
```

- The `default_threshold_voltage_group` attribute is defined with a unique value on each library

For example,

```
set_attribute lvt_lib default_threshold_voltage_group lvt
set_attribute svt_lib default_threshold_voltage_group svt
```

- You pay attention to the FOPT-28 and FOPT-29 messages in the log file

Information: Optimizing leakage power with 3 voltage thresholds (FOPT-028).

Warning: Libcells cell\_name1 and cell\_name2 have same footprint but different pin geometry - eco route may be required after Leakage optimization (FOPT-029).

These information and warning messages list the library cells that have issues with cell footprint attributes.

- You validate the cell footprint

To validate the cell footprint, run the `verify_zrt_route` command before and after the `focal_opt -power` command and verify that the number of violations reported in both cases is the same, as shown in [Figure 5-2](#). If the number of violations reported after running the `focal_opt -power` command is more than the number of violations reported before, it implies that the physical libraries have issues such as dissimilar pin shape that result in additional DRC violations.

*Figure 5-2 Cell Footprint Validation*



## Performing Final Stage Leakage-Power Recovery

To perform final stage leakage-power recovery on a postroute design,

1. For a multicorner-multimode design, use the `set_scenario_options` command to select the leakage scenario. You can select only a single leakage scenario.

To ensure that you set only one leakage scenario, enter the following commands:

```
icc_shell> set leakage_scenario S1
icc_shell> set_scenario_options -leakage_power false \
           -scenarios [all_active_scenarios]
icc_shell> set_scenario_options -leakage_power true \
           -scenario $leakage_scenario
```

For more information about selecting the leakage scenarios, see “[Enabling and Disabling Scenarios for Specific Optimizations](#)” on page 3-33.

2. If the postroute design has setup, hold, or logical DRC violations, run the `focal_opt` command to perform focal optimization to fix these violations.

For more information about the `focal_opt` command, see “[Performing Focal Optimization](#)” on page 8-83.

3. Run the `focal_opt -power` command.

This command performs the postroute focal optimization for leakage-power recovery. This step performs swapping of cell footprint to improve leakage power at final stage, while maintaining timing QoR. Note that this command does not perform placement legalization or ECO routing after the leakage-power recovery.

When you use the `-power` option, you cannot use any other options with the `focal_opt` command.

The following example script shows how to perform final stage leakage-power recovery for a multicorner-multimode design after routing optimization:

```
# Set one scenario as the leakage corner
set_scenario_options -leakage_power false \
                     -scenarios [all_active_scenarios]
set_scenario_options -leakage_power true -scenarios S1

# Fix setup, hold, and logical DRC violations
focal_opt -setup_endpoints all
focal_opt -hold_endpoints all
focal_opt -drc_nets all

# Perform final stage leakage-power recovery
focal_opt -power
```

If you do not have exactly one leakage scenario defined during final stage leakage-power recovery, IC Compiler issues the PSYN-706 error message.

```
Error: There are multiple scenarios or no scenario with  
set_scenario_options -leakage_power true. (PSYN-706)
```

---

## Leakage-Power Optimization Flow Example

The following script shows an example of a leakage-power optimization flow:

```
# This is required only for multicorner-multimode designs  
set_scenario_options -scenarios S1 -leakage_power true  
place_opt -power  
psynopt -power  
clock_opt -power  
route_opt -power  
# Fix setup, hold, and logical DRC violations  
focal_opt -setup_endpoints all  
focal_opt -hold_endpoints all  
focal_opt -drc_nets all  
  
focal_opt -power
```



# 6

## Placement

---

This chapter describes the IC Compiler placement and optimization capabilities.

This chapter contains the following sections:

- [Defining Placement Blockages](#)
- [Setting Placement Options](#)
- [Inserting Port Protection Diodes](#)
- [Preparing for High-Fanout Net Synthesis](#)
- [Analyzing Placement and Optimization Feasibility](#)
- [Performing Clock Tree Synthesis During Placement](#)
- [Performing Placement and Optimization](#)
- [Using Physical Optimization](#)
- [Performing Layer Optimization](#)
- [Performing Preroute RC Estimation](#)
- [Analyzing Placement](#)
- [Refining Placement](#)

---

## Defining Placement Blockages

Placement blockages are areas that leaf cells must avoid during placement and legalization, including overlapping any part of the placement blockage. Placement blockages can be hard or soft.

- A hard blockage prevents cells from being placed in the blockage area.
- A soft blockage restricts the coarse placer from putting cells in the blockage area, but optimization and legalization can place cells in a soft blockage area.

If you define both hard and soft placement blockages in your design, the hard placement blockages take priority over the soft placement blockages in places where they overlap.

You can define a placement blockage by either specifying a region around fixed macros (keepout margins) or by specifying a rectangular blockage area (area-based placement blockages).

---

## Defining Keepout Margins

A keepout margin is a region (the unshaded portion in [Figure 6-1](#)) around the boundary of fixed macros in your design in which no other cells are placed.

*Figure 6-1 Placement Keepout Margin*

**Keepout margin**



Keeping the placement of cells out of such regions avoids congestion and net detouring and produces better QoR.

Keepout margins can be defined as hard or soft. In addition, you can define global keepout margins, which apply to all fixed macros in the design, or cell-specific keepout margins.

The width of the keepout margin on each side of a fixed macro can be the same or different, depending on how you define the keepout margin.

## Defining Global Keepout Margins

To define a hard global keepout margin, specify the width, in microns, of the keepout margin by setting the `physopt_hard_keepout_distance` variable. The specified width is used for all sides of each fixed macro in your design.

For example, to specify a hard keepout margin of 10 microns around each fixed macro in your design, enter

```
icc_shell> set_app_var physopt_hard_keepout_distance 10
```

To define a soft global keepout margin, specify the width, in microns, of the keepout margin by setting the `placer_soft_keepout_channel_width` variable.

A soft global keepout margin does not apply to every fixed macro in your design or to every side of the fixed macro; it applies only in the following cases:

- The distance between the fixed macro boundary and the core area boundary is less than the soft keepout margin.
- The distance between two fixed macros is less than the soft keepout margin, forming a thin channel between the objects.

For example, to specify a soft keepout margin of 25 microns around each fixed macro in your design, enter

```
icc_shell> set_app_var placer_soft_keepout_channel_width 25
```

[Figure 6-2](#) shows an example of using both hard and soft global keepout margins in a design containing five RAM cells. The hard keepout margins are applied to all macros, whereas the soft keepout margins are applied only where the distance requirements are met.

*Figure 6-2 Global Keepout Distances*



## Defining Cell-Specific Keepout Margins

To define a keepout margin with different widths on each side or to define a keepout margin for specific cells, use the `set_keepout_margin` command (or choose Placement > Set Keepout Margin in the GUI). This is the full command syntax:

```
set_keepout_margin
  [-type hard | soft]
  [-outer {lx by rx ty}]
  [-tracks_per_macro_pin value]
  [-min_padding_per_macro value]
  [-max_padding_per_macro value]
  [-all_macros] [-macro_masters] [-macro_instances]
  [object_list]
  [-north]
```

For example,

```
icc_shell> set_keepout_margin -type hard -all_macros \
  -outer {10 10 10 10}
```

Use `-type hard` or `-type soft` to specify the type of keepout, either hard or soft. The default is hard. Use `-all_macros` to apply the keepout margins to all macros, `-macro_masters object_list` for all instances of specified macro masters, or `-macro_instances object_list` for specified instances of macros.

You can specify explicit keepout margins by using `-outer {lx by rx ty}`, where the four numbers are the left, bottom, right, and top margins. A value of 0 results in no keepout margin for that side. The `-north` option sets the margins with respect to the north orientation of the cell.

Instead of specifying the keepout margins explicitly, you can have them derived automatically by using `-tracks_per_macro_pin value`. In that case, the keepout margin is calculated from the track width, the number macro pins, and the specified track-to-pin ratio, which is typically set to a value near 0.5. A larger value results in larger keepout margins. The derived keepout margin is always hard; the `-type` setting is ignored. For derived margins, the `-all_macros`, `-macro_masters`, and `-macro_instances` options are not allowed. The derived margins are subject the minimum and maximum values specified by `-min_padding_per_macro` and `-max_padding_per_macro`. Here is an example:

```
icc_shell> set_keepout_margin -tracks_per_macro_pin .6 \
  -min_padding_per_macro .1 -max_padding_per_macro 0.2
```

For more information about setting keepout margins, see the man page for the `set_keepout_margin` command.

To report the cell-specific keepout margins in your design, use the `report_keepout_margin` command. It reports the keepout margin values set by the `set_keepout_margin` command, the values of any pin-count-based parameters defined by the `set_keepout_margin` command, and all derived keepout margins for the specified macro cells and standard cells.

To remove the cell-specific keepout margins from your design, use the `remove_keepout_margin` command.

---

## Defining Area-Based Placement Blockages

Hard placement blockages can be defined in the DEF as shown in [Example 6-1](#).

### *Example 6-1 Placement Blockages in DEF*

```
BLOCKAGES 2 ;
- PLACEMENT
  RECT ( 0 327600 ) ( 652740 327660 ) ;
- PLACEMENT
  RECT ( 0 327600 ) ( 652740 327660 ) ;
END BLOCKAGES
1
```

You can also create placement blockages in IC Compiler by using the `create_placement_blockage` command or by choosing Floorplan > Create Placement Blockage in the GUI. At a minimum, you must specify the coordinates of the bounding box for the placement blockage. By default, the `create_placement_blockage` command creates a hard placement blockage.

For example, to create a hard placement blockage in the area enclosed by a rectangle with corners at (10, 20) and (100, 200), use the following command:

```
icc_shell> create_placement_blockage -bbox {10 20 100 200}
```

You can optionally assign a name to a blockage by using the `-name` option. You can then reference that blockage by name when you use the `get_placement_blockages` or `remove_placement_blockage` command.

In addition to hard placement blockages, IC Compiler supports several other types of placement blockages; however, a single `create_placement_blockage` command can create just one type of placement blockage.

- Hard (the default)

A hard blockage prevents the placement of standard cells and hard macros within the specified area during optimization, coarse placement, and legalization.

- Soft

A soft blockage prevents the placement of standard cells and hard macros within the specified area during coarse placement, but allows optimization and legalization to place cells within the specified area. To create a soft blockage, use the `-type soft` option.

- Partial

A partial blockage limits the placement of cells in the specified area. To create a partial blockage, use the `-type partial` option. The `-blocked_percentage` option must be used to specify the percentage of the area that is blocked. To allow unlimited usage of the specified partial blockage area, specify the `-blocked_percentage 0` option. Partial blockages apply only to coarse placement. They have no effect on legalization or optimization.

Note:

When using the `-type partial` option, you must set the `placer_enable_redefined_blockage_behavior` variable to `true`.

For example, to define a partial blockage with a maximum allowed cell density of 60 percent (a blocked percentage of 40), enclosed by the rectangle with corners at (10,20) and (100,200), use the following commands:

```
icc_shell> set placer_enable_redefined_blockage_behavior true
icc_shell> create_placement_blockage -bbox {10 20 100 200} \
    -type partial -blocked_percentage 40
```

In addition to controlling the maximum cell density of partial blockage, you can also control the types of cells that are placed within the partial blockage area. Note that the following options are mutually exclusive, and need to be specified along with the `-type partial` option.

- **Buffer-only**

A buffer-only blockage is a special type of partial blockage that allows only buffers and inverters to be placed within the blockage. To create a buffer-only blockage, use the `-type partial`, `-blocked_percentage`, and `-buffer_only` options.

For example, to define a partial blockage that allows only the placement of buffers and inverters, with a cell density of 30 percent, use the following commands:

```
icc_shell> set placer_enable_redefined_blockage_behavior true  
icc_shell> create_placement_blockage -bbox {10 20 100 200} \  
      -type partial -blocked_percentage 70 -buffer_only
```

- **No-register**

A no-register blockage is a special type of partial blockage that prevents registers from being placed within the blockage. To create a no-register blockage, use the `-type partial`, `-blocked_percentage`, and `-no_register` options.

For example, to define a partial blockage that excludes registers, but allows a cell density of 50 percent for other cells, use the following commands:

```
icc_shell> set placer_enable_redefined_blockage_behavior true  
icc_shell> create_placement_blockage -bbox {10 20 100 200} \  
      -type partial -blocked_percentage 50 -no_register
```

- **No-relative-placement**

A no-relative-placement blockage is a special type of partial blockage that prevents relative placement groups from being placed within the blockage. To create a no-relative-placement blockage, use the `-type partial`, `-blocked_percentage`, and `-no_rp_group` options.

For example, to define a partial blockage that excludes relative placement groups, but allows a cell density of 100 percent for all other cells, use the following commands:

```
icc_shell> set placer_enable_redefined_blockage_behavior true  
icc_shell> create_placement_blockage -bbox {10 20 100 200} \  
      -type partial -blocked_percentage 0 -no_rp_group
```

- Category

A category blockage is a special type of partial blockage that controls the placement of a predefined category of cells within the partial blockage.

To create a category blockage,

1. Create the cell category by defining a user attribute for the category and applying it to the affected cell references or instances.

The syntax to define the user attribute is

```
define_user_attribute
    -type boolean -class lib_cell | cell attribute_name
```

The syntax to apply the user attribute is

```
set_attribute inst_or_ref_name attribute_name true | false
```

To prevent the cell from being placed in the category blockage, set the attribute to true. To allow the cell in the category blockage, set the attribute to false.

2. Set the `placer_enable_redefined_blockage_behavior` variable to `true`. Then create the category blockage by using the `create_placement_blockage` command with the `-type partial`, `-blocked_percentage`, and `-category` options. The argument to the `-category` option is the name of the user attribute.

```
set placer_enable_redefined_blockage_behavior true
create_placement_blockage -type partial \
    -blocked_percentage percent -category attribute_name
```

When defining and applying attributes, observe the following rules:

- A blockage can only be controlled by a single attribute.
- Multiple blockages can be controlled by the same attribute.
- A cell can have multiple attributes, which could impact its placement in multiple category blockages.
- The same attribute can be applied to a reference and an instance.
- If a cell instance and its reference have different attributes, the attribute on the cell instance takes precedence.

For example, to define a blockage that prevents a certain category of cells from being placed within it, use the following commands:

```
icc_shell> define_user_attribute -type boolean \
    -class lib_cell dr_cells
icc_shell> set_attribute [get_lib_cell mylib/dr*] dr_cells true
icc_shell> set placer_enable_redefined_blockage_behavior true
icc_shell> create_placement_blockage -bbox {4300 2400 4500 2700} \
    -type partial -blocked_percentage 45 -category dr_cell
```

For example, to define a blockage that only allows a certain category of cells to be being placed within it, use the following commands:

```
icc_shell> define_user_attribute -type boolean \
    -class lib_cell non_iso
icc_shell> set_attribute [get_lib_cell mylib/*] non_iso true
icc_shell> set_attribute [get_lib_cell mylib/iso/*] non_iso false
icc_shell> set placer_enable_redefined_blockage_behavior true
icc_shell> create_placement_blockage -bbox {4300 2400 4500 2700} \
    -type partial -blocked_percentage 30 -category non_iso
```

- Pin

A pin blockage prevents the global router from routing in the specified area, and the pin placer from assigning pins to the area. To create a pin blockage, use the `-no_pin` option. You can optionally specify which layers are blocked with the `-blocked_layers` option. If you do not specify the layers, all layers are blocked.

- Hard macro

A hard macro blockage prevents the placement of hard macros within the specified area, but not standard cells. To create a hard macro blockage, use the `-no_hard_macro` option.

To return a collection of placement blockages in the current design that match certain criteria, use the `get_placement_blockages` command.

To remove placement blockages from the design, use the `remove_placement_blockage` command.

## Creating Placement Blockages for Thin Channels

Thin channels often occur at top-level floorplans. Placing cells of the correct size in the thin channels can prevent large cell displacement caused by high local density after optimization. You can create placement blockages that fit in the thin channels to improve the quality of results at the top level by using the `derive_placement_blockages` command.

By default, the `derive_placement_blockages` command derives hard placement blockages to prevent the tool from placing standard cells in the thin channels. This command does not support soft and partial placement blockages. To specify the threshold value of the channel width, use the `-thin_channel_width` option. If you do not specify this option, the command uses the largest buffer width in the target libraries. To add the derived placement blockages to the design, use the `-apply` option. To generate a Tcl script for the derived placement blockages, use the `-output_script` option.

For example, the following command derives hard placement blockages and adds them to the design.

```
icc_shell> derive_placement_blockages -output_script test.tcl -apply
```

To change the type of blockages, you can use the following commands to generate a script and then change the setting of the `-type` option of the `create_placement_blockage` command in the script. Note that the names of the placement blockages have the `ICC_THIN_CHAN_PLACE_BLKG_` prefix.

```
icc_shell> open_mw_cel init_cel
icc_shell> derive_placement_blockages -output_script floorplan_blk.tcl
icc_shell> source floorplan_blk.tcl
```

The following script shows an example of an output file:

```
create_placement_blockage -name ICC_THIN_CHAN_PLACE_BLKG_#0 -type hard \
    -bbox { 425.565 815.215 883.790 823.215}
create_placement_blockage -name ICC_THIN_CHAN_PLACE_BLKG_#1 -type hard \
    -bbox { 425.565 1596.260 883.790 1604.375}
create_placement_blockage -name ICC_THIN_CHAN_PLACE_BLKG_#2 -type hard \
    -bbox { 883.790 815.215 891.790 910.215}
create_placement_blockage -name ICC_THIN_CHAN_PLACE_BLKG_#3 -type hard \
    -bbox { 905.425 1072.665 1079.585 1087.335}
create_placement_blockage -name ICC_THIN_CHAN_PLACE_BLKG_#4 -type hard \
    -bbox { 1082.935 1604.375 1089.515 2108.205}
create_placement_blockage -name ICC_THIN_CHAN_PLACE_BLKG_#5 -type hard \
    -bbox { 1270.930 425.565 1278.930 878.900}
```

For more information about the `derive_placement_blockages` command, see the man page.

## Preventing Cell Placement in the Default Voltage Area

In a UPF flow, a certain multivoltage design style implements abutted voltage areas at the top level, so no space is allowed for cell placement in the default voltage area. You can achieve this design style by setting the `mv_no_cells_at_default_va` variable to `true`, changing it from its default of `false`. Setting this variable prevents the tool from placing cells in the default voltage area, whether at the top level or not, to connect submodules. Instead, the tool inserts cells in the lower-level voltage areas.

For more information about the default voltage area, see “[Default Voltage Area](#)” on page 14-41.

---

## Setting Placement Options

There are many configuration settings that affect the behavior of placement in IC Compiler, including the following controls:

- [Setting the Congestion Options](#)
  - [Setting the Move Bounds](#)
  - [Defining Intercell and Boundary Spacing Rules](#)
  - [Defining the Buffer Strategy for Optimization](#)
  - [Setting the Preferred Buffers for Hold Fixing](#)
  - [Setting Up Multithreading](#)
  - [Enabling Tie Cell Insertion](#)
  - [Preserving dont\\_touch Nets During Optimization](#)
  - [Setting Placement and Optimization Attributes](#)
- 

### Setting the Congestion Options

IC Compiler attempts to minimize congestion during placement and optimization. Congestion occurs when the number of wires going through a region exceeds the capacity of that region. This condition is detected by global routing. IC Compiler places and moves cells in such a manner to avoid congestion and to fix congestion problems when they occur.

You can set certain options related to congestion avoidance with the `set_congestion_options` command:

```
set_congestion_options
  [-max_util value]
  [-layer name]
  [-availability value]
  [-coordinate {llx lly urx ury}]
```

The `-max_util` option specifies how densely cells can be packed in uncongested regions to relieve congestion in other regions. You should set this variable based on how much area is needed for placement. The default maximum utilization is 0.95.

The `-layer` and `-availability` options specify how much of the routing resource for the given layer is available to be used. For example, in a design whose M5 and M6 layers will be 70 percent occupied by future power and ground routing, you can set the availability of M5 and M6 to 0.30.

Congestion options can be design-wide or regional. Use the `-coordinate` option to specify two corners of the bounding box of the area to be affected by the command. Otherwise, the command affects the whole chip.

You can report and remove congestion option settings with the `report_congestion_options` and `remove_congestion_options` commands respectively. You can visualize congestion conditions by using the global route congestion visual mode as described in “[Congestion Maps](#)” on page 6-63.

To report congestion conditions, including DRC violations and routing density, use the `report_congestion` command. By default, the command reports the global route congestion conditions that are generated by Zroute. You can also report the congestion conditions based on the track assignment or detail routing in the design by setting the `-routing_stage` option to `track` or `detail` respectively. For more details, see “[Analyzing Congestion](#)” on page 8-90.

For placement that is not set up for congestion removal, you can control how densely cells can be packed by using the `placer_max_cell_density_threshold` variable. You can set this variable to a value between one and the overall average utilization of your design. Choosing a value near one allows cells to clump together more densely. A value of one allows no gaps between cells. You should choose a high value for designs with low utilization to improve timing and a low value for congested designs to avoid cell clumping. By default, this variable is set to -1 to disable this feature.

For example, if the utilization is 40 percent, you can choose a value between 0.4 and 1.

```
icc_shell> set placer_max_cell_density_threshold 0.6
```

---

## Setting the Move Bounds

Move bounds are placement constraints that control the placement of groups of leaf cells and hierarchical cells. Move bounds can be either soft, hard, or exclusive.

- Soft move bounds specify placement goals, with no guarantee that the cells will be placed inside the bounds.
- Hard move bounds force placement of the specified cells inside the bounds.
- Exclusive move bounds force the placement of the specified cells inside the bounds. All other cells must be placed outside the bounds.

Defining a move bound allows you to group cells to minimize wire length and place the cells at the most appropriate locations. For example, you might want to define a move bound for clock-gating cells or extremely timing-critical groups of cells that you want to guarantee will not be disrupted for placement by other logic. During placement, IC Compiler ensures that the cells you grouped remain together. However, defining move bounds restricts placement and defining too many can lower QoR. For best results, make the number of cells you place in placement bounds relatively small compared to the total number of cells in the design.

To create a move bound in IC Compiler, use the `create_bounds` command (or choose Floorplan > Create Bound in the GUI). This is the command syntax:

```
create_bounds
[-name bound_name]
[-coordinate {llx1 lly1 urx1 ury1 ...}]
[-dimension {width height}]
[-effort low | medium | high | ultra]
[-type soft | hard]
[-exclusive]
[-color range_0_to_63]
[-cycle_color]
object_list
```

For example,

```
icc_shell> create_bounds -name "b1" -coordinate {100 100 200 200} INST_1
```

You must specify a list of cells, ports, and pins to be included in the bound. If a hierarchical cell is included, all cells in the subdesign belong to the bound. You can also specify the characteristics of the bound, including the name, the coordinates of one or more rectangles for the bound, the dimensions, the effort level to bring the cells closer together, the type (soft, hard, or exclusive; soft is the default). You can also specify the color used to display the bound in the GUI.

To add or remove cells from a move bound, use the `update_bounds` command.

To report the move bounds in your design, use the `report_bounds` command.

To return a collection of move bounds in the current design that match certain criteria, use the `get_bounds` command.

To remove move bounds from your design, use the `remove_bounds` command.

---

## Defining Intercell and Boundary Spacing Rules

IC Compiler places standard cells by using a discrete grid, which is defined by the unit tile. By default, there are no spacing constraints between cells during placement. To enhance yield, you can define the valid spacing between standard cells in the same row.

IC Compiler implements intercell spacing rules by attaching labels, which are similar to attributes, to the left and right sides of library cells, assuming that the cell is in its north orientation, and specifying the invalid spacings between these labels.

To define the intercell spacing rules,

1. Add labels to the right and left sides of library cells that have minimum spacing constraints by using the `set_lib_cell_spacing_label` command.

Use the `-name` option to specify the label names. You can specify one or more labels. The labels are assigned to the right side of the cells specified with the `-right_lib_cells lib_cells` option and to the left side of the cells specified with the `-left_lib_cells lib_cells` option. You can assign the same label to both the right and left sides of a cell by including it in both the `-right_lib_cells` and `-left_lib_cells` options.

For example, to assign a label named X to the right side of the cellA library cell and the left side of the cellB and cellC library cells, enter the following command:

```
icc_shell> set_lib_cell_spacing_label -names {X} \
           -right_lib_cells {cellA} -left_lib_cells {cellB cellC}
```

To assign labels named Y and Z to the right side of the cellB library cell, enter the following command:

```
icc_shell> set_lib_cell_spacing_label -names {Y Z} \
           -right_lib_cells {cellB}
```

2. Define the spacing requirements between the labels by using the `set_spacing_label_rule` command.

Use the `-labels` option to specify which labels are being constrained. You must specify exactly two labels, which can be the same or different labels. Specify the range of invalid spacings, in terms of the unit tile, as the command argument.

For example, to specify that labels X and Y cannot abut (there must be at least one unit tile between them), enter the following command:

```
icc_shell> set_spacing_label_rule -labels {X Y} {0 0}
```

To specify that two X labels cannot have a spacing of two unit tiles, enter the following command:

```
icc_shell> set_spacing_label_rule -labels {X X} {2 2}
```

To specify that labels X and Z must have a spacing of less than two unit tiles or more than four unit tiles, enter the following command:

```
icc_shell> set_spacing_label_rule -labels {X Z} {2 4}
```

To define the boundary spacing rules,

1. IC Compiler assigns a built-in label named SNPS\_BOUNDARY to chip boundaries that include chip core boundary (two ends of a row), fixed hard macro boundary, and hard placement blockage boundary. You cannot use the `set_lib_cell_spacing_label` command to assign the built-in label to library cells.
2. Define the spacing requirements between the built-in label and other labels by using the `set_spacing_label_rule` command.

For example, to specify that the label X referenced cells should not be placed within zero to one unit tile from the chip boundaries, enter the following commands:

```
icc_shell> set_lib_cell_spacing_label -names {X} \
           -right_lib_cells {AND*} -left_lib_cells {AND*}
icc_shell> set_spacing_label_rule -labels {X SNPS_BOUNDARY} {0 1}
```

To report both the intercell and boundary spacing rules, use the `report_spacing_rules` command with the `-all` option. To report the intercell spacing rules for a specific collection of library cells, use the `report_spacing_rules` command with the `-of_library_cells` option.

To remove all spacing rules, use the `remove_all_spacing_rules` command.

Note:

If the power or ground net is defined as a complete blockage, the legalizer and the `check_legality` command ignore the spacing rule violations between library cells and the power or ground net. If the power or ground net is defined as a partial blockage, the legalizer and the `check_legality` command check for spacing rule violations between library cells and the power or ground net.

---

## Defining the Buffer Strategy for Optimization

During the optimization step, the `place_opt` command introduces buffers and inverters to fix timing and DRC violations. However, this buffering strategy is local to some critical paths. The buffers and inverters that are inserted become excess later because critical paths change during the course of optimization. You can reduce the excess buffer and inverter counts after `place_opt` by using the `set_buffer_opt_strategy` command, as shown in the following example:

```
icc_shell> set_buffer_opt_strategy -effort low
```

This buffering strategy does not degrade the quality of results (QoR).

---

## Setting the Preferred Buffers for Hold Fixing

You can specify a list of preferred buffers to fix hold violations during preroute optimization by using the `set_prefer` and `set_fix_hold_options` commands. For example, the following commands instruct the tool to use cells BUF1 and BUF2 as the preferred cells during hold fixing. Note that cells BUF1 and BUF2 can also be used to resolve setup and DRC violations.

```
icc_shell> set_prefer -min {BUF1 BUF2}
icc_shell> set_fix_hold_options -preferred_buffer
icc_shell> psynopt -congestion -area_recovery
```

If you use the `set_dont_use` command to set the `dont_use` attribute on cells BUF1 and BUF2 as shown in the following script, IC Compiler uses cells BUF1 and BUF2 to fix hold violations, but not setup and DRC violations.

---

## Setting Up Multithreading

By default, the `place_opt` command uses a single thread to perform placement and optimization. If the placement step takes up a large portion of the `place_opt` runtime, you can enable the multithreaded placer. When working with multicorner-multimode designs, you can reduce the elapsed time required to run the `place_opt` command by using multithreading for preroute timing analysis.

To enable multithreading, use the `set_host_options` command with the `-max_cores` option. You can limit the number of threads used for placement by setting the `placer_max_parallel_computations` variable. To limit the number of threads used for multicorner-multimode timing analysis, set the `timing_max_parallel_computations` variable. For more information about using the `set_host_options` command to configure multithreading, see “[Enabling Multicore Processing](#)” on page 2-43.

During placement performed by the `place_opt` command, if the `placer_enable_enhanced_router` variable is set to `true` for congestion-driven placement, Zroute runs on a single core regardless of the settings of the `set_host_options` command.

---

## Enabling Tie Cell Insertion

A tie cell is a special-purpose standard cell whose output is constant high or constant low and is used to hold the input of another cell at the given constant value. To prepare the `place_opt` or `psynopt` commands for automatic insertion and optimization of tie-offs required in the design, execute commands similar to the following:

```
set_auto_disable_drc_nets -constant false
set_app_var physopt_new_fix_constants true
set_attribute [...] max_fanout 12
set_attribute [...] max_capacitance 0.2 -type float
```

Optimization means using a single tie cell to hold as many inputs as possible at a given logic level, while meeting specified maximum fanout and maximum capacitance constraints. The `set_auto_disable_drc_nets` command enables DRC fixing on constant nets. Setting the `physopt_new_fix_constants` variable to `true` causes IC Compiler to observe the maximum capacitance constraint during tie-off optimization. The maximum capacitance constraint is determined by the `max_capacitance` attribute, which is set with the `set_max_capacitance` or `set_attribute` command. The `set_attribute` command is used to specify explicitly both the maximum fanout and maximum capacitance constraints for objects in the design.

By default, IC Compiler performs tie-off optimization one hierarchical level at a time. You can enable tie-off optimization down to the lowest hierarchy without port punching by setting the `tieoff_hierarchy_opt` variable to `true`, changing it from its default of `false`. When this variable is set to `true`, IC Compiler fixes DRC violations of constant nets crossing multiple hierarchies and removes the driving cells of these constant nets. To keep these driving cells, set the `tieoff_hierarchy_opt_keep_driver` variable to `true`, changing it from its default of `false`. IC Compiler does not insert tie cells to dangling hierarchical ports.

You can also insert tie cells manually with the `connect_tie_cells` command. The command inserts tie cells and connects them to specified cell ports, while meeting the maximum fanout and maximum wire length constraints specified in the command. For details, see the man page.

## Preserving `dont_touch` Nets During Optimization

By default, IC Compiler ignores the `dont_touch` attribute on a net that is connected to a cell without the `dont_touch` attribute and can split the net during optimization. To honor the `dont_touch` attribute on this type of net, you specify the following command:

```
icc_shell> set_dont_touch_network -no_propagate object_list
```

The object list a list of one or more clocks, ports, or pins in the design. The command prevents cells and nets in the transitive fanout of the specified object from being replaced or modified during optimization. The `-no_propagate` option prevents the don't touch network from being propagated through logic gates.

In the example circuit shown in [Figure 6-3](#), N1 is a net marked with the `dont_touch` attribute, but the net driver does not have the `dont_touch` attribute. By default, net N1 can be split during optimization. However, if you apply the `set_dont_touch_network` command to the pin driving net N1 and use the `-no_propagate` option, the tool marks the C1 cell with the `size_only` attribute and leaves net N1 untouched during optimization.

For more information, see the man page for the `set_dont_touch_network` command.

*Figure 6-3 dont\_touch Net Remains Untouched During Optimization*



---

## Setting Placement and Optimization Attributes

**Table 6-1** lists the restrictions imposed on the placement and optimization of cells by attributes.

*Table 6-1 Restrictions Imposed by Placement and Optimization Attributes*

| Attribute                                                                  | Coarse placement  | Detail placement  | Optimization                           |
|----------------------------------------------------------------------------|-------------------|-------------------|----------------------------------------|
| is_fixed                                                                   | Cannot move cells | Cannot move cells | Cannot move, rotate, or resize cells   |
| cts_fixed<br>(imposed on clock buffers by clock tree synthesis)            | Cannot move cells | Cannot move cells | Cannot move, rotate, or resize cells   |
| is_soft_fixed                                                              | Cannot move cells | No restrictions   | No restrictions                        |
| size_only                                                                  | No restrictions   | No restrictions   | Can only resize cells                  |
| in_place_size_only                                                         | Cannot move cells | No restrictions   | Can resize cells only if there is room |
| cts_in_place_size_only<br>(imposed on clock sinks by clock tree synthesis) | Cannot move cells | No restrictions   | Can resize cells only if there is room |
| dont_touch                                                                 | No restrictions   | No restrictions   | Cannot move, rotate, or resize cells   |

---

## Inserting Port Protection Diodes

IC Compiler can automatically insert protection diodes on subdesign ports to prevent antenna violations at the top level. You insert the port protection diodes after floorplanning but before starting placement. Use the `insert_port_protection_diodes` command to add diodes to the specified ports to your netlist, one diode per port. The new diodes are legalized near their corresponding ports. Note the following limitations:

- This command does not add diodes to ports with the `dont_touch` attribute.
- This command is not voltage-area aware. You need to select correct voltage diodes for ports in different voltage areas.

To report the port protection diodes that are inserted in your design, use the `report_port_protection_diodes` command.

---

## Preparing for High-Fanout Net Synthesis

During placement and optimization, IC Compiler does not buffer clock nets as defined by the `create_clock` command, but it does, by default, buffer other high-fanout nets, such as resets or scan enables, using a built-in high-fanout synthesis engine.

Before running high-fanout net synthesis during the `place_opt` step, define the buffering options by using the `set_ahfs_options` command. For more information about this command, see the man page.

During high-fanout net synthesis, IC Compiler automatically analyzes the buffer trees to determine the fanout thresholds by default, and then it removes and builds buffer trees.

The high-fanout synthesis engine does not buffer nets that are set as ideal nets or nets that are disabled with respect to design rule constraints.

As an alternative to performing high-fanout net synthesis during the `place_opt` command, you can use the `create_buffer_tree` command to run standalone high-fanout net synthesis. The command removes the preexisting buffer trees in the design and re-creates the buffer trees. To preserve the preexisting buffer trees, you can run incremental high-fanout net synthesis by specifying the `-incremental` option.

To get information about the buffer trees in your design, use the `report_buffer_tree` command.

To remove buffer trees from your design, use the `remove_buffer_tree` command.

---

## Generating Physical Data Reports

You can run statistical analysis on the design to perform a quick check or to analyze the optimization results before or after an optimization stage, including `place_opt`, `clock_opt`, and `route_opt`. To perform statistical analysis, specify the `-design_statistics` option with the `check_physical_design` command. The statistical analysis reports the design statistics, such as cells, nets, DRC violations, and area, but not floorplan limitations or timing constraints. For example,

```
icc_shell> check_physical_design -design_statistics
```

The example creates a `cpd_design_statistics_datetime` directory that stores the design statistics report named `index.html` and the statistical analysis tables in HTML format. The `index.html` file summarizes the design statistics in tabular format and provides a link to each HTML table. You click the More Info link under each category to view the HTML table for detailed statistics. To view the design statistics report, use a Web browser, such as Firefox, as shown in the following example:

```
% firefox cpd_design_statistics_datetime/index.html
```

[Figure 6-4](#) shows an example of the design statistics report.

*Figure 6-4 Design Statistics Report*

## **DESIGN STATISTICS REPORT**

| <b>Short Summary for Design : ORCA</b> |                                             |               |                           |
|----------------------------------------|---------------------------------------------|---------------|---------------------------|
| <b>Date : Thu Jul 28 12:26:57 2011</b> |                                             |               |                           |
| 1)                                     | Number of Std cells in design :             | 22209         | <a href="#">More Info</a> |
| 2)                                     | Number of Inv/Buf cells in design :         | 6457          | <a href="#">More Info</a> |
| 3)                                     | Number of ICG cells in design :             | 0             | <a href="#">More Info</a> |
| 4)                                     | Number of Macro cells in design :           | 13            | <a href="#">More Info</a> |
| 5)                                     | Number of Physical Only cells in design :   | 20            | <a href="#">More Info</a> |
| 6)                                     | Number of dont_touch cells in design :      | 0 0 % of Std  | <a href="#">More Info</a> |
| 7)                                     | Number of size_only cells in design :       | 24 0 % of Std | <a href="#">More Info</a> |
| 8)                                     | Number of fixed_placement cells in design : | 0 0 % of Std  | <a href="#">More Info</a> |
| 9)                                     | Number of Buffers Avail in libraries :      | 26            | <a href="#">More Info</a> |
| 10)                                    | Number of Buffers with dont_use :           | 0             | <a href="#">More Info</a> |
| 11)                                    | Number of Inverters Avail in libraries :    | 13            | <a href="#">More Info</a> |
| 12)                                    | Number of Inverters with dont_use :         | 0             | <a href="#">More Info</a> |
| 13)                                    | Number of Sequential cells in design :      | 2959          | <a href="#">More Info</a> |

To direct the output of the `check_physical_design` command to a specified directory, use the `-output` option. To direct the output of the command to a text file, use the UNIX redirection operators (`>` or `>>`) or the `redirect` command. For example,

```
icc_shell> check_physical_design -design_statistics > my_file
```

You cannot use the `-design_statistics` option with the `-stage` option, except when the `-stage` option is set to `pre_clock_opt`. For example, running the following command not only reports the design statistics but also generates a clock tree report.

```
icc_shell> check_physical_design -design_statistics \
    -stage pre_clock_opt
```

## Analyzing Placement and Optimization Feasibility

During placement and optimization, you might need to run the `place_opt` command multiple times to obtain optimal results. To improve runtime and to reduce iterations of placement and optimization during early design stages, you can use the `place_opt_feasibility` command to analyze placement and optimization feasibility. Running the feasibility flow can minimize the number of iterations, validate timing constraints, and report all paths that are not feasible.

[Table 6-2](#) defines the `place_opt_feasibility` options. For more information about these options, see the man page.

*Table 6-2 The place\_opt\_feasibility Options*

| To do this                                                                                                  | Use this option                                         |
|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| Enable congestion removal to improve routability.                                                           | <code>-congestion</code>                                |
| Specify to which stage the command should run.                                                              | <code>-stage initial_placement   drc   first_opt</code> |
| Specify which stage the command should skip.                                                                | <code>-skip initial_placement   drc   first_opt</code>  |
| Enable scan chain reordering if scan chains exist.                                                          | <code>-optimize_dft</code>                              |
| Enable leakage-power optimization.                                                                          | <code>-power</code>                                     |
| Recover area for cells that are not on the critical timing paths.                                           | <code>-area_recovery</code>                             |
| Use the zero wire load model to analyze timing.                                                             | <code>-zero_wire_load</code>                            |
| Specify to consider the scan chain connections during placement. By default, the command ignores scan nets. | <code>-consider_scan</code>                             |

*Table 6-2 The place\_opt\_feasibility Options (Continued)*

| To do this                                                                                                                                                                                                                                                                                                                                                             | Use this option              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Specify to continue placement when the design contains scan chains but no SCANDEF data. By default, missing SCANDEF data causes the command to exit with an error message. Setting this option enables the placer to continue with a warning and results in reduced QoR.                                                                                               | -continue_on_missing_scandef |
| The <code>place_opt_feasibility</code> command performs                                                                                                                                                                                                                                                                                                                |                              |
| <ol style="list-style-type: none"> <li>1. Initial placement.</li> <li>2. High-fanout net synthesis and logical DRC violations fixing.</li> <li>3. Timing optimization.</li> <li>4. Congestion removal when the <code>-congestion</code> option is specified.</li> <li>5. Further timing optimization when the <code>-congestion</code> option is specified.</li> </ol> |                              |
| If your design is congested, you should specify the <code>-congestion</code> option to achieve better correlation with the <code>place_opt</code> flow. To obtain better QoR, the <code>-congestion</code> option is recommended. During early design stages, you do not need to specify the <code>-congestion</code> option.                                          |                              |

The feasibility flow performs the following tasks:

- Performs quick initial placement, high-fanout net synthesis, logical DRC checking, and timing optimization.
- Invokes the `check_physical_design` and `check_scenarios` commands internally to check the design and libraries.
- Checks and reports timing endpoints that are not feasible and bottlenecks in timing constraints or floorplans.

Using the feasibility flow results in faster placement and optimization relative to the `place_opt` flow.

---

## Analyzing Cell Displacement During Legalization

Floorplans that contain narrow channels, high local congestion, and poor placement of blockages or macros can lead to large cell displacement during legalization. Large cell displacement can impact timing optimization and degrade quality of results. To identify the cause of potential large cell displacement in your designs, you can perform cell displacement analysis after running the `place_opt_feasibility` or `clock_opt_feasibility` command.

Cell displacement analysis performs the following tasks:

- Correlates large cell displacement with critical timing paths and congestion maps.
- Reports displacement count that occurs during each legalization stage.
- Plots displacement vectors for each legalization stage if the appropriate layout window is open.

To perform cell displacement analysis, use the `analyze_displacement` command with the mandatory `-input` option to provide the cell location history report file, which is automatically generated by the `place_opt_feasibility` or `clock_opt_feasibility` command, as shown in the following example:

```
icc_shell> analyze_displacement -input feas_cell_history
...
*****
Minimal cell row height: 5.040.

Summary of analysis Result
-----
Checkpoint 1: Start_legalizer
    39 new large displacement to next checkpoint
Checkpoint 2: End_legalizer
    0 new large displacement to next checkpoint
Checkpoint 3: Start_legalizer
    42 new large displacement to next checkpoint
Checkpoint 4: End_legalizer
    0 new large displacement to next checkpoint
Checkpoint 5: Current.
1
```

You can also view cell displacement by choosing Placement > Large Displacement Analysis in the GUI. [Figure 6-5](#) displays the large cell displacement as an overlay over the cell density map.

Figure 6-5 Cell Density Map With Large Cell Displacement



To identify the timing impact of large cell displacement, you can specify both `-move_back` and `-compare_timing` options. Use the `-move_back` option to reverse the displacement of cells to the locations of the specified stage, and use the `-compare_timing` option to compare the timing between the specified stage and the final placement. The `-compare_timing` option performs preroute RC estimation, updates timing, and regenerates the timing report. You can specify which timing paths to compare by using the `-timing_path` option. To preserve the results of the `-move_back` option, you should use the `-commit_change` option.

For example, the following command moves the displaced cells back to the locations of legalization stage 3 and reports timing comparison information for the timing paths in the `report.tim` file.

```
icc_shell> analyze_displacement -input feas_cell_history \
    -move_back 3 -compare_timing -timing_path report.tim
```

To find out if specific cells have large cell displacement, use the `-cells` option.

For more information about the `analyze_displacement` command, see the man page.

---

## Performing Clock Tree Synthesis During Placement

If your design contains simple clock tree structures and uses the same design rule constraints for placement and clock tree synthesis, you can simplify the design flow by performing clock tree synthesis and optimization during placement.

To perform clock tree synthesis and optimization during placement,

1. Define the clock trees as described in [Chapter 7, “Clock Tree Synthesis”](#).
2. Identify the clock tree synthesis options by using the `set_place_opt_cts_strategy` command.

The following table shows the options that you can specify.

| To do this                                                                                                                                                    | Use                                                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| Specify the operating condition to use for clock tree synthesis and optimization. If you do not specify this option, the maximum operating condition is used. | <code>-operating_condition min   max   min_max</code> |
| Prevent routing of the clock tree.                                                                                                                            | <code>-no_clock_route</code>                          |
| Perform interclock delay balancing.                                                                                                                           | <code>-inter_clock_balance</code>                     |
| Fix hold time violations on the clock tree.                                                                                                                   | <code>-fix_hold</code>                                |
| Update the clock latency values.                                                                                                                              | <code>-update_clock_latency</code>                    |

3. Use the `-cts` option when you run the `place_opt` command.

---

## Performing Placement and Optimization

After you have finished design planning and power planning, you can perform placement and optimization on your design.

To perform placement and optimization, use the `place_opt` command or choose Placement > Core Placement and Optimization in the GUI.

The `place_opt` command performs coarse placement, high-fanout net synthesis, physical optimization, and legalization.

During area recovery phase, removing cells on noncritical timing paths increases the fanout. The paths sometimes become timing-critical during postroute optimization to correct signal integrity problems. To avoid removing cells from potential timing-critical paths, you can specify a maximum fanout threshold limit for optimization by setting the `psynopt_high_fanout_legality_limit` variable. By default, this variable has a value of 0 and there is no high-fanout limit. If you set this variable to a nonzero value, optimizations that result in a fanout greater than the specified value are not performed.

During placement and optimization, the `place_opt` command does not touch the clock networks in the design.

[Table 6-3](#) describes the available `place_opt` options.

*Table 6-3 The place\_opt Options*

| GUI object                                              | Command option                           | Description                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Effort option                                           | <code>-effort low   medium   high</code> | Improves the quality of results or reduce runtime. Higher effort levels use additional runtime in an attempt to improve the quality of results. The default is medium.                                                                                                                                                                            |
| “Recover area” check box                                | <code>-area_recovery</code>              | Recovers area for cells not on timing-critical paths.                                                                                                                                                                                                                                                                                             |
| “Power optimization” check box                          | <code>-power</code>                      | Enables leakage-power optimization and power-aware placement.<br>For multicorner-multimode designs, you must use the <code>set_scenario_options</code> command to identify the leakage scenarios before enabling leakage-power optimization and power-aware placement. For more information, see <a href="#">Chapter 5, “Power Optimization.”</a> |
| “Clock compilation, optimization and routing” check box | <code>-cts</code>                        | Runs clock tree synthesis and optimization with placement and optimization.<br>Typically, this is used for the quick flow for designs not requiring extensive clock tree synthesis and optimization work. For more information about clock tree synthesis and optimization, see <a href="#">Chapter 7, “Clock Tree Synthesis.”</a>                |

*Table 6-3 The place\_opt Options (Continued)*

| GUI object                                                   | Command option                            | Description                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| “Reorder scan chains during placement” check box             | <code>-optimize_dft</code>                | Reorders scan chains.<br>For more information, see <a href="#">Chapter 4, “Design for Test.”</a>                                                                                                                                                               |
| “Consider scan chain connections during placement” check box | <code>-consider_scan</code>               | Considers the scan chain connections during placement. By default, the command ignores scan nets.                                                                                                                                                              |
| “Continue with missing scan definitions” check box           | <code>-continue_on_missing_scandef</code> | Continues placement when the design contains scan chains but no SCANDEF data. By default, missing SCANDEF data causes the command to exit with an error message. Setting this option enables the placer to continue with a warning and results in reduced QoR. |
| “Minimize congestion” check box                              | <code>-congestion</code>                  | Reduces congestion for improved routability.<br>For best results, use this option only for congested designs.                                                                                                                                                  |
| “Use Synopsys physical guidance” check box                   | <code>-spg</code>                         | Enables IC Compiler to use the Synopsys physical guidance information in Design Compiler as a starting point for place and route. For more information, see <a href="#">“Using Physical Guidance From Design Compiler” on page 6-29.</a>                       |
| “Skip initial placement” check box                           | <code>-skip_initial_placement</code>      | Omits initial placement. Do not use this option with the <code>-spg</code> option.<br>For more information, see <a href="#">“Omitting Initial Placement” on page 6-28.</a>                                                                                     |

## Omitting Initial Placement

If you have already run the placer on a design, you can skip the initial placement step of the `place_opt` command. To omit initial placement, you specify the `-skip_initial_placement` option of the `place_opt` command. When using this option, you must ensure that every cell has a legal location and all macros are fixed. Otherwise, the `place_opt` command terminates with an error. This option is disabled by default. Do not use this option with the `-spg` option.

---

## Using Physical Guidance From Design Compiler

You can use the Synopsys physical guidance information in Design Compiler as a starting point for place and route in IC Compiler. You enable the capability in IC Compiler by specifying the `-spg` option of the `place_opt` command.

Using Design Compiler placement provides the following benefits:

- Reduces the runtime of the placement step.
- Achieves better correlation between IC Compiler and Design Compiler.

You can transfer the Design Compiler placement to IC Compiler, in either a .ddc file, a Milkyway design, or a DEF file. If you use a DEF file to transfer the placement information, you also need to transfer the design database in the Verilog format, along with constraint files such as SDC and UPF.

Note:

Before using a DEF file to transfer the placement information, you need to set the `spg_enable_ascii_flow` variable to true.

The placement information generated from Design Compiler contains only the placement information for the standard cells and macros cells in the design. It does not contain any floorplan information. Reapply the floorplan and other physical constraints, before you run the `place_opt -spg` command. To preserve placement consistency and improve correlation with the Design Compiler, use the same floorplan and physical constraints used in Design Compiler. Do not change the physical constraints, such as the die area, macro placements, port locations, and move bounds. However, you can provide additional floorplan information that is not currently supported by Design Compiler, but is needed in IC Compiler for physical implementation.

The following example shows how to use the Synopsys physical guidance with the `place_opt` command:

```
icc_shell> read_ddc design_spg.ddc
icc_shell> read_def floorplan.def
icc_shell> place_opt -area_recovery -power -congestion -optimize_dft -spg
```

Note:

The Synopsys physical guidance feature is only available in the Design Compiler Graphical tool.

For more information, see the Synopsys physical guidance information in the *Design Compiler User Guide*.

---

## Saving Intermediate Results During Preroute Optimization

You can enable `place_opt` checkpointing to analyze your designs during preroute optimization by using the `set_checkpoint_strategy -enable` command. Checkpointing is disabled by default.

When checkpointing is enabled, the `place_opt` command

- Saves design snapshots in the Milkyway database at a periodic interval. You can analyze the intermediate results while the optimization is still proceeding.
- Updates the log file with checkpoint design names.

To analyze your checkpoint designs, you can use timing analysis, extraction, legalization, routing congestion analysis, and multicorner-multimode scenario commands, such as `report_timing`, `report_qor`, `extract_rc`, `legalize_placement`, `create_ilm`, `create_scenario`, `current_scenario`, `all_scenarios`, `set_active_scenarios`, `remove_scenario`, and `route_zrt_global`. You can also use the commands on an interface logic model (ILM) created from a checkpoint design for top-level analysis.

The following commands are not allowed on a checkpoint design or ILM created from a checkpoint design: `place_opt`, `psynopt`, `create_buffer_tree`, `clock_opt`, `compile_clock_tree`, `route_opt`, `signoff_opt`, `skew_opt`, `optimize_clock_tree`, `optimize_dft`, `optimize_fp_timing`, and `optimize_pre_cts_power`. Note that IC Compiler terminates any of these commands with an error if you try to use them on a checkpoint design.

Note:

This functionality does not apply to block abstraction models.

The following example shows how to use the `set_checkpoint_strategy` command in an optimization flow:

```
icc_shell> set_checkpoint_strategy -enable -prefix "runx" -overwrite  
icc_shell> place_opt
```

The resulting checkpoint design is

```
runx_place_opt_single_checkpoint_MYDESIGN_080908_120402_1
```

Each subsequent run with the `-overwrite` option overwrites the previous checkpoint design and uses the same checkpoint design name.

To remove checkpoint designs, use the `remove_checkpoint_designs` command. For example, to remove all checkpoint designs, enter

```
icc_shell> remove_checkpoint_designs
```

To remove all checkpoint designs created by `place_opt` only, enter

```
icc_shell> remove_checkpoint_designs -command place_opt
```

To disable checkpointing, enter

```
icc_shell> set_checkpoint_strategy -disable
```

---

## Setting Up for Congestion-Driven Placement

By default, the placer uses a built-in congestion estimator for congestion removal during placement. If you set the `placer_enable_enhanced_router` variable to `true`, changing it from its default of `false`, the placer uses the global route congestion map during the following congestion-driven placement stages:

- `create_placement -congestion`
- `place_opt -congestion`
- `place_opt -effort high`
- `place_opt_feasibility -congestion`
- `psynopt -congestion`
- `refine_placement`

For most designs, using the default setting for the `placer_enable_enhanced_router` variable should meet the congestion optimization requirements during placement. However, when the design remains highly congested, set this variable to `true`. Running congestion-driven placement by setting this variable to `true` can increase the runtime.

---

## Enabling Magnet Placement

To improve congestion for a complex floorplan or to improve timing for the design, you can use magnet placement to specify fixed objects as magnets and have IC Compiler move their connected standard cells close to them. You can specify fixed macro cells, a pin of a fixed macro cell, or an I/O pin as the magnet object.

For best results, perform magnet placement before standard cells are placed.

To perform magnet placement, use the `magnet_placement` command with a specification of the magnets and options for any special functions you need to perform.

```
icc_shell> magnet_placement [options] magnet_objects
```

**Table 6-4** shows the `magnet_placement` options.

*Table 6-4 magnet\_placement Command Options*

| To do this                                                                                                                                                                                      | Use this option                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| Enable the movement of fixed (or soft fixed) cells and display a warning that lists the fixed cells to be moved.                                                                                | <code>-move_fixed</code><br><code>-move_soft_fixed</code> |
| Fix (or soft fix) cells in their locations after magnet placement.                                                                                                                              | <code>-mark_fixed</code><br><code>-mark_soft_fixed</code> |
| Specify the number of logic levels from the magnet that should be checked for magnet placement.                                                                                                 | <code>-logical_level number</code>                        |
| Prevent movement of buffers and inverters.                                                                                                                                                      | <code>-exclude_buffers</code>                             |
| Prevent cells from being placed over soft blockages.                                                                                                                                            | <code>-avoid_soft_blockages</code>                        |
| Prevent placement beyond sequential cells.                                                                                                                                                      | <code>-stop_by_sequential_cells</code>                    |
| Specify to pull only the cells between the magnet objects and the specified pin, port, or cell objects on the timing path. This option is mutually exclusive with <code>-logical_level</code> . | <code>-stop_points object_list</code>                     |
| Specify to pull the specified cells that form a continuous datapath toward the magnet object.                                                                                                   | <code>-cells cell_list</code>                             |
| Specify not to pull the specified cells toward the magnet object.                                                                                                                               | <code>-exclude_cells cell_list</code>                     |

To instruct the `magnet_placement` command whether or not to pull cells toward the magnet objects, you can set the `magnet_placement_fanout_limit` variable to specify the fanout limit. If the fanout of a net exceeds the specified limit, the command does not pull cells of the net toward the magnet objects. The default setting is 1000.

Magnet placement allows cells to be overlapped by default. To prevent overlapping of cells, you can set the `magnet_placement_disable_overlap` variable to `true`, changing it from its default of `false`.

## Pulling Cells in a Continuous Datapath Toward a Magnet Object

You can pull cells that form a continuous datapath toward a magnet object by specifying the `-cells` option. When you use this option, specify one magnet object only. You cannot use the `-cells` option with the `-stop_points`, `-stop_by_sequential_cells`, `-exclude_buffers`, or `-logical_level` option.

The following examples use the datapaths shown in [Figure 6-6](#).

*Figure 6-6 Example of Pulling Cells in a Continuous Datapath*



The following command pulls all cells, C1 through C8, toward the C0 magnet object:

```
icc_shell> magnet_placement c0 -cells {C1 C2 C3 C4 C5 C6 C7 C8}
```

The following command pulls the C6, C7, and C8 cells toward the C2 magnet object:

```
icc_shell> magnet_placement c2 -cells {C6 C7 C8}
```

Although the C3, C4, and C5 cells form a continuous datapath, they are isolated from the C0 cell, so the following command pulls no cells toward the C0 cell.

```
icc_shell> magnet_placement c0 -cells {C3 C4 C5}
```

The following command pulls no cells toward the C0 magnet object because the C3, C6, and C8 cells do not form a continuous datapath.

```
icc_shell> magnet_placement c0 -cells {C3 C6 C8}
```

## Excluding Cells From Magnet Placement

You can specify which cells to skip during magnet placement. To exclude cells from being pulled toward a magnet object, specify the `-exclude_cells cell_list` option with the `magnet_placement` command.

For example, to exclude the C4 and C6 cells from magnet placement in the datapaths shown in [Figure 6-7](#), enter

```
icc_shell> magnet_placement C0 -exclude_cells {C4 C6} -logical_level 4
```

This command pulls the C1, C2, and C3 cells toward the C0 magnet object. The C5 and C7 cells are not pulled because they do not form continuous datapaths when the C4 and C6 cells are excluded.

*Figure 6-7 Datapaths Example*



To exclude cells when reporting cells that can be pulled toward a magnet object, specify the `-exclude_cells cell_list` option with the `get_magnet_cells` command. Using the same datapaths shown in [Figure 6-7](#), the following command reports the C1, C2, and C3 cells but not the excluded cells, C4 and C6, and the cells in the subsequent logic level, C5 and C7.

```
icc_shell> get_magnet_cells C0 -exclude_cells {C4 C6} -logical_level 4
```

## Reporting Magnet Cells

To return a collection of cells that can be moved with magnet placement, use the `get_magnet_cells` command with the options you need.

```
icc_shell> get_magnet_cells [options] magnet_list
```

*Table 6-5 get\_magnet\_cells Command Options*

| To do this                                                                                                                                                                         | Use this option                                           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| Get the fixed (or soft fixed) cells that can be moved.                                                                                                                             | <code>-move_fixed</code><br><code>-move_soft_fixed</code> |
| Get the cells in the specified number of logic levels from the magnet.                                                                                                             | <code>-logical_level number</code>                        |
| Get the cells encountered between magnet cells and sequential cells.                                                                                                               | <code>-stop_by_sequential_cells</code>                    |
| Exclude the buffers and inverters.                                                                                                                                                 | <code>-exclude_buffers</code>                             |
| Identify the cells between magnet objects and the specified pin, port, or cell objects on the timing path.<br>This option is mutually exclusive with <code>-logical_level</code> . | <code>-stop_points object_list</code>                     |
| Exclude the specified cells when reporting cells that can be pulled toward the magnet object.                                                                                      | <code>-exclude_cells cell_list</code>                     |

## Using the Top-Level Buffering Technique for Optimization

If your design contains the following characteristics, the traditional place and route flow might not produce optimal results:

- A fragmented floorplan with thin channels caused by many macros and blocks
- Minimal or no interface logic between blocks
- Buffering that is driven by design rule constraints, primarily the maximum net length constraint
- Many long nets through channels, especially low fanout or point-to-point nets

To improve the QoR and reduce congestion of such designs, you should consider using the top-level buffering technique for optimization, as shown in the following example:

```
icc_shell> set_max_net_length integer
icc_shell> create_placement
icc_shell> create_buffer_tree -align_hierarchy_for_long_nets
....
icc_shell> create_buffer_tree -on_route
```

When using this technique,

- Specify the `create_placement` command only if your design contains interface logic at the top level.
- Specify the `-align_hierarchy_for_long_nets` and `-on_route` options together with the `create_buffer_tree` command if you have no intermediate steps between the two `create_buffer_tree` steps.
- You can optionally run the `route_opt` command to perform additional topology-based optimization or use the `focal_opt` command to fix specific DRC violations after the flow.

---

## Using Physical Optimization

You can run incremental placement-based optimization that supports area recovery, design rule fixing, sizing, and route-based optimization by using the `psynopt` command. By default, this command performs timing optimization and design rule fixing, based on the maximum capacitance and maximum transition settings while keeping the clock networks untouched. It can also perform power optimizations. The `psynopt` command continues to optimize until no more optimizations can be performed. When done, it completes the optimizations with a legalized placement of the design.

This process can remove dangling cells (cells that do not drive other cells), resulting in a reduced number of cells in the design. If you need to prevent the removal of such cells, do one of the following:

- To prevent the removal of specific cells, use the `set_dont_touch` command to apply a `dont_touch` attribute on each of those cells.
- To retain the unloaded cells globally, set the `physopt_delete_unloaded_cells` variable to `false`.

To perform placement optimization with the `psynopt` command, enter

```
icc_shell> psynopt [options]
```

**Table 6-6** shows the options supported by the `psynopt` command.

*Table 6-6 The psynopt Options*

| To do this                                                                                                                                                               | Use this option                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Enable area recovery within the cluster boundary for noncritical paths. Using this switch can have a severe runtime impact if the design contains many high-fanout nets. | <code>-area_recovery</code>      |
| Perform only area recovery. You cannot use this option with <code>-only_design_rule</code> or <code>-only_hold_time</code> .                                             | <code>-only_area_recovery</code> |
| Exit <code>psynopt</code> without fixing design rule violations, allowing you to check the results in a constraint report before fixing the violations.                  | <code>-no_design_rule</code>     |
| You cannot use <code>-no_design_rule</code> with <code>-only_design_rule</code> .                                                                                        |                                  |
| Perform design rule fixing without performing timing optimizations. This option uses <code>psynopt</code> placement to target DRC problems.                              | <code>-only_design_rule</code>   |
| You cannot use <code>-only_design_rule</code> with <code>-no_design_rule</code> or <code>-only_area_recovery</code> .                                                    |                                  |
| Fix only hold time violations; ignore other design rules. The <code>set_fix_hold</code> command must be specified for hold time fixing to be performed.                  | <code>-only_hold_time</code>     |
| You cannot use this option with <code>-no_design_rule</code> or <code>-only_area_recovery</code> .                                                                       |                                  |
| Restrict postroute flow optimization to gate sizing only. You cannot use this option with <code>-in_place_size_only</code> .                                             | <code>-size_only</code>          |
| Restrict postroute flow optimization to in-place gate sizing only. You cannot use this option with <code>-size_only</code> .                                             | <code>-in_place_size_only</code> |
| Restrict cell sizing to cells having the same footprint and size.                                                                                                        | <code>-preserve_footprint</code> |
| Reduce congestion to improve routability.                                                                                                                                | <code>-congestion</code>         |
| Enable power optimization.                                                                                                                                               | <code>-power</code>              |
| Enable only power optimizations.                                                                                                                                         | <code>-only_power</code>         |
| For more information, see <a href="#">Chapter 5, “Power Optimization.”</a>                                                                                               |                                  |

**Table 6-6 The psynopt Options (Continued)**

| To do this                                                                                                                                                                                                                                                     | Use this option                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| Ignores the scan chain connections during the congestion optimization stage. By default, the command considers scan nets during congestion optimization ( <code>psynopt -congestion</code> ).                                                                  | <code>-ignore_scan</code>                 |
| Continues placement when the design contains scan chains but no SCANDEF data. By default, missing SCANDEF data causes the command to exit with an error message. Setting this option enables the placer to continue with a warning and results in reduced QoR. | <code>-continue_on_missing_scandef</code> |

## Performing Layer Optimization

You can use the `preroute_focal_opt` command to perform preroute optimization to fix high-fanout nets, setup, hold, and logical DRC violations after the `place_opt` or `clock_opt` stage but before the `route_opt` stage. You can also use the command to perform layer optimization to control the tradeoff between buffering and layer assignment by specifying the `-layer_optimization` option. Layer optimization works only in the current scenario.

In advanced technologies, upper layers have much lower resistance values than lower layers. When you specify the `-layer_optimization` option, the `preroute_focal_opt` command uses the layer optimization strategy to assign upper layers to buffer trees and then removes buffers to reduce the buffer count and fix DRC violations. This option cannot be used with other options except the `-effort` option. The default settings of the layer optimization strategy include using the available top two layers as the minimum and maximum upper layers for routing, setting the buffer threshold to 4, and using the low congestion effort.

To change the default settings of layer optimization, use the `set_preroute_focal_opt_strategy` command. To report the settings, use the `report_preroute_focal_opt_strategy` command. [Table 6-7](#) shows the options of the `set_preroute_focal_opt_strategy` command.

**Table 6-7 The set\_preroute\_focal\_opt\_strategy Options**

| To do this                             | Default                         | Use this option              |
|----------------------------------------|---------------------------------|------------------------------|
| Reset the layer optimization strategy. | N/A                             | <code>-default</code>        |
| Specify the minimum upper layer.       | The top (first) available layer | <code>-min_layer_name</code> |
| Specify the maximum upper layer.       | The second available layer      | <code>-max_layer_name</code> |

*Table 6-7 The set\_preroute\_focal\_opt\_strategy Options (Continued)*

| To do this                                              | Default | Use this option                           |
|---------------------------------------------------------|---------|-------------------------------------------|
| Specify the routing effort for global route congestion. | low     | -congestion_effort<br>low   medium   high |
| Specify the buffer count threshold.                     | 4       | -buffer_threshold                         |

## Performing Preroute RC Estimation

IC Compiler automatically performs preroute RC estimation when you run the following commands: `place_opt`, `clock_opt`, `create_placement`, `legalize_placement`, and `psynopt`. In addition, you can explicitly perform preroute RC estimation by running the `extract_rc` command.

**Note:**

By default, the `extract_rc` command performs RC estimation on any unrouted nets in your design and performs RC extraction on the routed nets in your design. If your design contains a mix of routed and unrouted nets, and you do not want to run RC extraction on the routed nets, use the `extract_rc -estimate` command, which performs only RC estimation.

When performing preroute RC estimation, IC Compiler performs the following tasks:

- Determines the RC coefficients

IC Compiler derives the RC coefficients from the TLUPlus models. For information about attaching the TLUPlus data to your Milkyway design library, see “[Setting Up the TLUPlus Files](#)” on page 3-36.

The TLUPlus models contain layer-specific RC coefficients. Because layers are not assigned for preroute estimation, IC Compiler calculates the RC coefficients by applying averaging techniques to the layer-specific RC coefficients.

For information about how you can modify the RC coefficients to improve your preroute optimization results, see “[Modifying the RC Coefficients](#)” on page 6-40.

- Estimates the routing topology

IC Compiler uses virtual route technology to estimate the routing topology from the placement information. The virtual route does not contain layer assignments.

- Calculates the RC values

IC Compiler uses virtual routing to estimate the preroute parasitics.

- Performs delay estimation

IC Compiler uses the Elmore delay model to estimate the delay values, based on the estimated routing topology and the estimated RC values.

- Saves the timing data and attributes in the Milkyway design library

IC Compiler saves total capacitance as a design attribute. To save the parasitics in a data file, run the `write_parasitics` command.

---

## Modifying the RC Coefficients

When IC Compiler runs preroute RC estimation, it displays the derived coefficients on your screen. You can modify these coefficients by using the following methods:

- Defining net-based layer constraints

At small geometries, the RC coefficients, especially resistance coefficients, can vary significantly between layers. In this case, the coefficients derived by averaging the coefficients for all layers might not provide sufficient correlation with the postroute values. You can restrict the set of routing layers used for a specific net by defining net-based layer constraints.

- Introducing pessimism

If, after analyzing the estimation results calculated from the derived RC coefficients, you feel that the derived RC coefficients are too optimistic, you can consider introducing pessimism to these values. Using pessimistic RC values means that you provide larger values, so that for a given net, IC Compiler computes a larger delay. This, in turn, drives the optimization of your design such that extra buffering or more powerful driving cells are introduced.

- Defining the pattern density outside the block

In StarRC, the `DENSITY_OUTSIDE_BLOCK` command specifies the pattern density outside the block, which affects the thickness variation and parasitic RC values. For correct correlation with StarRC, specify the same pattern density value in IC Compiler by using the `-density_outside_block` option of the `set_delay_estimation_options` or `set_extraction_options` command. For more information about specifying the pattern density outside the block, see the description of the `DENSITY_OUTSIDE_BLOCK` command in the *StarRC User Guide and Command Reference*.

To report the delay estimation coefficients, use the `report_delay_estimation_options` command.

## Defining Net-Based Layer Constraints

In addition to restricting the layers to which a specific net can be assigned during routing, net-based layer constraints improve RC correlation by reducing the set of values used by the averaging techniques that determine the RC coefficients used for preroute estimation.

To set net-based layer constraints, use the `set_net_routing_layer_constraints` command.

```
icc_shell> set_net_routing_layer_constraints {netA} \
             -min_layer_name metal1 -max_layer_name metal3
```

The routing layer names you specify must exist in both the physical library and the design, and the maximum routing layer must be the same or on top of the minimum routing layer.

If the net you specify already has routing layer constraints set, a warning appears and the constraints specified by this invocation overwrite the existing routing layer constraints.

To report and remove routing layer constraints, use the `report_net_routing_layer_constraints` and `remove_net_routing_layer_constraints` commands.

## Introducing Pessimism

You can introduce pessimism by either scaling the derived coefficients or manually specifying the coefficients. Avoid more than doubling the default numbers, because the gate sizes and runtime increase. The basic rule is to increase values by 10 percent (multiply by 1.1). Usually, change the number by small amounts, such as increments of 0.1.

### Scaling the RC Coefficients

To scale the RC coefficients,

1. Determine the scaling factor you want to apply.
2. Use the following `set_delay_estimation_options` command options to set the scaling factors:

```
-max_unit_horizontal_capacitance_scaling_factor
-max_unit_vertical_capacitance_scaling_factor
-max_unit_horizontal_resistance_scaling_factor
-max_unit_vertical_resistance_scaling_factor
-min_unit_horizontal_capacitance_scaling_factor
-min_unit_vertical_capacitance_scaling_factor
-min_unit_horizontal_resistance_scaling_factor
-min_unit_vertical_resistance_scaling_factor
```

IC Compiler produces new RC coefficients by multiplying the derived RC coefficients by the scaling factors you specify. During RC estimation, IC Compiler uses the scaled coefficients.

## Manually Specifying RC Coefficients

To specify the RC coefficients,

1. Run RC estimation to derive the base RC coefficients.
2. Determine the new, pessimistic values you want to apply.
3. Use the following `set_delay_estimation_options` command options to specify the RC coefficients:

```
-max_unit_horizontal_capacitance  
-max_unit_vertical_capacitance  
-max_unit_horizontal_resistance  
-max_unit_vertical_resistance  
-min_unit_horizontal_capacitance  
-min_unit_vertical_capacitance  
-min_unit_horizontal_resistance  
-min_unit_vertical_resistance
```

Note:

At the minimum, you must specify all four `-max_*` options; otherwise, IC Compiler uses the derived RC coefficients.

The values you specify override the derived RC coefficients. During RC estimation, IC Compiler uses the specified coefficients.

If you specify both scaling factors and user-defined RC coefficients, the resulting RC coefficients are the result of multiplying your RC coefficients by your scaling factors.

For multicorner-multimode designs, use the `set_delay_estimation_options` command to specify scaling factors and user-defined RC coefficients for each scenario. The `set_delay_estimation_options` command applies only to the current scenario. For information about setting the current scenario see “[Defining Scenarios](#)” on page 3-30.

---

## Enabling Via Resistance Estimation

By default, preroute RC estimation does not perform via resistance calculations. To enable via resistance calculations, set the `physopt_enable_via_res_support` variable to `true`. When this capability is enabled, IC Compiler determines the via resistance values from the TLUPlus models. As with the net RC coefficients, you can introduce pessimism by either scaling the derived values or manually specifying the values.

## Scaling the Via Resistance Values

To scale the via resistance values,

1. Determine the scaling factor you want to apply.
2. Use the following `set_delay_estimation_options` command options to set the scaling factors:

```
-max_via_resistance_scaling_factor  
-min_via_resistance_scaling_factor
```

IC Compiler produces new resistance values by multiplying the derived values by the scaling factors you specify. During delay estimation, IC Compiler uses the scaled values.

## Manually Specifying Via Resistance Values

To specify the via resistance values,

1. Run RC estimation to derive the base resistance values.
2. Determine the new, pessimistic values you want to apply.
3. Use the following `set_delay_estimation_options` command options to specify the resistance values:

```
-max_via_resistance  
-min_via_resistance
```

The values you specify override the derived via resistance values. During delay estimation, IC Compiler uses the specified values.

Note:

If you specify both scaling factors and user-defined via resistance values, the resulting via resistance values are the result of multiplying your values by your scaling factors.

---

## Analyzing Placement

After placement, you can view and analyze the results. You can report the area utilization with the `report_placement_utilization` command, the design timing with the `report_timing` command, the power consumption characteristics with the `report_power` command, and the QoR with the `create_qor_snapshot` command.

---

## Placement Area Utilization

Placement area utilization, or simply “utilization,” means the percentage of area available for placement that is already occupied by placed cells. For example, a utilization of 80 percent means that 80 percent of the available area is occupied by cells and 20 percent is empty and can still be used for additional cell placement, for movement of cells for legalization and optimization, or as an allowance to prevent excessive routing congestion.

You can report the utilization for part or all of the design with the `report_placement_utilization` command.

This syntax of this command is

```
report_placement_utilization
  [-non_fixed_only]
  [-grid_size float]
  [-verbose]
  [-coordinates {llx lly urx ury}]
```

For example, to report the utilization of the rectangular area bounded by the corner points (340, 380) and (400, 450), you would use the following command:

```
icc_shell> report_placement_utilization -coordinates {340 380 400 450}
...
Std cell utilization:      84.02%  (2193/(2610-0),
                           (std_cell_area/(region_area-blockage_area)))
(Non-fixed + Fixed)
Std cell utilization:      77.66%  (1450/(2610-743))
(Non-fixed only)
Total region area:        2610    sites, bbox
                           (340.00 380.00 400.00 450.00) um
Std cell area :            2193    sites, (non-fixed:1450, fixed:743)
Macro cell area :          0       sites
Blkgs exclude fixed cells: 0       sites
Blkgs include fixed cells: 743    sites
Std cell count :           301    (non-fixed:183, fixed:118)
Macro cell count :         0
Pnet area :                0       sites

*****
Sub-Region Utilization
*****
Number of regions with placement utilization 0 - 0.125 is 0 (0.00%)
Number of regions with placement utilization 0.125 - 0.25 is 0 (0.00%)
Number of regions with placement utilization 0.25 - 0.375 is 0 (0.00%)
Number of regions with placement utilization 0.375 - 0.5 is 0 (0.00%)
Number of regions with placement utilization 0.5 - 0.625 is 0 (0.00%)
Number of regions with placement utilization 0.625 - 0.75 is 0 (0.00%)
Number of regions with placement utilization 0.75 - 0.875 is 0 (0.00%)
Number of regions with placement utilization 0.875 - 1 is 16 (100.00%)
```

If you do not specify the coordinates, the command reports the utilization of the whole chip.

In the reporting of utilization, there are two basic ways to consider the presence of standard cells that have fixed placement (“fixed standard cells”). These cells can be considered the same as unfixed cells, in other words, as cells occupying the available space. Conversely, the space occupied by fixed cells can be considered unavailable space, in what is called a “non-fixed-only” utilization report.

Consider the example shown in [Figure 6-8](#). This area of four square units is occupied by three cells, each with an area of one square unit, leaving one square unit of empty space.

*Figure 6-8 Non-Fixed-Only Utilization Example*



Default utilization (fixed and unfixed standard cells):  $3/4 = 75$  percent  
 Non-fixed-only standard cell utilization:  $1/2 = 50$  percent

The default utilization is reported to be 75 percent because  $3/4$  of the available area is occupied by standard cells. However, for non-fixed-only utilization reporting, the area occupied by fixed standard cells is considered unavailable, so the available area is two square units, occupied by one square unit of non-fixed standard cells, for a utilization of  $1/2$  or 50 percent.

Utilization reporting also considers the presence of placement blockages. For both default and non-fixed-only reporting, any part of the area occupied by a blockage is considered unavailable for placement. Thus, the default utilization is calculated as follows:

$$(\text{non-fixed\_standard\_cell\_area} + \text{fixed\_standard\_cell\_area}) / (\text{total\_area} - \text{blocked\_area})$$

whereas non-fixed-only utilization is calculated as follows:

$$(\text{non-fixed\_standard\_cell\_area}) / (\text{total\_area} - \text{fixed\_standard\_cell\_area} - \text{blocked\_area})$$

The `report_placement_utilization` command reports both the default and non-fixed-only utilization values. It also divides the specified region into subregions and separately reports the utilization within those subregions, to give an idea of the “evenness” of the utilization. By default, the subregion size is five times the placement site height. You can specify a different subregion size, in microns, by using the `-grid_size` option.

The `-verbose` option causes the reporting of the dimensions, locations, and individual utilization values of the subregions. Otherwise, the report shows only a summary listing of the number and percentage of subregions having different ranges of utilization values. The `-non_fixed_only` option specifies whether to use default or non-fixed-only utilization values for the subregion utilization report.

---

## Timing Analysis

After you set the timing constraints such as clocks, input delays, and output delays, it is a good idea to use the `check_timing` command to check for timing setup problems and timing conditions such as incorrectly specified generated clocks and combinational feedback loops. The command checks the timing attributes of the current design and issues warning messages about any unusual conditions found.

This is the full syntax of the `check_timing` command:

```
check_timing
[-overlap_tolerance minimum_distance]
[-override_defaults check_list]
[-include check_list]
[-exclude check_list]
[-multiple_clock]
[-retain]
```

These are the types of timing checks that can be performed:

```
clock_crossing
data_check_multiple_clock
data_check_no_clock
generated_clocks
generic
loops
multiple_clock
no_input_delay
retain
unconstrained_endpoints
pulse_clock_cell_type
gated_clock
ideal_timing
clock_no_period
```

The types of timing checks shown in boldface are performed by default. You can include or exclude specific types of timing checks by using the `-include` and `-exclude` options or by setting the `timing_check_defaults` variable. For details, see the man pages for the `check_timing` command and the `timing_check_defaults` variable.

After placement, you can use the `report_timing` command to report the worst-case timing paths in the design. This is the command syntax:

```
report_timing
  [-to to_list]
  [-from from_list]
  [-through through_list]
  [-path_type short | full | full_clock | full_clock_expanded | only |
   start | end]
  [-delay_type min | min_rise | min_fall | max | max_rise | max_fall]
  [-nworst paths_per_endpoint]
  [-max_paths max_path_count]
  [-input_pins]
  [-nets]
  [-transition_time]
  [-crosstalk_delta]
  [-capacitance]
  [-attributes]
  [-physical]
  [-slack_greater_than greater_slack_limit]
  [-slack_lesser_than lesser_slack_limit]
  [-lesser_path max_path_delay]
  [-greater_path min_path_delay]
  [-loops]
  [-true [-true_threshold path_delay] ]
  [-justify]
  [-enable_preset_clear_arcs]
  [-significant_digits digits]
  [-nosplit]
  [-sort_by group | slack]
  [-group group_name]
  [-trace_latch_borrow]
  [-derate]
  [-scenarios scenario_list]
  [-temperature]
  [-voltage]
```

By default, the command reports the path having the worst maximum (setup) delay in each clock group. Net delays are based on estimated route lengths.

For example, here is a typical `report_timing` command:

```
icc_shell> report_timing
...
Startpoint: I_SDRAM_TOP/I_SDRAM_IF/DQ_out_1_reg_8_
(falling edge-triggered flip-flop clocked by SDRAM_CLK)
Endpoint: sd_DQ_out[8]
(output port clocked by SD_DDR_CLK)
Path Group: SD_DDR_CLK
Path Type: max

Point                                Incr      Path
-----
clock SDRAM_CLK (fall edge)          3.75     3.75
clock network delay (ideal)         0.00     3.75
I_SDRAM_TOP/I_SDRAM_IF/DQ_out_1_reg_8_/CPN (sdcfq1) 0.00     3.75 f
I_SDRAM_TOP/I_SDRAM_IF/DQ_out_1_reg_8_/Q (sdcfq1)   0.36     4.11 r
I_SDRAM_TOP/I_SDRAM_IF/sd_mux_dq_out_8/Z (mx02d4)  0.21 *   4.31 r
I_SDRAM_TOP/I_SDRAM_IF/sd_DQ_out[8] (SDRAM_IF)       0.00     4.31 r
I_SDRAM_TOP/sd_DQ_out[8] (SDRAM_TOP)           0.00     4.31 r
sd_DQ_out[8] (out)                  0.00     4.31 r
data arrival time                   0.00     4.31

clock SD_DDR_CLK (rise edge)        7.50     7.50
clock network delay (ideal)         1.00     8.50
clock uncertainty                  -0.05    8.45
output external delay              -2.00    6.45
data required time                 0.00     6.45
-----                                 6.45
data required time                 0.00     -4.31
-----                                 -4.31
-----                                 2.14
...
```

The default report shows the startpoint, endpoint, path group (clock domain), path type (minimum delay, maximum delay, max\_rise, min\_fall, and so on), the incremental and cumulative time delay values along the data and clock paths, the data required time at the path endpoint, and the timing slack for the path.

The `report_timing` command options let you specify the scope of paths reported (from/to/through specified points in the design), the path types reported, the numbers of worst-case paths reported, and the types of information reported for intermediate points in the path (transition times, capacitance, net delays, and so on).

For more information, see the man page for the `report_timing` command.

Using the GUI, you can generate color-coded diagrams showing the locations of worst-case timing conditions such as path slack, cell slack, net capacitance, clock latency/transition, and crosstalk. From the Visual Mode panel (View > Visual Mode) select the desired type of

visual analysis, and then click the Reload button and OK button. An example of a path slack display is shown in [Figure 6-9](#). The layout view shows the worst-case timing paths with the pins and flylines of the paths color-coded according to amount of slack. For more information about generating these views, see the “Visual Mode panel” topic in IC Compiler Help, or see [Appendix A, “Using GUI Tools.”](#)

*Figure 6-9 Path Slack Visual Mode*



To get a detailed report on the delay calculation at a given point along a timing path, use the `report_delay_calculation` command. This is the command syntax:

```
report_delay_calculation
  [-min] [-max]
  -from from_pin -to to_pin
  [-nosplit]
  [-crosstalk]
  [-from_rise_transition value]
  [-from_fall_transition value]
```

Specify the “from” and “to” pins of the cell or net that you want to report. These two pins can be the input and output pins of a cell to report the calculation of a cell delay, or can be the driver pin and a load pin of a net to report the calculation of a net delay. For example, the following command reports in detail the delay calculation between two pins of a cell:

```
icc_shell> report_delay_calculation \
    -from I_SDRAM_TOP/I_SDRAM_IF/DQ_out_1_reg_8_/CPN \
    -to I_SDRAM_TOP/I_SDRAM_IF/DQ_out_1_reg_8_/Q
...
From pin:           I_SDRAM_TOP/I_SDRAM_IF/DQ_out_1_reg_8_/CPN
To pin:            I_SDRAM_TOP/I_SDRAM_IF/DQ_out_1_reg_8_/Q
Main Library Units: 1ns 1pF 1kOhm

Operating Conditions: cb13fs120_ts_max   Library: cb13fs120_ts_max
Library: 'cb13fs120_ts_max'
Library Units: 1ns 1pF 1kOhm
Library Cell: 'sdcfq1'

arc sense:          falling_edge
arc type:           cell
Clock rise transition: 0
Clock fall transition: 0

Rise Delay

cell delay = 0.35504
Table is indexed by
(X) input_pin_transition = 0
(Y) output_net_total_cap = 0.0124603
Relevant portion of lookup table:
(X) 0.0150      (X) 0.2500
(Y) 0.0070      (Z) 0.3380      (Z) 0.3880
(Y) 0.0140      (Z) 0.3640      (Z) 0.4150

Z = A + B*X + C*Y + D*X*Y
A = 0.3089        B = 0.2085
C = 3.7052        D = 0.6079

Z = 0.35504
scaling result for operating conditions
multiplying by 1 gives 0.35504
...
Fall Delay

...
```

For more information, see the `report_delay_calculation` man page.

---

## Power Analysis

The `report_power` command calculates and reports power for a design. The command uses the user-annotated switching activity to calculate the net switching power, cell internal power, and cell leakage power, and it displays the calculated values in a power report. This is the command syntax:

```
report_power
  [-net]
  [-cell]
  [-only cell_or_net_list]
  [-hierarchy]
  [-levels level_value]
  [-verbose]
  [-cumulative]
  [-flat]
  [-exclude_boundary_nets]
  [-include_input_nets]
  [-analysis_effort low | medium | high]
  [-nworst number]
  [-sort_mode mode]
  [-histogram [-exclude_leq le_val | -exclude_geq ge_val]]
  [-nosplit]
  [-scenarios scenario_list]
```

For example, here is a typical `report_power` command:

```
icc_shell> report_power
...
Library(s) Used:
cb13fs120_ts_max (File: /remote/techp5/ref/db/sc_max.db)
ram8x64_max (File: /remote/techp5/ref/db/ram8x64_max.db)
ram16x128_max (File: /remote/techp5/ref/db/ram16x128_max.db)

Operating Conditions: cb13fs120_ts_max Library: cb13fs120_ts_max
Wire Load Model Mode: enclosed
Design           Wire Load Model           Library
-----
ORCA_TOP          ForQA                  cb13fs120_ts_max
PCI_FIFO_1_DW01_sub_1 ForQA                cb13fs120_ts_max

Global Operating Voltage = 1.08
Power-specific unit information :
  Voltage Units = 1V
  ...
```

```

Cell Internal Power = 34.8033 mW (93%)
Net Switching Power = 2.7620 mW (7%)
-----
Total Dynamic Power = 37.5653 mW (100%)

Cell Leakage Power = 424.5199 uW

```

The following example reports the total power of all cells, including the leakage power of physical-only cells:

```

icc_shell> report_power -cell -only [get_cells -all]
...
Attributes
-----
h - Hierarchical cell

          Cell           Driven Net   Tot Dynamic      Cell
          Internal       Switching Power    (%Cell/Tot)  Leakage
Cell      Power        Power          (N/A)          Power   Attrs
-----
CTS_eclk_delay3  0.0121        0.0162    2.83e-02 (43%)  1.3527
CKBD16HVT_G2B3I1 9.439e-03    0.0259    3.53e-02 (27%)  1.0109
CKBD12HVT_G2B3I2 9.384e-03    0.0207    3.01e-02 (31%)  1.0109
SNPS_dcap_324    0.0000        0.0000    0.0000 (N/A)     0.8000
... (omitted value)
-----
Totals (2026cells) 947.939uW  630.335uW  1.573mW (60%)  856.898nW

```

The SNPS\_dcap\_324 cell denotes leakage power consumption of the physical-only cells.

By default, the `report_power` command shows the total dynamic power and leakage power for the whole chip. The command options let you restrict the scope of the power report to specified instances, to nets or cells alone, or to particular cells or nets obtained by filtering. You can also control the format of the generated report, including the levels of hierarchy reported, the sorting of nets and cells reported, and an optional histogram display of net power. For more information, see the man page for `report_power`.

## Reporting Quality-of-Results

You can generate a report on the quality of results (QoR) for the design in its current state by using the `create_qor_snapshot` command (or by choosing Timing > Create QoR Snapshot in the GUI). This command measures and reports the quality of the design in terms of timing, design rules, area, power, congestion, clock tree synthesis, routing, and so on. It stores the quality information into a set of snapshot files. You can later retrieve and report the snapshot with the `report_qor_snapshot` command. You can also selectively

retrieve, sort, and display the desired information from the snapshot with the `query_qor_snapshot` command (or by choosing Timing > Query QoR Snapshot in the GUI).

## **create\_qor\_snapshot**

You can use the `create_qor_snapshot` command to measure the quality of the design in its current state and store the quality information into a set of report files. You can capture the quality information using different optimization strategies or at different stages of the design and compare the quality results.

Alternatively, you can create a QoR snapshot in the GUI by choosing Timing > Create QoR Snapshot.

The command options let you specify which aspects of quality are to be measured (power, clock tree, and routes) and the conditions for analysis (zero wire load, maximum paths per timing group, and maximum paths per endpoint).

When you use this command, you must at least specify a name for the snapshot by using the `-name` option. For example,

```
icc_shell> create_qor_snapshot -name my_snapshot1
```

The report is written to a set of files into a directory called “snapshot” in the current working directory. After the report is written, you can retrieve the report any time with the `report_qor_snapshot` command. For example,

```
icc_shell> report_qor_snapshot
...
*****
Report      : create_qor_snapshot (my_snapshot1)
Design       : system_controller
Version     : D-2010.03
Date        : Thu Feb 11 13:56:48 2010
Time unit   : 1.0e-09 Second(ns)
Capacitance unit: 1.0e-12 Farad(pF)
Voltage unit : 1 Volt
Power unit   : N/A
Location     : /remote/grayc/PnR/implementation/lab/snapshot
*****
No. of scenario = 1
-----
WNS of each timing group:
-----
-----
Setup WNS:          0.000
Setup TNS:          0.0
Number of setup violations: 0
Hold WNS:           0.000
```

```

Hold TNS:                      0.000
Number of hold violations:      0
Number of max trans violations: 65
Number of max cap violations:   22
Route drc violations:          0
-----
Area:                          451495
Cell count:                     23139
Buf/inv cell count:            3088
Std cell utilization:          18.324%
CPU/ELAPSE(hr):                0.11/23.88
Mem(Mb):                        1274
Host name:                      igcae007
-----
Histogram:
-----
Max violations:    ...
...

```

If your design contains multiple scenarios, you can use the `-scenarios` option to create a snapshot of the specified scenarios. If you do not specify this option, the command creates a snapshot of all active scenarios.

For example, the following command creates a snapshot of the sn1, sn2, and sn3 scenarios:

```
icc_shell> create_qor_snapshot -name test -scenarios {sn1 sn2 sn3}
```

To create a snapshot for the sn1 scenario only, enter

```
icc_shell> create_qor_snapshot -name test -scenarios sn1
```

You can also create a snapshot for the analysis of clock tree synthesis by using the `-clock_tree` option. For example,

```
icc_shell> create_qor_snapshot -name cts_snapshot -clock_tree
```

## **query\_qor\_snapshot**

The `query_qor_snapshot` command reads in a QoR report generated by previous usage of the `create_qor_snapshot` command and analyzes the results by collecting information about each path. You can query the collected information with various searches and display the results in text or HTML format, or in an interactive HTML window linked to the GUI layout view. The interactive HTML report lets you quickly find paths with certain problems, such as large fanouts or transition degradation, and then view the path in the current design.

Alternatively, you can analyze a QoR snapshot in the GUI by choosing Timing > Query QoR Snapshot.

The command options let you filter and sort the query results and display those results in text or HTML format. The command does not perform any additional analysis of the design, but merely processes the report information already saved in the snapshot report files. Therefore, execution of the `query_qor_snapshot` command is much faster than execution of the `create_qor_snapshot` command.

The following examples demonstrate usage of the `query_qor_snapshot` command.

```
icc_shell> query_qor_snapshot -name preroute -filters "-wns -4.0,-3.0"
...
Path Group      Start Point      End Point      WNS
...            ...           ...          -3.312
...            ...           ...          -3.277
```

This example analyzes the snapshot named preroute and reports the paths having a worst negative slack between  $-4.0$  and  $-3.0$  time units.

```
icc_shell> query_qor_snapshot -name placeopt \
-filters "-wns ,-1.0 -fanout 40"
...
Path Group      Start Point      End Point      WNS      Large Fanout
...            ...           ...          -3.312      42
...            ...           ...          -3.277      42
```

This example reports the paths having a slack worse than  $-1.0$  time units and a fanout greater than 40.

```
icc_shell> query_qor_snapshot -hierarchy
```

Sometimes the paths with the worst timing start in one hierarchical block and end in another. Identifying and grouping these paths can be a challenging task. The `-hierarchy` option automates this process of finding potential path groupings that cross hierarchical boundaries so that the problem paths can be analyzed more efficiently. The `-hierarchy` option, when used by itself, finds all the timing violations that cross ILMs, block abstraction models, and hard macros in the design.

The following example finds violating paths that pass through modules A, B, and C:

```
icc_shell> query_qor_snapshot -hierarchy -through {A B C}
```

The following example uses the `-incremental` option, which keeps the previous analysis results (through modules A, B, and C), and applies an additional query about paths starting from module A or B and ending at module A or B.

```
icc_shell> query_qor_snapshot -hierarchy -incremental \
-from {A/* B/*} -to {A/* B/*}
```

The following example reads the snapshot named max\_logic\_level and specifies the -filters option to report all paths between logic levels 2 and 14.

```
icc_shell> query_qor_snapshot -name max_logic_level \
    -filters "-logic_level 2,15"
```

Note that the paths of logic level 2 are included but the paths of logic level 15 are excluded in the report.

The following example reports paths that start from module C and end at module B, having a worst negative slack worse than -3.0 ns or a fanout more than 40.

```
icc_shell> query_qor_snapshot -name my_snapshot \
    -hierarchy -from top/A/C/* -to top/B/* \
    -filters "-wns ,-3.0 -fanout 40"
```

For more information about the `query_qor_snapshot` command, see the man page for the command.

---

## Analyzing Timing Results in the GUI

In addition to generating timing reports in HTML or text format by using the `query_qor_snapshot` command, you can also use the command to invoke a Categorized Timing Report Interactive Viewer in the GUI. The interactive viewer provides a fast and user-friendly way to analyze timing results during early design stages. To help you debug the causes of timing issues, the viewer contains hypertext links of paths and data that point to the timing reports. To enable you to visualize the selected paths in the design, the viewer cross-highlights the paths in an open layout view.

To open a Categorized Timing Report Interactive Viewer, you must first generate a QoR snapshot by using the `create_qor_snapshot` command and then specify the `query_qor_snapshot -display` command.

For example, to open the viewer with the default filter settings, enter

```
icc_shell> create_qor_snapshot -name my_snapshot
icc_shell> query_qor_snapshot -name my_snapshot -display
```

**Figure 6-10** displays a typical view of the Categorized Timing Report Interactive Viewer.

*Figure 6-10 Categorized Timing Report Interactive Viewer*



For more information about the Categorized Timing Reporting Interactive Viewer, see IC Compiler Help.

The following sections describe the features commonly used during timing analysis:

- [Applying Filters](#)
- [Creating Subgroups](#)
- [Analyzing the Clock Tree Synthesis Results](#)

## Applying Filters

You can apply filters to selected paths in the design by using the following methods:

- Check the filters in the Query QoR Snapshot menu by choosing Timing > Query QoR Snapshot in the GUI.
- Use the `-filters` option of the `query_qor_snapshot` command.

For example, the following command reports all paths that have a worst negative slack less than zero:

```
icc_shell> query_qor_snapshot -name my_snapshot -filters "-wns ,0"
```

The following example reports all paths that meet any of the specified filter requirements:

```
icc_shell> query_qor_snapshot -name my_snapshot \
    -filters "-wns -4.0 -transition_degradation 5.0 \
    -slew_degradation 4.0 -fanout 20"
```

If you do not specify the `-filters` option, the `query_qor_snapshot` command automatically applies a set of default filters. The default filter settings for the maximum condition are shown in the following example:

```
icc_shell> query_qor_snapshot -name my_snapshot \
    -filters "-wns ,0 -zero_path ,0 -fanout 40 \
    -transition_degradation 2.0 -slew_degradation 2.0 -logic_level 50"
```

For a complete list of filters, see the `query_qor_snapshot` man page.

When you enable the top-level view by specifying the `-hierarchy` option, the `query_qor_snapshot` command automatically generates a report of all violating paths between the extracted timing models (ETMs), ILMs, block abstraction models, and hard macros. You can apply filters or expand the top-level paths by specifying the `-to`, `-from`, and `-through` options.

## Creating Subgroups

You can create subgroups of selected paths to manage a large number of paths in the categorized timing reports. To create subgroups, specify the `-subgroup` option with the allowed subgroup options of the `query_qor_snapshot` command. You can optionally specify subgroup names. If you do not specify the subgroup names, IC Compiler automatically assigns a name to each subgroup, such as Q1 or Q2. A subgroup named Others is created by default, which contains all remaining paths that are not included in the subgroups created by the `-subgroup` option.

The following restrictions apply when you specify the `-subgroup` option:

- The allowed subgroup options to select and sort paths for each subgroup include `-columns`, `-filters`, `-and`, `-group_by`, `-sort_by`, and `-case_sensitive`.
- You cannot specify the `-subgroup` option with the `-hierarchy`, `-incremental`, and `-clock_tree_only` options.

You can specify the `-subgroup` option multiple times for each `query_qor_snapshot` command. Each subgroup consists of paths that meet the requirements specified by the `-filters` option for that subgroup. The paths available to subsequent subgroups are those paths that do not meet the requirements of the options specified by the preceding subgroups.

For example, the following command creates three subgroups, WNS\_group, Trans\_deg, and an arbitrary subgroup name assigned by IC Compiler, in addition to the Others default subgroup.

```
icc_shell> query_qor_snapshot -name my_snapshot \
    -subgroup {"WNS_group" -group_by path_group -sort_by wns \
        -filters "-wns ,0"} \
    -subgroup {"Trans_deg" -sort_by startpoint \
        -filters "transition_deg 2.0"} \
    -subgroup {-filters "-w_deg 2.0"}
```

## Analyzing the Clock Tree Synthesis Results

You can also use the Categorized Timing Report Interactive Viewer to analyze the results of clock tree synthesis. For example, the following commands open the viewer with the default filter settings:

```
icc_shell> create_qor_snapshot -name my_snapshot -clock_tree
icc_shell> query_qor_snapshot -name my_snapshot -clock_tree_only -display
```

For more information about using the viewer to analyze clock tree synthesis, see [“Generating Categorized Timing Reports for Clock Tree Synthesis” on page 7-124](#).

---

## Placement Analysis Tools in the GUI

The IC Compiler graphical user interface (GUI) provides a wide range of tools for analyzing and visualizing the quality of results after placement. To generate a layout view showing the desired quality-of-results parameter, open the Visual Mode or Map Mode panel (View > Visual Mode or View > Map Mode), and from the pull-down menu in the panel, select the desired type of report. [Figure 6-11](#) shows the types of visual reports available in the Visual Mode and Map Mode panels.

Figure 6-11 Report Types in the Visual Mode and Map Mode Panels



After you select the desired type of visual report, the panel changes to show the options for that type of display. Select the desired options and click the Reload button, which opens a dialog box that typically offers some additional options. In the dialog box, click OK to update the display.

Some of the GUI features commonly used after placement are described in the following sections.

## Cell Density Map

A cell density map is a typical GUI report. When you select Cell Density as the Map Mode, the Map Mode panel offers you the option to specify the analysis grid dimensions, solid or unfilled grid units, the number of histogram bins, the bin threshold levels, and the utilization text display. [Figure 6-12](#) shows a typical cell density map.

*Figure 6-12 Cell Density Map, Full-Chip View*



To generate a chip density map, IC Compiler divides the layout into a grid of squares measuring five standard-cell heights on each side. It finds the area utilization in each grid square and then color-codes each square according to the utilization value. It also displays a histogram showing the number of grid squares in each of the utilization value bins. When the view is zoomed in enough, the utilization values are displayed inside the grid squares, as shown in [Figure 6-13](#). Otherwise, the text values are omitted from the display. [Figure 6-13](#) shows both a solid-filled grid display and an unfilled grid display.

**Figure 6-13 Cell Density Maps With and Without Solid Filled Grids**

Cell Density Map With Solid Filled Grids



Cell Density Map Without Solid Filled Grids



## Congestion Maps

A congestion map can help you visualize the quality of placement with respect to the avoidance of routing congestion. An example is shown in [Figure 6-14](#).

*Figure 6-14 Global Route Congestion Map*



To generate a congestion map, choose **Route > Global Route Congestion Map** in the GUI and click Reload in the Map Mode dialog box. You can also generate congestion maps based on the track assignment and detail routing in your design. To generate a congestion map based on track assignment, choose **Route > Track Assign Congestion Map** in the GUI. To generate a congestion map based on detail routing, choose **Route > Detail Route Congestion Map** in the GUI. For more information about the congestion maps, see [“Analyzing Congestion” on page 8-90](#).

## Hierarchy Visual Mode

The hierarchy visual mode is a display of the design with cells highlighted and color-coded according to block membership or levels of hierarchy. By default, the layout display shows the cells belonging to each top-level block highlighted in its own color, as shown in [Figure 6-15](#). A histogram-like bar graph shows the number of cells belonging to each top-level block, identified by name.

*Figure 6-15 Hierarchy Visual Mode*



You can also highlight cells using a different color for each second-level hierarchical block or each third-level hierarchical block, and so on, or you can highlight only the cells belonging to one or more particular hierarchical blocks, identified by name, at any level. You can set the hierarchical coloring options in the dialog box opened by clicking the Reload button.

## Clock Tree Visual Mode

The clock tree visual mode highlights the flylines and cells of a clock tree using a different color for each buffer level of the tree. For example, [Figure 6-16](#) shows the connections in levels 0, 1, and 2 of the sys\_clk clock tree, with the level 0 in yellow, level 1 in magenta, and level 2 in blue. This display can help you visualize the extent and approximate route lengths of the clock tree. A histogram-like bar graph shows the number of objects at each level of the clock tree.

*Figure 6-16 Clock Tree Visual Mode*



A dialog box displayed by clicking the Reload button lets you choose the clock, the clock levels, and the types of objects to be highlighted: levels, sinks, preexisting cells, inverters, or buffers.

## Net Connections in Area Visual Mode

The net connections in area visual mode lets you visualize the nets enclosed in or crossing a specified rectangular area of the design and examine the properties of those nets. To display net connections in an area, first select Net Connections In Area in the Visual Mode panel. Click Reload. In the dialog box, you can enter the coordinates of two corners of the desired area, or you can drag a rectangle directly in the layout view. You can also specify the types of nets to be displayed: signal and clock nets by default, and optionally power, ground, tie-high, and tie-low nets. Then click OK to update the display.

[Figure 6-17](#) shows an example of a net connections in area display superimposed on a global route congestion map. The area of interest is the white dotted rectangle, which was drawn to analyze nets in a region of high congestion. There are three types of flyline connections highlighted in the view, called the local, global, and pass-through connections.

*Figure 6-17 Net Connections in Area, Flyline Display*



The local connections, shown in magenta, are completely enclosed by the rectangle. The global connections, shown in orange, are the nets that have one or more pins both inside and outside the rectangle. The pass-through connections, shown in red, have pins outside of the rectangle only; the nets are expected to pass through the rectangle without connecting to any pins inside the rectangle.

You can optionally turn off the display of flylines and show the connection pins instead by checking the “Show only pins” option in the Net Connections In Area panel. See [Figure 6-18](#). You can also separately enable or disable the display of local, global, or pass-through type pins or net connections by checking or unchecking the respective options in the Visual Mode panel.

*Figure 6-18 Net Connections in Area, Pin-Only Display*



The three types of net connections highlighted in the net connections in area view traverse the designated rectangular area in different ways, as demonstrated in [Figure 6-19](#).

Connections are local if all the pins of the net are inside the designated area. Connections are global if one or more pins of the net are both inside and outside the area. Connections are pass-through if all the pins of the net are outside the area and the connections are expected to pass through the area.

*Figure 6-19 Local, Global, and Pass-Through Connections*



In the net connections in area display, a bar graph shows the numbers of local, global, and pass-through nets. To get more information about these nets in a category, select the category in the bar graph and then click the List button. This opens a table in a new dialog box. The table lists the local and hierarchical net names, net types, number of pins, and other information in the nets. From this table, you can change the types of net information displayed, highlight specific nets in the layout, generate histograms of the net data, and export the data to a spreadsheet.

The net connections in area display capability lets you determine the net topology in a particular region and observe the properties of the nets in that area. This feature works with both routed and unrouted designs. You can analyze the nets that cross a specific area and use the information to change the floorplan or add constraints such as blockages. For example, excessive local nets might imply that utilization changes are needed, or excessive global or pass-through nets might imply that floorplan or placement constraint changes are needed.

## Refining Placement

If your design shows large timing or violations after you run the `place_opt` command, adjust the `place_opt` options and rerun `place_opt`, as described in “[Performing Placement and Optimization](#)” on page 6-26.

If your design shows small timing or violations after you run `place_opt`, run `psynopt` to fix these violations, as described in “[Using Physical Optimization](#)” on page 6-36.

If your design has congestion violations after you run `place_opt`, rerun `place_opt` with high-effort congestion reduction (-congestion option). If your design still has congestion violations, you can refine the placement to fix these violations.

To refine the placement, use the `refine_placement` command (or choose Placement > Refine Placement in the GUI). The `refine_placement` command performs incremental placement and legalization.

[Table 6-8](#) describes the available `refine_placement` options.

*Table 6-8 refine\_placement Options*

| GUI object                                       | Command option                                             | Description                                                                                                                                                              |
|--------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| “Congestion optimization effort” option          | <code>-congestion_effort low   medium   high</code>        | Improve the quality of results or reduce runtime.<br>Higher effort levels use additional runtime in an attempt to improve the quality of results. The default is medium. |
| “Perturbation level effort” option               | <code>-perturbation_level min   medium   high   max</code> |                                                                                                                                                                          |
| “Whole chip” option                              | N/A                                                        | Perform incremental placement and legalization on the entire chip.                                                                                                       |
| “Specified region” option, plus Coordinates list | <code>-coordinate {llx lly urx ury}</code>                 | Perform incremental placement and legalization on the specified region.                                                                                                  |
| “Snap to” list box                               | N/A                                                        |                                                                                                                                                                          |

*Table 6-8 refine\_placement Options (Continued)*

| GUI object                                                 | Command option                            | Description                                                                                                                                                                                                                                                                |
|------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| “Ignore scan-chain connections during placement” check box | <code>-ignore_scan</code>                 | Ignores the scan chain connections during placement. By default, the command considers scan nets.                                                                                                                                                                          |
| “Continue with missing scan definitions” check box         | <code>-continue_on_missing_scandef</code> | Specifies to continue placement when the design contains scan chains but no SCANDEF data. By default, missing SCANDEF data causes the command to exit with an error message. Setting this option enables the placer to continue with a warning and results in reduced QoR. |

To refine the placement with a minimum impact on QoR, use the medium-effort congestion removal:

```
icc_shell> refine_placement -congestion_effort medium
```

To achieve the best congestion removal, use high-level perturbation, and then perform physical optimization:

```
icc_shell> refine_placement -perturbation_level high
icc_shell> psynopt
```

# 7

## Clock Tree Synthesis

---

This chapter provides detailed information about the IC Compiler clock tree synthesis capability.

This chapter contains the following sections:

- Prerequisites for Clock Tree Synthesis
- Analyzing the Clock Trees
- Defining the Clock Trees
- Specifying Clock Tree Exceptions
- Specifying the Clock Tree References
- Defining Clock Cell Spacing Rules
- Specifying Clock Tree Synthesis Options
- Specifying Clock Tree Optimization Options
- Inserting User-Specified Clock Trees
- Handling Specific Design Characteristics
- Verifying the Clock Trees
- Implementing the Clock Trees
- Implementing Clock Meshes

- Using Batch Mode to Reduce Runtime
- Analyzing the Clock Tree Results
- Fine-Tuning the Clock Tree Synthesis Results
- Analyzing and Refining the Design

---

## Prerequisites for Clock Tree Synthesis

Before you run clock tree synthesis, ensure that your design and libraries meet the prerequisites described in the following sections.

---

### Design Prerequisites

Before running clock tree synthesis, your design should meet the following requirements:

- The design is placed and optimized.

Use the `check_legality -verbose` command to verify that the placement is legal. Running clock tree synthesis on a design that does not have a legal placement might result in long runtimes and reduced QoR.

The estimated QoR for the design should meet your requirements before you start clock tree synthesis. This includes acceptable results for

- Congestion

If congestion issues are not resolved before clock tree synthesis, the addition of clock trees can increase congestion. If the design is congested, you can rerun `place_opt` with the `-congestion` and `-effort high` options, but the runtime can be long.

- Timing
- Maximum capacitance
- Maximum transition time

To ensure that the clock tree can be routed, verify that the placement is such that the clock sinks are not in narrow channels and that there are no large blockages between the clock root and its sinks. If these conditions occur, fix the placement before running clock tree synthesis.

- The power and ground nets are prerouted.
- High-fanout nets, such as scan enables, are synthesized with buffers.

---

## Library Prerequisites

Before you run clock tree synthesis, your libraries must meet the following requirements:

- Any cell in the logic library that you want to use as a clock tree reference (a buffer or inverter cell that can be used to build a clock tree) or for sizing of gates on the clock network must be usable by clock tree synthesis and optimization.

By default, clock tree synthesis and optimization cannot use buffers and inverters that have the `dont_use` attribute to build the clock tree. To use these cells during clock tree synthesis and optimization, you can either remove the `dont_use` attribute by using the `remove_attribute` command or you can override the `dont_use` attribute by specifying the cell as a clock tree reference by using the `set_clock_tree_references` command, as described in “[Specifying the Clock Tree References](#)” on page 7-27.

- The physical library should include
  - All clock tree references (the buffer and inverter cells that can be used to build the clock trees)
  - Routing information, which includes layer information and nondefault routing rules
- TLUPlus models must exist.

Extraction requires these models to estimate the net resistance and capacitance.

---

## Analyzing the Clock Trees

Before running clock tree synthesis, analyze each clock tree in your design to determine its characteristics and its relationship to other clock trees in the design.

For each clock tree, determine

- What the clock root is
- What the desired clock sinks and clock tree exceptions are

IC Compiler supports the following types of clock tree exceptions: exclude pins, stop pins, float pins, don't touch subtrees, don't buffer nets, and don't size cells.

- Whether the clock tree contains preexisting cells, such as clock-gating cells

If your design contains existing clock trees, you might want to either identify them or remove them before running clock tree synthesis. For information about handling existing clock trees, see “[Handling Existing Clock Trees](#)” on page 7-60.

- Whether the clock tree converges, either with itself (a convergent clock path) or with another clock tree (an overlapping clock path)

- Whether the clock tree has timing relationships with other clock trees in the design, such as interclock skew requirements
- What the logical design rule constraints (maximum fanout, maximum transition time, and maximum capacitance) are
- What the routing constraints (routing rules and metal layers) are

Use this information when you define the clock trees and to validate that IC Compiler has the correct clock tree definitions.

Note:

You can generate clock tree reports to analyze the clock tree structure, even before you perform clock tree synthesis and optimization. For information about generating clock tree reports, see “[Generating Clock Tree Reports](#)” on page 7-120.

---

## Defining the Clock Trees

IC Compiler uses the clock sources defined by the `create_clock` command as the clock roots and derives the default set of clock sinks by tracing through all cells in the transitive fanout of the clock roots. You can designate either an input port or internal hierarchical pin as a clock source. To disallow clock sources defined on a hierarchical pin, set the `cts_enable_clock_at_hierarchical_pin` variable to `false` before using the `create_clock` command. This variable is `true` by default.

Note:

IC Compiler does not synthesize a clock tree if its source is set to a constant value by using `set_case_analysis`.

In addition to simple clock trees, IC Compiler also supports cascaded clock trees. A cascaded clock tree contains another clock tree in its fanout. The nested clock tree can either have its own source identified by the `create_clock` command or be a generated clock identified by the `create_generated_clock` command.

---

## Cascaded Clocks

If a nested clock tree has its own source, as shown in the example that is given in [Figure 7-1](#), IC Compiler considers the source pin of the driven clock (`clk2` in this example) to be an implicit exclude pin of the driving clock (`clk1` in this example). Sinks of the driven clock are not considered sinks of the driving clock.

*Figure 7-1 Cascaded Clock With Two Source Clocks*



To verify that the clock sources are correctly defined, use the `check_clock_tree` command.

## Cascaded Generated Clocks

If a nested clock tree has a generated source, as shown in [Figure 7-2](#), IC Compiler traces back to the master-clock source from which the generated clock is derived and considers the sinks of the generated clock to be the sinks of the driving clock tree.

*Figure 7-2 Cascaded Clock With Generated Clock*



Incorrectly defining the master-clock source, as in the following cases, results in poor skew and timing QoR.

- If IC Compiler cannot trace back to the master-clock source, the tool cannot balance the sinks of the generated clock with the sinks of its source.
- If the master-clock source is not a clock source defined by the `create_clock` or `create_generated_clock` command, IC Compiler cannot synthesize a clock tree for the generated clock or its source.

Use the `check_clock_tree` command to verify that your master-clock sources are correctly defined.

If a nested clock tree has a generated source that is defined at the intersection of overlapping clocks, IC Compiler traces back to the master clock source from which the generated clock is derived and considers the source pin of the generated clock on a per

clock basis during synthesis. By default, IC Compiler clock tree synthesis supports querying phase delay and clock tree exceptions for each clock domain to achieve the best QoR for cascaded generated clocks with overlapping clocks.

For example, assume that a flip-flop inside the clk1 and clk2 overlapping domains has a generated clock, genclk2, which is defined at its Q output and which uses clk2 as the master clock. If you perform clock tree synthesis on clk2, the clock tree after that flip-flop is synthesized and balanced as a generated clock of clk2, as is shown in [Figure 7-3](#).

*Figure 7-3 Cascaded Generated Clock with Overlapping Clock Domains*



## Identifying the Clock Tree Endpoints

Clock paths have two types of endpoints:

- Stop pins

Stop pins are the endpoints of the clock tree that are used for delay balancing. During clock tree synthesis, IC Compiler uses stop pins in calculations and optimizations for both design rule constraints and clock tree timing (skew and insertion delay).

Stop pins are also referred to as sink pins.

- Exclude pins

Exclude pins are clock tree endpoints that are excluded from clock tree timing calculations and optimizations. IC Compiler uses exclude pins only in calculations and optimizations for design rule constraints.

IC Compiler traces the transitive fanout from the clock roots to determine the implicit stop pins (the default sink pins) and the implicit exclude pins.

When IC Compiler finds a pin in the clock's transitive fanout that is defined as a clock pin of either a sequential cell (a latch or flip-flop) or a macro cell, it adds that pin to the default set of clock sinks (unless the fanout of that cell drives a generated clock).

If the fanout of a sequential cell drives a generated clock, IC Compiler considers the clock pin to be an implicit nonstop pin and traces through the sequential cell to locate the clock tree endpoints. In addition, IC Compiler considers the clock input pins of integrated clock-gating (ICG) cells to be implicit nonstop pins.

IC Compiler defines the following clock endpoints as implicit exclude pins:

- Source pins of clock trees in the fanout of another clock
- Nonclock input pins of sequential cells
- Multiplexer select pins
- Three-state enable pins
- Output ports
- Incorrectly defined clock pins (for example, the clock pin does not have trigger edge information or does not have a timing arc to the output pin)
- Buffer or inverter input pins that are held constant (by using `set_case_analysis`)
- Input pins of combinational cells or integrated clock-gating cells that do not have any fanout or that do not have any enabled timing arcs

Verify that the default sink pins (implicit stop pins), implicit nonstop pins, and implicit exclude pins are accurate by generating a clock tree exceptions report, as described in “[Generating Clock Tree Reports](#)” on page 7-120.

If the default sink pins, implicit nonstop pins, and implicit exclude pins are correct, you are done with the clock tree exception definition. Otherwise, first identify any timing settings, such as disabled timing arcs and case analysis settings, that affect the clock tree traversal. To identify disabled timing arcs in your design, use the `report_disable_timing` command. To identify case analysis settings in your design, use the `report_case_analysis` command. Remove any timing settings that cause an incorrect clock tree definition.

You can modify the set of sink (stop) pins, nonstop pins, and exclude pins by setting clock tree exceptions, as described in “[Specifying Clock Tree Exceptions](#)” on page 7-13.

## Analyzing Clock Sink Groups

A clock sink group is a group of clock sinks driven directly by a single net. The sink group assumes the net name. As shown in [Figure 7-4](#), the CKA net drives 1000 sinks, the MXA net drives 5000 sinks, and the MXB net drives 6000 sinks to form three clock sink groups, CKA, MXA, and MXB.

*Figure 7-4 Example of Clock Sink Groups*



Sink groups can have timing relationships when an endpoint in a sink group has one or more startpoints or endpoints in another sink group. Each startpoint-and-endpoint pair forms one timing relationship path. To better understand the clock structure, you can report sink groups and their timing relationships to guide you in constraining the timing paths between sink groups before running clock tree synthesis. Analyzing sink groups at an early design stage can help balance the timing between sink groups during clock tree synthesis.

To report sink groups and their timing relationships, specify the `-sink_group` option with the `report_clock_tree` command.

Sink groups can overlap because each sink group can be in more than one clock domain. When sink group overlapping occurs, the `report_clock_tree -sink_group` command issues a warning message by default. To suppress the warning message, set the `timing_enable_multiple_clocks_per_reg` variable to `true`, changing it from its default of `false`.

The following sections describe how to control the sink group reporting options:

- [Setting Sink Group Options](#)
- [Ignoring Clock Tree Exceptions](#)
- [Ignoring Buffers and Inverters](#)

## Setting Sink Group Options

When you specify the `-sink_group` option of the `report_clock_tree` command or choose Report Clock Tree > Sink Group in the GUI and select the Sink Group tab, you can also set the options described in [Table 7-1](#) to refine the reporting of sink groups.

*Table 7-1 Options for Refining Sink Group Reports*

| Command option (GUI option)                                                                                 | Description                                                                                                                                                                                                                                                                                                                                    |
|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-clock_trees clock_tree_list</code><br>("Clock tree names" text box)                                  | Reports the specified clock trees only.<br>By default, the command reports all currently defined clock trees.                                                                                                                                                                                                                                  |
| <code>-sink_group_ignore_cts_exceptions</code><br>("Ignore cts exceptions" check box)                       | Ignores the clock tree exceptions, but excludes the nonstop pin exception, when traversing the clock trees to find the sink groups.<br>For more information, see " <a href="#">Ignoring Clock Tree Exceptions</a> " on page 7-11.                                                                                                              |
| <code>-sink_group_timing_relationship_limit limit</code><br>("Timing Relationship limit" text box)          | Reports sink groups that have timing relationships with other sink groups that are less than or equal to the specified limit.<br>If you set the limit to zero, the command reports only sink groups without any timing relationships.<br>By default, the limit is infinite, and the command reports all sink groups with timing relationships. |
| <code>-sink_group_sort_by clock   sink_group</code><br>("Clock" or "Sink group" option)                     | Sorts the first-level text output either by clock or by sink group.<br>When you specify <code>clock</code> , which is the default, the sort key is the sink number under the clock. When you specify <code>sink_group</code> , the sort key is the timing relationship number. A tie is broken by the clock or sink group name.                |
| <code>-sink_group_sort_order ascending   descending</code><br>("Ascending" or "Descending" option)          | Reports sink groups in ascending or descending order. The default is <code>ascending</code> .                                                                                                                                                                                                                                                  |
| <code>-sink_group_detail_file file_name</code><br>("Detail output file" text box)                           | Writes the details of sink group information to the specified file.                                                                                                                                                                                                                                                                            |
| <code>-sink_group_timing_relationship_file file_name</code><br>("Timing relationship output file" text box) | Writes the timing relationships of the sink pairs in the design, but not the sink group information. Depending on the design, the file size could be large, so use this option with caution.                                                                                                                                                   |

*Table 7-1 Options for Refining Sink Group Reports (Continued)*

| <b>Command option (GUI option)</b>                                                | <b>Description</b>                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-sink_group_ignore_buf_inv</code><br>("Ignore buffers/inverters" check box) | Treats buffers and inverters as transparent cells during analysis if no clocks or generated clocks are defined on them.<br><br>For more information, see " <a href="#">Ignoring Buffers and Inverters</a> " on page <a href="#">7-12</a> . |
| <code>-sink_group_ignore_icg</code><br>("Group ignore ICG" check box)             | Treats integrated clock-gating cells as transparent cells during analysis if no clocks or generated clocks are defined on them.                                                                                                            |

## Ignoring Clock Tree Exceptions

By default, the `report_clock_tree -sink_group` command respects the clock tree exceptions when traversing the clock tree network. To ignore the clock tree exceptions, specify the `-sink_group_ignore_cts_exceptions` option. [Table 7-2](#) shows how the command validates a sink with and without this option.

*Table 7-2 Validating Sinks With and Without Clock Tree Exceptions*

| <b>Clock tree exception</b> | <b>Default</b> | <b>Ignoring clock tree exceptions<br/><code>-sink_group_ignore_cts_exceptions</code></b> |
|-----------------------------|----------------|------------------------------------------------------------------------------------------|
| Default sink                | Counted        | Counted                                                                                  |
| Explicit stop pin           | Counted        | Ignored                                                                                  |
| Float pin                   | Counted        | Ignored                                                                                  |
| Explicit ignore pin         | Not counted    | Ignored                                                                                  |
| Implicit ignore pin         | Not counted    | Ignored                                                                                  |
| Nonstop pin                 | Ignored        | Ignored                                                                                  |

The following restrictions apply:

- When an explicit stop pin or a float pin is not an endpoint of a timing relationship, the tool does not count the timing relationship.
- The tool does not support per-clock exceptions on sinks.

For example, a sink group contains one pin that is defined as a stop pin in one clock domain and as a nonstop pin in another clock domain. When this type of conflict occurs, the tool issues a warning message and excludes this pin from the sink group.

## Ignoring Buffers and Inverters

By default, the `report_clock_tree -sink_group` command does not allow the driving nets to pass through preexisting buffers and inverters. As shown in [Figure 7-5](#), the net0 net drives two sink groups, net1 and net2, with a buffer before each sink group. Because the net0 net does not pass through buffers, the resulting sink groups are net1 with 1000 sinks and net2 with 2000 sinks.

*Figure 7-5 Example of Clock Sink Groups Driven by Buffers*



For the same example shown in [Figure 7-5](#), to enable the net0 net to pass through preexisting buffers and inverters, specify the `-sink_group_ignore_buf_inv` option with the `report_clock_tree` command. Then, the command treats the buffers as transparent cells and reports the net0 sink group with 3000 sinks, as shown in [Figure 7-6](#).

*Figure 7-6 Example of Passing Through Buffers*



The pass-through effect does not occur for a buffer or inverter on which a clock or generated clock has been defined.

---

## Defining the Clock Root Attributes

If the clock root is an input port (without an I/O pad cell), you must accurately specify the driving cell of the input port. A weak driving cell does not affect logic synthesis, because logic synthesis uses ideal clocks. However, during clock tree synthesis, a weak driving cell can cause IC Compiler to insert extra buffers as the tool tries to meet the clock tree design rule constraints, such as maximum transition time and maximum capacitance.

For example, if clock tree CLK1 has input port CLK1 as its root and CLK1 is driven by cell CLKBUF, enter

```
icc_shell> set_driving_cell -lib_cell mylib/CLKBUF [get_ports CLK1]
```

If you do not specify a driving cell (or drive strength), IC Compiler assumes that the port has infinite drive strength.

If the clock root is an input port with an I/O pad cell, you must accurately specify the input transition time of the input port.

For example, if clock tree CLK1 has input port CLK1 as its root and the I/O pad cell has already been inserted, enter

```
icc_shell> set_input_transition -rise 0.3 [get_ports CLK1]
icc_shell> set_input_transition -fall 0.2 [get_ports CLK1]
```

---

## Specifying Clock Tree Exceptions

To define clock tree exceptions, use the `set_clock_tree_exceptions` command or choose Clock > Set Clock Tree Exceptions in the GUI. You can set clock tree exceptions on pins or hierarchical pins. If a pin is on paths in multiple clock domains, you can define different clock tree exceptions for each clock domain.

By default, when you use the `set_clock_tree_exceptions` command, the clock tree exceptions apply to all clocks for all multicorner-multimode scenarios. You can specify clock tree exceptions on a per-clock basis for the current scenario by using the `-clocks` option.

For example, to specify a stop pin exception for pins on the path in the CLK1 clock domain, enter

```
icc_shell> set_clock_tree_exceptions -stop_pins \
           -clocks CLK1 [get_pins pins_on_the_clock_path]
```

When you use the `-clocks` option, the following restrictions apply:

- The specified clock tree exceptions are for the current scenario.
- The allowed clock tree exceptions are nonstop pins, exclude pins, float pins, and stop pins.
- The specified clocks must come from the current scenario.
- The specified clocks must be master clocks, which are defined by the `create_clock` command. If you specify generated clocks, the tool issues an error message.
- The specified pins should be on the paths of either the specified master clocks or the generated clocks based on the specified master clocks.

When you use the `set_clock_tree_exceptions` command without the `-clocks` option, the tool

- Applies the clock tree exceptions to all clocks for all multicorner-multimode scenarios.

To specify clock tree exceptions for the current scenario only, use the `-current_scenario` option. Do not use the `-current_scenario` option with the `-clocks` option.

- Defines the clock tree exceptions for all master clocks that contain the paths of the pin, including the paths of the generated clocks.

For example, a master clock CLK1 has a generated clock GCLK1, which has a generated clock GGCLK1, and another master clock CLK2 has a generated clock GCLK2, which has a generated clock GGCLK2. The PIN\_A pin is on the paths of generated clocks GGCLK1 and GGCLK2, but not on the paths of the other clocks. When you use the following command, IC Compiler sets PIN\_A as a float pin for the CLK1 and CLK2 clock domains.

```
icc_shell> set_clock_tree_exceptions -float_pins [get_pins PIN_A]
```

**Table 7-3** describes the command options and GUI objects to set the clock tree exceptions supported by IC Compiler.

*Table 7-3 Clock Tree Exceptions*

| Command option                                                                                                                                            | GUI object                                                                                                                            | Description                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Pin Exceptions</b>                                                                                                                                     |                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                        |
| -non_stop_pins                                                                                                                                            | “Non stop pins” box                                                                                                                   | Nonstop pins are pins through which clock tree tracing continues.<br>For more information, see “ <a href="#">Specifying Nonstop Pins</a> ” on page 7-18.                                                                                                                                                                                               |
| -exclude_pins                                                                                                                                             | “Exclude pins” box                                                                                                                    | Exclude pins are clock tree endpoints that are not used in clock tree timing calculations and optimizations (they are used for design rule constraint calculations and optimizations).<br>For more information, see “ <a href="#">Identifying the Clock Tree Endpoints</a> ” on page 7-7 and “ <a href="#">Specifying Exclude Pins</a> ” on page 7-19. |
| -float_pins<br>-float_pin_logic_level<br>-float_pin_max_delay_fall<br>-float_pin_max_delay_rise<br>-float_pin_min_delay_fall<br>-float_pin_min_delay_rise | “Float pins” box“<br>Max delay fall” box<br>“Max delay rise” box<br>“Min delay fall” box<br>“Min delay rise” box<br>“Logic level” box | Float pins are clock sinks that have special insertion delay requirements.<br>For more information, see “ <a href="#">Specifying Float Pins</a> ” on page 7-20.                                                                                                                                                                                        |
| -stop_pins                                                                                                                                                | “Stop pins” box                                                                                                                       | Stop pins are clock tree endpoints that are used in calculations and optimizations for both design rule constraints and clock tree timing (skew and insertion delay).<br>For more information, see “ <a href="#">Identifying the Clock Tree Endpoints</a> ” on page 7-7 and “ <a href="#">Specifying Stop Pins</a> ” on page 7-23.                     |
| -dont_touch_subtrees                                                                                                                                      | “Don’t touch subtree pins” box                                                                                                        | Prevents modification of the clock network beyond the specified pins. IC Compiler considers the sinks of the don’t touch subtree when balancing clock delays or computing the clock skew.<br>For more information, see “ <a href="#">Specifying Don’t Touch Subtrees</a> ” on page 7-24.                                                               |

*Table 7-3 Clock Tree Exceptions (Continued)*

| <b>Command option</b>       | <b>GUI object</b>             | <b>Description</b>                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Net Exceptions</b>       |                               |                                                                                                                                                                                                                                                                                                                                                                  |
| -dont_buffer_nets           | “Don’t buffer nets” box       | Prevents buffering of the specified nets during clock tree synthesis. IC Compiler still performs global prerouting on these nets.<br><br>For more information, see “ <a href="#">Specifying Don’t Buffer Nets</a> ” on page 7-24.                                                                                                                                |
| <b>Cell Exceptions</b>      |                               |                                                                                                                                                                                                                                                                                                                                                                  |
| -dont_size_cells            | “Don’t size cells” box        | Identifies cells that should not be sized during clock tree synthesis and optimization.<br><br>For more information, see “ <a href="#">Specifying Don’t Size Cells</a> ” on page 7-25.                                                                                                                                                                           |
| -size_only_cells            | “Size only cells” box         | Specifies clock tree cells or instances that can only be sized but not moved during clock tree synthesis and optimization.<br><br>For more information, see “ <a href="#">Specifying Size-Only Cells</a> ” on page 7-25                                                                                                                                          |
| -dont_self_gate             | “Don’t self-gate” box         | Specifies the registers that should not be XOR self-gated.<br><br>For more information, see “ <a href="#">Using XOR Self-Gating to Save Dynamic Power</a> ” on page 7-64                                                                                                                                                                                         |
| <b>Hierarchy Exceptions</b> |                               |                                                                                                                                                                                                                                                                                                                                                                  |
| -preserve_hierarchy         | “Preserve hierarchy pins” box | Prevents clustering of clock sinks in the specified local hierarchies that have clock sinks in other logical hierarchies, so the clock pins of the specified logical hierarchies are preserved during clock tree synthesis and optimization.<br><br>For more information, see “ <a href="#">Preserving the Clock Pins of Existing Hierarchies</a> ” on page 7-26 |

To see the clock tree exceptions defined in your design, generate a clock tree exceptions report by running the `report_clock_tree -exceptions` command or by choosing Clock > Report Clock Tree in the GUI and selecting Exceptions.

You remove clock tree exceptions based on how they are defined:

- If a clock tree exception is defined without the `-clocks` option, use the `remove_clock_tree_exceptions` command without the `-clocks` option.
- If a clock tree exception is defined with the `-clocks` option, use the `remove_clock_tree_exceptions -clocks` command.

You can also remove clock tree exceptions by choosing Clock > Remove Clock Tree Exceptions in the GUI.

Note:

If your design contains sequential cells with unconnected outputs, the clock pins of these cells are marked as implicit ignore pins. When you run clock tree synthesis, these unloaded sequential cells are deleted from the design. As a result, at the end of clock tree synthesis, you no longer see these implicit ignore pins. To prevent the removal of these sequential cells, set the `physopt_delete_unloaded_sequential_cells` variable to `false` before running clock tree synthesis.

If your design contains dangling nets, the clock tree exceptions report might show false implicit ignore pins on these nets. If this happens, you can remove the false implicit ignore pins by saving your design and reopening it.

The following sections provide details for each of the clock tree exceptions.

---

## Precedence of Clock Tree Exceptions

If you issue the `set_clock_tree_exceptions` command multiple times for the same pin, the pin keeps the highest-priority exception. IC Compiler prioritizes the clock tree pin exceptions in the following order:

1. Nonstop pins
2. Exclude pins
3. Float pins
4. Stop pins

Note:

The don't touch subtree exception is compatible with the nonstop, exclude, float, or stop pin exception. You can set both exceptions on a pin, and clock tree synthesis honors both exceptions.

In the following example, PIN\_A is on the path in clock domain CLK1. The first command specifies PIN\_A as a float pin for CLK1. The second command specifies PIN\_A as an exclude pin, which takes higher precedence over a float pin exception. The third command attempts to specify PIN\_A as a stop pin. Because higher precedence is given to an exclude pin exception, PIN\_A remains an exclude pin for CLK1.

```
icc_shell> set_clock_tree_exceptions -clocks CLK1 \
    -float_pins [get_pins PIN_A]
icc_shell> set_clock_tree_exceptions -clocks CLK1 \
    -exclude_pins [get_pins PIN_A]
icc_shell> set_clock_tree_exceptions -clocks CLK1 \
    -stop_pins [get_pins PIN_A]
```

When you define multiple exceptions on the same pin, the `set_clock_tree_exceptions` command with the `-clocks` option always overrides the command without the `-clocks` option. The same rule applies even when the command without the `-clocks` option sets a higher-priority exception than the command with the `-clocks` option.

For example, the following commands set PIN\_A as a stop pin for CLK1 but a nonstop pin for other clocks.

```
icc_shell> set_clock_tree_exceptions -non_stop_pins [get_pins PIN_A]
icc_shell> set_clock_tree_exceptions -clocks CLK1 \
    -stop_pins [get_pins PIN_A]
```

After you set a clock tree exception on a pin globally, if you create a new clock definition that contains a path with that pin, the new clock definition inherits the same clock tree exception.

## Specifying Nonstop Pins

Nonstop pins are pins that would normally be considered endpoints of the clock tree, but instead IC Compiler traces through them to find the clock tree endpoints. The clock pins of sequential cells driving generated clocks are implicit nonstop pins. In addition, IC Compiler supports user-defined (or explicit) nonstop pins.

To specify a nonstop pin, use the `set_clock_tree_exceptions -non_stop_pins` command.

For example, to specify pin U2/CLK as a nonstop pin, enter

```
icc_shell> set_clock_tree_exceptions -non_stop_pins [get_pins U2/CLK]
```

To remove the nonstop pin definition from a pin, use the `remove_clock_tree_exceptions -non_stop_pins` command.

For example, to remove the nonstop pin definition from pin U2/CLK, enter

```
icc_shell> remove_clock_tree_exceptions -non_stop_pins [get_pins U2/CLK]
```

---

## Specifying Exclude Pins

Exclude pins are clock tree endpoints that are excluded from clock tree timing calculations and optimizations. IC Compiler uses exclude pins only in calculations and optimizations for design rule constraints. In addition to the exclude pins inferred by IC Compiler (the implicit exclude pins), IC Compiler supports user-defined (or explicit) exclude pins. For example, you might define an exclude pin to exclude all branches of the clock tree that fan out from some combinational logic or to exclude an implicit stop pin.

During clock tree synthesis, IC Compiler isolates exclude pins (both implicit and explicit) from the clock tree by inserting a guide buffer before the pin. Beyond the exclude pin, IC Compiler never performs skew or insertion delay optimization, but does perform design rule fixing.

To specify an exclude pin, use the `set_clock_tree_exceptions -exclude_pins` command.

For example, to exclude clock sink U2/CLK, enter

```
icc_shell> set_clock_tree_exceptions -exclude_pins [get_pins U2/CLK]
```

To remove the exclude pin definition from a pin, use the `remove_clock_tree_exceptions -exclude_pins` command.

For example, to remove the exclude pin definition from pin U2/CLK, enter

```
icc_shell> remove_clock_tree_exceptions -exclude_pins [get_pins U2/CLK]
```

For another example, assume that a clock tree also drives combinational logic, as shown in [Figure 7-7](#).

*Figure 7-7 Explicit Exclude Pin*

To exclude all branches of the clock tree that fan out from this point, enter

```
icc_shell> set_clock_tree_exceptions -exclude_pins [get_pins U2/A]
```

## Specifying Float Pins

Float pins are clock pins that have special insertion delay requirements. IC Compiler adds the float pin delay (positive or negative) to the calculated insertion delay up to this pin.

To specify a float pin and its timing characteristics, use the following `set_clock_tree_exceptions` options:

- `-float_pins [get_pins pin_list]`
- `-float_pin_max_delay_fall max_delay_fall_value`
- `-float_pin_max_delay_rise max_delay_rise_value`
- `-float_pin_min_delay_fall min_delay_fall_value`
- `-float_pin_min_delay_rise min_delay_rise_value`
- `-float_pin_logic_level logic_level_value`

The `-float_pin_logic_level` option specifies the number of logic levels beyond the float pin (this information is used for logic-level balancing). For more information about logic-level balancing, see “[Enabling Logic-Level Balancing](#)” on page 7-46.

Note:

If you use the `-float_pins` option, you must specify at least one of the float pin delay options or an error occurs.

IC Compiler assumes the active edge of the float pin based on the specified float delay options. [Table 7-4](#) describes the edge-aware float pin behavior.

*Table 7-4 Edge-Aware Float Pins Delays*

| Options specified                                                                                                                                | Active edge          | Comments                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fall delays only:<br>-float_pin_max_delay_fall<br>-float_pin_min_delay_fall                                                                      | Falling <sup>1</sup> | If only one of these options is specified, the specified value is used for both the minimum and maximum fall delay.                                                                                                                                                                  |
| Rise delays only:<br>-float_pin_max_delay_rise<br>-float_pin_min_delay_rise                                                                      | Rising <sup>1</sup>  | If only one of these options is specified, the specified value is used for both the minimum and maximum rise delay.                                                                                                                                                                  |
| Mix of rise and fall delays:<br>-float_pin_max_delay_fall<br>-float_pin_max_delay_rise<br>-float_pin_min_delay_fall<br>-float_pin_min_delay_rise | Both                 | If one of the fall delay options is not specified, the specified fall delay option is used for both the minimum and maximum fall delays.<br>If one of the rise delay options is not specified, the specified rise delay option is used for both the minimum and maximum rise delays. |

1. To define an edge-aware stop pin, set the appropriate float pin delay values to zero.

For example, to define an active-low float pin (so that clock tree synthesis considers only the falling edge), enter

```
icc_shell> set_clock_tree_exceptions -float_pins [get_pins U1/CLK] \
-float_pin_max_delay_fall 0.10 -float_pin_min_delay_fall 0.08
```

The clock tree exceptions report (`report_clock_tree -exceptions`) shows the float pin values only for the active edge. For example, the report for the float pin defined in the previous example shows

```
Explicit sync pins: 1
(F) U1/CLK ( - 0.100 - 0.080 )
```

The float pin delay values can be either positive or negative, depending on your timing requirements. To increase the path delay to a pin, specify a negative float pin delay. To decrease the path delay to a pin, specify a positive float pin delay.

For example, the following float pin exceptions result in a clock tree similar to that shown in Figure 7-8:

```
# Specifying a negative float pin
icc_shell> set_clock_tree_exceptions -float_pins U1/CLK \
    -float_pin_max_delay_rise -0.5 -float_pin_max_delay_fall -0.5

# Specifying a positive float pin
icc_shell> set_clock_tree_exceptions -float_pins U4/CLK \
    -float_pin_max_delay_rise 0.5 -float_pin_max_delay_fall 0.5
```

*Figure 7-8 Float Pin Timing*



For an example of defining float pins, see “[Handling Hard Macro Cells](#)” on page 7-60.

To remove the float pin definition from a pin, use the `remove_clock_tree_exceptions -float_pins` command.

## Specifying Float Pins for Multicorner Clock Tree Optimization

When you specify a float pin value on the leaf node of a clock tree, you must scale the float pin value to apply to each scenario corner. However, achieving a single float pin phase delay across all corners is impossible because cell delays differ in speed. The float pin values that you specify using the `set_clock_tree_exceptions` command apply only to the corners of the default clock tree synthesis scenario in which the clock tree synthesis constraints are specified.

For other corners, specify float pin values by using one of the following two ways:

- Scale float pin values based on the intrinsic speed of cells in different corners by using IC Compiler's automatic capability. For example, if the cells of a corner have a speed twice as fast as that of the default clock tree synthesis scenario, IC Compiler scales down the float pin values that you specify for the default clock tree synthesis scenario by half for the corner.
- Use the `set_clock_tree_exceptions` command with the `-max_float_pin_scale_factor` and the `-min_float_pin_scale_factor` options to specify float pin value scaling factors. You can set the scaling factors on a per scenario basis as shown in the following example:

```
icc_shell> current_scenario scn1
icc_shell> set_clock_tree_exceptions \
    -max_float_pin_scale_factor 1.0 -min_float_pin_scale_factor 0.6

icc_shell> current_scenario scn2
icc_shell> set_clock_tree_exceptions \
    -max_float_pin_scale_factor 0.9 -min_float_pin_scale_factor 0.5
```

---

## Specifying Stop Pins

Stop pins are the endpoints of the clock tree that are used for delay balancing. During clock tree synthesis, IC Compiler uses stop pins in calculations and optimizations for both design rule constraints and clock tree timing (skew and insertion delay).

The default clock sinks are implicit stop pins. In addition, IC Compiler supports user-defined (or explicit) stop pins. For example, you might define a stop pin to end a branch at an input to a combinational cell or to use an implicit exclude pin as a clock sink.

IC Compiler assigns a phase delay of zero to all stop pins (implicit and explicit) and uses this delay during delay balancing.

To specify a stop pin, use the `set_clock_tree_exceptions -stop_pins` command.

For example, to specify pin U2/A as a stop pin, enter

```
icc_shell> set_clock_tree_exceptions -stop_pins [get_pins U2/A]
```

To remove the stop pin definition from a pin, use the `remove_clock_tree_exceptions -stop_pins` command.

For example, to remove the stop pin definition from pin U2/A, enter

```
icc_shell> remove_clock_tree_exceptions -stop_pins [get_pins U2/A]
```

---

## Specifying Don't Touch Subtrees

In some cases you want to preserve a portion of an existing clock tree. You need to do this, for example, when two clock networks share part of some clock logic behind a multiplexer. The portion of the clock tree that is preserved is called a don't touch subtree.

To specify a don't touch subtree, specify the root pin of the don't touch subtree by using the `set_clock_tree_exceptions -dont_touch_subtrees` command.

Although IC Compiler does not make any modifications to the don't touch subtree during clock tree synthesis, it does propagate the clock tree attributes and the nondefault routing rules beyond the don't touch subtree. To prevent propagation of the clock attributes and the nondefault routing rules, set the `cts_traverse_dont_touch_subtrees` variable to `false`.

IC Compiler considers the sinks in the don't touch subtree when balancing clock delays and computing the clock skew.

To remove the don't touch subtree exception from a pin, use the `remove_clock_tree_exceptions -dont_touch_subtrees` command.

---

## Specifying Don't Buffer Nets

In some cases you might be able to improve the results by preventing IC Compiler from buffering certain nets (IC Compiler still performs global prerouting on these nets).

Note:

During clock tree synthesis, the don't buffer nets exception has priority over the clock tree design rule constraints. However, the clock tree specification in the clock tree configuration file has priority over the don't buffer nets exception.

To specify nets that should not be buffered, use the `set_clock_tree_exceptions -dont_buffer_nets` command.

For example, to specify net n1 as a don't buffer net, enter

```
icc_shell> set_clock_tree_exceptions -dont_buffer_nets [get_nets n1]
```

To remove the don't buffer net exception, use the `remove_clock_tree_exceptions -dont_buffer_nets` command.

For example, to remove the don't buffer net exception from net n1, enter

```
icc_shell> remove_clock_tree_exceptions -dont_buffer_nets [get_nets n1]
```

---

## Specifying Don't Size Cells

During clock tree synthesis and optimization, IC Compiler ignores the `dont_touch` attribute on cells and nets. To prevent sizing of cells on the clock path during clock tree synthesis and optimization, you must identify the cells as don't size cells.

To specify cells that should not be sized, use the `set_clock_tree_exceptions -dont_size_cells` command.

For example, to specify cell U1/U3 as a don't size cell, enter

```
icc_shell> set_clock_tree_exceptions -dont_size_cells [get_cells U1/U3]
```

To remove the don't size cell exception, use the `remove_clock_tree_exceptions -dont_size_cells` command.

For example, to remove the don't size cell exception from cell U1/U3, enter

```
icc_shell> remove_clock_tree_exceptions \
-dont_size_cells [get_cells U1/U3]
```

---

## Specifying Size-Only Cells

During clock tree synthesis and optimization, size-only cells can only be sized, not moved or split. If a size-only cell overlaps with an adjacent cell after sizing, the size-only cell might be moved during the legalization step. To specify size-only cells, use the `set_clock_tree_exceptions -size_only_cells` command.

For example, to specify cell U1/U3 as a size-only cell, enter

```
icc_shell> set_clock_tree_exceptions -size_only_cells [get_cells U1/U3]
```

To remove the size-only cell exception, use the `remove_clock_tree_exceptions -size_only_cells` command.

For example, to remove the size-only cell exception from cell U1/U3, enter

```
icc_shell> remove_clock_tree_exceptions \
-size_only_cells [get_cells U1/U3]
```

## Preserving the Clock Pins of Existing Hierarchies

In some cases, clock tree synthesis and optimization might cluster clock sinks from hierarchies to create new clock pins. You can prevent the clustering of clock sinks in the desired hierarchies that have clock sinks in other logical hierarchies by using the `set_clock_tree_exceptions -preserve_hierarchy` command, so the clock pins of the desired logical hierarchies are preserved.

For example, suppose your design has two hierarchical block instances I1 and I2 in the top level, and each block has clock pins CK1, CK2, and CKO, as shown in [Figure 7-9](#).

*Figure 7-9 Hierarchical Clock Pins*



To preserve pin CK1 in cell instance I1, enter

```
icc_shell> set_clock_tree_exceptions -preserve_hierarchy \
[get_pins I1/CK1]
```

To preserve pins CK1, CK2, and CKO in cell instance I2, enter

```
icc_shell> set_clock_tree_exceptions -preserve_hierarchy \
[get_cells I2]
```

To preserve pins CK1, CK2, and CKO in cell instances I1 and I2, enter

```
icc_shell> set_clock_tree_exceptions -preserve_hierarchy \
[get_references -hierarchical REG_A]
```

To remove the preserve-hierarchy exception, use the `remove_clock_tree_exceptions -preserve_hierarchy` command. If the specified hierarchical pins or cells contain any leaf pins or cells that are not in the clock network, the tool issues a warning message.

---

## Specifying the Clock Tree References

IC Compiler uses four clock tree reference lists:

- One for clock tree synthesis
- One for boundary cell insertion
- One for sizing
- One for delay insertion

By default, each clock tree reference list contains all the buffers and inverters in your technology library.

To fine-tune the results, you can restrict the set of buffers and inverters used for one or more of these operations. For example, if your clock tree has too many levels, it could be that the clock tree synthesis references have a low drive strength.

To define a clock tree reference list, use the `set_clock_tree_references` command (or choose Clock > Set Clock Tree References in the GUI). When you define a clock tree reference list, ensure that the buffers and inverters that you specify have a wide range of drive strengths, so that clock tree synthesis can select the appropriate buffer or inverter for each cluster.

Note:

The clock tree synthesis reference list must include at least one inverter, or clock tree synthesis fails. If you are using the default clock tree reference list, you must ensure that your target library contains at least one inverter that does not have a `dont_use` attribute. If you define a clock tree synthesis reference list, you must ensure that it contains at least one inverter.

**Table 7-5** shows the options used for generating the reference lists. If you specify a reference list, but do not select any of these options, the specified reference list is used for clock tree synthesis. If you specify a reference list with one or more of these options, the specified clock tree reference lists are created (the clock tree synthesis reference list is not changed).

*Table 7-5 Clock Tree Reference List Options*

---

| Reference list type     | Option                                                                          |
|-------------------------|---------------------------------------------------------------------------------|
| Clock tree synthesis    | N/A                                                                             |
| Boundary cell insertion | <code>-boundary_cell_only</code><br>("Boundary cell only" check box in the GUI) |

*Table 7-5 Clock Tree Reference List Options (Continued)*

| Reference list type | Option                                                                              |
|---------------------|-------------------------------------------------------------------------------------|
| Sizing              | <code>-sizing_only</code><br>("Sizing only" check box in the GUI)                   |
| Delay insertion     | <code>-delay_insertion_only</code><br>("Delay insertion only" check box in the GUI) |

When you run the `set_clock_tree_references` command, IC Compiler verifies that the cells you specify exist in the target libraries, and it generates a warning message if it cannot find a cell.

**Note:**

For multicorner-multimode designs, IC Compiler checks only the libraries associated with the clock tree synthesis scenario. You need to ensure that the specified clock references exist in the target library specified for the clock tree synthesis scenario.

When you explicitly include a cell in a clock tree reference list, IC Compiler can use the cell for the task associated with the reference list, even if the cell has a `dont_use` attribute. However, if you set the `dont_use` attribute on a cell after it is included in a clock tree reference list, IC Compiler honors the `dont_use` attribute.

IC Compiler uses this clock tree reference list for all clock trees.

If you issue the `set_clock_tree_references` command multiple times, the new references you specify are added to existing references. References you previously listed but omitted from a later list are not deleted. To delete references, use the `reset_clock_tree_references` command or choose Clock > Set Clock Tree References in the GUI and click Default.

For example, to create a clock tree synthesis reference list, enter

```
icc_shell> set_clock_tree_references \
-references {clk1a6 clk1a9 clk1a15 clk1a27}
```

IC Compiler uses this clock tree reference list for all clock trees.

---

## Defining Clock Cell Spacing Rules

Clock cells consume more power than cells that are not in the clock network. Clock cells that are clustered together in a small area increase current densities for the power and ground rails, where a potential electromigration problem might occur. One way to avoid the problem is to set spacing requirements between clock cells. You set the spacing requirements by defining clock cell spacing rules for inverters, buffers, and integrated clock-gating cells in the clock network. Thus, you can prevent local clumping of the clock cells along a standard cell power rail between the perpendicular straps. You should not attempt to globally space the clock cells on the design because it can result in an area requirement larger than the size of the clock tree synthesis clusters of sinks.

To define clock cell spacing rules, use the `set_clock_cell_spacing` command:

- Set either or both of the `-x_spacing` and `-y_spacing` options to a nonzero value. The `-x_spacing` value is usually dependent on the library cell's drive strength and clock frequency. The `-y_spacing` value is usually less than half a row height. Each setting specifies the minimum distance, in microns, from the adjacent clock cells in the specified direction. If two adjoining clock cells both have a spacing value specified in a given direction, the sum of the spacing values applies. For example, if the `-x_spacing` option value is 5 for two adjoining clock cells, they are placed at least 10 microns apart in the x-direction.

You can relax the adjoining cell spacing rule by setting the `legalize_use_cts_max_spacing` variable. When this variable is set to `true`, IC Compiler uses the larger of the spacing settings between two adjoining cells instead of the sum of the spacing settings. For example, two adjoining clock cells, each with a `-x_spacing` option value of 5, are placed at least 5 microns apart in the x-direction.

**Note:**

Using a large spacing value increases the skew because the cells are spaced further away from the intended clusters of sinks.

- Optionally restrict the clock cell spacing rules to a collection of library cells by using the `-lib_cells` option or to a collection of clock names by using the `-clocks` option.

To report clock cell spacing rules, use the `report_clock_cell_spacing` command. The report categorizes information into three sections:

1. Clock cell spacing rules set by the `-lib_cell` option only or by no option.
2. Clock cell spacing rules set by the `-clocks` option only.
3. Clock cell spacing rules set by both the `-lib_cell` and `-clocks` options.

To remove clock cell spacing rules, use the `remove_clock_cell_spacing` command. You can specify the `-lib_cells` and `-clocks` options to remove clock cell spacing constraints from the specified library cells and clocks respectively.

If you use the `remove_clock_cell_spacing` command with

- The `-lib_cells` option

The command removes only the clock cell spacing rules defined by the `set_clock_cell_spacing -lib_cells` command with the specified library cells.

- The `-clocks` option

The command removes only the clock cell spacing rules defined by the `set_clock_cell_spacing -clocks` command with the specified clock names.

- Both the `-lib_cells` and `-clocks` options

The command removes the clock cell spacing rules defined by the `set_clock_cell_spacing -lib_cells -clocks` command with the specified library cells and clock names.

- No option

The command removes the clock cell spacing rules defined by the `set_clock_cell_spacing` command with no option.

For more information about these commands, see the man pages.

You use the following steps to reduce electromigration in the design:

1. After obtaining a placement CEL view, set the clock cell spacing rules by using the `set_clock_cell_spacing` command.

To remove and report the clock cell spacing rules, use the `remove_clock_cell_spacing` and `report_clock_cell_spacing` commands respectively.

2. Perform clock tree synthesis by using either the `compile_clock_tree` or `optimize_clock_tree` command.

3. Check clock cell spacing rule violations by using the `check_legality -verbose` command.

You should not see any violations if you set the appropriate clock cell spacing constraints.

Note that the `compile_clock_tree`, `optimize_clock_tree`, `split_clock_net`, and `balance_inter_clock_delay` commands support clock cell spacing rules.

Because clock cell spacing is a preventive and not a corrective technique, the `optimize_clock_tree` command does not correct the spacing violations that remain unfixed after the `compile_clock_tree` command. Clock tree optimization or the `psynopt` command does not fix spacing violations caused by changing spacing rules in the middle of the flow.

---

## Specifying Clock Tree Synthesis Options

[Table 7-6](#) describes the clock tree synthesis options supported by IC Compiler. Some options can be applied either on all clocks (globally) or on a per-clock basis, while other options can be applied globally only.

To define clock tree synthesis options, use the `set_clock_tree_options` command (or choose Clock > Set Clock Tree Options in the GUI). [Table 7-6](#) summarizes the clock tree synthesis options supported by IC Compiler and the command option or GUI object used to specify them.

*Table 7-6 Clock Tree Synthesis Options*

| Option                                                                                                                      | Scope               | Default         | Description                                          |
|-----------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------|------------------------------------------------------|
| <b>Clock Tree Selection Options</b>                                                                                         |                     |                 |                                                      |
| <code>-clock_trees</code><br>("Clock tree" box)                                                                             | N/A                 | All clock trees | Specifies the clock trees that the options apply to. |
| <b>Clock Tree Design Rule Constraints</b> (see “ <a href="#">Setting Clock Tree Design Rule Constraints</a> ” on page 7-35) |                     |                 |                                                      |
| <code>-max_capacitance</code><br>("Max capacitance" box in the "Target and CTO" tab)                                        | global or per-clock | 0.6 pF          | Specifies the maximum capacitance constraint.        |
| <code>-max_fanout</code><br>("Max fanout" box in the "Target and CTO" tab)                                                  | global or per-clock | 2000            | Specifies the maximum fanout constraint.             |
| <code>-max_transition</code><br>("Max transition" box in the "Target and CTO" tab)                                          | global or per-clock | 0.5 ns          | Specifies the maximum transition time constraint.    |

**Table 7-6 Clock Tree Synthesis Options (Continued)**

| Option                                                                                                      | Scope               | Default                                 | Description                                                                                        |
|-------------------------------------------------------------------------------------------------------------|---------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------|
| <b>Clock Tree Timing Goals</b> (see “ <a href="#">Setting Clock Tree Timing Goals</a> ” on page 7-37)       |                     |                                         |                                                                                                    |
| -target_skew<br>(“Target skew” box in the “Target and CTO” tab)                                             | global or per-clock | 0                                       | Specifies the maximum skew goal.                                                                   |
| -target_early_delay<br>(“Target early delay” box in the “Target and CTO” tab)                               | global or per-clock | 0                                       | Specifies the minimum insertion delay goal.                                                        |
| <b>Clock Tree Routing Options</b> (see “ <a href="#">Setting Clock Tree Routing Options</a> ” on page 7-38) |                     |                                         |                                                                                                    |
| -layer_list<br>(Layers check boxes in the “Routing” tab)                                                    | global or per-clock | All routing layers                      | Specifies the preferred layers for clock tree routing.                                             |
| -routing_rule<br>(“Routing rule” box in the “Routing” tab)                                                  | global or per-clock | Default routing rule                    | Specifies the nondefault routing rule used for clock tree routing.                                 |
| -use_default_routing_for_sinks<br>(“Use default routing for sinks at level” check box in the “Routing” tab) | global              | Specified routing rule for all nets     | Specifies that default routing rules are used for the clock tree levels closest to the clock sink. |
| <b>Boundary Cell Insertion</b> (see “ <a href="#">Inserting Boundary Cells</a> ” on page 7-45)              |                     |                                         |                                                                                                    |
| -insert_boundary_cell<br>(“Insert boundary cell” check box)                                                 | global              | Disabled                                | Enables boundary cell insertion.                                                                   |
| <b>Clock Tree Clustering</b> (see “ <a href="#">Selecting the Clock Tree Clustering</a> ” on page 7-45)     |                     |                                         |                                                                                                    |
| -ocv_clustering<br>(“OCV clustering” check box)                                                             | global              | Clustering based on minimum wire length | Selects clustering based on on-chip variation (OCV).                                               |

**Table 7-6 Clock Tree Synthesis Options (Continued)**

| Option                                                                                                      | Scope               | Default  | Description                                                                                    |
|-------------------------------------------------------------------------------------------------------------|---------------------|----------|------------------------------------------------------------------------------------------------|
| <b>Logic Level Balancing</b> (see “Enabling Logic-Level Balancing” on page 7-46)                            |                     |          |                                                                                                |
| -logic_level_balance<br>(“Logic level balance” check box)                                                   | global              | Disabled | Enables logic-level balancing.                                                                 |
| <b>Embedded Clock Tree Optimizations</b><br>(see “Specifying Clock Tree Optimization Options” on page 7-50) |                     |          |                                                                                                |
| -buffer_relocation<br>(“Buffer relocation” check box)                                                       | global or per-clock | Enabled  | Enables buffer relocation during optimization.                                                 |
| -buffer_sizing<br>(“Buffer sizing” check box)                                                               | global or per-clock | Enabled  | Enables buffer sizing during optimization.                                                     |
| -gate_relocation<br>(“Gate relocation” check box)                                                           | global or per-clock | Enabled  | Enables gate relocation during optimization. <sup>1</sup>                                      |
| -gate_sizing<br>(“Gate sizing” check box)                                                                   | global or per-clock | Disabled | Enables gate sizing during optimization.                                                       |
| <b>Clock Tree Configuration File Options</b> (see “Inserting User-Specified Clock Trees” on page 7-53)      |                     |          |                                                                                                |
| -config_file_read<br>(“Read file” box in “Configuration files” box)                                         | global              | None     | Specifies the clock configuration file to read.                                                |
| -config_file_write<br>(“Write file” box in “Configuration files” box)                                       | global              | None     | Specifies the name of the clock configuration file that is written after clock tree synthesis. |

1. Cells with the `is_fixed` attribute are not moved during clock tree synthesis.

The `set_clock_tree_options` command is additive; you can run the command multiple times to set different options. If you specify the same option multiple times, the new specification overrides the old specification.

To reset the clock tree synthesis options to their defaults, use the `reset_clock_tree_options` command (or choose Clock > Set Clock Tree Options in the GUI and click Default).

To see the current settings for the clock tree synthesis options, use the `report_clock_tree_settings` command or choose Clock > List Clock Tree Options in the GUI.

The following sections provide details for each of the clock tree synthesis options.

---

## Specifying the Clock Tree Synthesis Goals

The optimization goals used for synthesizing the design and the optimization goals used for synthesizing the clock trees might differ. Perform the following steps to ensure that you are using the proper constraints:

- Set the clock tree design rule constraints
- Set the clock tree timing goals

IC Compiler prioritizes the clock tree synthesis optimization goals as follows:

1. Design rule constraints
  - a. Meet maximum capacitance constraint
  - b. Meet maximum transition time constraint
  - c. Meet maximum fanout constraint
2. Clock tree timing goals
  - a. Meet maximum skew target
  - b. Meet minimum insertion delay target

## Setting Clock Tree Design Rule Constraints

IC Compiler supports the following design rule constraints for clock tree synthesis:

- Maximum capacitance (`set_clock_tree_options -max_capacitance`)  
If you do not specify this constraint, the clock tree synthesis default is 0.6 pF.
- Maximum transition time (`set_clock_tree_options -max_transition`)  
If you do not specify this constraint, the clock tree synthesis default is 0.5 ns.
- Maximum fanout (`set_clock_tree_options -max_fanout`)  
If you do not specify this constraint, the clock tree synthesis default is 2000.

You can specify the clock tree design rule constraints for a specific clock (by using the `-clock_trees` option to specify the clock) or for all clocks (by omitting the `-clock_trees` option).

Note:

IC Compiler does not support the specification of per-clock design rule constraints for overlapping clock domains.

In addition to the clock tree design rule constraint values that you specify, IC Compiler also considers the design rule constraint values from the logic library and the design. [Table 7-7](#) summarizes how IC Compiler determines the design rule constraint values used during the design rule fixing stage of clock tree synthesis and optimization. The clock tree synthesis value refers to the value you specified by using the `set_clock_tree_options` command (or the clock tree synthesis default if you did not specify a value).

*Table 7-7 Clock Tree Synthesis Design Rule Constraints*

| Variable settings      |                                                                                                                                                                |                                                                                                                                                                                             |                                                                                                                                              |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Design rule constraint | Default behavior:<br><code>cts_use_lib_max_fanout =false</code><br><code>cts_use_sdc_max_fanout =false</code><br><code>cts_force_user_constraints=false</code> | Use library and SDC settings for maximum fanout:<br><code>cts_use_lib_max_fanout =true</code><br><code>cts_use_sdc_max_fanout =true</code><br><code>cts_force_user_constraints=false</code> | Use only clock tree synthesis settings for clock tree synthesis and clock tree optimization:<br><code>cts_force_user_constraints=true</code> |
|                        |                                                                                                                                                                |                                                                                                                                                                                             |                                                                                                                                              |

**Table 7-7 Clock Tree Synthesis Design Rule Constraints (Continued)**

| <b>Variable settings</b>       |                                                                                                                                                                       |                                                                                                                                                                       |                                |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| <i>Maximum capacitance</i>     | The minimum value from <ul style="list-style-type: none"> <li>• The clock tree synthesis value</li> <li>• The logic library</li> <li>• The SDC constraints</li> </ul> | The minimum value from <ul style="list-style-type: none"> <li>• The clock tree synthesis value</li> <li>• The logic library</li> <li>• The SDC constraints</li> </ul> | The clock tree synthesis value |
| <i>Maximum transition time</i> | The minimum value from <ul style="list-style-type: none"> <li>• The clock tree synthesis value</li> <li>• The logic library</li> <li>• The SDC constraints</li> </ul> | The minimum value from <ul style="list-style-type: none"> <li>• The clock tree synthesis value</li> <li>• The logic library</li> <li>• The SDC constraints</li> </ul> | The clock tree synthesis value |
| <i>Maximum fanout</i>          | The clock tree synthesis value                                                                                                                                        | The minimum value from <ul style="list-style-type: none"> <li>• The logic library</li> <li>• The SDC constraints</li> </ul>                                           | The clock tree synthesis value |

To see the design rule constraint settings that will be used for clock tree synthesis, generate the clock tree settings reports, as described in [“Generating Clock Tree Reports” on page 7-120](#). Review these values. If any of the values are incorrect for clock tree synthesis, you can override them by setting clock tree design rule constraints.

**Note:**

The clock tree settings report displays the design rule constraints based on the default behavior; it does not consider the effects of the `cts_force_user_constraints` or `cts_use_lib_max_fanout` variables.

## Setting the Maximum Transition Time Constraints

You can set the maximum transition time constraints to data paths and clock paths by using the `set_max_transition` command. By default, the maximum transition time constraints apply to all pins on the data paths and clock paths launched by the specified clocks for the current scenario only. To restrict the constraints to data paths only, specify the `-data_path` option. To restrict the constraints to clock paths only, specify the `-clock_path` option. Alternatively, you can use the `set_clock_tree_options` command with the `-max_transition` option to constrain clock paths.

For example, the following command applies a maximum transition time of 0.200 ns to the `clk1` clock path:

```
icc_shell> set_max_transition 0.200 -clock_path [get_clocks clk1]
```

When an SDC file contains multiple maximum transition time constraints set by the `set_max_transition` and `set_clock_tree_options -max_transition` commands for the same clock path, the strictest constraint value is honored. As shown in the following example, an SDC file contains three maximum transition time constraints for the `clk1` clock path; IC Compiler applies the maximum transition time of 0.1 ns to the `clk1` clock path.

```
icc_shell> set_max_transition 0.1 [current_design]
icc_shell> set_max_transition 0.2 [get_clocks clk1]
icc_shell> set_max_transition 0.3 -clock_path [get_clocks clk1]
```

However, when you set the `cts_force_user_constraints` variable to `true`, only the constraints set by the `set_clock_tree_options -max_transition` command are honored.

The following two criteria show the behavior differences between IC Compiler and PrimeTime when you run the `set_max_transition` command:

- A maximum transition time constraint is specified on a master clock, but no constraint is set on its generated clock.

In IC Compiler, the generated clock inherits the stricter value of the maximum transition time constraints set on the current design and on the master clock. In PrimeTime, the generated clock inherits the maximum transition time constraint that is set on the current design. For example, when you run the following commands, the resulting maximum transition time for the generated clock in the `clock1` master clock domain is 0.3 ns in IC Compiler but 0.5 ns in PrimeTime.

```
icc_shell> set_max_transition 0.5 [current_design]
icc_shell> set_max_transition 0.3 -clock_path [get_clock clock1]
```

- Both the `-clock_path` and `-data_path` options are specified for the same path.

Clock tree synthesis and optimization in IC Compiler honors the setting of the `-clock_path` option, whereas PrimeTime honors the stricter setting of the two options.

## Setting Clock Tree Timing Goals

During clock tree synthesis, IC Compiler considers only the clock tree timing goals. It does not consider the latency (as specified by the `set_clock_latency` command) or uncertainty (as specified by the `set_clock_uncertainty` command).

Note:

IC Compiler can consider the clock latency specification during interclock delay balancing. For more information, see “[Balancing Multiple Clocks](#)” on page 7-72.

You can specify the following clock tree timing goals for a clock tree:

- Maximum skew (`set_clock_tree_options -target_skew`)

During optimization, IC Compiler computes the skew value by comparing the arrival times of all clock signals in a clock domain, including those that do not communicate through data paths (global skew).

If you do not specify a maximum skew value, IC Compiler uses zero as the maximum skew.

- Minimum insertion delay (`set_clock_tree_options -target_early_delay`)

IC Compiler checks the minimum insertion delay after synthesizing the initial clock tree. If the synthesized clock tree does not meet the specified minimum insertion delay, IC Compiler inserts buffers at the clock root to match the requirement.

If you do not specify a minimum insertion delay value, IC Compiler uses 0 as the minimum insertion delay.

You can specify the clock tree timing goals for a specific clock by using the `-clock_trees` option. To specify the clock tree timing goals for all clocks, omit the `-clock_trees` option.

For multicorner-multimode designs, you specify the same skew value for all corners, as shown in following example:

```
icc_shell> set_clock_tree_options -target_skew 0.050
```

To specify various skew values for different corners, use the `set_clock_tree_optimization_options` command, as shown in the following example:

```
icc_shell> set_clock_tree_optimization_options \
-corner_target_skew "scn1:max=0.100 scn_cts:max=0.050 scn2:min=0.070"
```

---

## Setting Clock Tree Routing Options

IC Compiler allows you to specify the following options to guide the clock tree routing:

- Which routing rule (type of wire) to use
- Which clock shielding methodology to use
- Which routing layers to use
- Which nondefault routing rules to use with which cell types

## Specifying Routing Rules

If you do not specify which routing rule to use for clock tree synthesis, IC Compiler uses the default routing rule (default wires) to route the clock trees. To reduce the wire delays in the clock trees, you can use wide wires instead. Wide wires are represented by nondefault routing rules.

Before you can use a nondefault routing rule, the rule must either exist in the Milkyway design library or have been previously defined by using the `define_routing_rule` command. For example, to define the `clk_rule` nondefault routing rule, enter the following command:

```
icc_shell> define_routing_rule clk_rule \
   -widths {M1 0.28 M2 0.28 M3 0.28 M4 0.28 M5 0.28 M6 0.28 M7 0.28} \
   -spacings {M1 0.28 M2 0.28 M3 0.28 M4 0.28 M5 0.28 M6 0.28 M7 0.28}
```

To see the current routing rule definitions, run the `report_routing_rules` command.

To set the clock tree routing rule, use the `set_clock_tree_options -routing_rule` command.

You can specify the clock tree routing rule for a specific clock tree by using the `-clock_trees` option to specify the clock or for all clocks by omitting the `-clock_trees` option.

For example, to use the previously defined `clk_rule` nondefault routing rule for routing all clock trees, enter the following command:

```
icc_shell> set_clock_tree_options -routing_rule clk_rule
```

By default, the specified routing rule is used for all nets in the clock tree. However, wide wires are often not required on the nets closest to the clock sinks. To use default wires on the nets connected to the clock sinks and the bottom  $n-1$  levels of the clock tree, use the `-use_default_routing_for_sinks` option on the command line.

### Note:

If you enable default routing for sinks, it applies to all clock trees. You cannot enable this capability on a per-clock basis. In addition, the default routing applies only to clock sinks connected to flip-flops. Clock sinks connected to macro cells are not affected by this option.

For finer control of the clock tree routing rules, you can specify the routing rules in a clock configuration file. For information about the clock configuration file, see “[Inserting User-Specified Clock Trees](#)” on page 7-53. Clock tree routing rules defined in a clock configuration file override those set by using the `set_clock_tree_options` command.

To see the nondefault routing rules defined for the clock trees in your design, run the `report_clock_tree -settings` command.

## Shielding Clock Nets

IC Compiler implements clock shielding using nondefault routing rules. You can choose either to shield clock nets before routing signal nets or vice versa. The methodology of shielding clock nets before routing signal nets yields better shielding coverage but can cause more DRC violations during signal net routing compared to the methodology of routing signal nets before shielding clock nets.

[Figure 7-10](#) shows the flow of both clock shielding methodologies.

*Figure 7-10 Clock Shielding Methodologies*



To define nondefault routing rules for clock shielding, use the `define_routing_rule` command.

The syntax is

```
define_routing_rule rule_name
    [-snap_to_track]
    [-shield_spacings shield_spacings]
    [-shield_widths shield_widths]
```

To assign nondefault routing rules to clock nets before clock tree synthesis, use the `set_clock_tree_options` command. For more information about nondefault routing rules, see “[Using Nondefault Routing Rules](#)” on page 8-22.

The syntax to assign a nondefault routing rule to unsynthesized clock trees is

```
set_clock_tree_options
  [-clock_trees clock_tree_names]
  [-routing_rule rule_name]
  [-use_default_routing_for_sinks]
```

The nondefault routing rules of clock shielding apply only to nets that are assigned with nondefault routing rules. You can indicate whether to add shielding to leaf pins by using the `-use_default_routing_for_sinks` option.

After assigning nondefault routing rules to clock nets, you can synthesize clock trees and route clock nets using the `clock_opt` command.

IC Compiler router and extractor honor virtual shielding rules. Virtual shielding rules require that the router leaves enough routing resources for shielding to be inserted later and that the extractor considers the shielding effect before shielding metal is inserted. Virtual shielding is supported by virtual routing, global routing, track assignment, and detail routing stages.

To route signal nets, you can use standalone commands such as `route_zrt_global`, `route_zrt_detail`, and `route_zrt_auto`, or the `route_opt` command. After routing signal nets, you can add shielding to the routed clock nets using the `create_zrt_shield` command. Alternatively, you can choose to add shielding to the routed clock nets before routing signal nets.

The following script shows the methodology for routing signal nets before clock shielding.

```
#Create new nondefault routing rule named SP
define_routing_rule SP \
  -widths {M1 0.14 M2 0.14 M3 0.14 M4 0.14 M5 0.14 M6 0.42} \
  -spacings {M1 0.14 M2 0.42 M3 0.42 M4 0.42 M5 0.42 M6 1.60} \
  -via_cuts {V12 "1x1" V23 "1x1" V34 "1x1" V45 "1x1" V56 "1x1"} \
  -shield_widths {M1 0.14 M2 0.14 M3 0.14 M4 0.14 M5 0.14 M6 0.42} \
  -shield_spacings {M1 0.14 M2 0.42 M3 0.42 M4 0.42 M5 0.42 M6 1.60}

#Assign nondefault routing rule to clock nets
set_clock_tree_options -clock_trees CLK -routing_rule SP

#Synthesize and route clock trees
clock_opt
set_clock_nets [get_nets -of [all_fanout -clock_tree]]
```

```
#Route signal nets
route_opt

#Add shielding to clock nets
create_zrt_shield -nets $clock_nets
```

For detailed information about shielding, see “[Shielding Nets](#)” on page 9-41.

## Specifying Routing Layers

If you do not specify which routing layers to use for clock tree synthesis, IC Compiler can use any routing layers. For more control of the clock tree routing, you can specify preferred routing layers by using the `set_clock_tree_options -layer_list` command.

You can specify the preferred clock tree routing layers for a specific clock tree by using the `-clock_trees` option to specify the clock or for all clocks by omitting the `-clock_trees` option. For example,

```
icc_shell> set_clock_tree_options -clock_trees CLK1 \
    -layer_list {metal4 metal5}
```

When you specify the clock tree routing layers by using this command, the specified layers apply to all levels of the clock tree. For finer control of the clock tree routing layers, you can specify the layer constraints in a clock configuration file. For information about the clock configuration file, see “[Inserting User-Specified Clock Trees](#)” on page 7-53. Clock tree layer constraints defined in a clock configuration file override those set by using `set_clock_tree_options`.

By default, IC Compiler treats the minimum layer specification as a soft constraint and can use lower layers for clock tree routing, if necessary. To require clock tree routing on the specified layers, set the following option before running clock tree synthesis:

```
icc_shell> set_route_zrt_common_options -min_layer_mode hard
```

Note:

If you have defined layer constraints on signal nets, you must reset this option to `soft` before performing detail routing on the design.

To remove the restrictions on the clock tree routing layers, use the `reset_clock_tree_options -layer_list` command.

## Association of Nondefault Routing Rules With Reference Cells

Electromigration problems result from an increase in current densities, which often occurs when strong cells drive thin nets. Electromigration can lead to opens and shorts due to metal ion displacement caused by the flow of electrons and can lead to the functional failure of the IC device. To prevent these problems in clock networks, you can associate reference cells with compatible nondefault routing rules by using the `set_reference_cell_routing_rule` command.

You use the following syntax to associate reference cells with nondefault routing rules:

```
set_reference_cell_routing_rule
    -routing_rule NDR_name
    -references list_of_reference_cells
```

You must specify both the `-routing_rule` and `-references` options. If you use the `set_reference_cell_routing_rule` command, specifying only the `-routing_rule` option but not the `-references` option, the nondefault routing rule does not apply during clock tree synthesis and optimization.

For example, to use the `CLOCK_RULE` nondefault routing rule for nets that are driven by instances of the `BUF`, `BUF2`, and `INV1` reference clock cells, enter

```
icc_shell> set_reference_cell_routing_rule \
    -routing_rule CLOCK_RULE -references {BUF1 BUF2 INV1}
```

When you associate reference cells with nondefault routing rules,

- If multiple nondefault routing rules are associated with a reference cell, clock tree synthesis and optimization uses the nondefault routing rule that provides the best result for each instance of the reference cell.
- The `compile_clock_tree` command, the `optimize_clock_tree` command, and interclock delay balancing consider these nondefault routing rules.
- These nondefault routing rules do not apply to nets beyond exception pins.

Note:

The `-use_default_routing_for_sinks` option of the `set_clock_tree_options` command is not supported with these nondefault routing rules. If you use both the `-use_default_routing_for_sinks` option and nondefault routing rules associated with reference cells, the `-use_default_routing_for_sinks` option is ignored.

To report the nondefault routing rules, use the `report_reference_cell_routing_rule` command. If you specify the `-routing_rule` option, the command lists the corresponding reference cells for each specified nondefault routing rule. If you specify the `-references` option, the command lists the corresponding nondefault routing rules for each specified reference cell.

To reset all nondefault routing rules, use the `reset_reference_cell_routing_rule` command.

[Figure 7-11](#) shows the flow of associating nondefault routing rules with reference cells.

*Figure 7-11 Flow of Associating Nondefault Routing Rules With Reference Cells*



---

## Inserting Boundary Cells

When you are working on a block-level design, you might want to preserve the boundary conditions of the block's clock ports (the boundary clock pins). A boundary cell is a fixed buffer that is inserted immediately after the boundary clock pins to preserve the boundary conditions of the clock pin.

To enable boundary cell insertion during clock tree synthesis,

1. Specify the buffers (or inverters) used for boundary cell insertion. (See “[Specifying the Clock Tree References](#)” on page 7-27.)
2. Enable boundary cell insertion by using the `set_clock_tree_options -insert_boundary_cell true` command.

If you enable boundary cell insertion, it applies to all clock trees. You cannot enable boundary cell insertion on a per-clock basis.

Note:

You cannot use boundary cell insertion together with a clock tree configuration file. If you specify both options, IC Compiler disables the boundary cell insertion and generates a warning message.

When boundary cell insertion is enabled, IC Compiler inserts a cell from the buffer insertion clock tree reference list immediately after the boundary clock pins. For multivoltage designs, IC Compiler inserts the boundary cells in the default voltage area.

IC Compiler does not insert a boundary cell when the net is either a don't buffer net or a bidirectional net or when there is a large blockage at the boundary clock pin, which would cause a large distance between the boundary cell and the clock pin.

The boundary cells are fixed for clock tree synthesis; after insertion, IC Compiler does not move or size the boundary cells. In addition, no cells are inserted between a clock pin and its boundary cell.

---

## Selecting the Clock Tree Clustering

IC Compiler performs clustering of the clock sinks to minimize wire length. If your design is sensitive to on-chip variation (OCV), IC Compiler can also consider on-chip variation effects during clustering.

If you are using a multicorner design flow, you can reduce skew variation by using RC constraint-based clustering. To use RC constraint-based clustering, you must use a clock configuration file to specify the clock tree structure. For more information about clock configuration files and RC constraint-based clustering, see “[Inserting User-Specified Clock Trees](#)” on page 7-53.

## Enabling On-Chip-Variation-Aware Clustering

The optional OCV-aware clustering considers the timing constraints between clock sinks to influence clustering. Sinks with timing-critical paths driven by the same gates are clustered together. To enable the OCV-aware clustering, use the `set_clock_tree_options -ocv_clustering true` command. When you set this option, it applies to all clock trees in your design.

When you use timing derating, using the `set_timing_derate` command, OCV-aware clustering can result in better timing (worst negative slack and total negative slack) with minimal impact on the clock tree skew and insertion. However, using OCV-aware clustering can increase the runtime and power.

**Note:**

You cannot use OCV-aware clustering with clock tree configuration files. If you specify the `-ocv_clustering` option when these options are set, IC Compiler ignores the `-ocv_clustering` option. If you specify a clock tree configuration file after setting the `-ocv_clustering` command, IC Compiler generates an error message and ignores both settings.

---

## Enabling Logic-Level Balancing

If on-chip variation is an issue for your design, use the logic-level balancing mode.

**Note:**

If the level count or fanout varies greatly between the branches of the initial clock tree, logic-level balancing might not be able to achieve good clock tree QoR.

By default, IC Compiler balances the delay in each branch of the clock tree, but it does not consider the number of logic levels in each branch. IC Compiler can take into account both delay and the number of logic levels when balancing the clock tree. This feature is called logic-level balancing. [Figure 7-12](#) shows a clock tree that was synthesized using logic-level balancing.

*Figure 7-12 Logic-Level Balancing*

Logic-level balancing can use buffers, inverters, or both to balance the logic levels. If you use only inverters for logic-level balancing and the initial clock network does not have balanced logic levels, the generated clock trees might be unbalanced by one level, as shown in [Figure 7-13](#).

*Figure 7-13 Logic-Level Balancing Using Inverters*

To enable logic-level balancing, use the `set_clock_tree_options -logic_level_balance true` command.

If you enable logic-level balancing, it applies to all clock trees. You cannot enable logic-level balancing on a per-clock basis.

If a clock tree contains a subtree that is not modified during clock tree synthesis (either a don't touch subtree or a subtree within an ILM or block abstraction model), IC Compiler traces through the subtree to determine the number of logic levels contained in the subtree. IC Compiler considers these logic levels when constructing the clock tree. If the subtree

does not have balanced logic levels, IC Compiler generates a warning message and uses the maximum number of levels in the subtree as the number of logic levels for the subtree. For example, for the don't touch subtree shown in [Figure 7-14](#), IC Compiler uses four as the number of logic levels in the don't touch subtree.

*Figure 7-14 Logic-Level Balancing With a Don't Touch Subtree*



If your design contains hard macros, use the `set_clock_tree_exceptions -float_pin_logic_level` command to specify the number of logic levels within the hard macro. The number of logic levels must be a positive integer. If you do not specify the number of logic levels and IC Compiler cannot derive the number of logic levels, IC Compiler assumes that there are no logic levels within the hard macro.

**Note:**

When you remove float pin logic-level information by using the `remove_clock_tree_exceptions -float_pin_logic_level` command, IC Compiler removes logic-level information for the entire design. It does not remove logic-level information for an individual pin.

After clock tree synthesis finishes, IC Compiler verifies that the clock trees are balanced. If the number of logic levels varies between branches, IC Compiler generates a warning message.

To enable OCV-aware clustering while running logic-level balancing, set both the `-logic_level_balance` and `-ocv_clustering` options to `true` with the `set_clock_tree_options` command. For more information about OCV-aware clustering, see [“Enabling On-Chip-Variation-Aware Clustering” on page 7-46](#).

**Caution:**

If you use logic-level balancing, do not run clock tree optimization with delay insertion. Doing so can unbalance the logic levels. If you use logic-level balancing when running the `clock_opt` command, delay insertion is automatically disabled during the embedded clock tree optimization.

## Enabling Region-Aware Clock Tree Synthesis

Region-aware clock tree synthesis considers region constraints to create more balanced clock trees and to avoid DRC violations in designs with complex floorplans. For designs with region constraints, using region-aware clock tree synthesis can produce better QoR. This capability is enabled by default. If you want to disable region-aware clock tree synthesis, set the `cts_region_aware` variable to `false`, changing it from its default of `true`.

Region-aware clock tree synthesis can identify the following region constraints:

- Logic modules with exclusive move bounds

Note:

Soft move bounds and hard move bounds are ignored during clock tree synthesis.

- Logic modules with target library subset constraints
- Disjoint voltage areas
- Power guides in power-down regions

During region-aware clock tree synthesis, the tool performs the following steps:

1. Enables the `clock_opt` or `compile_clock_tree` command to group buffers in the target library by the same operating condition, power state, and target library subset associated with exclusive move bounds.
2. Partitions a design into regions according to constraints such as voltage areas, plan groups, and exclusive move bounds, as shown in [Figure 7-15](#).
3. Associates each buffer group with a region and vice versa.
4. Associates each power guide with the region that contains it.
5. Performs region-aware clustering.

*Figure 7-15 Design Partitions*



---

## Specifying Clock Tree Optimization Options

IC Compiler optimizes the clock trees during the design stages that are shown in [Table 7-8](#). During the optimization phases, IC Compiler can perform several optimization tasks, which you can enable or disable by setting the appropriate options.

*Table 7-8 Design Stages Using Clock Tree Optimization*

| Design Stage                      | Command                          |
|-----------------------------------|----------------------------------|
| Clock tree synthesis              | <code>compile_clock_tree</code>  |
| Preroute clock tree optimization  | <code>optimize_clock_tree</code> |
| Postroute clock tree optimization | <code>optimize_clock_tree</code> |

Note:

IC Compiler uses the clock tree synthesis design rule constraints for all optimization phases, as well as for clock tree synthesis. For information about setting the clock tree synthesis design rule constraints, see “[Setting Clock Tree Design Rule Constraints](#)” on [page 7-35](#).

---

## Controlling Embedded Clock Tree Optimization

To set the optimization options for embedded clock tree optimization, use the `set_clock_tree_options` command or choose Clock > Set Clock Tree Options in the GUI. You can set these options either for a specific clock by using the `-clock_trees` option or for all clock trees by omitting the `-clock_trees` option. [Table 7-9](#) shows the available options and their defaults.

*Table 7-9 Embedded Clock Tree Optimization Options*

| Option                          | Default | Description                                                                          |
|---------------------------------|---------|--------------------------------------------------------------------------------------|
| <code>-buffer_relocation</code> | true    | Optimizes the placement of the buffers and inverters in the synthesized clock trees. |
| <code>-buffer_sizing</code>     | true    | Optimizes the sizing of the buffers and inverters in the synthesized clock trees.    |

*Table 7-9 Embedded Clock Tree Optimization Options (Continued)*

| <b>Option</b>                 | <b>Default</b> | <b>Description</b>                                                                                                                                 |
|-------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-gate_relocation</code> | true           | Optimizes the placement of the preexisting gates in the clock trees by moving them closer to the clock sinks. Gates marked as fixed are not moved. |
| <code>-gate_sizing</code>     | false          | Optimizes the sizing of the preexisting gates in the clock trees.                                                                                  |

## Controlling Preroute Clock Tree Optimization

During `clock_opt`, the clock tree optimization phase performs all the optimization tasks listed in [Table 7-10](#). You cannot independently control these tasks for `clock_opt`.

To set the optimization options for standalone preroute clock tree optimization, specify the options when you run the `optimize_clock_tree` command (or choose *Clock > Optimize Clock Tree* in the GUI). [Table 7-10](#) shows the available options and their defaults.

*Table 7-10 Preroute Clock Tree Optimization Options*

| <b>Option</b>                   | <b>Default</b> | <b>Description</b>                                                                                                                                 |
|---------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-buffer_relocation</code> | true           | Optimizes the placement of the buffers and inverters in the synthesized clock trees.                                                               |
| <code>-buffer_sizing</code>     | true           | Optimizes the sizing of the buffers and inverters in the synthesized clock trees.                                                                  |
| <code>-delay_insertion</code>   | true           | Inserts delays on clock paths to reduce the clock skew, while at the same time ensuring that the longest clock path does not change.               |
| <code>-gate_relocation</code>   | true           | Optimizes the placement of the preexisting gates in the clock trees by moving them closer to the clock sinks. Gates marked as fixed are not moved. |
| <code>-gate_sizing</code>       | true           | Optimizes the sizing of the preexisting gates in the clock trees.                                                                                  |

---

## Controlling Postroute Clock Tree Optimization

To set the optimization options for postroute clock tree optimization, specify the options when you run the `optimize_clock_tree` command or choose Clock > Optimize Clock Tree in the GUI. [Table 7-11](#) shows the available options and their defaults.

*Table 7-11 Postroute Clock Tree Optimization Options*

| Option                      | Default | Description                                                                       |
|-----------------------------|---------|-----------------------------------------------------------------------------------|
| <code>-buffer_sizing</code> | true    | Optimizes the sizing of the buffers and inverters in the synthesized clock trees. |
| <code>-gate_sizing</code>   | true    | Optimizes the sizing of the preexisting gates in the clock trees.                 |

---

## Saving Intermediate Results During Preroute Optimization

You can enable `clock_opt` checkpointing to analyze your designs during preroute optimization by using the `set_checkpoint_strategy -enable` command. Checkpointing is disabled by default.

When checkpointing is enabled, the `clock_opt` command

- Saves design snapshots in the Milkyway database at a periodic interval. You can analyze the intermediate results while the optimization is still proceeding.
- Updates the log file with checkpoint design names.

To analyze your checkpoint designs, you can use timing analysis, extraction, legalization, routing congestion analysis, and multicorner-multimode scenario commands. For information about what commands are allowed, see “[Saving Intermediate Results During Preroute Optimization](#)” on page 6-30.

The following example shows how to use the `set_checkpoint_strategy` command in an optimization flow:

```
icc_shell> set_checkpoint_strategy -enable
icc_shell> clock_opt
```

The checkpoint designs created are

```
clock_opt_checkpoint_MYDESIGN_080908_120402_1
clock_opt_checkpoint_MYDESIGN_080908_120402_2
clock_opt_checkpoint_MYDESIGN_080908_120402_3
...
...
```

To remove checkpoint designs, use the `remove_checkpoint_designs` command. For example, to remove all checkpoint designs, enter

```
icc_shell> remove_checkpoint_designs
```

To remove all checkpoint designs created by `clock_opt` only, enter

```
icc_shell> remove_checkpoint_designs -command clock_opt
```

To disable checkpointing, enter

```
icc_shell> set_checkpoint_strategy -disable
```

---

## Inserting User-Specified Clock Trees

IC Compiler supports the use of a clock configuration file to enable user specification of the clock tree structure. The following sections describe how to

- Read a clock configuration file before clock tree synthesis
- Reduce skew variation by using RC constraint-based clustering
- Save a clock configuration file after clock tree synthesis
- Describe your clock tree structure in a clock configuration file

---

## Reading a Clock Configuration File

If you have a configuration file that describes the desired clock tree structure, run the `set_clock_tree_options -config_file_read config_file` command before running clock tree synthesis. For details about the syntax of the configuration file, see “[Defining the Clock Tree Structure](#)” on page 7-54.

---

## Reducing Skew Variation by Using RC Constraint-Based Clustering

If you use a configuration file to specify the clock tree structure for a multicorner design, you can use RC constraint-based clustering to reduce the skew variation across corners. To enable this capability, set the `cts_enable_rc_constraints` variable to `true` before running clock tree synthesis.

When you enable this capability, IC Compiler uses the RC values to derive maximum delay and maximum skew constraints, which are then used during clustering to reduce the skew variation. Although RC constraint-based clustering reduces skew variation, you should be aware that it can increase the buffer count and runtime. You can reduce the buffer count and

runtime impact by relaxing the derived constraints. To relax the constraints, set the `cts_rc_relax_factor` variable to a number greater than 1.0. You can also tighten the constraints by setting this variable to a number between 0 and 1.0.

Alternatively, you can use either the `-max_rc_delay_constraint` option or the `-max_rc_scale_factor` option of the `set_clock_tree_options` command to enable RC constraint-based clustering. Note that these two options are mutually exclusive.

To use the `-max_rc_delay_constraint` option, you specify a maximum RC constraint value in the design time unit. For example, to set the RC constraint value to 0.05 ns if the time unit is ns, enter

```
icc_shell> set_clock_tree_options -max_rc_delay_constraint 0.05
```

To use the `-max_rc_scale_factor` option, specify a scale factor with which IC Compiler multiplies the derived RC value during clock tree synthesis. For example, to relax the derived RC value by a factor of 1.5, enter,

```
icc_shell> set_clock_tree_options -max_rc_scale_factor 1.5
```

---

## Saving a Clock Configuration File

To save the generated clock tree structure in a clock configuration file after clock tree synthesis, run the `set_clock_tree_options -config_file_write config_file` command before running clock tree synthesis.

---

## Defining the Clock Tree Structure

Use the following syntax to define the structure for each user-specified clock tree in your design:

```
begin_clock_tree number_of_levels
  clock_net net_name [routing_rule rule_name]
    [routing_layer_constraints min_layer max_layer]
    {buffer_level reference_cell number_of_buffers
      [buffer_level_pin instance/pin]
      [routing_rule rule_name]
      [routing_layer_constraints min_layer max_layer]
      ...
    }
  ...
end_clock_tree

begin_clock_tree number_of_levels
```

This statement starts the clock tree structure definition and specifies the number of levels for the clock tree.

You must specify an integer value for this argument. If you specify 0, IC Compiler determines the number of levels (and the number of buffers in each level) for the clock tree.

`clock_net net_name`

The `net_name` argument is a string that specifies the name of the clock net. You can specify the clock net name as a regular expression, for example, `clk.*` or `clk[10].*`

`routing_rule rule_name`

The `rule_name` argument is a string that specifies the name of the routing rule.

To define a nondefault routing rule that applies to the entire clock tree, insert a `routing_rule` statement after the `clock_net` statement that defines the clock root. If you do not define a nondefault routing rule for the root net, IC Compiler uses the default routing rule.

To define a net-specific nondefault routing rule for a net other than the root net, insert a `routing_rule` statement after the associated `clock_net` statement.

To define a level-specific nondefault routing rule, insert a `routing_rule` statement after the associated `buffer_level` statement.

If you specify a net- or level-specific nondefault routing rule, it overrides the clock tree routing rule (whether it is default or nondefault). If you specify a nondefault clock tree routing rule, you can use the default routing rule on specific nets or levels by specifying `routing_rule default` for that net or level.

If a routing rule has not been explicitly defined for a net or level, IC Compiler determines the routing rule as follows:

- If the clock tree structure is completely specified, IC Compiler uses the clock tree routing rule (whether it is default or nondefault).
- If the clock tree structure is not completely specified because the number of levels is not specified, the routing rule for the previous level is used.
- If the clock tree structure is not completely specified because the number of buffers for a level is not specified, IC Compiler uses the clock tree routing rule (whether it is default or nondefault).

The clock tree routing rules specified in the configuration file override the routing rules specified by using the `set_clock_tree_options` command.

For more information about nondefault routing rules, see “[Specifying Routing Rules](#)” on page 7-39.

`routing_layer_constraints min_layer max_layer`

Specifies the minimum and maximum routing layer to use for clock tree synthesis. You can specify the layers using either the layer names (for example, M2 and M4) or the metal layer numbers (for example, 2 and 4).

To define global layer constraints that apply to the entire clock tree, insert a `routing_layer_constraints` statement after the `clock_net` statement that defines the clock root. If you do not define layer constraints for the root net, IC Compiler can use any routing layer for clock tree routing.

To define net-specific layer constraints for a net other than the root net, insert a `routing_layer_constraints` statement after the associated `clock_net` statement.

To define level-specific layer constraints, insert a `routing_layer_constraints` statement after the associated `buffer_level` statement.

If you specify net- or level-specific layer constraints, they override the clock tree layer constraints. If you define clock tree layer constraints, you can remove these constraints for specific nets or levels by specifying `routing_layer_constraints 0 0` for that net or level. The clock tree layer constraints specified in the configuration file override the routing rules specified by using the `set_clock_tree_options` command.

For more information about nondefault routing rules, see “[Specifying Routing Layers](#)” on page 7-42.

`buffer_level reference_cell number_of_buffers`

Specifies the reference cell and buffer count for each level in the clock tree (one statement per level). The first `buffer_level` statement defines the level closest to the clock source; the last `buffer_level` statement defines the level closest to the clock sink. If you do not define all levels, the specified levels are closest to the clock sink.

The `reference_cell` argument is a string that specifies the buffer or inverter that is used for all clock tree instances at this level.

The `number_of_buffers` argument is an integer value that specifies the total number of buffers or inverters at this level. If you specify 0, IC Compiler determines the number of buffers or inverters at this level.

Note:

If the specification in the clock tree configuration file conflicts with a don't buffer nets exception, the clock tree configuration file has priority.

By default, IC Compiler determines the sink pins connected at each level of the clock tree. For more control, such as when you want a RAM to be placed near the clock root, you can explicitly specify the sink pins by using the `buffer_level_pin` statement.

`buffer_level_pin instance/pin`

Specifies the sink pin connections for the associated buffer level.

You define all user-specified clock trees in a single clock configuration file. For any clock tree that is not specified in the clock configuration file, IC Compiler determines the structure for that clock tree.

## Complete Specification Without Sink Pins

The following example completely specifies a clock tree that has six levels. Clock tree synthesis does not change the number of levels or the number of buffers in each level.

```
begin_clock_tree 6
clock_net core/clk
buffer_level bufx6 2
buffer_level invx12 4
buffer_level bufx12 7
buffer_level invx12 11
buffer_level bufx12 48
buffer_level bufx12 268
end_clock_tree
```

## Complete Specification With Sink Pins

The following example completely specifies a clock tree that has six levels. The sink pins are specified for the first two levels (closest to the clock root) and last level (closest to the clock sinks) of the clock tree. The first level connects to two multiplexers, the second level connects to the RAM, and all other flip-flops are connected at the last level.

```
begin_clock_tree 6
clock_net core/clk
buffer_level bufx6 2
buffer_level_pin top/inst1/inst2mux/u1/A
buffer_level_pin top/inst1/inst3mux/u2/A
buffer_level invx12 4
buffer_level_pin top/inst1/inst_ram/CKB
buffer_level bufx12 7
buffer_level invx12 11
buffer_level bufx12 48
buffer_level bufx12 268
buffer_level_pin top/inst1/my_reg[5]/CKB
buffer_level_pin top/inst1/my_reg[4]/CKB
...
end_clock_tree
```

## Incomplete Specification—Unspecified Levels

The following example defines the bottom four levels of a clock tree but lets IC Compiler determine the structure of the top levels (those closest to the clock root) of the clock tree.

```
begin_clock_tree 0
clock_net core/clk
buffer_level bufx12 7
buffer_level bufx12 11
buffer_level bufx12 48
buffer_level bufx12 268
end_clock_tree
```

### Incomplete Specification—Unspecified Buffer Count

The following example defines all six levels of a clock tree but lets IC Compiler determine the number of buffers in the third level of the clock tree.

```
begin_clock_tree 6
clock_net core/clk
buffer_level bufx6 2
buffer_level invx12 4
buffer_level bufx12 7
buffer_level invx12 0
buffer_level bufx12 48
buffer_level bufx12 268
end_clock_tree
```

---

## Handling Specific Design Characteristics

Several design styles might require special considerations during clock tree synthesis. These design styles include

- Multicorner-multimode designs
- Hard macro cells
- Preexisting clock trees
- Non-unate gated clocks
- Integrated clock-gating (ICG) cells
- Multiple clocks (with balanced skew)
- Hierarchical designs
- Extracted timing models
- Multivoltage designs

The following sections describe how to use IC Compiler clock tree synthesis with these design styles.

---

## Multicorner-Multimode Designs

To perform clock tree synthesis and optimization on a multicorner-multimode design, you must specify which scenarios to use for clock tree synthesis and optimization by using the `set_scenario_options` command, as shown in the following steps:

1. Create all scenarios by using the `create_scenario` command.
2. Enable the analysis of multiple clocks that reach a register clock pin by setting the `timing_enable_multiple_clocks_per_reg` variable to `true`.
3. Activate all user-selected scenarios by using the following script:

```
set user_selected_cts_scenarios "scn1 scn2 scn3 scn4"
set_scenario_options -scenarios $user_selected_cts_scenarios \
    -cts_mode true
set_scenario_options -scenarios $user_selected_cts_scenarios \
    -cts_corner min_max

foreach s [user_selected_cts_scenarios] {
    # read in scenario-specific constraints, exceptions, and so forth
}
```

Alternatively, if all scenarios are to be considered, you can activate them simultaneously by using the following script:

```
set_scenario_options -scenarios {list_of_all_scenarios} -cts_mode true
```

To see all the scenarios for which clock tree synthesis is performed, use the `report_scenario_options` command.

After setting up the scenarios, you can perform

- Multimode clock tree synthesis  
For more information, see “[Performing Multimode Clock Tree Synthesis](#)” on page 7-91.
- Multicorner clock tree optimization  
For more information, see “[Performing Multicorner Clock Tree Optimization](#)” on page 7-95.

For details about working with multicorner-multimode designs, see “[Setting Up for Multicorner-Multimode Analysis and Optimization](#)” on page 3-29.

---

## Handling Hard Macro Cells

The internal delays for a hard macro cell are represented in the cell's timing model. IC Compiler uses the timing model to determine the external clock pins of the hard macro cell and uses these pins as clock sinks. During clock tree synthesis, IC Compiler performs skew balancing and insertion delay minimization up to these external clock pins. No additional specification is required for hard macro cells.

If you do not have a timing model for the hard macro cell or you want to modify the timing characteristics of the hard macro cell, use float pins to specify the timing characteristics of the clock trees internal to the hard macro. You define the timing characteristics by specifying the minimum and maximum insertion delay seen from the float pin to the clock sinks that are internal to the macro. For information about defining float pins, see [“Specifying Float Pins” on page 7-20](#).

For example, assume that timing analysis shows that the delay of the precompiled clock tree from the RAM\_block/CLK port to the earliest sink is 0.33 ns, and the delay to the latest endpoint is 0.52 ns.

The following command defines these timing characteristics for IC Compiler clock tree synthesis:

```
icc_shell> set_clock_tree_exceptions \
    -float_pins [get_pins RAM_block/CLK] \
    -float_pin_max_delay_rise 0.52 -float_pin_max_delay_fall 0.52 \
    -float_pin_min_delay_rise 0.33 -float_pin_min_delay_fall 0.33
```

---

## Handling Existing Clock Trees

If your design contains existing clock trees, you must decide how to handle them before you perform clock tree synthesis. By default, IC Compiler keeps an existing clock tree and might modify it. Instead, you can either prevent IC Compiler from modifying the existing clock tree or you can remove the clock tree.

The following sections describe how to

- Identify clock trees synthesized in Astro or a third-party tool
- Preserve all or part of an existing clock tree
- Remove a clock tree

## Identifying Existing Clock Trees

You can identify clock trees in your netlist that were created in Astro or a third-party tool and optimize them in IC Compiler. To identify a clock tree, use the `mark_clock_tree -clock_synthesized` command (or choose Clock > Mark Clock Tree in the GUI and select “Clock synthesized”). Specify the startpoint for the clock tree by using the `-clock_trees` option (or the “Clock Tree Pin” box in the GUI). The startpoint can be any port or pin on the clock tree; it does not have to be the clock root. If you do not specify a startpoint, IC Compiler uses the clock roots defined by the `create_clock` and `create_generated_clock` commands.

IC Compiler traverses the clock tree from the specified startpoint and sets the clock tree attributes as if the tree were synthesized. Clock tree traversal continues until it finds an exception pin or a default sink pin.

After running `mark_clock_tree -clock_synthesized`, the imported clock trees are treated just like clock trees synthesized by IC Compiler: the buffers and inverters are fixed; the clock sink cells can only be sized, not moved; the clocks are set to propagated; and the user-defined clock latency values are removed. Similar to using the `cts_fix_clock_tree_sinks` variable to fix clock sink cells after clock tree synthesis, you can use the `-fix_sinks` option when you run `mark_clock_tree` to prevent any modification to the clock sink cells after clock tree synthesis. For more information about the IC Compiler clock tree synthesis process, see “[Implementing the Clock Trees](#)” on page 7-81.

**Important:**

Because the buffers and inverters (and possible clock sink cells) are fixed after running `mark_clock_tree`, you must ensure that the placement is legal before running the `mark_clock_tree` command.

## Preserving Portions of an Existing Clock Tree

In some cases you want to preserve a portion of an existing clock tree. You need to do this, for example, when two clock networks share part of some clock logic behind a multiplexer. The portion of the clock tree that is preserved is called a don’t touch subtree. For information about don’t touch subtrees, see “[Specifying Don’t Touch Subtrees](#)” on page 7-24.

## Removing Clock Trees

To remove a clock tree, use the `remove_clock_tree` command (or choose Clock > Remove Clock Tree in the GUI).

For example,

```
icc_shell> remove_clock_tree -clock_trees my_clock
```

When IC Compiler removes a clock tree, it traverses from the clock root to each endpoint (stop pin, exclude pin, float pin, or don't touch subtree) and by default, removes all buffers and inverters along those paths, including those with `dont_touch` attributes. If you want to keep buffers and inverters that have a `dont_touch` attribute, specify the `-honor_dont_touch` option when you run `remove_clock_tree` (or select “Honor don’t touch” in the GUI). If you want to remove only those buffers and inverters inserted by IC Compiler, specify the `-synopsys_only` option when you run `remove_clock_tree` (or select “Remove only Synopsys CTS added buffers/inverters” in the GUI). In addition, IC Compiler traverses beyond exclude pins, stop pins, and float pins and removes only buffers and inverters inserted by IC Compiler (whether or not you specify `-synopsys_only`). The `dont_touch` attributes on buffers and inverters beyond the exception pins are honored only if you specify `-honor_dont_touch`.

**Note:**

This command removes only unrouted clock trees. To remove a routed clock tree, you must first remove the clock tree routing.

[Table 7-12](#) shows how clock tree removal is affected by the structure of the clock tree.

*Table 7-12 Clock Tree Removal Behavior*

| Object                             | Impact on clock tree removal                                                                                                         |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Boundary cell                      | Removed.                                                                                                                             |
| Cells on don't buffer nets         | Preserved.                                                                                                                           |
| Don't touch subtree                | Preserved.                                                                                                                           |
| Fixed cells                        | Preserved.                                                                                                                           |
| Generated clock                    | Preserved, if generated clock is defined on buffer/inverter pin. Traversal and clock tree removal continue past the generated clock. |
| Guide buffer                       | Removed.                                                                                                                             |
| Integrated clock-gating (ICG) cell | Preserved. Traversal (and clock tree removal) continues past the integrated clock-gating cell.                                       |
| ILM or block abstraction model     | Preserved. Traversal (and clock tree removal) continues past the ILM or block abstraction model.                                     |
| Inverter                           | Removed in pairs only. If a clock tree contains a single inverter, it is not removed.                                                |
| Isolation cell                     | Preserved.                                                                                                                           |

*Table 7-12 Clock Tree Removal Behavior (Continued)*

| <b>Object</b>                                                       | <b>Impact on clock tree removal</b>                                            |
|---------------------------------------------------------------------|--------------------------------------------------------------------------------|
| Level shifter                                                       | Preserved.                                                                     |
| Three-state buffer                                                  | Preserved. Traversal (and clock tree removal) stops at the three-state buffer. |
| Buffer or inverter added beyond exclude pin, stop pin, or float pin | Removed.                                                                       |

## Handling Non-Unate Gated Clocks

If the clock-gating logic uses a non-unate cell, such as an XOR or XNOR gate, IC Compiler uses both the positive-unate timing arc and the negative-unate timing arc when tracing the clock path. If this does not correspond to the functional mode of your design, use the `set_case_analysis` command to hold all nonclock inputs of the cell at a constant value. In this way you force the cell into the desired functional mode for timing analysis during clock tree synthesis.

For example, suppose your design has the gating logic shown in [Figure 7-16](#).

*Figure 7-16 Non-Unate Gated Clock*

To force the XOR gate (U0) into functional mode for timing analysis, enter the following command:

```
icc_shell> set_case_analysis 0 U0/B
```

---

## Handling Integrated Clock-Gating Cells

When using clock gating to reduce power, you need to consider the impact not only on power and timing, but also on the clock tree QoR. The methodology that you use to insert the integrated clock-gating cells (ICGs) and to optimize the clock tree depends on your power and clock tree QoR goals.

The following sections describe the methodology and techniques:

- [Using XOR Self-Gating to Save Dynamic Power](#)
- [Optimizing for Clock Tree QoR](#)
- [Optimizing for Power](#)
- [Optimizing for Timing on Enable Signals](#)

### Using XOR Self-Gating to Save Dynamic Power

To reduce the dynamic power consumption of the clock tree network, you can use the advanced clock-gating technique known as XOR self-gating. The XOR self-gating technique turns off the clock signal during the clock cycles when the data in the register remains unchanged. [Figure 7-17](#) shows an example of a register gated by an XOR clock-gating cell. The clock gate is enabled only when switching activity occurs at the register. For more information about XOR self-gating, see the *Power Compiler User Guide*.

*Figure 7-17 Example of XOR Self-Gating*



To perform XOR self-gating,

1. Ensure the design contains the following:

- A reference library that contains integrated clock-gating cells and logic gates, including XOR, AND, OR, INV, and NAND, which cannot be marked with the `dont_use` and `dont_touch` attributes.
- Registers that have a noninverting D input and a Q output to provide the enable signals for the XOR clock-gating cells.
- A SAIF file that contains the switching activity annotation.

2. Use either of the following two methods:

- Perform XOR self-gating during standalone clock tree synthesis by specifying the `-insert_self_gating` option with the `compile_clock_tree` command after reading in the SAIF file.

For example,

```
icc_shell> read_saif -input saif_file
icc_shell> compile_clock_tree -insert_self_gating ...
icc_shell> optimize_clock_tree
icc_shell> psynopt
```

- Perform XOR self-gating when implementing the clock trees by specifying the `-insert_self_gating` option with the `clock_opt` command after reading in the SAIF file.

For example,

```
icc_shell> read_saif -input saif_file
icc_shell> clock_opt -insert_self_gating ...
```

To exclude registers from XOR self-gating, specify the `-dont_self_gate_registers` option of the `set_clock_tree_exceptions` command.

To report the power consumption after performing XOR self-gating, use the `report_clock_tree_power` command. To see the power consumption of the registers, specify the `-include_register` option.

To remove all XOR clock-gating cells and the enable logic, use the `remove_self_gating_logic` command. To remove specific XOR clock-gating cells and the corresponding enable logic, specify the `-self_gating_icgs` option with the instance names of the XOR clock-gating cells.

To verify the design in Formality, set the `verification_clock_gate_hold_mode` variable, as shown in the following example:

```
fm_shell> set verification_clock_gate_hold_mode any
```

To avoid design congestion and timing issues later in the flow, you can set the variables that are described in the following section.

### Setting the XOR Self-Gating Variables

You can restrict the registers used during XOR self-gating by setting the variables shown in [Table 7-13](#). You should set these variables before running the `compile_clock_tree` or `clock_opt` command.

*Table 7-13 XOR Self-Gating Variables*

| Variable                                                     | Default  | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>cts_self_gating_connect_scan_enable</code>             | false    | Specifies whether to connect the scan enable pin of an XOR self-gated register to one of the corresponding enable nets.                                                                                                                                                                                                                                                                                      |
| <code>cts_self_gating_data_toggle_rate_filter</code>         | 0.001    | Sets the register data and control pin toggle rate limit so that only those registers with a toggle rate more than this limit are XOR self-gated.                                                                                                                                                                                                                                                            |
| <code>cts_self_gating_num_regs</code>                        | 20000    | Sets the maximum number of registers that are XOR self-gated.                                                                                                                                                                                                                                                                                                                                                |
| <code>cts_self_gating_num_regs_max_percent</code>            | 24       | Sets the maximum percentage of registers (out of the total register count) that are XOR self-gated.                                                                                                                                                                                                                                                                                                          |
| <code>cts_self_gating_num_regs_max_percent_total_cell</code> | 7        | Sets the maximum percentage of registers (out of the total cell count) that are XOR self-gated.                                                                                                                                                                                                                                                                                                              |
| <code>cts_self_gating_reg_power_filter</code>                | 0.001 mW | Sets the register power threshold such that only registers that use more power than this threshold are XOR self-gated                                                                                                                                                                                                                                                                                        |
| <code>cts_self_gating_wns_backoff</code>                     | 0.23     | Sets a register slack threshold to prevent registers in critical timing paths from being XOR self-gated. Only those registers whose timing slack is better than the threshold are candidates for XOR self-gating. The slack threshold is determined by the following equation:<br>$\text{slack\_threshold} = \text{pathgroup\_WNS} + (\text{cts\_self\_gating\_wns\_backoff\_value} * \text{clock\_period})$ |

You can use the `cts_self_gating_wns_backoff` variable to set a register slack threshold based on the worst negative slack (WNS) for the register selection. The following examples use the default of this variable.

For example, consider a path group that has a 1-ns clock period and a WNS of -0.5 ns. The register slack threshold is  $-0.5 + (0.23 \times 1) = -0.27$ ; therefore, only registers with slack that is better than -0.27 ns are considered for XOR self-gating.

If the same path group meets the timing constraints, the WNS is 0. The register slack threshold is  $0 + (0.23 \times 1) = 0.23$ , so only registers with slack that is better than 0.23 ns are considered for XOR self-gating.

## Optimizing for Clock Tree QoR

A balanced clock tree provides the best clock tree timing results. Following these setup recommendations before inserting the integrated clock-gating cells results in a more balanced clock tree:

- Use a small maximum clock-gating fanout value.
- Set the `power_cg_all_registers` variable to `true`.

This variable inserts always-enabled integrated clock-gating cells for ungated registers, so that the clock tree is balanced for both gated and ungated registers.

- Set the `power_remove_redundant_clock_gates` variable to `false`.

This variable prevents Design Compiler from optimizing away the integrated clock-gating cells that are used for balancing.

After placing your design, use the `split_clock_net` command to balance the clock tree fanout before running clock tree synthesis.

### Note:

You should use `split_clock_net` to balance the clock tree fanout when the clock trees are unbalanced and the design is not meeting your skew targets, or when you want to relax the constraint on the enable pin of the clock gate by delaying the clock arrival time at the clock gate.

The `split_clock_net` command replicates clock-gating cells to balance the clock tree fanout of the clock gates or clock nets specified in the `-objects` option, which can improve the skew and insertion delay for those clock trees.

```
icc_shell> split_clock_net -objects clk -gate_sizing -gate_relocation
```

The `split_clock_net` command uses the same clustering technique, which is used during clock tree synthesis. This clustering technique improves the skew by using smaller transition time and capacitance constraints, which are based on a technology-dependent computation. This can, however, lead to an increase in clock cell area and power. To force

the clustering technique to use a more relaxed constraint, use `set_clock_tree_options` to define the setup values for the constraints and set the `cts_force_user_constraints` variable to `true`. (For information about setting the clock tree design rule constraints, see “[Setting Clock Tree Design Rule Constraints](#)” on page 7-35.)

The `split_clock_net` command automatically sizes clock gates replicated to minimize the skew in each cluster.

By default, the `split_clock_net` command

- Does not buffer ungated registers

To buffer ungated registers, specify the `-drive_ungated_registers` option when you run the `split_clock_net` command.

- Replicates only integrated clock-gating cells (ICGs)

To replicate any clock gates, specify the `-split_any_cell_type` option when you run the `split_clock_net` command.

- Does not replicate clock gates that have unsynthesized clock subtrees in their fanout

To force replication of these clock gates, specify the `-split_intermediate_level_clock_gates` option when you run the `split_clock_net` command.

The `split_clock_net` command does not replicate the clock-gating cells in the following situations:

- The clock-gating cell has a pin that is defined as a clock (by the `create_clock` command) or as a generated clock (by the `create_generated_clock` command).
- All input pins of the clock-gating cell have a stop pin, exclude pin, or float pin exception.
- The clock-gating cell has a don't buffer net or don't touch subtree exception defined on its input or output pin.
- The clock-gating cell is an integrated clock-gating (ICG) cell inside a hierarchical clock-gating wrapper that also contains other cells.
- The clock-gating cell is inside an ILM or block abstraction model.
- All fanout of the clock-gating cell is inside an ILM or block abstraction model.

To report the number of clock-gating cells inserted by the `split_clock_net` command, run the `report_clock_tree` command.

## Optimizing for Power

When your goal is minimizing power, use a large (or unlimited) maximum clock-gating fanout during insertion of the integrated clock-gating cells (ICGs).

After placing your design, perform clock tree power optimization before running clock tree synthesis. To perform clock tree power optimization,

1. Specify the clock tree references (as described in “[Specifying the Clock Tree References](#)” on page 7-27).
2. Specify the clock tree synthesis options (as described in “[Specifying Clock Tree Synthesis Options](#)” on page 7-31) and exceptions (as described in “[Specifying Clock Tree Exceptions](#)” on page 7-13).
3. Enable power optimization by setting the `-power` option of the `clock_opt` command.
  - To run power-aware placement, set the `-low_power_placement` option to `true` with the `set_optimize_pre_cts_power_options` command.
  - To perform clock gate restructuring during power optimization, set the `-merge_clock_gates` option of the `set_optimize_pre_cts_power_options` command to `true`.

For multicorner-multimode designs, you must first set the `set_scenario_options` command options before enabling power optimization.

4. Annotate the switching activity by running the `read_saif` or `set_switching_activity` command.

**Important:**

If you use a SAIF file to annotate the switching activity, verify that it was generated at the actual clock frequency. If the SAIF file was not generated at the actual clock frequency, the numbers reported for dynamic power might be very small and incorrect.

For more information about annotating the switching activity, see “[Annotating Switching Activity](#)” on page 5-2.

5. Disable automatic group bounding of the gated clocks by setting the `placer_disable_auto_bound_for_gated_clock` variable to `true`.
6. (Optional) Specify the design constraints used during clock tree power optimization.

You specify the design constraints used during clock tree power optimization in a Tcl script file. You create separate constraint files for clock tree optimization and for post-clock-tree-synthesis optimization.

To specify the name of the constraint file used for clock tree synthesis, use the `-cts_constraint_file` option with the `set_optimize_pre_cts_power_options` command.

To specify the name of the constraint file used for post-clock-tree-synthesis optimization, use the `-psyn_constraint_file` option with the `set_optimize_pre_cts_power_options` command.

## 7. Perform clock tree power optimization.

To perform standalone clock tree power optimization, run the `optimize_pre_cts_power` command (or choose Clock > Optimize Pre-CTS Power in the GUI). To perform clock tree power optimization as part of the `clock_opt` process, use the `-power` option when you run the `clock_opt` command. For more information about the `clock_opt` command, see “[Implementing the Clock Trees](#)” on page 7-81.

Note:

When you run the `clock_opt -power` command, IC Compiler also performs leakage-power optimization.

IC Compiler performs the following tasks during clock tree power optimization:

- a. Merges integrated clock-gating cells that have the same enable signal.  
Only integrated clock-gating cells with positive slack are merged; cells with negative slack are not merged.
- b. Performs high-fanout net synthesis to fix design rule violations on the enable signals.
- c. Performs power-aware placement of the integrated clock-gating cells and registers.

Note:

If a significant portion of the clock gates are disabled, power-aware placement is not able to effectively optimize the design.

- d. (Optional) Performs timing optimization on the enable signals of integrated clock-gating cells.

The `split_clock_gates` command is invoked if you specify the `set_optimize_pre_cts_power_options -split_clock_gates true` command. The `split_clock_gates` command optimizes the timing on the enable signals of integrated clock-gating cells by fixing timing violations and by splitting the clock-gating cells that affect the worst negative slack. For more information about the `split_clock_gates` command, see “[Optimizing for Timing on Enable Signals](#)” on page 7-71.

Note:

The `-split_clock_gates` option performs the trial clock tree synthesis step, so you should specify the clock tree synthesis variables, constraints, and exceptions before running this option.

By default, clock tree power optimization ignores `dont_touch` and `size_only` attributes on integrated clock-gating cells. To override these defaults, use the `set_optimize_pre_cts_power_options` command (or choose Clock > Set Optimize Pre-CTS Power Options in the GUI).

To honor `dont_touch` attributes, specify the `-honor_dont_touch` option. To honor `dont_size` attributes, specify the `-honor_size_only` option.

To report the current clock tree power optimization options, use the `report_optimize_pre_cts_power_options` command or choose Clock > Report Pre-CTS Power Optimization Options in the GUI.

## Optimizing for Timing on Enable Signals

After Power Compiler inserts integrated clock-gating cells (ICGs), timing delays can cause negative slack or timing violations on the enable signals of the integrated clock-gating cells. The timing violations occur because the enable signals are asserted after the clocks become active. To improve the timing on the enable signals, use the `split_clock_gates` command.

Before running the `split_clock_gates` command, you can use the `report_qor` command to check the timing on the enable signals of integrated clock-gating cells. The report shows timing slack based on ideal clocks. If the negative slack of a path is serious, running the `split_clock_gates` command cannot improve the timing. Note that using the `split_clock_gates` command can optimize timing, but can also increase the area and power.

During the timing optimization step, the `split_clock_gates` command performs the following tasks:

1. Identify integrated clock-gating cells

By default, the command finds integrated clock-gating cells in the design and creates a path group of integrated clock-gating cells that is named `icg_en`. If no integrated clock-gating cells are found, the command terminates with a warning message.

2. Run initial clock tree synthesis

To include propagated delays on the enable signals of integrated clock-gating cells, the command invokes the `compile_clock_tree` command to build clock trees.

3. (Optional) Perform placement optimization

During the clock tree power optimization step, if you specify `set_optimize_pre_cts_power_options -split_clock_gates true` to run the `split_clock_gates` command, the command invokes the `psynopt -power -area_recovery` command to perform timing optimization. The `split_clock_gates` standalone command does not invoke the `psynopt` command. For more information about clock tree power optimization, see “[Optimizing for Power](#)” on page 7-69.

#### 4. Split integrated clock-gating cells

When finding an integrated clock-gating cell with negative slack that is smaller than the value specified by the `set_split_clock_gates_options -slack_margin` command, the `split_clock_gates` command invokes the `split_clock_net` command to split the integrated clock-gating cell. If the integrated clock-gating cell is marked with the `is_fixed` attribute or contains a clock definition, the integrated clock-gating cell cannot be split.

#### 5. Remove buffers and inverters

The command invokes the `remove_clock_tree` command to remove the buffers and inverters that are inserted by the `compile_clock_tree` command during Step 2 so that the design reverts to the unsynthesized stage.

By default, timing optimization ignores the `dont_touch` and `size_only` attributes on integrated clock-gating cells. To override these defaults, use the `set_split_clock_gates_options` command. For example, to honor cells with the `size_only` attribute when running the `split_clock_gates` command, enter

```
icc_shell> set_split_clock_gates_options -honor_size_only  
icc_shell> split_clock_gates
```

To reset the settings, use the `reset_split_clock_gates_options` command. To report the current timing optimization settings, use the `report_split_clock_gates_options` command. For more information about these commands, see the man pages.

After running the `split_clock_gates` command, use the `report_timing -group icg_en` command to report the timing of integrated clock-gating cells in the design. If running the `split_clock_gates` command does not fix the timing violations on the enable signals, apply the useful skew technique by using the `skew_opt` command. For more information about using the skew technique, see “[Using the Useful Skew Technique](#)” on page 7-137.

---

## Balancing Multiple Clocks

IC Compiler can automatically balance the skew between a group of clocks, either as part of the `clock_opt` process or as a standalone process.

Note:

IC Compiler cannot balance skew between a generated clock and other clocks.

This section describes how to set up the interclock delay balancing requirements. For information about performing interclock delay balancing during the `clock_opt` process, see “[Implementing the Clock Trees](#)” on page 7-81. For information about running standalone interclock delay balancing, see “[Running Interclock Delay Balancing](#)” on page 7-97.

IC Compiler also supports interclock delay balancing for multicorner-multimode designs. To set up a multicorner-multimode design, see “[Multicorner-Multimode Designs](#)” on page 7-59.

To define the interclock delay balancing requirements,

1. Define the buffers used for delay balancing.
2. Define the clock balance groups.
3. Define the interclock delay requirements.

## Defining the Delay Balancing Buffers

By default, IC Compiler can use all buffers and inverters in your technology library during interclock delay balancing.

To restrict the set of buffers and inverters used during delay balancing, use the `set_clock_tree_references -delay_insertion_only` command. For more information about specifying clock tree references, see “[Specifying the Clock Tree References](#)” on page 7-27.

## Defining a Clock Balance Group

By default, IC Compiler balances the delay between all master clocks in the design when you run interclock delay balancing. You can define a clock balance group to restrict the set of clocks considered during delay balancing or to define delay requirements between groups of clocks.

To define a clock balance group, use the `set_inter_clock_delay_options` command (or choose Clock > Set Interclock Delay Options in the GUI). To specify the clock trees in the group, use the `-balance_group` option (or the “Clocks in the group” box in the GUI). You can also assign a name to the balance group by using the `-balance_group_name` option (or the “Group name” box in the GUI). Although assigning a name to the balance group is optional, you must name the clock group to define a relationship between the group and other clock trees in the design.

For multicorner-multimode designs, IC Compiler balances the interclock delay in a clock balance group while considering the following mode and corners:

- The mode set by the `-cts_mode` option with the `set_scenario_options` command for the scenario in which the balance group is created
- All the corners specified by the `-cts_corner` option with the `set_scenario_options` command

For example, a multicorner-multimode design has the CLK1 and CLK2 clocks defined in the func\_WORST and func\_BEST scenarios. When you run the following commands, IC Compiler balances the CLK1 and CLK2 clocks by using the mode from the func\_WORST scenario and the corners from both the func\_WORST and func\_BEST scenarios.

```
icc_shell> current_scenario func_WORST  
icc_shell> set_inter_clock_delay_options -balance_group {CLK1 CLK2}
```

If you set the `-cts_mode` option to `true` with the `set_scenario_options` command for a scenario but define no balance groups, IC Compiler automatically creates a default balance group that includes all the clocks.

## Defining the Interclock Delay Requirements

By default, IC Compiler has a goal of zero delay offset between clocks. If you have different requirements, you can specify them by using the following methods:

- Specifying a delay offset between clock trees or clock groups
- Using the specified clock latency for each clock

You should not specify multiple interclock delay requirements (for example, specifying both a clock balance group and a delay offset) for a given clock. If a clock has multiple requirements, IC Compiler uses the following precedence when determining the interclock delay requirements:

1. Balancing delays within a clock balance group
2. The delay offset requirements
3. The target insertion delay
4. The SDC clock latency specification, if honored
5. The longest clock network delay

### Specifying the Delay Offset Requirements

You specify the delay offset requirement by specifying the following options with the `set_inter_clock_delay_options` command:

- `-delay_offset` (or “Delay offset” box in the GUI)
- `-offset_to` (or “Offset to” box in the GUI)
- `-offset_from` (or “Offset from clock” in the GUI)
- `-offset_from_group` (or “Offset from clock group” box in the GUI)

For example, assume that clk1 has a delay of 500, clk2 has a delay of 700, and clk3 has a delay of 100. If you want to balance the delay between clk1 and clk2 and have clk3 offset by 200, enter the following commands:

```
icc_shell> set_inter_clock_delay_options \
    -balance_group { clk1 clk2 } -balance_group_name grp1
icc_shell> set_inter_clock_delay_options -delay_offset -200 \
    -offset_to clk3 -offset_from_group grp1
```

The result is a delay of 700 for clk1 and clk2, the largest of the delays in the balance group, and a delay of 500 (700-200) for clk3.

As another example, assume that clk1 has a delay of 100 and clk2 has a delay of 200. If you want a delay offset of 200 between clk1 and clk2, enter the following command:

```
icc_shell> set_inter_clock_delay_options -delay_offset 200 \
    -offset_to clk1 -offset_from clk2
```

In this case, the result is a delay of 400 for clk1 (the clk2 delay plus the offset delay) and a delay of 200 for clk2.

### Specifying the Target Insertion Delay

To specify the target insertion delay for a clock, specify the clock by using the `-target_delay_clock` option (or “Target delay clocks” in the GUI) and specify the delay value by using the `-target_delay_value` option (or the “Target delay value” box in the GUI).

When you specify a target insertion delay for a clock, IC Compiler increases the insertion delay of the specified clock if it is less than the specified value. If the insertion delay of the specified clock is greater than the target insertion delay, no delay balancing is performed on that clock.

For example, if you want clk1 to have a delay of 100, enter the following command:

```
icc_shell> set_inter_clock_delay_options \
    -target_delay_clock clk1 -target_delay_value 100
```

If the delay on clk1 is less than 100, IC Compiler increases the delay to 100. If the delay on clk1 is greater than 100, IC Compiler does not perform delay balancing on clk1.

For multicorner-multimode designs, the `-delay_offset` and `-target_delay_value` options of the `set_inter_clock_delay_options` command consider the mode and corner from the scenario in which these options are defined.

For example, a multicorner-multimode design has the CLK1 and CLK2 clocks defined in the func\_WORST and func\_BEST scenarios. When you run the following commands, IC Compiler balances the target delay of 2 ns for the CLK1 clock by using the mode and corner from the func\_BEST scenario.

```
icc_shell> current_scenario func_BEST
icc_shell> set_inter_clock_delay_options -target_delay_value 2 \
           -target_delay_clock CLK1
```

### Using the Clock Latency Specification

The clock latency is specified by using the `set_clock_latency` command. By default, IC Compiler ignores the clock latency during interclock delay balancing. To honor the SDC clock latency specification, use the `-honor_sdc` option or choose Clock > Interclock Delay Options and select the “Honor latency defined in SDC” check box in the GUI. The `-honor_sdc` option applies to all scenarios for multicorner-multimode designs.

## Removing the Interclock Delay Settings

The clock balance groups, target insertion delay, clock latency specification, and the delay offset requirements that are set by the `set_inter_clock_delay_options` command during an IC Compiler session apply to the design in subsequent sessions. To remove the interclock delay settings, use the `reset_inter_clock_delay_options` command with the appropriate options. If you do not specify any options, the command removes all interclock delay settings.

For example, to remove a previously defined clock balance group named grp1, enter

```
icc_shell> reset_inter_clock_delay_options -balance_group_name grp1
```

To remove a list of clock balance groups CLK1 and CLK2, enter

```
icc_shell> reset_inter_clock_delay_options -balance_group "CLK1 CLK2"
```

For example, you use the following command to define interclock delay settings.

```
icc_shell> set_inter_clock_delay_options -offset_from CLK1 \
           -offset_to "CLK2 CLK3" -delay_offset 2
```

To remove the delay offset from CLK1 to both CLK2 and CLK3, enter

```
icc_shell> reset_inter_clock_delay_options -offset_from CLK1
```

To remove the delay offset from CLK1 to CLK2 but to preserve the delay offset from CLK1 to CLK3, enter

```
icc_shell> reset_inter_clock_delay_options -offset_from CLK1 \
           -offset_to CLK2
```

To remove the target insertion delay and clock latency specification, specify the `-target_delay_clock` and `-honor_sdc` options respectively.

To report the interclock delay settings, use the `report_inter_clock_delay_options` command.

---

## Hierarchical Designs

You can use hierarchical models, such as block abstraction models and interface logic models (ILMs), to increase the capacity and reduce the runtime for top-level clock tree synthesis. Before creating hierarchical models for use with top-level clock tree synthesis, you must perform clock tree synthesis on the blocks.

During clock tree synthesis and optimization, IC Compiler

- Identifies any hierarchical models inside a clock tree
- Honors clocks or generated clocks defined on a port of a hierarchical model or a pin internal to the hierarchical model
- Times the clock subtrees inside the hierarchical model to calculate the phase and transition delays for the hierarchical model

IC Compiler preserves all nets inside the hierarchical model, and the phase delays of the pins of the hierarchical model are calculated for delay balancing.

If there are multiple subtrees after a hierarchical model, IC Compiler synthesizes each subtree independently and does not balance the insertion delay between them, which can result in large skew between them. To reduce this skew, run the `optimize_clock_tree` command after performing clock tree synthesis.

- Honors explicit stop pins, exclude pins, and sink pins on a port of a hierarchical model or inside a hierarchical model

For more information about hierarchical models, see [Chapter 12, “Using Hierarchical Models.”](#)

---

## Handling Extracted Timing Models

An extracted timing model (ETM), which is generated from a gate-level netlist of a design in PrimeTime, can be used to replace the netlist for timing analysis at a higher level of the design. This type of model consists of clock-related arcs and timing arcs constraining input pins and output pins.

Clock tree synthesis and optimization provides the following capabilities to support ETMs:

- Minimize skew across multiple outputs of an ETM for the clock that launches these outputs, taking into account the arc delays in the ETM.
  - Honor the clock tree synthesis options and references defined on the internal pins of ETMs.
  - Run all clock tree synthesis commands for clocks that start from or go through ETMs.
- 

## Multivoltage Designs

Clock tree synthesis and optimization are voltage-area-aware. When running clock tree synthesis on multivoltage designs,

- Sink pins are separated and clustered by voltage area so that clock subtrees are built for each voltage area.
- A guide buffer is inserted for the set of sink pins for each voltage area to ensure that any subsequent levels of clustering do not mix pins from different voltage areas.
- Clocks defined on hierarchical pins that drive clock sinks in multiple voltage areas are supported, as shown in [Figure 7-18](#).
- Buffers are not inserted between an isolation cell and the shut-down power domain boundary.
- Dual-power always-on clock cells can be inserted or removed as needed on always-on paths in the shut-down or powered-up power domain.

Figure 7-18 Hierarchical Clock Pin Driving Clock Sinks in Multiple Voltage Areas



After the clock subtrees are built for each voltage area, clock tree synthesis can proceed in the usual manner, joining the subtrees at the root of the clock net. In addition to the synthesis of the initial clock tree, the preceding behaviors are honored by all clock tree optimization techniques, such as buffer relocation, buffer sizing, gate relocation, gate sizing, and delay insertion.

For more information about working with multivoltage designs, see [Chapter 14, “Multivoltage Design Flow.”](#)

---

## Verifying the Clock Trees

Before you synthesize the clock trees, use the `check_clock_tree` command to verify that the clock trees are properly defined.

```
icc_shell> check_clock_tree -clocks my_clk
```

If you do not specify the `-clocks` option, IC Compiler checks all clocks in the current design.

The `check_clock_tree` command checks for the following issues:

- Hierarchical pin defined as a clock source
- Generated clock without a valid master clock source

A generated clock does not have a valid master-clock source in the following situations:

- The master clock specified in `create_generated_clock` does not exist
- The master clock specified in `create_generated_clock` does not drive the source pin of the generated clock
- The source pin of the generated clock is driven by multiple clocks, and some of the master clocks are not specified with `create_generated_clock`.

For example, in [Figure 7-19](#), the reg01/Q pin is driven by both clka and clkb. If only clkb is specified as a master clock in a `create_generated_clock` command, `gen_clkb` does not have a valid master clock source.

*Figure 7-19 Generated Clock With Invalid Master Clock Source*



- Clock (master or generated) with no sinks
- Looping clock
- Cascaded clock with an unsynthesized clock tree in its fanout
- Multiple-clocks-per-register propagation not enabled, but the design contains overlapping clocks
- Ignored clock tree exceptions
- Stop pin or float pin defined on an output pin

- Buffers with multiple timing arcs used in clock tree references
- Situations causing empty buffer list

For multicorner-multimode designs, the `check_clock_tree` command checks all scenarios automatically for the following issues:

- Conflicting per-clock exception settings for each scenario
- Conflicting balancing settings in merged scenarios
- Conflicting multicorner-multimode interclock delay balancing settings

Each message generated by the `check_clock_tree` command has a detailed man page that describes how to fix the identified issue. Fixing these issues can improve the clock tree and timing QoR.

To see the current clock tree definition, generate the clock tree settings and exceptions reports, as described in “[Generating Clock Tree Reports](#)” on page 7-120.

---

## Implementing the Clock Trees

The recommended process for implementing the clock trees in your design is to use the `clock_opt` command, which performs clock tree synthesis and incremental physical optimization. This process results in a timing optimized design with fully implemented clock trees.

**Note:**

Before implementing the clock trees, save your design. This allows you to refine the clock tree synthesis goals and rerun clock tree synthesis with the same starting point, if necessary.

By default, IC Compiler uses the following naming convention for buffers and inverters inserted during clock tree synthesis:

`reference_GxByIz`

where `reference` is the library reference cell of the buffer or inverter, `x` is the gate level, `y` is the buffer level, and `z` is the instance count. To more easily locate the inserted buffers and inverters in your netlist, you can add a prefix to the instance names by setting the `cts_instance_name_prefix` variable. Similarly, you can add a prefix to any nets inserted during clock tree synthesis by setting the `cts_net_name_prefix` variable.

To perform clock tree synthesis, clock tree optimization, and incremental physical optimization, use the `clock_opt` command or choose Clock > Core CTS and Optimization in the GUI.

By default, IC Compiler ignores the `dont_touch` attribute on cells and nets during clock tree synthesis and clock tree optimization. To prevent sizing of cells during clock tree synthesis and clock tree optimization, use the `set_clock_tree_exceptions -dont_size_cells` command.

By default, the `clock_opt` command uses virtual routing during clock tree synthesis, but the optimization process uses the integrated clock global router to estimate the wire delay and capacitance. To ensure better postroute correlation, the integrated clock global router saves clock global routing information in the Milkyway database to be used by clock routing.

[Table 7-14](#) describes the options you can specify for the `clock_opt` command.

*Table 7-14 Clock Tree Synthesis and Optimization Options*

| Command option                    | GUI object                                                                         | Description                                                                                                                                                                                                                                        |
|-----------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                               | “CTS, clock routing, extraction, optimization and fix hold time violations” option | Selects the default <code>clock_opt</code> behavior.                                                                                                                                                                                               |
| N/A                               | “Allow cell insertion and deletion” option                                         | Selects the default <code>clock_opt</code> clock tree optimization behavior.                                                                                                                                                                       |
| <code>-area_recovery</code>       | “Recover area” check box                                                           | Enables area recovery during placement and timing optimization.                                                                                                                                                                                    |
| <code>-fix_hold_all_clocks</code> | “Fix hold time violations for all clocks” check box                                | Fix hold time violations.                                                                                                                                                                                                                          |
| <code>-in_place_size_only</code>  | “Minimal ECO placement changes” option                                             | Restrict placement and timing optimization to gate sizing only when there is enough space.<br>You cannot use this option with <code>-size_only</code> .<br>For more information, see “ <a href="#">Using Physical Optimization</a> ” on page 6-36. |
| <code>-inter_clock_balance</code> | “Balance interclock delay” check box                                               | Enables interclock delay balancing.                                                                                                                                                                                                                |
| <code>-no_clock_route</code>      | “Route clock nets” check box (uncheck for <code>-no_clock_route</code> )           | Do not perform clock routing.                                                                                                                                                                                                                      |
| <code>-only_cts</code>            | “CTS only (CTS, CTO, clock routing)” option                                        | Do not perform extraction, optimization, or hold time fixing.                                                                                                                                                                                      |

**Table 7-14 Clock Tree Synthesis and Optimization Options (Continued)**

| <b>Command option</b>                     | <b>GUI object</b>                                                                                  | <b>Description</b>                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-only_hold_time</code>              | “Fix hold timing only after CTS” check box                                                         | Performs only hold time fixing. (Do not perform clock tree synthesis, clock tree optimization, clock routing, extraction, or optimization.)                                                                                                                                                                                                               |
| <code>-only_psyn</code>                   | “Incremental optimization only (clock routing, extraction, optimization and fix hold time)” option | Do not perform initial gate upsizing, clock tree synthesis, or clock tree optimization.                                                                                                                                                                                                                                                                   |
| <code>-operating_condition</code>         | “Operating condition” list box                                                                     | Specifies the operating condition to use for clock tree synthesis and optimization: <code>min</code> , <code>max</code> , or <code>min_max</code> .                                                                                                                                                                                                       |
| <code>-optimize_dft</code>                | “Reorder scan cells” check box                                                                     | Enables scan chain optimization. For more information about scan designs in IC Compiler, see <a href="#">Chapter 4, “Design for Test.”</a>                                                                                                                                                                                                                |
| <code>-ignore_scan</code>                 | “Ignore scan” check box                                                                            | Ignores the scan chain connections during the congestion optimization stage. By default, the command considers scan nets.                                                                                                                                                                                                                                 |
| <code>-continue_on_missing_scandef</code> | “Continue with missing scan definitions” check box                                                 | Continues placement when the design contains scan chains but no SCANDEF data. By default, missing SCANDEF data causes the command to exit with an error message. Setting this option enables the placer to continue with a warning and results in reduced QoR.                                                                                            |
| <code>-power</code>                       | “Power optimization” check box                                                                     | Performs power optimization. For multicorner-multimode designs, you must first use the <code>set_scenario_options</code> command to set the leakage scenarios before enabling power optimization.<br>For more information, see <a href="#">“Handling Integrated Clock-Gating Cells”</a> on page 7-64 and <a href="#">Chapter 5, “Power Optimization.”</a> |

*Table 7-14 Clock Tree Synthesis and Optimization Options (Continued)*

| <b>Command option</b>              | <b>GUI object</b>                                   | <b>Description</b>                                                                                                                                                                                                         |
|------------------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-size_only</code>            | “Sizing changes only” option                        | Restrict placement and timing optimization to gate sizing only. You cannot use this option with <code>-in_place_size_only</code> . For more information, see “ <a href="#">Using Physical Optimization</a> ” on page 6-36. |
| <code>-update_clock_latency</code> | “Update real and virtual clock latencies” check box | Enables updating of clock latency values.                                                                                                                                                                                  |
| <code>-insert_self_gating</code>   | “Insert XOR self-gating” check box                  | Enables XOR self-gating. For more information, see “ <a href="#">Using XOR Self-Gating to Save Dynamic Power</a> ” on page 7-64.                                                                                           |

The `clock_opt` command does the following:

1. (Optional) Performs clock tree power optimization.

To perform clock tree power optimization during the `clock_opt` process, enable physical optimization of the integrated clock-gating cells and power-aware placement, as described in “[Optimizing for Power](#)” on page 7-69, and use the `-power` option of the `clock_opt` command.

2. Synthesizes the clock trees.

Before implementing the clock trees, IC Compiler upsizes, and possible moves, the existing clock gates, which can improve the quality of results (QoR) and reduce the number of clock tree levels.

**Note:**

To prevent the upsizing of existing clock gates before clustering, set the `cts_prects_upsize_gates` variable to `false`. To prevent the moving of existing clock gates before clustering, set the `cts_move_clock_gate` variable to `false`.

In addition, IC Compiler might move the existing gates, including integrated clock-gating (ICG) cells, when this could improve QoR. To prevent IC Compiler from moving existing gates, including integrated clock-gating cells, before clustering, set the `cts_move_clock_gate` variable to `false`.

IC Compiler builds clock trees that meet the clock tree design rule constraints, while balancing the loads and minimizing the clock skew. In addition, IC Compiler optimizes the clock paths beyond exclude pins, stop pins, and float pins to fix any design rule constraint violations.

**Note:**

Optimization is not performed on don't buffer nets or inside ILMs or block abstraction models.

By default, the clock sink cells might be moved or sized during the legalization and optimization steps that occur after clock tree synthesis. To prevent any modification to the clock sink cells after clock tree synthesis, set the `cts_fix_clock_tree_sinks` variable to `true`. Note that fixing the clock sinks can impact the timing QoR.

You can also run clock tree synthesis as a standalone process, using the `compile_clock_tree` command, as described in [“Performing Clock Tree Synthesis” on page 7-90](#).

**3. Optimizes the clock trees.**

During clock tree optimization, IC Compiler uses the optimization techniques, such as buffer relocation, buffer sizing, delay insertion, gate sizing, and gate relocation, to further improve the skew.

**Note:**

During clock tree optimization, IC Compiler ignores the `dont_touch` attribute on cells and nets. To prevent sizing of cells during clock tree optimization, use the `set_clock_tree_exceptions -dont_size_cells` command.

You can also run clock tree optimization as a standalone process, using the `optimize_clock_tree` command, as described in [“Performing Clock Tree Optimization” on page 7-93](#).

**4. (Optional) Performs interclock delay balancing.**

To perform interclock delay balancing during the `clock_opt` process, define the interclock delay balancing requirements, as described in [“Balancing Multiple Clocks” on page 7-72](#), and use the `-inter_clock_balance` option of the `clock_opt` command.

**Note:**

IC Compiler performs interclock delay balancing by performing delay insertion at the clock root. If the clock root net has a don't buffer net exception, IC Compiler cannot perform interclock delay balancing.

If the clock root is defined as a port of a pad cell, the delay insertion is performed on the net driven by the pad cell.

You can also run interclock delay balancing as a standalone process, using the `balance_inter_clock_delay` command, as described in [“Running Interclock Delay Balancing” on page 7-97](#).

5. Performs detail routing of the clock nets.

You can also perform detail routing of the clock nets as a standalone process, using the `route_zrt_group -all_clock_nets -reuse_existing_global_route true` command.

To prevent routing of the clock nets, use the `-no_clock_route` option of the `clock_opt` command.

6. Performs RC extraction of the clock nets and computes accurate clock arrival times.

7. (Optional) Adjusts the I/O timing.

To adjust the input and output delay based on the actual clock arrival times, use the `-update_clock_latency` option of the `clock_opt` command. IC Compiler uses the adjusted input and output delays during placement and timing optimization.

You can also update the I/O timing as a standalone process, using the `update_clock_latency` command, as described in “[Adjusting the I/O Timing](#)” on [page 7-97](#).

8. (Optional) Optimizes the scan chains.

To optimize the scan chains by reordering the chains to minimize the number of buffer crossings in the scan chain, use the `-optimize_dft` option of the `clock_opt` command.

For more information about scan designs in IC Compiler, see [Chapter 4, “Design for Test.”](#)

9. Fixes the placement of the clock tree buffers and inverters.

10. Performs placement and timing optimization.

If you specify `-update_clock_latency`, IC Compiler uses the adjusted input and output delays during placement and timing optimization. IC Compiler uses propagated arrival times for all clock sinks.

You can customize the placement and timing optimization process by specifying the following options: `-area_recovery`, `-in_place_size_only`, and `-size_only`. You can perform leakage-power optimization by using the `-power` option. For more information about these options, see [Table 7-14 on page 7-82](#).

You can also run only placement and timing optimization as a standalone process, using the `psynopt` command. For more information about the `psynopt` command, see “[Using Physical Optimization](#)” on [page 6-36](#).

To prevent placement and timing optimization, use the `-only_cts` option of the `clock_opt` command.

To run only placement and timing optimization (and not clock tree synthesis, clock tree optimization, or clock tree routing), use the `-only_psyn` option of the `clock_opt` command.

## 11.(Optional) Fixes hold time violations.

To fix hold time violations during the `clock_opt` process, use the `-fix_hold_all_clocks` option of the `clock_opt` command.

To reduce the runtime and buffer count, you can set the `-effort` option to `high` with the `set_fix_hold_options` command to guide the hold fixing performed by the `clock_opt` command. By default, the `-effort` option is set to `medium`. Fixing hold time violations during preroute also improves the QoR for postroute optimization.

**Note:**

The setting of the `-effort` option with the `set_fix_hold_options` command applies only to the preroute optimization stage.

After running the `clock_opt` command, analyze the results as described in “[Analyzing the Clock Tree Results](#)” on page 7-119.

## Optimizing Clock Tree Synthesis Only and Clock Tree Synthesis Hold Only Scenarios

To enable the clock tree synthesis only scenarios, run the `set_scenario_options` command with the following settings before running the `clock_opt` command:

```
icc_shell> set_scenario_options -cts_mode true -setup false -hold false \
    -cts_corner value -scenarios cts_scenario
```

Here, `value` could be any of `max`, `min`, or `min_max`.

Similarly, to enable the clock tree synthesis hold only scenarios, run the `set_scenario_options` command before running the `clock_opt` command:

```
icc_shell> set_scenario_options -cts_mode true -setup false -hold true \
    -cts_corner value -scenarios cts_scenario
```

Here, `value` could be any of `max`, `min`, or `min_max`.

For the clock tree synthesis and clock tree optimization stages of the `clock_opt` process, IC Compiler requires that any clock tree synthesis only scenario must have the `-setup` option set to `true` in its scenario options. As shown in the *IC Compiler Reference Methodology*, run the following command to ensure that this requirement is met by all clock tree synthesis only and clock tree synthesis hold only scenarios:

```
icc_shell> set_scenario_options -setup true \
    -scenarios [get_scenarios -cts_mode true -setup false]
```

Then, you must run the `clock_opt` command in two stages – first with the `-only_cts` option specified and then with the `-only_psyn` option specified (as shown in *IC Compiler Reference Methodology*).

This is recommended because the datapath optimization process (the `clock_opt` command run with the `-only_psyn` option specified or run without either `-only_cts` or `-only_psyn` option specified) optimizes data paths in all scenarios with the `-setup` option set to `true` for `max_delay`. This is not the desired behavior for these scenarios.

For clock tree reporting with the `report_clock_timing` and `report_clock_tree` command, ensure that the scenarios have the `-setup` option set to `true` when you want to review timing of the max delay paths through the clock network.

You can set the `-setup` option back to `false` after the clock tree synthesis and clock tree optimization stages of the `clock_opt` process.

---

## Analyzing Optimization Feasibility After Clock Tree Synthesis

After you finish implementing the clock trees, you can evaluate the design constraints for setup and hold time by analyzing optimization feasibility. You perform the feasibility analysis at an early design stage to fine-tune the design constraints for optimization. To perform the feasibility analysis, you use the `clock_opt_feasibility` command with the `-only_psyn` option.

Running optimization feasibility provides the following benefits:

- Improves timing QoR by resolving setup time violations and performing hold time fixing analysis.
- Reduces the runtime relative to the comparable `clock_opt` flow for optimization.

The following recommended script shows how to analyze optimization feasibility:

```
icc_shell> place_opt -congestion -power -area_recovery  
icc_shell> clock_opt -only_cts -no_clock_route \  
    -inter_clock_balance -update_clock_latency  
icc_shell> clock_opt_feasibility -only_psyn -congestion \  
    -power -area_recovery
```

You can specify any of the options of the `clock_opt` command when using the `clock_opt_feasibility` command. To reduce runtime, the `clock_opt_feasibility` command does not perform congestion removal or clock routing by default. You can optionally run congestion removal and clock routing by specifying the `-congestion` and `-clock_route` options respectively. To enable area recovery, specify the `-area_recovery` option.

When you specify the `-congestion` option with the `clock_opt_feasibility` command, the command performs placement to meet the congestion optimization requirements. By default, the command considers scan nets in the design. To ignore the scan chain

connections during congestion optimization, specify the `-ignore_scan` option. To specify to continue placement when the design contains scan chains but no SCANDEF data, specify the `-continue_on_missing_scandef` option.

For more information about the command, see the man page.

---

## Standalone Clock Tree Synthesis Capabilities

Using the `clock_opt` command is the recommended method for performing clock tree synthesis and optimization with IC Compiler. However, in cases where finer control is required, IC Compiler also provides the following standalone clock tree synthesis capabilities:

- Clock tree power optimization
- Clock tree synthesis
- High-fanout net synthesis
- Clock tree optimization
- Interclock delay balancing
- I/O timing adjustment
- Clock Tree Routing

The script in [Example 7-1](#) provides an example of performing clock tree synthesis and optimization by using the standalone capabilities. The following sections provide details about these capabilities.

### *Example 7-1 Clock Tree Synthesis and Optimization Using Standalone Capabilities*

```
optimize_pre_cts_power
compile_clock_tree
optimize_clock_tree
balance_inter_clock_delay
route_zrt_group -all_clock_nets -reuse_existing_global_route true
update_clock_latency
set_fix_hold [all_clocks]
psynopt -area_recovery -power
```

## Performing Clock Tree Power Optimization

For information about performing clock tree power optimization, see “[Optimizing for Power](#)” on page [7-69](#).

## Performing Clock Tree Synthesis

Clock tree synthesis is the process of implementing the clock trees based on your requirements. Clock tree synthesis is performed during the `clock_opt` process (see “[Implementing the Clock Trees](#)” on page 7-81) and can also be run as a standalone process.

IC Compiler clock tree synthesis is blockage-aware by default. The blockage-aware capability avoids routing and placement blockages to reduce DRC violations in designs with complex floorplans. Furthermore, it implements clock trees with minimum clock insertion delay, small clock skew, low buffer count, and small clock cell area to produce the best quality of results (QoR).

During clock tree synthesis, IC Compiler

- Upsizes and moves the existing clock gates, which can improve the QoR and reduce the number of clock tree levels.

Note:

To prevent upsizing of specific cells during this process, use the `set_clock_tree_exceptions -dont_size_cells` command.

- Inserts buffers and inverters to build clock trees that meet the clock tree design rule constraints, while balancing the loads and minimizing the clock skew.
- Fixes DRC violations beyond clock exceptions without balancing the skew if the `cts_fix_drc_beyond_exceptions` variable is set to `true` (the default).
- Builds a blockage map infrastructure per voltage area to identify whether a location is blocked for routing or placement, so the legalizer can move buffers to the nearest unblocked locations toward clock sources
- Locates the shortest blockage-avoiding route path from a startpoint to an endpoint with minimum delay to prevent DRC violations.

If your design has logical hierarchy, IC Compiler uses the lowest common parent of a buffer’s fanout pins to determine where to insert the buffers.

- If the lowest common parent is not the top level of the design, the buffer is inserted in the lowest common parent.
- If the lowest common parent is the top level of the design, the buffer is inserted in the block that contains the driving pin of the buffer.

IC Compiler adds new ports to the subdesigns where needed. The ports are added such that a minimal number of new ports are added.

To perform standalone clock tree synthesis, use the `compile_clock_tree` command (or choose Clock > Compile Clock Tree in the GUI and specify the clock trees in the “Clock tree names” box).

**Note:**

If you compile one clock at a time, be aware that the order in which you compile the clocks can affect the clock tree QoR. For best results, compile the most critical clock first.

## Performing Multimode Clock Tree Synthesis

System-on-chip designs integrate multiple modes, such as scan mode, memory BIST mode, and sleep mode, in addition to the normal mode in a single chip. You create a different clock tree synthesis scenario for each mode to run sequential clock tree synthesis, or you combine all scenario constraints in one SDC file to run single-mode clock tree synthesis. Both methods, which are time-consuming and error-prone, fail to produce optimal results. IC Compiler can perform multimode clock tree synthesis by simultaneously processing multiple scenarios to build balanced clock trees under different modes.

Running multimode clock tree synthesis provides the following benefits:

- Reduces the runtime relative to running sequential clock tree synthesis or single-mode clock tree synthesis.
- Produces better QoR because clock trees are built and optimized across all scenarios.

To enable multimode clock tree synthesis, use the `set_scenario_options` command. After creating all the scenarios, set the `-cts_mode` option of the `set_scenario_options` command to `true`, changing it from its default of `false`, for each scenario for which you want to perform clock tree synthesis.

For example, the following command instructs the tool to use scenario s1 for clock tree synthesis.

```
icc_shell> set_scenario_options -cts_mode true -scenarios s1
```

IC Compiler automatically invokes multimode clock tree synthesis when the `compile_clock_tree` command detects that more than one scenario has the `-cts_mode` option set to `true`. To run single-mode clock tree synthesis, set the `-cts_mode` option to `true` for only one scenario.

To perform multimode clock tree synthesis,

1. Run multimode clock tree synthesis by using the `compile_clock_tree` command.
2. Perform optimization by using the `optimize_clock_tree` command.
3. Proceed with routing by using the `route_zrt_clock_tree` and `route_opt` commands.

## High-Fanout Net Synthesis

You can use the `compile_clock_tree` command to perform high-fanout net synthesis by using the `-high_fanout_net nets_or_driving_pins` option (or by choosing Clock > Compile Clock Tree in the GUI and specifying the high-fanout nets in the “High fanout nets” box).

**Note:**

In a single `compile_clock_tree` run, you can perform either high-fanout net synthesis (by specifying the `-high_fanout_net` option) or clock tree synthesis (by specifying no clock names or by specifying the clock trees with the `-clock_trees` option); you cannot perform both tasks in a single run.

When you use `compile_clock_tree -high_fanout_net` to perform high-fanout net synthesis, the result is a balanced buffer tree (called a *high-fanout tree*), which is similar to a clock tree. When you use the `create_buffer_tree` command to perform high-fanout net synthesis, the resulting buffer tree might not be balanced.

The `compile_clock_tree` command performs high-fanout net synthesis by balancing the arrival times from the drivers of the nets specified in `-high_fanout_net` to the fanouts of those nets. High-fanout net synthesis does not traverse through preexisting gates on the high fanout net, nor does it support the use of clock tree exceptions.

**Important:**

If a clock tree exception exists on any fanout pin of a high-fanout net, high-fanout net synthesis generates an error message and fails. You must remove the clock tree exceptions and rerun high-fanout net synthesis.

By default, high-fanout clock tree synthesis can use any of the buffers or inverters in the library. To restrict the set of buffers or inverters used by high-fanout clock tree synthesis, use the `set_clock_tree_references` command, as described in “[Specifying the Clock Tree References](#)” on page 7-27.

High-fanout clock tree synthesis determines the clock tree design rules in the same way as standard clock tree synthesis. To define the clock tree design rules, use the `set_clock_tree_options` command, as described in “[Setting Clock Tree Design Rule Constraints](#)” on page 7-35.

By default, high-fanout clock tree synthesis uses the rising edge to determine the skew and arrival times. To use the falling edge instead, use the `-sync_phase fall` option when you run `compile_clock_tree`. To use both edges, use the `-sync_phase both` option when you run `compile_clock_tree`.

When you perform high-fanout clock tree synthesis, neither the endpoints nor the inserted buffers are fixed after high-fanout net synthesis. This is to allow `psynopt` to optimize the timing of the high-fanout trees.

To report the skew and path delay of the synthesized high-fanout net, use the `report_clock_tree -high_fanout_net pins_or_nets` command. You can use the following `report_clock_tree` options together with the `-high_fanout_net` option: `-summary`, `-structure`, `-level_info`, `-drc_violators`, `-operating_condition`, and `-nosplit`. All other `report_clock_tree` options are not supported with `-high_fanout_net`.

High-fanout clock tree synthesis has the following limitations:

- High-fanout clock tree synthesis does not support multicorner or multimode designs.
- High-fanout clock tree synthesis does not insert level shifters or isolation buffers in multivoltage designs. You must insert the level shifters and isolation buffers before running high-fanout clock tree synthesis.
- You cannot use `optimize_clock_tree` to optimize the high-fanout trees. Use the `psynopt` command instead.

## Performing Clock Tree Optimization

Clock tree optimization improves the clock skew and clock insertion delay by applying additional optimization iterations. Clock tree optimization is performed during the `clock_opt` process (see “[Implementing the Clock Trees](#)” on page 7-81) and can also be run as a standalone process before clock routing, after clock tree routing, or after detail routing. Typically, you would perform standalone clock tree optimization when timing optimization or incremental placement disturbs the clock skew or clock insertion delay.

To perform standalone clock tree optimization, use the `optimize_clock_tree` command or choose Clock > Optimize Clock Tree in the GUI. You can specify a list of clock trees, ports, or pins, but not hierarchical pins, as starting points of the clock network by using the `-clock_trees` option.

IC Compiler provides the following incremental optimization capabilities:

- Buffer relocation by using the `-buffer_relocation` option.
- Buffer sizing by using the `-buffer_sizing` option.
- Delay insertion by using the `-delay_insertion` option.
- Gate relocation by using the `-gate_relocation` option.
- Gate sizing by using the `-gate_sizing` option.

Note:

During clock tree optimization, IC Compiler ignores the `dont_touch` attribute on cells and nets. To prevent sizing of cells during clock tree optimization, use the `set_clock_tree_exceptions -dont_size_cells` command.

By default, the `optimize_clock_tree` command assumes that the clock trees in your design are not routed. For unrouted clock trees, the `optimize_clock_tree` command can perform any of the incremental optimization capabilities. The default behavior is to perform all incremental optimizations.

If your clock trees are routed, you must explicitly specify the routing stage of the clock trees by using the `-routed_clock_stage` option of the `optimize_clock_tree` command.

[Table 7-15](#) shows the supported routing stage keywords.

*Table 7-15 Routing Stage Keywords*

| Value  | Description                            |
|--------|----------------------------------------|
| none   | The clock trees are not routed.        |
| global | The clock trees have global routing.   |
| track  | The clock trees have track assignment. |
| detail | The clock trees have detail routing.   |

For routed clock trees, `optimize_clock_tree` can perform only the sizing optimizations (default behavior is to perform both buffer sizing and gate sizing).

To run a subset of the available optimizations, you must explicitly specify the optimizations that you want. If you specify options that are not compatible with the routing status of your design, IC Compiler generates an error message.

You only need to run postroute clock tree optimization once. Running multiple postroute clock tree optimizations offers minimum or no advantage because you do not see skew improvement over the runtime.

For example, to perform only gate sizing on a routed design, enter the following command:

```
icc_shell> optimize_clock_tree -gate_sizing
```

After optimizing postroute clock trees, the `optimize_clock_tree` command performs engineering change order (ECO) routing and extraction. The type of ECO routing performed depends on the routing stage of the clock trees.

- For global routed clock trees, IC Compiler performs incremental global routing.
- For track assigned clock trees, IC Compiler performs detail routing (utilizing dangling wires).
- For detail routed clock trees, IC Compiler performs detail routing (utilizing dangling wires) and performs two search-and-repair loops. To change the number of search-and-repair loops, use the `-search_repair_loop` option of the `optimize_clock_tree` command.

To disable ECO routing during `optimize_clock_tree`, specify the `-no_clock_eco_route` option.

By default, clock tree optimization uses the integrated clock global router to estimate the wire delay and capacitance for better correlation with postroute timing. For best QoR, you should use the integrated clock global router and specify the `-clock_arnoldi` option whenever possible.

### **Performing Multicorner Clock Tree Optimization**

IC Compiler can perform multicorner clock tree optimization to achieve the best QoR for your designs by processing various scenario corners simultaneously. Running multicorner clock tree optimization automatically enables the integrated clock global router and the Arnoldi delay analysis (`set_delay_calculation -clock_arnoldi`) to obtain the best clock network correlation and to ensure accurate insertion delay and skew.

To run multicorner clock tree optimization, use the following commands:

```
icc_shell> set_scenario_options -scenarios {list_of_scenarios} \
    -cts_mode true -cts_corner corner]
icc_shell> compile_clock_tree
icc_shell> optimize_clock_tree
```

The following script shows an example of running multicorner clock tree optimization:

```
create_scenario scn1
set_operating_conditions \
    -max $opcond_slow -max_library $lib_slow1\
    -min $opcond_fast -min_library $lib_fast1
set_tlu_plus_files \
    -max_tluplus $tlu_high_r \
    -min_tluplus $tlu_low_r \
    -tech2itf_map $tlu_map
```

```

create_scenario scn2
set_operating_conditions \
    -max $opcond_slow -max_library $lib_slow\
    -min $opcond_fast -min_library $lib_fast2
set_tlu_plus_files \
    -max_tluplus $tlu_high_r \
    -min_tluplus $tlu_low_r \
    -tech2itf_map $tlu_map
set_clock_tree_optimization_options \
    -corner_target_skew "scnf1:max=0.100 scn_cts:max=0.050 scn2:min=0.070"
set_clock_tree_optimization_options \
    -enable_multicorner_optimization "scn1:max scn1:min scn2:max scn2:min"

set_scenario_options -scenarios [all_scenarios] -cts_mode true \
    -cts_corner max
compile_clock_tree
optimize_clock_tree

report_clock_tree -scenarios {scn_ctrl scn1 scn2} -operating_condition min
route_zrt_group -all_clock_nets -reuse_existing_global_route true

```

When you enable multicorner clock tree optimization, the default value for the `-balance_rc` option of the `set_clock_tree_optimization_options` command is `true`. When the `-balance_rc` option is `true`, IC Compiler focuses on balancing the net delays between the different clock paths, during clock tree optimization. As a result, it improves the overall clock skew across the different process and temperature corners of a multicorner design. When you do not enable multicorner clock tree optimization, the default value is `false`. You can change these default values by explicitly specifying a value for the `-balance_rc` option.

## Fixing DRC Violations

The `optimize_clock_tree` command can automatically fix DRC violations in the clock network that are not fixed by the `compile_clock_tree` command because of heuristic limitations. You enable this capability by setting the `cto_enable_drc_fixing` variable to `true`, changing it from its default of `false`.

Fixing DRC violations during clock tree optimization improves the correlation between the following two stages:

1. Preroute, which uses virtual routing and the integrated clock global router.

The `compile_clock_tree` command uses virtual routing to estimate the wire delay and capacitance, whereas the `optimize_clock_tree` command invokes the integrated clock global router to perform global routing of clock nets.

2. Postroute, which uses the integrated clock global router and detail router.

To fix DRC violations in multicorner designs, you must also specify the maximum corner.

## Fixing DRC Violations on Signal Nets

Clock tree synthesis considers some nets as signal nets, such as a net in the clock network that is connected to the data input of a flip-flop or to an output port. Clock tree synthesis does not fix DRC violations on the signal nets. By default, the `psynopt` command fixes DRC violations on the signal nets after clock tree synthesis. To enable automatic DRC fixing on the signal nets during clock tree synthesis, set the `cts_enable_drc_fixing_on_data` variable to `true`, changing it from its default of `false`.

When this variable is set to `true`,

- The `compile_clock_tree` and `clock_opt` commands fix DRC violations on the signal nets in the clock network based on the constraints of clock tree synthesis.
- The `remove_clock_tree` and `mark_clock_tree` commands also apply to the signal nets in the clock network.
- The `report_clock_tree -drc_violators` command includes DRC violations on the signal nets in the clock network.

## Running Interclock Delay Balancing

Interclock delay balancing balances the skew between a group of clock trees, either as part of the `clock_opt` process (see “[Implementing the Clock Trees](#)” on page 7-81) or as a standalone process.

For information about defining the interclock delay balancing requirements, see “[Balancing Multiple Clocks](#)” on page 7-72.

By default, interclock delay balancing uses the integrated clock global router to estimate the wire delay and capacitance for better correlation with postroute timing.

To run standalone interclock delay balancing, use the `balance_inter_clock_delay` command or choose Clock > Balance Interclock Delay in the GUI. The `balance_inter_clock_delay` command honors the Elmore or Arnoldi delay model that is set by the `set_delay_calculation` command.

Note:

The `-max_target_delay` option of the `balance_inter_clock_delay` command does not support interclock delay balancing for multicorner-multimode designs.

## Adjusting the I/O Timing

After implementing the clock trees, IC Compiler can update the input and output delays to reflect the actual clock arrival times. When you adjust the I/O timing, IC Compiler calculates the median insertion delay for each clock tree and applies these values as the clock latency. The Milkyway database and SDC constraints are automatically updated, so you can easily export this data to PrimeTime for detailed timing analysis.

To adjust the I/O timing,

- Run the `update_clock_latency` command.
- or
- Specify the `-update_clock_latency` option when you run the `clock_opt` command.

IC Compiler adjusts the I/O timing to achieve the accuracy of clock latency and to prevent false timing violations on I/O paths after clock tree synthesis in the following ways:

- For synthesized generated clocks, the network latency of a clock object is updated, but the source latency of the clock object is updated when its master clock is synthesized.
- For synthesized clocks, network latency is computed by using the median value of the clock propagation delay, that is, the arrival time relative to the clock root at all boundary registers.
- For virtual clocks defined with the same `create_clock` command, network latency is calculated using the clock propagation delay of the boundary registers clocked by the individual virtual clocks.

To adjust the I/O timing for virtual clocks, you must define the relationships between the virtual clocks and the real clocks before you adjust the I/O timing as follows:

```
icc_shell> set_latency_adjustment_options \
           -to_clock my_virtual_clock -from_clock my_real_clock
icc_shell> update_clock_latency
```

When you save your design in Milkyway format, the relationships defined by the `set_latency_adjustment_options` command are stored in the Milkyway design library.

When adjusting the I/O timing based on virtual clocks, the `update_clock_latency` command defines the clock latency for both the real clock and its associated virtual clocks as the median insertion delay of the real clock.

You can report the virtual clock definitions by using the `report_latency_adjustment_options` command. You can remove the virtual clock definitions by using the `reset_latency_adjustment_options` command.

## Performing Clock Routing

After you finish clock tree optimization, you can perform clock routing using either the default router, Zroute, or the classic router.

Both Zroute and the classic router support the integrated clock global router and balanced-mode routing. To achieve the best correlation results, IC Compiler uses the integrated clock global router and saves clock global routing information.

When using Zroute (the default router), use the `route_zrt_group -all_clock_nets` command to perform clock routing. You must also use the `-reuse_existing_global_route` option so that Zroute detects the clock global routing information in the Milkyway database and performs incremental global routing.

```
icc_shell> route_zrt_group -all_clock_nets \
           -reuse_existing_global_route true
```

Note:

If you have an IC Compiler-PC package, use the `route_zrt_clock_tree` command to route the clock nets; the `route_zrt_group` command is not included in the IC Compiler-PC package.

For information about using Zroute to perform clock routing, see [Chapter 8, “Routing Using Zroute”](#).

To enable the classic router rather than Zroute, set the following command.

```
icc_shell> set_route_mode_options -zroute false
```

When using the classic router, you use the `route_group -all_clock_nets` command to perform clock routing. The `route_group` command can detect the clock global routing information in the Milkyway database and can set the global route incremental model automatically.

---

## Implementing Clock Meshes

Clock meshes are homogeneous shorted grids of metal that are driven by many clock drivers. The purpose of a clock mesh is to reduce clock skew in both nominal designs and designs across variations such as on-chip variation (OCV), chip-to-chip variation, and local power fluctuations. A clock mesh reduces skew variation mainly by shorting the outputs of many clock drivers.

[Figure 7-20](#) shows the structure of a clock mesh. The network of drivers from the clock port to the mesh driver inputs is called the premesh tree. The network of shorted clock driver outputs is called the mesh.

*Figure 7-20 Clock Mesh Structure*

Using clock meshes provides the following benefits:

- Small skew variation, especially for high-performance designs
- Consistent design performance across variations
- Predictable results throughout both the design stage and ECO stage later
- Stability resulting from mesh grids being close to receivers

Using clock meshes has the following disadvantages:

- More routing resources are required to create clock meshes.
- Power consumption is higher during transitions on parallel drivers driving the mesh.

## Prerequisites for Creating Clock Meshes

Before you run clock mesh commands, your design should meet the following requirements:

- The design should be mesh-conducive.

A basic mesh-conducive design contains at least one high-fanout clock net that has no more than two levels below the proposed mesh. If necessary, you can use the `remove_clock_gating` command in Power Compiler or the `flatten_clock_gating` command in IC Compiler to flatten the circuitry under the proposed mesh.

- The design should have enough room to place mesh drivers near the mesh loads for driving the mesh optimally.
- To analyze clock mesh circuits, you must have the NanoSim or HSIM transistor models for all the clock mesh gates. A circuit simulator is needed because static timing tools cannot handle clock meshes.
- You should be able to run NanoSim from the shell where you invoke the IC Compiler.

---

## The Clock Mesh Flow

Figure 7-21 shows the flow to follow when IC Compiler is used to create clock meshes.

Figure 7-21 IC Compiler Clock Mesh Flow



\* This is a Power Compiler command.

The following sections describe the steps in the clock mesh flow:

- [Flattening the Logic of Integrated Clock-Gating Cells](#)
- [Splitting Clock Nets](#)
- [Creating Clock Meshes](#)
- [Adding Clock Mesh Drivers](#)
- [Routing Mesh Nets](#)
- [Performing Quick Mesh Analysis](#)
- [Compiling Premesh Trees](#)
- [Routing Clock Nets](#)
- [Analyzing Clock Mesh Circuits](#)

These sections describe how to implement flat clock meshes. To implement hierarchical clock meshes, see “[Implementing Hierarchical Clock Meshes](#)” on page 7-115.

---

## Flattening the Logic of Integrated Clock-Gating Cells

Some designs have several levels of logic below the clock mesh, such as nested integrated clock-gating cells (ICGs). Integrated clock-gating cells are useful for reducing power consumption, but they can also introduce skew variation because of the number of levels.

To minimize skew induced by integrated clock-gating cells, you can

- Limit the depth of integrated clock-gating cells, preferably to a single level, by rerunning Power Compiler with appropriate options.
- Use the `remove_clock_gating` command in Power Compiler to remove integrated clock-gating cells.
- Use the `flatten_clock_gating` command to identify the integrated clock-gating cell that is driving a child integrated clock-gating cell. The command moves the child cell to a higher level of hierarchy in the circuitry where the primary mesh clock net is its clock input. To retain the same logic behavior, the command adds an AND gate and feeds both enable signals of the child cell and the parent cell to the AND gate.

Note:

Because the resulting design is more difficult to verify, use the `flatten_clock_gating` command only if you cannot rerun Power Compiler or use the `remove_clock_gating` command to remove integrated clock-gating cells.

---

## Splitting Clock Nets

The clock mesh flow starts with a placed design where the clock network has not been built. As such, clock ports might be driving the clock inputs of registers, latches, macros, or float pins, resulting in a large number of clock sinks and causing large loads on the clock network. You can use the `split_clock_net` command to reduce the loads by clustering the clock sinks according to the placement of the loads, DRC requirements, and timing constraints.

If the clock network drives macros, use the `-isolate_float_pins` option with the `split_clock_net` command to isolate the float pin delays of the macro blocks from other pins while duplicating the clock gates. Next, you need to decide whether to connect the macro pins to the premesh tree or under the mesh. To determine the connection, you need to consider the pin capacitance and phase delay of the pins. You can use the `adjust_premesh_connection` command to make the correct connection.

The `split_clock_net` command automatically balances clock trees and performs clustering to improve skew. However, the command does not optimize the premesh trees because clock mesh designs impose strict timing constraints on the premesh trees. For high-performance clock mesh designs, use the following command to further reduce skew variation:

```
icc_shell> optimize_clock_tree -postmesh -mesh_net mesh_net \
    -clock_trees clock
```

where `mesh_net` is the high-fanout net associated with the clock to be implemented as a mesh.

The `optimize_clock_tree -postmesh` command performs optimization by sizing only.

---

## Creating Clock Meshes

To create clock meshes, use the `create_clock_mesh` command and specify options such as the layers for the meshes, the numbers of straps, and so forth. Alternatively, you can choose Clock > Clock Mesh > Create Clock Mesh in the GUI. You should implement a simple mesh on an existing net that is connected to both a driving pin or port and some loads; otherwise, the net will be removed during later stages.

The following command creates a 10 x 10 (horizontal straps x vertical straps) clock mesh that geometrically fits the tree structure of the existing `clk` clock net.

```
icc_shell> create_clock_mesh -load clk -net clk \
    -layers {METAL4 METAL5} -num_straps {10 10}
```

The `-load` option specifies the mesh wires for the load pins of the clk net and the `-layers` option specifies placing the mesh straps on METAL4 (a horizontal layer) and METAL5 (a vertical layer). You can use the `get_layers` command to find what layers are present in your design before using the `create_clock_mesh` command.

You can enable the `-check_only` option the first time you use the `create_clock_mesh` command to verify the command options and display the statistics of the clock mesh areas without actually creating the mesh.

[Figure 7-22](#) shows an example of a resulting clock mesh using the `-num_straps {5 5}` option.

*Figure 7-22 A Clock Mesh Created With the `-num_straps {5 5}` Option*



[Figure 7-23](#) shows an example of a clock mesh that is created on the clk net.

*Figure 7-23 A Clock Mesh Created on the clk Net*



The process of creating clock meshes honors the fat wire rules that are specified in the technology file but does not honor the nondefault routing rules that are specified on the input nets. In addition, the command creates clock mesh wires with the clock strap attribute. To remove the clock mesh wires, enter

```
icc_shell> remove_clock_mesh -clockmesh clk_mesh
```

The `remove_clock_mesh` command allows you to remove different elements of the clock mesh, such as the premesh tree, the postmesh tree, and the entire clock mesh. [Table 7-16](#) describes the options of the command.

*Table 7-16 remove\_clock\_mesh Command Options*

| To do this                                  | Use this option |
|---------------------------------------------|-----------------|
| Specify a list of clock trees to be removed | -clock_tree     |
| Remove the premesh tree                     | -premesh        |
| Remove the routes of the premesh tree       | -route_only     |
| Remove the postmesh tree                    | -postmesh       |
| Remove the routes of the clock mesh         | -clockmesh      |

If you issue this command without any options, the tool removes the mesh and the routes of the mesh in the order of the clock mesh route, the premesh tree with all the routes, and the postmesh tree with all the routes. For more information, see the man page for this command.

## Adding Clock Mesh Drivers

Clock mesh drivers directly drive the clock mesh loads that include the mesh straps created by the `create_clock_mesh` command, the loads directly driven by the mesh, and the comb routes used to connect the drivers and loads to the mesh. You can use the `add_clock_drivers` command either to add only the clock mesh drivers or to create a hierarchy of drivers that drive the mesh drivers, starting from the root of the clock tree. Alternatively, you can choose *Clock > Clock Mesh > Add Clock Drivers* in the GUI. The circuitry from the root to the mesh driver inputs is called the premesh tree. An ideal premesh tree propagates signals to the clock mesh with almost no skew, such as an H-tree, which has logic-level balancing of buffers and routes to minimize on-chip variation.

Before adding the drivers, you need to choose the name of the clock net, the type of drivers, a prefix for naming new cells and nets, and a new name for the clock mesh net if you want the resulting clock mesh on a different clock net.

For example, the following command adds one level of buffers directly on the clock mesh, and you can build the premesh tree later to drive the buffers by using the `compile_premesh_tree` command.

```
icc_shell> add_clock_drivers -load clk \
    -driver_type CQCLKBFX20 -prefix ccc \
    -configuration { \
        {-level 1 -boxes {10 10} -short_outputs -output_net_name CLK_MESH}}
```

The following example adds 100 drivers directly to the clock mesh at level 3, 25 drivers to level 2, and 4 drivers to level 1. The `-driver_type` option specifies the buffd7 buffer for all three levels, and the `-prefix` option adds a prefix of `ccc` to the new cells and nets.

```
icc_shell> add_clock_drivers -load clk \
    -driver_type buffd7 -prefix ccc \
    -configuration { \
        {-level 1 -boxes {2 2}} \
        {-level 2 -boxes {5 5}} \
        {-level 3 -boxes {10 10} -short_outputs \
            -output_net_name clk_mesh -transfer_wires_from clk}}
```

Initially, the clock mesh was on the connected `clk` net. When the new mesh net named `clk_mesh` is created, the clock mesh is transferred to the `clk_mesh` net by using the `-transfer_wires_from` option.

Because level-3 buffers are driving the mesh directly, all their outputs are connected to create the new `clk_mesh` net.

[Figure 7-24](#) shows an example of a resulting mesh after inserting mesh drivers.

*Figure 7-24 Clock Mesh With Mesh Drivers*



---

## Routing Mesh Nets

After you create the mesh drivers and premesh trees, use the router to connect the outputs of the mesh drivers to the nearest clock mesh and the mesh loads to the nearest mesh straps. By default, IC Compiler uses Zroute as the default router. You can either use the `route_mesh_net` command or choose Clock > Clock Mesh > Route Mesh Net in the GUI to connect the mesh nets. For example,

```
icc_shell> route_mesh_net -net clk_mesh
```

By default, the `route_mesh_net` command uses comb topology when routing the clock mesh, which creates a thicker segment with many small segments coming off at perpendicular direction. To create a fishbone structure, which includes backbones grown from the mesh stripes and many fingers connecting the drivers and loads to the backbones, use the `-mode fishbone` option when you run the `route_mesh_net` command.

To specify a layer to construct the backbone of a fishbone structure, use the `-backbone_layer` option. This option takes effect only when you specify a backbone direction by setting the `-backbone_dir` option to horizontal or vertical and choose the fishbone topology by setting the `-mode` option to `fishbone`. The default backbone layer can be any layer that is suitable for routing without DRC violations

To honor the special routing rules that are specified on the mesh nets, use the following commands: `define_routing_rule` and `set_clock_tree_options`.

---

## Performing Quick Mesh Analysis

You should analyze whether the clock mesh circuitry, which is partially built, meets your skew targets.

### Prerequisites for Clock Mesh Analysis

You should analyze the partially built clock mesh circuitry to see if it meets the skew requirements.

- Create a temporary working directory to store the intermediate simulation files.
- Route the mesh nets by using the `route_mesh_net` command.
- Perform postroute RC extraction  
Before performing postroute RC extraction, ensure that the TLUPlus files are properly attached for extraction.
- Perform circuit simulation  
Before performing circuit simulations,

- Set up the transistor-level models for all gates of the clock network
- Set up the search path for NanoSim or HSIM

## Quick Mesh Analysis

After you create the initial clock mesh, the clock root net is not yet built and is still a high-fanout net. You can use the following commands to perform a quick mesh analysis:

```
icc_shell> set_ideal_network [get_nets name_of_clk_root_net]
icc_shell> set from_pin [get_pins *ADD_CLK_DRIVER*/A]
icc_shell> analyze_subcircuit -from $from_pin -to CLK_MESH \
    -clock clkdec \
    -driver_subckt_files ${ORIG_DESIGN_DIR}/spice/cells.sp \
    -spice_header_files ${ORIG_DESIGN_DIR}/spice/header.txt
icc_shell> report_clock_tree
```

If error messages occur during the mesh analysis process, you must fix them before continuing analysis and annotation because they can impact the accuracy of the analysis. The `analyze_subcircuit` command simulates the mesh circuits and back-annotates timing to the clock network. To see the clock skew, you can use the `report_clock_tree` command.

If you are not satisfied with the clock skew results, repeat the following steps until you get an acceptable result:

1. Remove the mesh structure and drivers by using the `remove_clock_mesh` command.
2. Re-create the mesh by using `create_clock_mesh`, using different mesh parameters.
3. Add mesh drivers by using the `add_clock_drivers` command.
4. Analyze the timing of the new mesh with the `analyze_subcircuit` command.
5. Report the clock skew by using the `report_clock_tree` command.

---

## Compiling Premesh Trees

Creating premesh trees using the `add_clock_drivers` command can be challenging, especially for nonrectangular placement areas because you need to determine the number of logic levels and a placement area for the buffers. However, you can use the `add_clock_drivers` command to add only the mesh drivers and then use `compile_premesh_tree` command or choose Clock > Clock Mesh > Compile Premesh Tree in the GUI to build premesh trees.

For example, first add only one level of drivers to the clock mesh:

```
icc_shell> add_clock_drivers -load clk \
    -driver_type buffd7 -prefix ccc \
    -configuration { \
        {-level 1 -boxes {10 10} -short_outputs \
            -output_net_name clk_mesh -transfer_wires_from clk}}
```

Then, add the premesh tree drivers:

```
icc_shell> compile_premesh_tree -clock_tree clk
```

[Figure 7-25](#) shows an example of a clock mesh with mesh drivers and premesh trees.

*Figure 7-25 A Clock Mesh With Mesh Drivers and Premesh Trees*



You can specify constraints and options for premesh tree synthesis by using the `set_clock_tree_options` command. By default, the `compile_premesh_tree` command enables the balancing of buffer levels for the premesh trees. To ensure a legal design with minimum skew, you can further improve the skew by running `optimize_clock_tree -premesh` after compiling the premesh trees.

#### Note:

The mesh root pin used for premesh clock tree synthesis must be the real clock root pin.

Alternatively, you can manually create a multilevel premesh tree by using `add_clock_drivers` (see “[Adding Clock Mesh Drivers](#)” on page 7-105 for an example) and then optimizing the premesh tree. For example, if the clock root of the premesh tree is `clk`, enter the following command to optimize the premesh tree:

```
icc_shell> optimize_clock_tree -premesh \
    -mesh_net [get_nets clk_mesh] -clock_trees clk
```

## Creating H-, T-, or I-Shape Routes for Premesh Trees

The `add_clock_drivers` command can create a very regular premesh tree if you set the appropriate options, but the router cannot guarantee regular routes and low skew for the premesh tree. You get regular routes and low skew if you choose the H-, I-, or T-shape route by using the `route_htree` command or by choosing Clock > Clock Mesh > Route HTree in the GUI.

The `route_htree` command uses Zroute in comb mode to create H-, I-, or T-shape routes.

For a net that has one driver and four loads, you can use the `route_htree` command to create an H-shape route. For example, the following command uses Zroute to create an H-shape route by using the M7 metal layer for vertical wires and the M6 layer for horizontal wires:

```
icc_shell> route_htree -nets [get_nets {ccc*L3_net* ccc*L2_net*}] \
    -layers {M6 M7} -orientation {H}
```

Note:

To ensure DRC convergence, Zroute might choose layers other than M6 and M7.

For a net that has one driver and two loads, you can use the `route_htree` command to create an I-shape route. The following example shows how to create a rotated I-shape route:

```
icc_shell> route_htree -nets [get_nets {ccc*L1_net*}] \
    -layers {M6 M7} -orientation {I_90}
```

Both H- and I-shape routes produce low skew. Using a series of I-shape routes instead of H-shape routes requires more drivers but minimizes skew.

For a net that has one driver and three loads, you can use `route_htree` command to create a T-shape route.

[Figure 7-26](#) shows the premesh tree structure of H-shape routes.

*Figure 7-26 H-Tree Structure*



Use the `route_htree` command with the `-wire_balance` option to balance the total wire length of each net within the specified limits for each level of the tree. If a level has a combination of H-, T-, and I-shaped nets, the tool attempts to balance the length of each net to match the largest length.

You can use the `route_htree` command for wire-length-balanced routing in the following ways:

- To create wire-length-balanced-routing from the specified root to a specified clock mesh net, use the following syntax:

```
route_htree
  -root cell_name
  -wire_balance
  -mesh_net mesh_net_name
  ...
```

The following example creates wire-length-balanced routing from the R\_BUF\_009\_INST root to mesh\_clock clock mesh by using the M6 layer for vertical wires and the M5 layer for horizontal wires:

```
icc_shell> route_htree -root R_BUF_009_INST -wire_balance \
  -mesh_net mesh_clock -layers {M5 M6}
```

- To create wire-length-balanced routing for a maximum of the specified levels from the specified root, use the following syntax:

```
route_htree
  -root cell_name
  -wire_balance
  -max_level num
  ...
```

**Note:**

The `-max_level` option specifies the maximum number of levels to be processed when creating wire-length-balanced routing.

The following example creates wire-length-balanced routing for a maximum of three levels starting from the K\_BUFA\_023\_INST root by using the M6 layer for vertical wires and the M5 layer for horizontal wires:

```
icc_shell> route_htree -root K_BUFA_023_INST -wire_balance \
    -max_level 3 -layers {M5 M6}
```

---

## Routing Clock Nets

After you complete the routing of mesh drivers and premesh trees, perform detail routing of the clock nets by using the `route_zrt_group -all_clock_nets -reuse_existing_global_route true` command or choose Route > Net Group Routing in the GUI. See “[Routing Clock Nets](#)” on page 8-55 for more information.

---

## Analyzing Clock Mesh Circuits

Clock mesh circuitry drives multiple loads across a wide area with many drivers, which are fundamentally different from the normal usage of CMOS logic gates. Additionally, clock mesh designs require higher timing accuracy than other designs to reduce skew variation. To analyze a clock mesh design, you use the RC extraction results followed by circuit simulation and then back-annotate the delay and transition time results to the IC Compiler static timing analyzer.

Before you analyze clock mesh circuits,

- Your design must meet the prerequisites for clock mesh analysis.  
See “[Prerequisites for Clock Mesh Analysis](#)” on page 7-107 for more information.
- You must complete the routing of the clock network.
- If you want to use StarRC for extraction and for signoff accuracy, define StarRC in the search path and include the nxtgrd files.

Analyzing clock meshes consists of the following steps:

1. Traverse the loads that you specify from the clock root to the clock mesh net.
2. Perform RC extraction on the clock meshes.
3. Store the extraction results in the directory that you specify.

4. Generate the SPICE files to simulate the clock meshes:

- Command files
- Measurement files
- Input pin capacitance and mesh receiver models

5. Invoke NanoSim or HSIM to perform simulation.

6. Annotate the timing analysis results from NanoSim to IC Compiler.

You can use the `report_clock_tree` or `report_clock_timing` command to see the timing results back-annotated from the `analyze_subcircuit` command.

To analyze clock mesh circuits, use the `analyze_subcircuit` command or choose Clock > Clock Mesh > Analyze Subcircuit in the GUI. For example,

```
icc_shell> analyze_subcircuit -name meshdir \
    -from clkroot -to clk_mesh -clock clk \
    -analysis_mode max -spice_header_files orig_data/header.txt \
    -driver_subckt_files orig_data/cells.sp
```

The command invokes extraction on the clock tree and places the results in a directory named meshdir that you specify by using the `-name` option. In addition, a CSV file records the latency and transition times for all input and output pins that are analyzed.

After the routing is complete, you can choose StarRC instead of `extract_rc` to perform extraction for signoff accuracy by specifying the `-starrcxt_map_file` and `-starrcxt_nxtgrd_file` options.

The `analyze_subcircuit` command supports two simulators: NanoSim and HSIM. NanoSim is the default simulator; however, you can invoke the HSIM simulator by specifying `-simulator hsim`.

The command provides three analysis modes: maximum (`max`), minimum (`min`), and maximum followed by minimum (`max_then_min`). The example uses the maximum mode for analysis. If you specify `-analysis_mode max_then_min`, the simulator performs analysis using the maximum corner first followed by the minimum corner.

You can also perform multicorner-multimode (MCMM) analysis on the clock mesh circuits by using the `-configuration` option. For example,

```
icc_shell> analyze_subcircuit -to clk \
    -driver_subckt_files max_spice_model \
    -spice_header_files header_file \
    -configuration { \
        {-scenario_name scenario1 \
            -max_driver_subckt_files max_file1 \
            -max_spice_header_files header_max1 \
            -min_driver_subckt_files min_file1 \
            -min_spice_header_files header_min1} \
        {-scenario_name scenario2 \
            -max_driver_subckt_files max_file2 \
            -max_spice_header_files header_max2 \
            -min_driver_subckt_files min_file2 \
            -min_spice_header_files header_min2}}
```

You must specify the scenario name that the `create_scenario` command uses. If you do not specify either `-max_driver_subckt_files` or `-max_spice_header_files` for the `-configuration` option, the command uses the files specified by the `-driver_subckt_files` or `-spice_header_files` option.

If your clock tree has multiple-input cells other than integrated clock-gating cells, such as multiplexers, you need to set the inputs explicitly by using the `-tie_high` and `-tie_low` options of the `analyze_subcircuit` command. The options provide control for the combinational gates in the premesh tree or other circuitry where the tool cannot identify an enable value automatically. For example,

```
icc_shell> analyze_subcircuit -tie_high [get_lib_pins my_lib/CT_CEL/E] \
    -name meshdir
```

## Optimizing Meshes With Macros

If your mesh circuitry has macro pins or pins with nonzero phase delays that are connected to the clock, use the `adjust_premesh_connection` command immediately after the `split_clock_net` command to analyze and connect those pins to the premesh trees.

Alternatively, you can choose Clock > Clock Mesh > Adjust Premesh Connection in the GUI.

As shown in [Figure 7-21 on page 7-101](#), the command sequence between the `split_clock_net` command and the second `analyze_subcircuit` command treats the output pin of the isolation buffer that is inserted by the `adjust_premesh_connection` command as the clock root. After the `analyze_subcircuit` step, connect the macro pins to the premesh tree and balance the input pin of the isolation buffer to ensure low skew by using the following command:

```
icc_shell> adjust_premesh_connection -root clock_root -premesh
```

During this process, the macro pins and the input pin of the isolation buffer are modeled as float pins. (Clock tree synthesis and analysis stops when encountering a float pin.) The input of the isolation buffer is annotated with the delay obtained from the circuit analysis, and then clock tree optimization is invoked to balance the timing of the float pins with the original clock root.

---

## Implementing Hierarchical Clock Meshes

The IC Compiler clock mesh technology supports hierarchical designs by using ILMs. During the block-level flow for your hierarchical design, you can also create a clock mesh for the clocks inside a block. The timing information of the block is available at the top level with the use of ILMs.

Note:

Block abstraction models are not supported by the hierarchical clock mesh flow.

## Prerequisites for the Hierarchical Clock Mesh Flow

Before you start creating a clock mesh in a block, make sure you have completed the following steps.

1. Complete the hierarchical design planning of the design, and create the Milkyway design libraries for the top-level and lower-level blocks.
2. Select a block that is clock mesh conducive.

For more detail on mesh conducive designs, see “[Prerequisites for Creating Clock Meshes](#)” on page 7-100.

## Procedures to Create Hierarchical Clock Mesh

To create a clock mesh for the clocks inside a block,

1. Complete the hierarchical design planning, open the block, and complete the placement process.
2. Create the clock mesh by using the clock mesh flow outlined in [Figure 7-21](#) and complete the routing of the block.
3. Run the `analyze_subcircuit` command to analyze the clock mesh.
4. Use the `create_ilm` command to generate the ILM for the block. The timing information is saved in the ILM view.
5. Create the FRAM view for the block to be used at the top level.
6. Return to the top level of the design and include the block with its FRAM and ILM views.

7. Propagate block-level timing to the top level and then proceed to complete the top-level flow. This is a required step in the hierarchical clock mesh flow.

```
icc_shell> propagate_ilm -clock_mesh_annotation
```

If you change the mesh structure to refine the result after creating the ILM, you need to run the `analyze_subcircuit` command again and create a new ILM.

[Figure 7-27](#) shows the design flow for implementing hierarchical clock mesh.

Figure 7-27 Design Flow for Implementing Hierarchical Clock Mesh



---

## Using Batch Mode to Reduce Runtime

When you run multiple `compile_clock_tree` commands on your design, the overhead of repeated clock tree synthesis preprocessing and postprocessing increases runtime. To reduce the `compile_clock_tree` runtime, you can enable the clock tree synthesis batch mode by using the `set_cts_batch_mode` command.

The following script shows an example of how to use batch mode with the `compile_clock_tree` command:

```
icc_shell> set_cts_batch_mode
icc_shell> compile_clock_tree -clock_trees c1
icc_shell> compile_clock_tree -clock_trees c2
icc_shell> report_cts_batch_mode
...
icc_shell> compile_clock_tree -clock_trees c3
...
icc_shell> reset_cts_batch_mode
```

The `reset_cts_batch_mode` command disables batch mode and invokes the postprocessing cleanup of excess clock trees that were inserted. The `report_cts_batch_mode` command displays whether the flow is in batch mode or normal mode.

Using batch mode for the `compile_clock_tree` command saves an average of 15 percent in runtime with a minimum impact on QoR. For best results, avoid using trigger commands that call clock tree synthesis preprocessing or postprocessing between the `set_cts_batch_mode` and `reset_cts_batch_mode` commands. Some examples of trigger commands are the `skew_opt`, `get_attribute`, `set_attribute`, `insert_buffer`, `remove_buffer`, `save_mw_cel`, `set_clock_tree_references`, and `latency` commands.

To use batch mode with the `clock_opt` command, set the `cts_clock_opt_batch_mode` variable to `true`. For example,

```
icc_shell> set_app_var cts_clock_opt_batch_mode true
icc_shell> clock_opt
```

When using batch mode with the `clock_opt` command, the average runtime improvement is about five percent.

---

## Analyzing the Clock Tree Results

After synthesizing the clock trees, analyze the results to verify that they meet your requirements. Typically the analysis process consists of the following tasks:

- Analyzing the clock tree reports (as described in “[Generating Clock Tree Reports](#)” on [page 7-120](#))
- Analyzing the clock tree timing (as described in “[Analyzing Clock Timing](#)” on [page 7-123](#))
- Reporting QoR (as described in “[Generating Categorized Timing Reports for Clock Tree Synthesis](#)” on [page 7-124](#))
- Verifying the placement of the clock instances, using the IC Compiler GUI (as described in “[Analyzing Clock Trees in the GUI](#)” on [page 7-127](#))

If the clock trees meet your requirements, you are ready to analyze the entire design for quality of results, as explained in “[Analyzing and Refining the Design](#)” on [page 7-148](#).

If the synthesis results do not meet your requirements, IC Compiler can help you debug the results by outputting additional information during clock tree synthesis. Set the `cts_use_debug_mode` variable to `true` before running clock tree synthesis to output the following additional information:

- User-defined design rule constraints (maximum transition time, maximum capacitance, and maximum fanout)  
For more information about user-defined design rule constraints, see “[Setting Clock Tree Design Rule Constraints](#)” on [page 7-35](#).
- User-defined clock tree timing constraints (skew and insertion delay)  
For more information about user-defined clock tree timing goals, see “[Setting Clock Tree Timing Goals](#)” on [page 7-37](#).
- Clustering targets set by IC Compiler (maximum transition time and maximum capacitance)

In addition, you can output detailed characterization data for the clock tree references by setting the `cts_do_characterization` variable to `true`.

Using this information, you can change the clock tree definitions to improve your results.

---

## Generating Clock Tree Reports

To generate clock tree reports, use the `report_clock_tree` command or choose **Clock > Report Clock Tree** in the GUI. By default, a report is generated for all clock trees for the current scenario. To limit the report to specific clock trees for the current scenario, use the `-clock_trees` option. To generate the report for a specific operating condition, use the `-operating_condition` option.

To generate the report for all clock trees of specific scenarios, use the `-scenarios` option.

**Note:**

The `-clock_trees` option and the `-scenarios` option are mutually exclusive; you can specify only one of these options.

You can use the `-histogram_transition`, `-histogram_capacitance`, `-histogram_rcdelay`, `-histogram_rcdelay_to_sink`, and `-histogram_fanout` options to report clock tree transition, capacitance, RC values, and fanout individually in a file in histogram-style format. When you specify the histogram options, use the `-number_of_bins` option to indicate the number of histogram bins.

[Table 7-17](#) shows the clock tree reports that are supported by IC Compiler.

*Table 7-17 Clock Tree Reports*

| Report type                    | Command option<br>(GUI object)                             | Description                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Default                        |                                                            | Reports the global skew for the specified clock trees.                                                                                                                                                                                                                                                                                                                             |
| Clock path from specific roots | <code>-from</code><br>("From pins" check box)              | Reports the fanout clock trees from the specified pins.                                                                                                                                                                                                                                                                                                                            |
| Clock path to specific sinks   | <code>-to</code><br>("To pins" check box)                  | Reports the clock paths to the specified sink pins.                                                                                                                                                                                                                                                                                                                                |
| DRC violators                  | <code>-drc_violators</code><br>("DRC violators" check box) | Lists the design rule violations that occur in the clock trees up to the endpoints (default sinks or don't touch subtrees), including violations beyond exception on stop pins, exclude pins, and float pins but excluding violations on don't buffer nets, don't touch subtrees, nets inside ILMs or block abstraction models, and nets connected to boundary cells or pad cells. |

*Table 7-17 Clock Tree Reports (Continued)*

| <b>Report type</b> | <b>Command option<br/>(GUI object)</b>                                        | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All DRC violators  | -all_drc_violators<br>("Include violators beyond exceptional pins" check box) | Lists all design rule violations that occur in the clock trees up to the default sinks through don't touch subtrees, including violations beyond exception pins.                                                                                                                                                                                                                                             |
| Exceptions         | -exceptions<br>("Exceptions" check box)                                       | Lists the stop pins, exclude pins, float pins, nonstop pins, don't touch subtrees, don't buffer nets, don't size cells, and size-only cells.                                                                                                                                                                                                                                                                 |
| Level information  | -level_info<br>("Level information" check box)                                | Reports on the structural and timing characteristics for all levels of the clock trees.                                                                                                                                                                                                                                                                                                                      |
| Settings           | -settings<br>("Settings" check box)                                           | <p>Lists the following global clock tree settings: clock tree synthesis, logic-level balancing, clock tree design rule constraints, clock tree configuration files nondefault routing rules, on-chip-variation-aware clustering.</p> <p>Lists the following per-clock tree settings: clock tree timing constraints, clock tree design rule constraints, maximum buffer levels, clock tree optimizations.</p> |
| Sinks              | -show_all_sinks<br>("Show all default sinks in design" check box)             | Lists the default sink pins.                                                                                                                                                                                                                                                                                                                                                                                 |
| Sink Groups        | -sink_group<br>("Sink Group" check box)                                       | <p>Lists clock sink groups and their timing relationships.</p> <p>See <a href="#">"Analyzing Clock Sink Groups" on page 7-9</a> for details.</p>                                                                                                                                                                                                                                                             |

**Table 7-17 Clock Tree Reports (Continued)**

| <b>Report type</b> | <b>Command option<br/>(GUI object)</b>                                                    | <b>Description</b>                                                                                                                                    |
|--------------------|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Structure          | -structure<br>("Clock tree structure" option)                                             | Lists the structure of the clock tree.                                                                                                                |
|                    | -partial_structure_within_exceptions<br>("Clock tree structure within exceptions" option) | Lists the structure of the clock tree up to any explicit exclude pins or float pins. The clock structure beyond these exception pins is not reported. |
|                    | -premesh<br>("Pre-mesh information" check box)                                            | Reports the clock network that has a clock mesh, starting from the clock root to the mesh driver inputs.                                              |
|                    | -postmesh<br>("Post-mesh information" check box)                                          | Reports the clock network that has a clock mesh, starting from the inputs of the clock drivers that are the load pins of the clock mesh.              |
| Summary            | -summary<br>("Summary" check box)                                                         | Reports the global clock skew summary.                                                                                                                |
| Histogram Analysis | -histogram_transition<br>("Transition" check box)                                         | Reports the transition of the selected clock trees in the specified file.                                                                             |
|                    | -histogram_capacitance<br>("Capacitance" check box)                                       | Reports the capacitance of the selected clock trees in the specified file.                                                                            |
|                    | -histogram_rcdelay<br>("RC delay" check box)                                              | Reports the RC values of the selected clock trees in the specified file.                                                                              |
|                    | -histogram_rcdelay_to_sink<br>("RC delay to sink" check box)                              | Reports the RC delay values per sink between the clock drivers and each valid sink in the specified file.                                             |
|                    | -histogram_fanout<br>("Fanout" check box)                                                 | Reports the fanout of the selected clock trees in the specified file.                                                                                 |
|                    | -number_of_bins<br>("Number of bins" check box)                                           | Specifies the number of histogram bins. When you specify the histogram options, you can use this option to set the histogram bins. The default is 10. |

---

## Generating Reports for Multicorner Clock Tree Optimization

To generate a clock tree report for a particular scenario corner, set the corner by using the `set_scenario_options` command and then run the `report_clock_tree` command. For example, to report the clock trees for the scn1, scn2, and scn3 scenarios for the minimum corner, enter the following commands:

```
icc_shell> set_scenario_options -scenarios {scn1 scn2 scn3} \
    -cts_mode true -cts_corner min
icc_shell> report_clock_tree -scenarios {scn1 scn2 scn3} \
    -operating_condition min
```

Because the `report_clock_tree` command requires that you define clocks in the scenario that you want to report, you should define clocks in every scenario when using multicorner clock tree optimization.

```
icc_shell> create_scenario scn1
icc_shell> set_operating_conditions -max $opcond1
icc_shell> set_tlu_plus_files -max_tluplus $tlu1 -tech2itf_map $tlu_map
icc_shell> create_clock -name clock -period 4 clock

icc_shell> create_scenario scn2
icc_shell> set_operating_conditions -max $opcond2
icc_shell> set_tlu_plus_files -max_tluplus $tlu2 -tech2itf_map $tlu_map
icc_shell> create_clock -name clock -period 4 clock
```

---

## Analyzing Clock Timing

The timing characteristics of the clock network are important in any high-performance design. To obtain detailed information about the clock networks in a design, use the `report_clock_timing` command. This command reports the clock latency, transition time, and skew characteristics at specified clock pins of sequential elements in the network.

In the `report_clock_timing` command, use the `-type` option to specify the type of report you want (see [Table 7-18](#) for available report types), the scope of the design to analyze, and any desired filtering or ordering options for the report. For analyzing the effect of clock tree synthesis exceptions and clock propagation, use the `-cts_mode` option. IC Compiler gathers the requested information and reports it in the specified order.

By default, the `report_clock_timing` command reports for the current scenarios only. Use the `-scenarios` option to report for the specified scenarios.

**Note:**

You cannot use the clock tree specification options `-clock`, `-from_clock`, and `-to_clock`, with the `-scenarios` option. The report has details of all clock trees of the specified scenarios.

*Table 7-18 Clock Timing Report Types*

| To generate this report                                                                            | Use this keyword             |
|----------------------------------------------------------------------------------------------------|------------------------------|
| Single-clock local skew                                                                            | <code>skew</code>            |
| Transition                                                                                         | <code>transition</code>      |
| Interclock skew                                                                                    | <code>interclock_skew</code> |
| Latency                                                                                            | <code>latency</code>         |
| Summary (shows the worst instances of transition time, latency, and skew for the specified clocks) | <code>summary</code>         |

---

## Generating Categorized Timing Reports for Clock Tree Synthesis

You can generate categorized timing reports to analyze the clock tree synthesis results for the design in its current state by using the `create_qor_snapshot` command (or by choosing Timing > Create QoR Snapshot in the GUI). This command measures and reports the quality of the design in terms of timing, design rules, area, power, congestion, routing, and so on. It stores the quality information in a set of snapshot files. You can retrieve and report the snapshot with the `report_qor_snapshot` command. You can also selectively retrieve, sort, and display the information from the snapshot with the `query_qor_snapshot` command (or by choosing Timing > Query QoR Snapshot in the GUI and then selecting CTS Mode in the Query Mode setting).

You can generate the quality of results snapshot for the current scenario only or for any specified set of scenarios.

### **`create_qor_snapshot`**

The `create_qor_snapshot` command measures the quality of the design in its current state and stores the quality information into a set of report files. You can capture the quality information using different optimization strategies or at different stages of the design and compare the quality results. Use the `-clock_tree` option of the `create_qor_snapshot` command to generate the information for clock tree synthesis categorized timing reports. See “[“create\\_qor\\_snapshot” on page 6-53](#) for details.

## query\_qor\_snapshot

The `query_qor_snapshot` command reads in a QoR report generated by previous usage of the `create_qor_snapshot` command and analyzes the results by collecting information about each path. You can query the collected information with various filters and display the results in text or HTML format, or in an interactive HTML window linked to the GUI layout view. The interactive HTML report lets you quickly find paths with certain problems such as large fanouts or transition degradation, and then view the path in the current design.

This is the syntax of the `query_qor_snapshot` command for generating clock tree synthesis categorized timing reports:

```
query_qor_snapshot
  -clock_tree_only
  [-name snapshot_name]
  [-directory directory_name]
  [-cts_output_file file_name]
  [-cts_sort_by column_list]
  [-cts_columns column_list]
  [-cts_and column_list]
  [-cts_filters filter_list]
  [-cts_set_exceptions_file file_name]
  [-cts_clear_exceptions_file file_name]
```

Alternatively, you can create a QoR snapshot in the GUI by choosing Timing > Query QoR Snapshot and then selecting CTS Mode in the Query Mode setting.

The command options let you filter and sort the query results and display those results in text or HTML format. The command reports a summary of the clock tree, subject to one or more specified filters by using the `-cts_filters` option. All values that match a filter are highlighted (with a \* for text or red text for HTML). You can specify the columns to display with the `-cts_columns` option, the column value sorting order with the `-cts_sort_by` option, and the filters to apply as AND filters with the `-cts_and` option. Use the `-cts_set_exceptions_file` option to generate a Tcl command file containing `set_clock_tree_exceptions` commands for each clock path matching one or more filters that can create clock tree exceptions. Use the `-cts_clear_exceptions_file` option to generate a Tcl command file containing `remove_clock_tree_exceptions` commands for each clock path matching one or more filters that can remove clock tree exceptions.

If you do not specify the `-cts_filters` option, the `query_qor_snapshot` command automatically applies a set of default filters. The default filter settings are shown in the following example:

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report \
  -cts_filters {-transitionViolation 1 -fanoutViolation 1 \
  -capacitanceViolation 1 -dontTouchSubtree 1 \
  -dontBufferNets 1 -dontSizeCells 1 -sizeOnlyCells 1 \
  -explicitIgnore 1 -skew 0 \
  -transitionDegradation 2.0 -slewDegradation 2.0}
```

The `query_qor_snapshot` command does not perform any additional analysis of the design, but merely processes the report information already saved in the snapshot report files. Therefore, execution of the `query_qor_snapshot` command is much faster than execution of the `create_qor_snapshot` command.

The following example looks at all clock paths matching the ETM impossible pins filter. An ETM impossible pin is a clock sink pin inside an extracted timing model (ETM) that has zero or negative latency. If the clock path has one or more ETM impossible pins, the command automatically generates the appropriate `set_clock_tree_exceptions` commands for those clock paths.

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report ... \
    -cts_filters {-etm_impossible_pins 1} -cts_set_exceptions_file {my_}
```

The following example looks at all clock paths matching the don't touch subtree filter. If the clock path has one or more don't touch subtree exceptions, the command automatically generates the appropriate `remove_clock_tree_exceptions` commands for those clock paths.

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report ... \
    -cts_filters {-dont_touch_subtree 1} -cts_clear_exceptions_file {my_}
```

In the following example, the `query_qor_snapshot` command reports all clocks with skew greater than 5 ns:

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report ... \
    -cts_filters {-skew 5.0}
```

In the following example, the `query_qor_snapshot` command reports all clocks that have cells with an output transition value or input transition value over 2:

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report ... \
    -cts_filters {-transition_degradation 2}
```

In the following example, the `query_qor_snapshot` command reports all clocks having ETM impossible pins and sets the ETM impossible pin threshold to 0.1 ns:

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report ... \
    -cts_filters {-etm_impossible_pins 1 -etm_impossible_threshold 0.1}
```

In the following example, the `query_qor_snapshot` command reports all clocks that have path segments with slew degradation over 3:

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report ... \
    -cts_filters {-slew_degradation 3}
```

In the following example, the `query_qor_snapshot` command reports all clocks that have over 50 logic levels:

```
icc_shell> query_qor_snapshot -clock_tree_only -name clk_report ... \
    -cts_filters {-logic_level 50}
```

For more information about the `query_qor_snapshot` command, see the man page for the command.

---

## Analyzing Clock Trees in the GUI

IC Compiler provides several GUI windows that you can use to analyze the clock trees:

- Layout window  
The clock tree visual modes allow you to view the structure or timing distribution of the clock trees in the layout window.
- Interactive clock tree synthesis window  
The interactive clock tree synthesis window provides information about all the clocks defined in your design.
- Clock tree option viewer  
The clock tree option viewer displays the current settings of the clock tree synthesis options.
- Clock tree hierarchy browser  
The clock tree hierarchy browser provides a hierarchical listing of the clock tree.
- Clock arrival histogram  
The clock arrival histogram provides a high-level overview of the timing of clock tree fanout.
- Clock tree latency graph view  
The clock tree latency graph view provides time-based representations of the clock trees.
- Clock tree leveled graph view  
The clock tree leveled graph view provides a view of the logical relationships of the clock trees.
- Fanin and fanout schematics

The following sections describe these windows.

- [Viewing Clock Trees in the Layout Window](#)
- [Using the Interactive Clock Tree Synthesis Window](#)
- [Using the Clock Tree Option Viewer](#)
- [Viewing the Clock Tree Hierarchy](#)
- [Viewing the Clock Tree Arrival Time Histogram](#)
- [Viewing Clock Latency and Skew in the Clock Graph View](#)
- [Using the Clock Tree Levelized Graph View](#)
- [Viewing the Fanout or Fanin Schematic](#)

## **Viewing Clock Trees in the Layout Window**

IC Compiler provides two clock tree visual modes:

- Clock tree structure
- Clock tree timing distribution

These modes are useful for analyzing the clock tree structure after clock tree synthesis. Analyzing the structure enables you to identify possible sources for clock tree timing problems, such as a restrictive floorplan or the use of nonoptimal references.

### **Viewing the Clock Tree Structure**

To view the clock tree structure in visual mode,

1. In the layout window, choose Clock > Color By Clock Trees.

The Visual Mode panel appears.

2. Click Reload.

The Configure Clock Tree Visual Mode dialog box appears.

3. Select the clock tree levels or cell types that you want displayed. (To view the clock tree display choices for a tree, click the plus sign (+) to the left of the clock tree name.)

[Table 7-19](#) describes the clock tree display choices. You must select at least one level or cell type.

**Table 7-19 Clock Tree Display Choices**

| <b>Partition name</b>    | <b>Description</b>                                                  |
|--------------------------|---------------------------------------------------------------------|
| AllLevel                 | Displays the entire clock tree in a single color.                   |
| Level 0...Level <i>n</i> | Displays each selected clock tree level in a different color.       |
| buffer                   | Displays the buffers inserted into the clock tree by IC Compiler.   |
| inverter                 | Displays the inverters inserted into the clock tree by IC Compiler. |
| preexisting              | Displays the preexisting gates in the clock tree.                   |
| sink                     | Displays the clock tree sinks.                                      |

To analyze the synthesized clock tree, you would typically select one or more clock tree levels (Level 0...Level *n*) to be displayed. You can use this display to debug the placement of the clock tree cells.

4. Click OK or Apply.

The GUI displays the selected clock tree levels and cell types in the layout view.

By default, the clock tree nets are displayed. To display the clock tree cells, deselect Cells in the “Exclude objects” section. To disable the display of clock tree nets, select Nets in the “Exclude objects” section.

### **Viewing the Clock Tree Timing Distribution**

To display the clock latency or transition time distribution,

1. In the layout window, choose Clock > Color By Clock Latency/Transition.

The Visual Mode panel appears.

2. Click Reload.

The Clock Latency/Transition dialog box appears.

3. In the Clock Latency/Transition dialog box, do the following:

- Type or select a clock tree in the Clock box.
- Select a Delay Type option (Latency or Transition).
- Set other options as needed.

4. Click OK.

## Using the Interactive Clock Tree Synthesis Window

The interactive clock tree synthesis window provides information about all of the clocks defined in your design. You can select clock trees in the window for further examination with other analysis tools.

To open an interactive clock tree synthesis window,

- Choose Clock > New Interactive CTS Window.

When you open an interactive clock tree synthesis window, it displays the clock browser view, which includes a table with information about each clock tree. The table columns show the clock names, sources, and other details about each clock tree.

The Browsers toolbar, shown in [Figure 7-28](#), lets you select a clock in the clock browser view and open a clock tree fanout browser or generate a clock arrival histogram. You can also display the clock browser view when it is hidden.

*Figure 7-28 Browsers Toolbar*



The Expand Browser toolbar, shown in [Figure 7-29](#), lets you expand or collapse fanout levels for the clock tree displayed in the active clock tree fanout browser. You can expand or collapse all levels, or expand a specified number of levels. This toolbar can be found in the interactive clock tree synthesis window.

*Figure 7-29 Expand Browser Toolbar*



You can open the following clock tree analysis windows from the interactive clock tree synthesis window:

- The clock tree option viewer
- The clock tree hierarchy browser
- The fanout schematic
- The clock tree arrival histogram
- The clock graph view
- The clock tree leveled graph view

You can also select clock tree objects in the clock tree fanout browser for analysis with tools in the layout window.

## Using the Clock Tree Option Viewer

IC Compiler provides a clock tree option viewer that you can use to view or set the clock tree options for each clock tree in the design.

To open the clock tree option viewer,

- In the layout window or the interactive clock tree synthesis window, choose Clock > List Clock Tree Options.

The clock tree option viewer displays a list of all the clock trees in the design. The list contains columns with the current values (whether default or previously set) for each clock tree option. You can use the buttons below the list to set or change options for the selected clock tree, display or hide columns in the list, or close the window.

## Viewing the Clock Tree Hierarchy

The clock tree hierarchy browser provides a hierarchical listing of the clock tree. This can be useful for analyzing complex clock tree structures before or after clock tree synthesis.

If you are not familiar with the clock trees in your design, you can explore the clock tree structures and gather information about objects (buffers, inverters, and preexisting cells) at each level. You can also select the names of objects you want to examine in graphic views or with other analysis tools.

Before you perform clock tree synthesis, use the clock tree hierarchy browser to understand the existing clock tree structure.

After you perform clock tree synthesis, use this view to analyze the resulting clock tree structures and for troubleshooting if you failed to achieve the expected QoR.

To display the clock tree hierarchy view,

1. In the interactive clock tree synthesis window, select the clock you want to view.
2. Choose View > Clock Tree Hierarchy Browser.

The clock tree hierarchy browser is associated with the interactive clock tree synthesis window in which it was opened. You can open multiple clock tree hierarchy browsers (one for each clock tree).

The view window consists of two panes, with expandable level trees (one for each clock tree) in the left pane and an object information table in the right pane. You can explore the complete structure of a clock tree, observe how many levels are present, and examine the clock tree fanout information for the cells at each level.

If you hold the pointer over a clock tree object, in either the left or right pane of the clock tree hierarchy browser, information about the clock object is displayed.

If you select a clock and right-click, a menu appears. You can open the following clock tree analysis windows from this menu:

- Clock tree visual mode
- The fanout or fanin schematic

In addition, you can view the longest and shortest paths for a clock tree in the clock tree browser. To view the longest path of the selected clock, click the longest path icon ( ) in the interactive clock tree synthesis window. To view the shortest path of the selected clock, click the shortest path icon ( ) in the interactive clock tree synthesis window.

## Viewing the Clock Tree Arrival Time Histogram

Clock arrival histograms provide a high-level overview of the timing quality in the fanout network of a selected clock tree. Create a clock arrival histogram to identify clock network pins that failed their constraints.

To display the clock tree arrival time histogram,

- In the interactive clock tree synthesis window, choose Timing > Clock Arrival Histogram.

The clock arrival histogram appears in a new histogram view window. The window is split into two panes, with the histogram bar graph in the left pane and an object table in the right pane. The number at the top of the tallest bin indicates the number of clock tree objects in the bin. Green bins (on the positive side of 0) contain objects in the design that met their constraints. Red bins (on the negative side of 0) contain objects that failed their constraints.

You can select one or more pin names in the table for further examination with other analysis tools. You can

- Select pins and display the clock fanin network in a path schematic
- View object properties for the selected pins

## **Viewing Clock Latency and Skew in the Clock Graph View**

The clock graph views provide a time-based scheduling relationship of a selected clock network. You can use a clock graph view to analyze the latency and skew issues but not to show the logic connectivity. The clock graph view shows the worst intrinsic path, the worst path if different from the worst intrinsic path, and the best path of the selected clock network.

To create a clock graph view, you can choose one of the following three ways.

From the interactive clock tree synthesis window,

1. Select a clock in the clock browser.
2. Choose Latency Graph > New Clock Tree Latency Graph.

From the clock tree hierarchy browser,

1. Select a clock in the left pane.
2. Right-click to display the pop-up menu and choose “Clock Tree Latency Graph from Selected”.

The previous two procedures create the same graph view of the selected clock.

From the clock arrival histogram view,

1. Select a histogram bar in the left pane to display clock objects.
2. Select the clock objects in the right pane.
3. Right-click to display the pop-up menu and choose “Clock Tree Fanin Latency Graph Of Selected”.

This clock graph view displays the relationship between the clock root and the clock objects that belong to the selected clock histogram bar.

In the clock graph view, you can right-click to

- Zoom in or out
- Delete or add clock objects
- Show the full clock tree fanout

- Show fanout or fanin schematics
- Expand or collapse the selected clock objects
- View the standard properties of the selected clock objects

## Using the Clock Tree Levelized Graph View

A clock tree leveled graph view can help you visualize the relationships between driving cells and output loads in a clock network or relationships between clock trees. Unlike a clock tree latency graph view that is a time-based representation, a clock tree leveled graph view shows logic gates based on the levels of their clock inputs in clock tree fanout networks. You can use a clock tree leveled graph view to analyze the fanout structure of clock networks before and after clock tree synthesis.

To create a clock tree leveled graph view, you can select one of the following three ways.

From the interactive clock tree synthesis window,

1. Select one or more clocks in the clock browser.
2. Right-click and choose “Clock Tree Levelized Graph From Selected”.

The leveled graph view displays the whole clock tree fanout of the selected clock root.

From the clock tree hierarchy browser,

1. Select one or more clocks in the left pane.
2. Right-click and choose “Clock Fanin Levelized Graph From Selected”.

The clock tree leveled graph view shows the relationship of the selected clock pins and their clock root that is shown in the clock tree hierarchy browser.

From the clock arrival histogram view,

1. Select a histogram bar in the left pane to display clock objects.
2. Select clock objects in the right pane.
3. Right-click and choose “Clock Tree Fanin Levelized Graph Of Selected”.

This leveled graph view displays the relationship between the clock root and the clock objects that belong to the selected clock histogram bar.

Figure 7-30 shows an example of a clock tree network in the clock tree leveled graph view.

Figure 7-30 Clock Tree Levelized Graph View for a Single-Clock Network



Figure 7-31 Clock Tree Levelized Graph View for Multiple Clock Trees



In the clock tree leveled graph view, you can right-click to

- Zoom in or out
- Delete or add clock objects
- Show the full clock tree fanout
- Show fanout or fanin schematics
- Expand or collapse the selected or unselected clock objects
- View the standard properties of the selected clock objects

## **Viewing the Fanout or Fanin Schematic**

IC Compiler can provide a schematic showing the fanout or fanin of a clock tree object.

To display a fanout or fanin schematic,

1. Select a clock tree object in the interactive clock tree synthesis window or clock tree hierarchy browser.
2. Right-click to display the pop-up menu.
3. Choose the appropriate menu selection:
  - In the interactive clock tree synthesis window, choose “Clock Fanout Network Schematic From Selected” to display the fanout of the selected clock.
  - In the clock tree hierarchy browser, choose “Clock Fanout Schematic from Selected” to display the fanout from the selected clock object.
  - In the clock tree hierarchy browser, choose “Clock Fanin Schematic from Selected” to display the fanin to the selected clock object.

---

## **Fine-Tuning the Clock Tree Synthesis Results**

IC Compiler supports the following methods for fine-tuning the clock tree synthesis results:

- [Using the Useful Skew Technique](#)
- [Balancing the Skew Using Skew Groups](#)
- [Resynthesizing the Clock Trees](#)
- [Modifying the Nondefault Routing Rule](#)
- [Modifying Clock Trees in the GUI](#)

---

## Using the Useful Skew Technique

The useful skew technique improves timing QoR by adjusting the clock arrival times to take advantage of positive slack in the network. Use the `skew_opt` command to automatically perform useful skew analysis and generate the useful skew constraints.

### **skew\_opt Details**

By default, the `skew_opt` command performs the following tasks:

- Analyzes the design to determine which paths can be used for useful skew.

IC Compiler looks for paths with positive slack where the slack could be redistributed (by adjusting the clock latencies) along the input-to-output paths to improve the overall design timing.

By default, IC Compiler evaluates only the setup constraints. To consider both setup and hold constraints, specify the `-hold` option. You can also tighten the setup and hold constraints by specifying the `-setup_margin` and `-hold_margin` options, respectively.

IC Compiler does not adjust the latency on the following types of paths:

- Paths that loop from a register to itself
- Paths that contain level-sensitive latches
- Combinational paths from an input port to an output port
- Paths within ILMs or block abstraction models

Note:

IC Compiler does not adjust the latency on a nonstop pin. For paths that start or end at nonstop pins (either implicit or explicit), IC Compiler adjusts the latency only at the other endpoints or startpoints.

By default, there is no limit to the amount of latency adjustment that can be made. To limit the amount of latency adjustment, specify the `-adjustment_limit` option. To further limit the amount the latency can be decreased, specify the `-decrease_factor` option.

To disable this analysis and use the existing clock latencies, specify the `-no_optimization` option.

- Determines the interclock relationships in the design.

IC Compiler analyzes the interclock relationships in the design and uses this analysis to define the interclock delay balancing groups.

- Generates a script file that is used to adjust the clock latencies and set the interclock delay balancing constraints.

The script contains `set_clock_latency` and `set_clock_tree_exceptions -float_pins` commands to adjust the clock latencies and `set_inter_clock_delay_options` commands to define the interclock delay balancing groups.

By default, a script is generated if any latency adjustments are identified. If you want to generate a script only if the worst negative slack (WNS) improves by a certain amount, specify the `-improvement_threshold` option.

By default, the generated script file is named `skew_opt.tcl`. To use another file name, specify the `-output` option.

- Sources the generated script file to apply the clock latency adjustments and interclock delay balancing constraints.

You can disable sourcing of some of the commands in the generated script, or of the entire generated script.

- To disable sourcing of the `set_clock_latency` commands, set the `skew_opt_skip_ideal_clocks` variable to `true` before running `skew_opt`.
- To disable sourcing of the `set_clock_tree_exceptions -float_pins` commands, set the `skew_opt_skip_propagated_clocks` variable to `true` before running `skew_opt`.
- To disable sourcing of the `set_inter_clock_delay_options` commands, set the `skew_opt_skip_clock_balancing` variable to `true` before running `skew_opt`.
- To disable sourcing of the entire script, specify the `-no_auto_source` option when you run `skew_opt`.

For detailed information about the `skew_opt` command, see the man page.

## **skew\_opt Flow**

The flow for using the `skew_opt` command is

- Determine the existing clock latencies by doing a quick `clock_opt` run.

Use the `set_latency_adjustment_options` command to identify the timing relationships between a source clock and associated generated clocks or virtual clocks. For example, for a generated clock, enter

```
icc_shell> set_latency_adjustment_options \
-from_clock master_clk -to_clock gen_clock
```

Use the `skew_opt -clock_balancing_only` to configure interclock delay balancing groups. The generated `skew_opt` script file includes the annotation of the changed ideal latencies for clock objects. In addition, to ensure the same I/O latencies that are seen by `skew_opt` and the `psynopt` command that is embedded in `clock_opt`, you should perform clock routing separately from the `clock_opt` command to avoid an additional `update_clock_latency` call inside `clock_opt` after clock routing.

The following script shows an example of how to determine the latencies for your design:

```
icc_shell> place_opt
icc_shell> save_mw_cel -as placed
icc_shell> close_mw_cel
icc_shell> open_mw_cel placed
icc_shell> set_latency_adjustment_options ...
icc_shell> skew_opt -clock_balancing_only
icc_shell> clock_opt -inter_clock_balance \
    -update_clock_latency -no_clock_route
icc_shell> route_zrt_group -all_clock_nets \
    -reuse_existing_global_route true
icc_shell> extract_rc
```

## 2. Run the `skew_opt` command.

```
icc_shell> skew_opt
icc_shell> close_mw_cel
```

## 3. Load the updated clock latencies and useful skew solution.

```
icc_shell> open_mw_cel placed
icc_shell> set_latency_adjustment_options ...
icc_shell> source skew_opt.tcl
```

## 4. Perform clock tree synthesis and optimization with interclock delay balancing.

```
icc_shell> clock_opt -inter_clock_balance -no_clock_route
icc_shell> route_zrt_group -all_clock_nets \
    -reuse_existing_global_route true
icc_shell> extract_rc
icc_shell> route_opt
```

### **Important:**

Because the `skew_opt` command works across all clock domains in your design, you must perform interclock delay balancing when running clock tree synthesis after `skew_opt`.

In addition, do not update the clock latency after clock tree synthesis (`clock_opt -update_clock_latency` option or `update_clock_latency` command). Updating the clock latency after clock tree synthesis invalidates the script file generated by `skew_opt`.

## Balancing the Skew Using Skew Groups

You can select a group of clock sinks from the same clock domain to form a subgroup named a skew group. IC Compiler automatically balances the skew of clock sinks, including the clock pins of integrated clock-gating cells, enable flip-flops, and clock dividers, in each skew group. You can specify different skew and insertion delay constraints for different skew groups in the same clock domain.

[Figure 7-32](#) shows the flow to follow when IC Compiler is used to define skew groups.

*Figure 7-32 Skew Group Flow*



## Guidelines for Defining Skew Groups

When defining a skew group, use the following guidelines:

- Select nonhierarchical pins such as leaf stop pins, leaf float pins, the clock pins of integrated clock-gating cells, and the clock pins that start the sequential timing arcs.
- Select pins from the same master-clock domain only. Pins from different generated clock domains are allowed in the same skew group.
- Each pin can only belong to one skew group.
- No pins should have upstream-downstream dependency in the same skew group.
- A skew group that contains any nonstop pins or clock pins of integrated clock-gating cells creates dependency on the skew group to which their downstream sink pins belong.

- Clock sinks that are not defined in any skew groups are automatically included in the default skew group.
- A skew group is independent when only clock sink pins are defined in the group.
- No dependency loop between skew groups is allowed.

For example, if skew group A is dependent on skew group B, then skew group B cannot be dependent on other skew groups

The guidelines also apply to the default skew group.

To create a skew group, use the `set_skew_group` command or choose Clock > Skew Group > Set Skew Group in the GUI.

For example, the following command creates a skew group named grp1 on the timing-critical path from `reg_0_/CLK` to `gen_ck_reg_1_/DATA` with two clock sinks, `reg_0_/CLK` and `gen_ck_reg_1_/CLK`, as shown in [Figure 7-33](#).

```
icc_shell> set_skew_group -name grp1 {reg_0_/CLK gen_ck_reg_1_/CLK}
```

*Figure 7-33 Skew Group grp1 With Two Clock Sinks*



The skew group grp1 automatically balances the skew, so you do not need to either adjust the clock latencies, latency A and latency B, or specify the float pin value at `reg_0_/CLK` to avoid setup violations.

You can specify the skew and insertion delay constraints by using the `-target_skew` and `-target_early_delay` options respectively. Note that the skew group constraints take precedence over the clock tree design rule constraints and the design rule constraints of the logic library and the design. If you do not specify the skew or insertion delay constraints for

a skew group, the skew group inherits the most strict clock tree design rule constraints of the clock sink in the clock domain. The default skew group always uses the clock tree design rule constraints.

To report the skew of each skew group, use the `report_clock_tree -skew_group` command.

## Validating and Committing Skew Groups

After creating or modifying a skew group, you should always commit the skew group by using the `commit_skew_group` command or choose Clock > Skew Group > Commit Skew Group in the GUI. The command checks the skew group in the design against the guidelines. When the command detects an invalid skew group, it generates an error message and makes no changes to the netlist. If all skew groups are valid, the command restructures the clock trees to separate the skew groups. When you specify the `-check_only` option, the command only validates the skew groups, but it does not restructure the clock trees.

You can report the settings of skew groups by using the `report_skew_group` command or by choosing the Clock > Skew Group > Report Skew Group in the GUI.

To remove a skew group, use the `remove_skew_group` command or choose Clock > Skew Group > Remove Skew Group in the GUI

## Limitations of Using Skew Groups

Using skew groups has the following three limitations:

- If you run the `remove_clock_tree` command on a design that contains skew groups, you must rerun the `commit_skew_group` command before balancing the clock trees again.
- If there is dependency between skew groups, the `-target_skew` and `-target_early_delay` options are not honored.
- You cannot use skew groups with features such as clock tree configuration files, logic-level balancing, and OCV-aware clustering.

---

## Resynthesizing the Clock Trees

In some cases, to achieve the best results, you must fine-tune the clock tree synthesis settings, then resynthesize the clock trees.

Resynthesizing the clock trees consists of the following steps:

1. Input the postplacement design that you saved before performing clock tree synthesis.

If you did not save the design before running clock tree synthesis (or if you want to keep some synthesized clock trees, but resynthesize others), you must remove the synthesized clock trees before you can resynthesize the clock trees (see “[Removing Clock Trees](#)” on page 7-61). The resulting design might not be identical to your design before running the initial clock tree synthesis, because some gates might have been moved or sized during the clock tree synthesis process.

2. Validate the setup.
3. Fine-tune the clock tree synthesis settings.
4. Resynthesize the clock trees.

The following sections describe these steps.

## Validating the Setup

If the synthesis results do not meet your requirements, check the following items before fine-tuning:

- The input design

Ensure that the input design meets the requirements for clock tree synthesis.

- TLUPlus models

- The clock root

Verify that you have correctly defined the clock root, including setting a driving cell if the clock root is a top-level input port. Verify that the attributes of the clock root, such as the input transition time and output capacitance, are correct. Verify that the library model for the root cells is accurate.

- The clock sinks

Run the `report_clock_tree -exceptions` command to verify that the clock tree exceptions (both implicit and explicit) are correctly set.

- The design rule constraints

To verify the design rule constraints and check that they are realistic, use the `report_clock_tree` command to report on the clock tree (or choose Clock > Report Clock Tree in the GUI). If your clock trees have too many cells or levels, this typically indicates that the design rule constraints are too tight.

## Resynthesizing the Clock Trees

You can resynthesize the clock trees either by using the `clock_opt` command (as described in “[Implementing the Clock Trees](#)” on page 7-81) or by using standalone clock tree synthesis (as described in “[Performing Clock Tree Synthesis](#)” on page 7-90).

---

## Modifying the Nondefault Routing Rule

If your design is congested, you can modify the nondefault routing rule of an existing clock tree. To modify the nondefault routing rule, use the `mark_clock_tree -routing_rule` command (or choose Clock > Mark Clock Tree in the GUI and specify the routing rule in the “Routing rule” box). In the same way that you specify the nondefault rule for unsynthesized clock trees, you can use the default routing rule for the nets connected to the clock sinks by specifying the `-use_default_routing_for_sinks level_count` option (or by selecting “Routing rule” in the GUI and specifying the level count in the “Use default routing for sinks at level” box). In addition, you can specify the layers to use for clock routing by specifying the `-layer_list layers` option (or by selecting the layers in the GUI). For more information about the clock tree routing options, see “[Setting Clock Tree Routing Options](#)” on page 7-38.

Note:

If you specify an undefined routing rule or layer, the `mark_clock_tree` command exits with an error message and does not change the existing settings.

When you change the nondefault routing rule, IC Compiler updates the RC data by running the `extract_rc` command to perform extraction using the new routing rule information.

---

## Modifying Clock Trees in the GUI

You can modify clock trees in the GUI by using the interactive clock tree synthesis capability. You can use interactive clock tree synthesis for both preroute and postroute designs.

Note:

Interactive clock tree synthesis considers a design to be postroute only if all clock nets are routed.

Interactive clock tree synthesis allows you to do what-if analysis on the clock trees and then commit the changes, if they meet your requirements.

You can invoke the interactive clock tree synthesis capabilities from the layout menu (by choosing Clock > ECO) or by selecting an object in the interactive clock tree synthesis window and right-clicking to open the pop-up menu. [Table 7-20](#) shows the capabilities supported by interactive clock tree synthesis and the menu option used to invoke this capability.

*Table 7-20 Interactive Clock Tree Synthesis Capabilities*

| Task                                                             | Supported phases      | Menu option       |
|------------------------------------------------------------------|-----------------------|-------------------|
| Insert buffer                                                    | preroute              | CTS Insert Buffer |
| Remove buffer                                                    | preroute              | CTS Remove Buffer |
| Move buffer or gate                                              | preroute              | CTS Move Cell     |
| Move a clock tree branch to another point in the same clock tree | preroute              | CTS Re-parent     |
| Size buffer or gate                                              | preroute or postroute | CTS Size Cell     |

When you make changes, you can update the timing by clicking Update Timing in the associated dialog box. If the change meets your requirements, click Legalize to legalize the placement and commit the changes. If the change does not meet your requirements, click Undo to remove the changes.

If you are using interactive clock tree synthesis on a postroute design, you can also perform ECO routing (by clicking Route ECO) and extraction (by clicking Extract RC) after committing the sizing changes.

**Note:**

If new nets are added to the design as a result of the modifications, IC Compiler does not propagate nondefault routing rules to these new nets. You can use the `mark_clock_tree` command to reapply the nondefault routing rule to the clock tree, including the new nets.

## Inserting a Buffer

To insert a buffer using interactive clock tree synthesis,

1. Select CTS Insert Buffer.

The CTS Insert Buffer dialog box appears.

2. Specify the following:

- Whether you want to insert a buffer or an inverter pair
- To which clock pin you want to insert the buffer

If you specify an output pin, the new buffer drives all fanouts of the specified pin. If you specify an input pin, the new buffer drives only that pin.

- The library reference cell to use  
If you specify a pattern, IC Compiler locates all library reference cells matching the specified pattern.
- (Optional) The names for the new cells and nets
- The physical location of the inserted buffer

Note:

You can also specify the physical location of the inserted buffer by left-clicking in the layout window

- (Optional) the colors to use to highlight the inserted buffer in the layout window

3. Click “Insert Buffer” to insert the buffer.

4. Click “Update Timing” to perform what-if analysis for this change.

5. Click Legalize to commit this change or click Undo to undo this change.

## Removing a Buffer

To remove a buffer using interactive clock tree synthesis,

1. Select CTS Remove Buffer.

The CTS Remove Buffer dialog box appears.

2. Specify the buffer to remove.

3. Click “Remove Buffer” to remove the buffer.

4. Click “Update Timing” to perform what-if analysis for this change.

5. Click Legalize to commit this change or click Undo to undo this change.

## Moving a Buffer or Gate

To move a buffer or gate using interactive clock tree synthesis,

1. Select CTS Move Cell.

The CTS Move Cell dialog box appears.

2. Click “Move Cell” to enter move mode in the layout window.
3. Move the cell (a clock buffer or clock gate) in the layout window.
4. Click Legalize to commit this change or click Undo to undo this change.

## Reparenting a Subtree

To reparent a subtree using interactive clock tree synthesis,

1. Select CTS Re-parent.

The CTS Re-parent dialog box appears.

2. Specify the following:
  - The subtree root pin
  - The new driving pin for the subtree
3. Click Re-parent to perform what-if analysis for this change.
4. Click Legalize to commit this change or click Undo to undo this change.

The new driving pin that you specify for the reparented subtree must meet the following requirements:

- It must be in the same clock tree as the existing driving pin.
- It must be in the same logical hierarchy as the existing driving pin.
- It must not be a don’t touch subtree pin.
- It must not drive a don’t buffer net.

## Sizing a Buffer or Gate

To size a buffer or gate using interactive clock tree synthesis,

1. Select CTS Size Cell.

The CTS Size Cell dialog box appears.

2. Specify the following:

- The buffer or gate to be sized (the cell must be on the clock path)
- The library reference cell that can be used

3. Click “Size Cell” to perform what-if analysis for this change.

4. Click Legalize to commit this change or click Undo to undo this change.

---

## Analyzing and Refining the Design

After you are satisfied with the clock tree synthesis results, analyze the QoR of the entire design by reporting on constraints (use the `report_constraint` command or choose Design > Report Constraints in the GUI) and timing (use the `report_timing` command).

Use the reports to check the following parameters:

- Worst negative slack (WNS)
- Total negative slack (TNS)
- Design rule constraint violations

# 8

## Routing Using Zroute

---

This chapter describes the routing capabilities of Zroute, which is the default router for all IC Compiler packages, with the exception of the ICC-XP package. Zroute is architected for multicore hardware and efficiently handles advanced design rules for 45 nm and below technologies and design-for-manufacturing (DFM) tasks. For information about the classic router, see the *IC Compiler Classic Router User Guide*.

Note:

The IC Compiler-PC package does not include signal routing capabilities. If you are using the IC Compiler-PC package, you need to export the design so that you can perform signal routing with another tool. (See “[Saving a Design](#)” on page 3-50.)

This chapter contains the following sections:

- [Zroute Features](#)
- [Basic Zroute Flow](#)
- [Prerequisites for Routing](#)
- [Checking Routability](#)
- [Setting Up for Routing](#)
- [Routing Clock Nets](#)
- [Routing Critical Nets](#)
- [Routing Signal Nets](#)

- Performing ECO Routing
- Cleaning Up Routed Nets
- Saving the Routing Information
- Analyzing the Routing Results
- Routing Nets and Buses in the GUI
- Postroute RC Extraction

---

## Zroute Features

Zroute has five routing engines: global routing, track assignment, detail routing, ECO routing, and routing verification. You can invoke global routing, track assignment, and detail routing by using the `route_opt` core command; by using task-specific commands; or by using an automatic routing command. You invoke ECO routing and routing verification by using task-specific commands.

Zroute includes the following main features:

- Multithreading on multicore hardware for all routing steps, including global routing, track assignment, and detail routing
- A realistic connectivity model where Zroute recognizes electrical connectivity if the rectangles touch; it does not require the center lines of wires to connect
- A dynamic maze grid that permits Zroute to go off-grid to connect pins, while retaining the speed advantages of gridded routers
- A polygon manager, which allows Zroute to recognize polygons and to understand that design rule checks (DRCs) are aimed at polygons
- Concurrent optimization of design rules, antenna rules, wire optimization, and via optimization during detail routing
- Concurrent redundant via insertion during detail routing
- Support for soft rules built into global routing, track assignment, and detail routing
- Timing- and crosstalk-driven global routing, track assignment, detail routing, and ECO routing
- Intelligent design rule handling, including merging of redundant design rule violations and intelligent convergence
- Net group routing with layer constraints and nondefault routing rules
- Clock routing
- Route verification
- Optimization for DFM and design-for-yield (DFY) using a soft rule approach

---

## Basic Zroute Flow

[Figure 8-1](#) shows the basic Zroute flow, which includes clock routing, signal routing, DFM optimizations, and route verification.

Figure 8-1 Basic Zroute Flow



---

## Prerequisites for Routing

Before you can run Zroute, you must ensure that the design and physical library meet the following requirements:

- Library requirements

Zroute gets all of the design rule information from the Milkyway technology file; therefore, you must ensure that all design rules are defined in the technology file before you start routing.

In addition, Zroute uses only default vias for nonpin access. Make sure that all vias that you want Zroute to use are defined as default vias (`isDefaultContact` attribute is 1) in the technology file.

For more information about the technology file and defining routing design rules, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

- Design requirements

Before you perform routing, your design must meet the following conditions:

- Power and ground nets have been routed after design planning and before placement.  
For more information, see the *IC Compiler Design Planning User Guide*.
- Clock tree synthesis and optimization have been performed.  
For more information, see [Chapter 7, “Clock Tree Synthesis.”](#)
- Estimated congestion is acceptable.
- Estimated timing is acceptable (about 0 ns of slack).
- Estimated maximum capacitance and transition have no violations.

To verify that your design meets the last three prerequisites, you can check the routability of its placement as explained in “[Checking Routability](#)” in the following section.

**Note:**

You can use the prerouter to preroute signal nets before running Zroute. The prerouted signal nets are marked as user nets. By default, Zroute does not rip up and reroute these user nets. Zroute makes only minor changes to correct DRC violations.

---

## Checking Routability

After placement is completed, you can have IC Compiler check whether your design is ready for detail routing. The tool checks pin access points, cell instance wire tracks, pins out of boundaries, minimum grid and pin design rules, and blockages to make sure they meet design requirements. It creates an error file named after the top-level design (*top\_design\_name.err*), with a list of violations that you should correct before performing detail routing.

To verify that your design is ready for detail routing, use the `check_routeability` command (or choose Route > Check Routability in the GUI).

After you run the `check_routeability` command, you can use the `report_error_coordinates` command to report the location of each error. You can also use the error browser to examine the errors in the GUI. For more information about the error browser, see “[Examining Routing and Verification Errors](#)” on page A-75 and the “Examining Routing and Verification Errors” topic in IC Compiler Help.

---

## Setting Up for Routing

You can specify general routing setups for Zroute to use whenever you perform routing. The following sections describe how to specify these setups:

- [Enabling Multicore Processing](#)
- [Defining Route Guides](#)
- [Defining Routing Corridors](#)
- [Setting the Preferred Routing Direction](#)
- [Controlling Pin Connections](#)
- [Creating Design-Specific Via Masters](#)
- [Using Nondefault Routing Rules](#)
- [Specifying the Routing Layers](#)
- [Setting Zroute Options](#)
- [Setting Signal Integrity Options](#)
- [Setting Multivoltage Options](#)

---

## Enabling Multicore Processing

You can use multicore processing to reduce the elapsed time for routing, crosstalk reduction during the `route_opt` command, and postroute optimization.

The following routing-related tasks support multithreading:

- Routing

Zroute is designed as a multithreaded router. During multithreaded routing, Zroute performs routing tasks in parallel. Each of these tasks is performed by a separate thread.

When you run routing with a single thread, the result is deterministic; if you start with the same design, you always get the same result. However, if you use multiple threads, the routing result are not deterministic; the final routing is slightly different between runs due to the varying division of tasks between threads.

- Signal integrity analysis during the `route_opt -only_xtalk_reduction` command
- Route verification using IC Validator with the `signoff_drc` command

The following routing-related tasks support distributed processing:

- Postroute optimization using the `route_opt`, `psynopt`, or `focal_opt` command
- Route verification using IC Validator with the `signoff_drc` command

You use the `set_host_options` command to configure multicore processing for both multithreading and distributed processing. For more information about using the `set_host_options` command to configure multicore processing, see “[Enabling Multicore Processing](#)” on page 2-43.

Note:

When you enable multicore processing by using the `set_host_options` command, it enables multithreading for all IC Compiler commands that support multithreading, not just the routing commands. When multicore processing is enabled, you can limit the number of cores used by Zroute by setting the `zrt_max_parallel_computations` variable.

---

## Defining Route Guides

A route guide provides routing directives for specific areas of your design. The routing directives include

- Preventing routing (signal or preroute) on specific layers
- Controlling the routing direction on specific layers
- Controlling the routing density on specific layers
- Encouraging river routing on specific layers
- Prioritizing specific routing regions on specific layers
- Fixing violations as a single switch box

A single route guide provides one or more of these directives.

To create a route guide, use the `create_route_guide` command or choose Floorplan > Create Route Guide in the GUI.

Note:

Route guides defined by this command are honored by Zroute; however, they are not honored by the Advanced Route tool.

When you create a route guide, you must specify its rectangular boundary, as well as information specific to the purpose of the route guide.

To specify the boundary, use the `-coordinate` option to specify the lower-left and upper-right corners of the rectangle; you can control the snapping of the coordinates by using the `set_object_snap_type` command. When you create a route guide by using the GUI, you can type the coordinates in the dialog box or draw the rectangle in the layout view; you can also specify that the route guide should snap to the minimum grid, placement site, routing track (the default), middle routing track, or user grid.

By default, IC Compiler names each route guide RG#*n*, where *n* is a unique integer; you can override the default name by assigning a name with the `-name` option.

Note:

The blockage, pin, and via (BPV) extraction process also creates route guides. For more information about creating route guides during BPV, see the *Library Data Preparation for IC Compiler User Guide*.

The following sections describe how to create route guides for various purposes. You can create a single route guide that serves multiple purposes.

## Using Route Guides to Prevent Routing

You can use a route guide to prevent signal routing or preroute (power and ground) routing within the route guide boundary on specific layers.

To prevent signal routing, use the `-no_signal_layers` option to specify the layers on which signal routing cannot occur within the route guide boundary. For example, to prevent signal routing on the M1 layer within the rectangle with its lower-left corner at (0, 0) and its upper-right corner at (100, 100), enter the following command:

```
icc_shell> create_route_guide -coordinate {0.0 0.0 100.0 100.0} \
    -no_signal_layers M1
```

To prevent preroute routing, use the `-no_preroute_layers` option to specify the layers on which signal routing cannot occur within the route guide boundary. For example, to prevent preroute routing on the M2 layer within the rectangle with its lower-left corner at (0, 0) and its upper-right corner at (100, 100), enter the following command:

```
icc_shell> create_route_guide -coordinate {0.0 0.0 100.0 100.0} \
    -no_preroute_layers M2
```

By default, when you use either of these options, the router must meet the minimum spacing requirements between the route guide boundary and the net shapes. To disable the minimum spacing rule between the route guide boundary and the net shapes, use the `-zero_min_spacing` option. When you use this option, the net shapes can touch, but not overlap, the route guide boundary.

## Using Route Guides to Control the Routing Direction

You can use a route guide to control the routing direction within the route guide boundary, either by specifying the layers where routes must be in the preferred direction within the route guide boundary or by switching the preferred direction for all layers within the route guide boundary.

A route guide that forces the router to route all nets in the preferred direction within the route guide boundary is called a preferred-direction-only route guide. You can use a preferred-direction-only route guide to prevent wrong-way jog wires on specific layers. To create a preferred-direction-only route guide, use the `-preferred_direction_only_layers` option. For example, to force the router to use only the preferred direction on the M4 layer within the rectangle with its lower-left corner at (0, 0) and its upper-right corner at (100, 100), enter the following command:

```
icc_shell> create_route_guide -coordinate {0.0 0.0 100.0 100.0} \
    -preferred_direction_only_layers M4
```

To change the preferred routing direction for all layers within the route guide boundary, use the `-switch_preferred_direction` option. This type of route guide is called a switch-preferred-direction route guide. If there is a lot of detour routing in your design, you might be able to reduce congestion by using a switch-preferred-direction route guide to allow routing over macros.

Note:

If a switch-preferred-direction route guide overlaps with a preferred-direction-only route guide, the switch-preferred-direction route guide takes precedence.

## Using Route Guides to Control the Routing Density

You can use a route guide to control the routing density within the route guide boundary. This type of route guide is called a utilization route guide.

To create a utilization route guide, use the `-horizontal_track_utilization` option to set the maximum track utilization for layers with a horizontal preferred direction and use the `-vertical_track_utilization` option to set the maximum track utilization for layers with a vertical preferred direction. By default, when you set these options, they apply to all layers within the route guide boundary. To set the routing density only for specific layers, use the `-track_utilization_layers` option to specify the affected layers.

For example, to set a maximum track utilization of 50 percent for all layers with a horizontal preferred direction and a maximum track utilization of 30 percent for all layers with a vertical preferred direction within the rectangle with its lower-left corner at (0, 0) and its upper-right corner at (100, 100), enter the following command:

```
icc_shell> create_route_guide -coordinate {0.0 0.0 100.0 100.0} \
    -horizontal_track_utilization 50 -vertical_track_utilization 30
```

## Using Route Guides to Prioritize Routing Regions

You can use a route guide to prioritize regions within the route guide boundary for routing. This type of route guide is called an access preference route guide.

An access preference route guide prioritizes specific areas for routing by assigning strengths to the various regions within the route guide boundary. These regions are called access preference areas. Access preference areas with higher strengths are preferred for routing. You can define access preference areas for both wires and vias. When you define a via access-preference area, you are defining a preference area for the via surrounds on the specified metal layer for vias coming from both above and below that metal layer.

To create an access preference route guide, use the `-access_preference` option. The syntax for specifying an access preference route guide is

```
{layer [{wire_access_preference wire_rect wire_strength}] \
    [{via_access_preference via_rect via_strength}] ...}
```

You can define multiple access preference areas. To define the relative preference of the access preference areas, use strength values between 0 and 1. If access preference areas overlap, the stronger access preference area takes precedence over the weaker access preference area. To require routing in a specific access preference area, use a strength value of 1. When you define access preference areas with a strength of 1, all access preference areas with a strength less than 1 are ignored and Zroute treats the access preference route guide as a hard constraint.

The following example creates an access preference route guide whose boundary is a rectangle with its lower-left corner at (0, 0) and its upper-right corner at (300, 300). It contains one wire access-preference area with coordinates of (0, 0) and (2, 1) and two via access-preference areas, one with coordinates of (0, 0) and (5, 5) and one with coordinates of (40, 40) and (45, 45). The wire access-preference area is slightly preferred over areas outside of the access preference area because it has a strength of 0.2. The via access-preference area with coordinates at (40, 40) and (45, 45) is ignored, because routing is required in the via access-preference area with coordinates at (0, 0) and (5, 5), which has a strength of 1.

```
icc_shell> create_route_guide -coordinate {{0 0} {300 300}} \
    -access_preference {M1 {wire_access_preference {{0 0} {2 1}} 0.2}
                        {via_access_preference {{0 0} {5 5}} 1.0}
                        {via_access_preference {{40 40} {45 45}} 0.5}}
```

To report information about the access preference route guides defined for your design, use the `report_access_preference_route_guide` command.

## Using Route Guides to Encourage River Routing

River routing refers to the routing of many nonshorting routes in roughly the same direction when routing is already restricted to just a few layers. To encourage river routing, create a single-layer route guide by using the `-single_layer_routing` option to specify the affected layers.

## Using Route Guides to Fix Violations

When there is a violation on a preroute wire or inside a large macro that is difficult to fix, you can use a route guide to force the router to repair violations on all layers within the route guide boundary as a single switch box. To create this type of route guide, use the `-repair_as_single_sbox` option.

## Querying Route Guides

To find route guides, use the `get_route_guides` command. For example, to get all the route guides in your design, enter

```
icc_shell> get_route_guides *
```

You can also find route guides by using a filter expression (`-filter expression`) or by using regions that encompass (`-within`) or touch (`-touch`) the route guides.

## Removing Route Guides

To remove route guides, use the `remove_route_guide` command. You can remove a collection of route guides, such as that returned by the `get_route_guides` command; all route guides (`-all` option); or a specific named route guide (`-name` option).

---

## Defining Routing Corridors

A routing corridor restricts Zroute global routing for specific nets to the region defined by a set of connected rectangles. In addition to specifying the region in which the routing occurs, you can also specify the minimum and maximum routing layers for each of the rectangles that comprise the routing corridor.

Routing corridors are intended to be used to route critical nets before signal routing. Zroute global routing considers routing corridors as a hard constraint, while track assignment and detail routing consider routing corridors as a soft constraint and might route nets slightly outside of the routing corridor to fix DRC violations.

Note:

If a route guide overlaps with a routing corridor and its attributes conflict with the routing corridor, the routing corridor takes precedence.

For example, [Figure 8-2](#) shows a routing corridor named `corridor_1`, which is made up of six rectangles. This routing corridor is associated with the nets shown in yellow. The figure on the left shows the nets before routing, while the figure on the right shows the nets routed within the routing corridor.

*Figure 8-2 Using a Routing Corridor*



To define a routing corridor, use the `create_routing_corridor` command (or choose Edit > Create > Routing Corridors in the GUI). At a minimum, you must define the rectangles that comprise the routing corridor. On the command line, use the `-rectangles` option to specify the rectangles. For each rectangle, you must define the minimum routing layer, the maximum layer, and the bounding box using the following format:

```
{min_layer_name max_layer_name {bounding_box} }
```

Specify the routing layers by using the layer names from the technology file. Specify the bounding box using the format `{lx ly urx ury}`, which defines the lower-left and upper-right corners of the rectangle in the units specified in the technology file. The tool assigns each rectangle a name in the format `CORRIDOR_SHAPE_objID`.

By default, the tool assigns each routing corridor a name in the format `CORRIDOR_objID`. You can specify a name for the routing corridor by using the `-name` option.

To assign nets to a routing corridor, use the `set_net_routing_corridor` command. Use the `-corridor` option to specify the routing corridor and the `-nets` option to specify the associated nets. You can assign a net to only one routing corridor and that routing corridor must cover all pins connected to the associated nets.

For example, to define a routing corridor named `corridor_a` and assign the nets named `n1` and `n2` to this routing corridor, enter the following commands:

```
icc_shell> create_routing_corridor -name corridor_a \
    -rectangles { {M2 M4 {10 10 20 35}}
                  {M2 M4 {20 25 40 35}}
                  {M2 M5 {40 10 50 35}} }
icc_shell> set_net_routing_corridor -corridor corridor_a \
    -nets [get_nets {n1 n2}]
```

Note:

You can also assign nets to the routing corridor by using the `-nets` option when you use the `create_routing_corridor` command to create the routing corridor.

To route the nets in a routing corridor, use the `route_zrt_group` command. For more information about the `route_zrt_group` command, see “[Routing Critical Nets](#)” on [page 8-57](#). After signal routing is complete, remove the routing corridors before performing ECO routing. For information about removing routing corridors, see “[Removing Routing Corridors](#)” on [page 8-15](#).

## Reporting Routing Corridors

To report the routing corridors in your design, use the `report_routing_corridors` command. You can either specify the routing corridors to report by using the `-corridors` option or you can report all routing corridors by using the `-all` option. By default, the command reports the following information for each routing corridor: its name; the rectangles associated with the routing corridor, including their names, bounding boxes,

minimum routing layer, and maximum routing layer; and the nets associated with the routing corridor. To check the connectivity of the routing corridors, use the `-check_connectivity` option. To output a Tcl script that re-creates the routing corridors, use the `-output` option.

To report the routing corridor for a specific net, use the `report_net_routing_corridor` command. When you run this command, you must use the `-nets` option to specify the nets of interest.

## Modifying Routing Corridors

You can make the following modifications to an existing routing corridor:

- Modify existing rectangles.

To modify existing rectangles, use the `update_routing_corridor -mode update` command. Use the `-corridor` option to specify the routing corridor that you want to update and the `-rectangles` option to specify the rectangles that you want to update. You can change the following attributes of the specified rectangles:

- The bounding box (`-bbox` option)
- The minimum routing layer (`-min_layer_name` option)
- The maximum routing layer (`-max_layer_name` option)

Each of these options takes a list of values, one value per rectangle specified in the `-rectangles` option. The format for each value is the same as when you specify that attribute when creating a routing corridor.

- Remove rectangles from the routing corridor.

To remove rectangles, use the `update_routing_corridor -mode remove` command. Use the `-corridor` option to specify the routing corridor that you want to update and the `-rectangles` option to specify the rectangles that you want to remove.

- Add new rectangles to the routing corridor.

To add new rectangles, use the `update_routing_corridor -mode add` command. Use the `-corridor` option to specify the routing corridor that you want to update. For each new rectangle, you must define the minimum routing layer (`-min_layer_name` option), the maximum routing layer (`-max_layer_name` option), and the bounding box (`-bbox` option). Each of these options takes a list of values, one value for rectangle you want to add. The format for each value is the same as when you specify that attribute when creating a routing corridor.

- Change the nets associated with the routing corridor.

To associate nets with a routing corridor, use the `set_net_routing_corridor` command. To dissociate nets with a routing corridor, use the `remove_net_routing_corridor` command.

You can also modify routing corridors in the GUI by using the Create Route Corridor tool, the Move/Resize tool, or the Delete tool, or by editing the attributes in the Properties dialog box.

## Removing Routing Corridors

To remove routing corridors, use the `remove_routing_corridor` command. You can either specify the routing corridors to remove by using the `-corridors` option or you can remove all routing corridors by using the `-all` option. You can also remove routing corridors in the GUI by using the Delete tool.

---

## Defining Routing Blockages

A routing blockage defines a rectangular or rectilinear region where no routing is allowed on a specific layer. You define routing blockages by using the `create_routing_blockage` command or by choosing Floorplan > Create Routing Blockage in the GUI.

### Note:

By default, routing blockages defined by this command are ignored by both the Advanced Route tool and Zroute. To have the Advanced Route tool honor these blockages, change the setting in the Mouse Tool Options panel or the Advanced Route tool dialog box. To have Zroute honor these routing blockages, use the `set_route_zrt_common_options` command to set the `read_user_metal_blockage_layer` common route option to true.

To define a routing blockage, you must specify

- The region of the blockage

Use the `-bbox` option to specify the region for a rectangular routing blockage. Use the `-boundary` option to specify the region for a rectilinear routing blockage.

- The blockage layers to which the routing blockage applies

Use the `-layers` option to specify the blockage layers. Valid values for the blockage layers are `metal1Blockage-metal15Blockage`, `via1Blockage-via14Blockage`, `polyBlockage`, and `polyContBlockage`. To query the Milkyway design library for the blockage layers, use the `get_layers -include_system` command.

You can specify one or more blockage layers. If the routing blockage is defined on a metal blockage layer, it is a metal routing blockage. If the routing blockage is defined on a via blockage layer, it is a via routing blockage.

For example, to create rectangular routing blockages on the `metal1` and `via1` blockage layers that are honored by Zroute, enter the following commands:

```
icc_shell> create_routing_blockage \
    -layers {metal1Blockage via1Blockage} -bbox {x1 y1 x2 y2}
icc_shell> set_route_zrt_common_options \
    -read_user_metal_blockage_layer true
```

When IC Compiler creates routing blockages, it assigns a name of RB\_ *id* to each routing blockage.

To find routing blockages, use the `get_routing_blockages` command. For example, to get all the routing blockages in your design, enter

```
icc_shell> get_routing_blockages *
```

You can also find routing blockages by using a filter expression (`-filter expression`), by using regions that encompass (`-within`), touch (`-touch`), or intersect (`-intersect`) the routing blockages, or by using a point overlapped by the routing blockage (`-at`).

To remove routing blockages, use the `remove_routing_blockage` command.

---

## Setting the Preferred Routing Direction

Use the `set_preferred_routing_direction` command to reset and override the default preferred routing direction specified in the library or the design for a specific layer. The layer direction set with this command applies to the current design only.

The syntax is

```
set_preferred_routing_direction  
  -layers list_of_layers  
  -direction horizontal | vertical
```

For example, to set the preferred routing direction to vertical for layer M5 and M7, enter

```
icc_shell> set_preferred_routing_direction -layers "M5 M7" \  
          -direction vertical
```

Note:

Settings with the `create_route_guide -switch_preferred_direction` command, which changes the preferred direction within the area that is covered by the route guide, override the settings made with the `set_preferred_routing_direction` command.

Use the `report_preferred_routing_direction` command to report the preferred routing direction for all the routing layers. The report lists the library and user-defined routing directions, as well as the direction that the tool will use. [Example 8-1](#) shows a report example.

### *Example 8-1 Preferred Direction Report*

```
*****
Report : Layers
Design : core_chip
Version: D-2010.03
Date   : Thu Jan 28 03:43:06 2010
*****
Layer Name      Library      Design      Tool understands
metal1          Horizontal   Not Set    Horizontal
metal2          Vertical    Not Set    Vertical
metal3          Horizontal   Not Set    Horizontal
metal4          Vertical    Not Set    Vertical
metal5          Horizontal   Vertical   Vertical
metal6          Vertical    Vertical   Vertical
```

Use the `remove_preferred_routing_direction` command to remove the user-defined directions for a specific layer from the design. The syntax is

```
remove_preferred_routing_direction -layers list_of_layers
```

## Controlling Pin Connections

By default, Zroute connects a signal route to a pin by using wires or vias anywhere on the pin. You can restrict the allowed types of pin connections on a per-layer basis by using the `set_route_zrt_common_options` command to set the `connect_within_pins_by_layer_name` common route option.

Valid values for this option are

- `off` (the default)

There are no restrictions on pin connections.

- `via_standard_cells_pins`

Only the connections to standard cell pins by using a via are restricted. When using a via connection, the via's metal enclosure must be contained within the pin shape.

There are no restrictions on signal routes connected to macro cell and pad cell pins by using a via or to any pins by using wires.

- `via_wire_standard_cell_pins`

The connections to standard cell pins by using a via or a wire are restricted. When using a via connection, the via's metal enclosure must be contained within the pin shape. When using a wire, the wire must be contained within the pin shape.

- `via_all_pins`

The connections to any pins (standard cell, macro cell, or pad cell) by using a via are restricted. When using a via connection, the via's metal enclosure must be contained within the pin shape.

There are no restrictions on signal routes connected to any pins by using wires.

- via\_wire\_all\_pins

The connections to any pins by using a via or a wire are restricted. When using a via connection, the via's metal enclosure must be contained within the pin shape. When using a wire, the wire must be contained within the pin shape.

For example, if you enter the following command (or use the default settings), all of the connections shown in [Figure 8-3](#) are valid and no DRC violations are reported:

```
icc_shell> set_route_zrt_common_options \
    -connect_within_pins_by_layer_name {{m1 off}}
```

*Figure 8-3 Unrestricted Pin Connections*



If you set the mode for metal1 to via\_all\_pins, as shown in the following example, the via enclosures must be inside the pin shape. The connections shown on the left side of [Figure 8-4](#) are valid; however, the connections on the right side of the figure cause DRC violations.

```
icc_shell> set_route_zrt_common_options \
    -connect_within_pins_by_layer_name {{m1 via_all_pins}}
```

*Figure 8-4 Restricted Via-to-Pin Connections*

If you set the mode for metal1 to `via_wire_standard_cell_pins`, as shown in the following example, both the via enclosures and wires must be inside the pin shape. The connections shown on the left side of [Figure 8-5](#) are valid; however the connections on the right side of the figure cause DRC violations.

```
icc_shell> set_route_zrt_common_options \
    -connect_within_pins_by_layer_name {{m1 via_wire_standard_cell_pins}}
```

*Figure 8-5 Restricted Via-to-Pin and Wire-to-Pin Connections*

---

## Creating Design-Specific Via Masters

If you need to use a via master that is not defined in the technology file, you can create a design-specific via master by using the `create_via_master` command. After it is created, the via master can be used anywhere in the design, similar to a `ContactCode` definition in the technology file. The via master is stored as an object together with the design cell in the Milkyway database, so it can be used only in that design.

The `create_via_master` command can create both parameter-based and rectangle-based via masters.

- Parameter-based via masters can be used for the following purposes:
  - Clock or signal routing using nondefault routing rules  
To define parameter-based design-specific via masters as nondefault vias, use the `-via_cuts` option with the `define_routing_rule` command, as described in [“Defining Nondefault Vias” on page 8-26](#).
  - Redundant via insertion  
To define the via masters used for redundant via insertion, including parameter-based design-specific via masters, use the `define_zrt_redundant_vias` command, as described in [“Defining a Customized Via Mapping Table” on page 9-27](#).
  - Power and ground routing with advanced via rules  
To define the parameter-based design-specific via masters used for power and ground routing, use the `set_preroute_advanced_via_rule` command.
  - Rectangle-based via masters must be H-shaped vias and can be used only for redundant via insertion  
To define the via masters used for redundant via insertion, including rectangle-based design-specific via masters, use the `define_zrt_redundant_vias` command, as described in [“Defining a Customized Via Mapping Table” on page 9-27](#).

The following sections describe how to create these types of via masters.

## Creating Parameter-Based Via Masters

To create a parameter-based design-specific via master, use the following syntax:

```
create_via_master
  -name string
  -cut_layer_name layer
  -lower_layer_name layer
  -upper_layer_name layer
  -cut_width float
  -cut_height float
  -lower_layer_enc_width float
  -lower_layer_enc_height float
  -upper_layer_enc_width float
  -upper_layer_enc_height float
  -min_cut_spacing float
  [-quiet]
```

For example,

```
icc_shell> create_via_master -name design_via1_HV -cut_layer_name VIA12 \
  -cut_height 0.05 -cut_width 0.05 \
  -lower_layer_name METAL1 \
  -lower_layer_enc_width 0.02 -lower_layer_enc_height 0.0 \
  -upper_layer_name METAL2 \
  -upper_layer_enc_width 0.0 -upper_layer_enc_height 0.02 \
  -min_cut_spacing 0.05
```

## Creating Rectangle-Based Via Masters

To create a rectangle-based design-specific via master, use the following syntax:

```
create_via_master
  -name string
  -cut_layer_name layer
  -lower_layer_name layer
  -upper_layer_name layer
  -rectangles {{layer{rectangle}...}}
  [-quiet]
```

You can specify multiple rectangles per layer; however, you cannot specify more than two metal layers.

For example, to create a design-specific rectangle-based H-shape via master, use a command similar to the following:

```
icc_shell> create_via_master -name design_H_shape_via \
    -cut_layer_name VIA12 \
    -lower_layer_name METAL1 -upper_layer_name METAL2 \
    -rectangles { {VIA12 {0.035 -0.035 0.100 0.035}}
    {VIA12 {-0.100 -0.035 -0.035 0.035}}
    {METAL1 {-0.130 -0.035 0.130 0.035}}
    {METAL2 {-0.100 -0.065 -0.035 0.065}}
    {METAL2 {0.035 -0.065 0.100 0.065}}
    {METAL2 {-0.100 -0.035 0.100 0.035}}
}
```

## Using Nondefault Routing Rules

Zroute supports the use of nondefault routing rules, both for routing and for shielding.

- For routing, you can use nondefault routing rules to define stricter wire width and spacing rules, to define the tapering distance, and to specify the vias used when routing nets with nondefault routing rules.
- For shielding, you can use nondefault routing rules to define the minimum width and spacing rules.

The following sections describe how to define and apply nondefault routing rules.

## Defining Nondefault Routing Rules

You define nondefault routing rules for specific nets by using the `define_routing_rule` command (or by choosing Route > Routing Setup > Define Routing Rule in the GUI). You can assign multiple nondefault routing rules to a net.

When you define a nondefault routing rule, you must specify a name for the nondefault routing rule. If you rerun the `define_routing_rule` command using a previously defined nondefault routing rule, the new definition overwrites the existing definition. To change the definition for an existing rule, you should use the `remove_routing_rules` command to remove the rule and then use the `define_routing_rule` command to redefine the rule.

The following sections describe the tasks associated with defining nondefault routing rules.

### Defining Minimum Wire Width Rules

You can use a nondefault routing rule to define minimum wire width rules that are stricter than the minimum width rules defined in the Milkyway technology file. Nondefault minimum width rules are hard constraints, which must be met during routing.

**Note:**

The minimum width defined in a nondefault routing rule applies to all metal segments, including via enclosures. To avoid DRC violations, ensure that the enclosures for nondefault vias meet the minimum width rule.

The syntax for specifying nondefault wire width rules is

```
define_routing_rule rule_name
  [-default_reference_rule | -reference_rule_name ref_rule]
  -widths {layer1 width1 layer2 width2 ... layern widthn}
```

You can define a single width value per layer. The minimum wire width for any layers not specified in the `-widths` option is determined from the reference rule, either the default routing rule or the reference rule specified in the `-reference_rule_name` option.

For example, to define a nondefault routing rule named `new_width_rule` that uses the default routing rule as the reference rule and defines nondefault width rules for metal1 and metal4, enter the following command:

```
icc_shell> define_routing_rule new_width_rule -widths {m1 0.8 m4 0.9}
```

### **Defining Spacing Rules**

You can use a nondefault routing rule to define minimum wire spacing rules that are stricter than the rules defined in the Milkyway technology file. Nondefault wire spacing rules can be defined as hard constraints, which must be met, or as soft constraints, which Zroute tries to meet. You can assign a weight to each nondefault spacing rule that defines the strength of the rule, you can define a length threshold for the nondefault spacing rules, and you can assign a routing effort to each nondefault spacing rule.

**Note:**

The spacing rules defined in the Milkyway technology file are always considered hard constraints, whether specified in the `define_routing_rule` command or not.

The syntax for specifying nondefault wire spacing rules, their weights, and their length thresholds is

```
define_routing_rule rule_name
  [-default_reference_rule | -reference_rule_name ref_rule]
  -spacings { layer1 {spacing11 spacing12 ... spacing1n}
              layer2 {spacing21 spacing22 ... spacing2n}
              ...
              layern {spacingn1 spacingn2 ... spacingnn} }
  -spacing_weights { layer1 {weight11 weight12 ... weight1n}
                     layer2 {weight21 weight22 ... weight2n}
                     ...
                     layern {weightn1 weightn2 ... weightnn} }
  -spacing_length_thresholds { layer1 {length11 length12 ... length1n}
                               layer2 {length21 length22 ... length2n}
                               ...
                               layern {lengthn1 lengthn2 ... lengthnn} }
```

The minimum wire spacing for any layers not specified in the `-spacings` option is determined from the reference rule, either the default routing rule or the reference rule specified in the `-reference_rule_name` option.

You can define multiple spacing values per layer. If you specify more than one spacing value per layer, you must assign a weight to each spacing value by using the `-spacing_weights` option. The weight values must be between 0.0 and 1.0. A weight of 1.0 indicates a hard rule and should be used for the smallest spacing value for a layer.

To increase the flexibility of DRC convergence without adversely affecting crosstalk, you might want to ignore violations of the nondefault spacing rules for short parallel distances, as shown in [Figure 8-6](#).

*Figure 8-6 Ignoring Nondefault Spacing Rule Violations*



You define the length thresholds within which to ignore the nondefault spacing violations by using the `-spacing_length_thresholds` option. The length threshold values are in microns and must have a one-to-one correspondence with the spacing entries specified in the `-spacings` option.

For example,

```
icc_shell> define_routing_rule new_rule \
-spacings {m1 {0.09 0.15 0.2} m2 {0.09 0.15 0.2} m3 {0.09 0.15 0.2}} \
-spacing_weights {m1 {1 0.5 0.2} m2 {1 0.5 0.2} m3 {1 0.5 0.2}} \
-spacing_length_thresholds {m1 {0.01 0 0} m2 {0.01 0 0} m3 {0.01 0 0}}
```

By default, Zroute uses a medium number of rip-up and route passes to resolve soft spacing rule violations. You can control the effort used to resolve all soft routing rule violations, including soft spacing rule violations, by using the `set_route_zrt_common_options` command to set the `route_soft_rule_effort_level` common route option. You can control the effort used to resolve specific soft routing rules by using the `set_route_zrt_common_options` command to set the `routing_rule_effort_level`

common route option. The rule-specific effort level set by the `routing_rule_effort_level` common route option overrides the global soft rule effort level set by the `route_soft_rule_effort_level` common route option.

The syntax for specifying the routing effort for the nondefault wire spacing rules is

```
set_route_zrt_common_options
  -routing_rule_effort_level
    { { rule_name { { layer1 {effort11 effort12 ... effort1n} }
      { layer2 {effort21 effort22 ... effort2n} }
      ...
      { layern {effortn1 effortn2 ... effortnn} } }
    }
  ...
}
```

You must use one of the following keyword values to specify the effort for each spacing rule:

- low

Zroute uses a small number of rip-up and reroute passes to resolve soft spacing rule violations.

- med

Zroute uses a medium number of rip-up and reroute passes to resolve soft spacing rule violations.

- high

Zroute treats soft spacing rule violations the same as regular design rule violations during rip up and reroute.

For example, to define a nondefault routing rule named `new_spacing_rule` that uses the default routing rule as the reference rule and defines nondefault spacing rules for metal1 and metal4, enter the following commands:

```
icc_shell> define_routing_rule new_spacing_rule \
  -spacings { m1 {0.12 0.24} m4 {0.14 0.28} } \
  -spacing_weights { m1 {1.0 0.7} m4 {1.0 0.7} }
```

To assign a high routing effort to the hard spacing rules and medium routing effort to the soft spacing rules, enter the following command:

```
icc_shell> set_route_zrt_common_options \
  -routing_rule_effort_level \
    { {new_spacing_rule {{m1 {high med}} {m4 {high med}}}} }
```

## Controlling Pin Tapering

When connecting wires to pins, Zroute uses the default routing rules within the tapering distance from the pin and the nondefault routing rules apply beyond the tapering distance.

By default, Zroute

- Determines the tapering distance, which is about 10 times the mean number of tracks for all routing layers.

To explicitly specify the tapering distance, use the `-taper_distance` option when you create a nondefault routing rule with the `define_routing_rule` command.

- Uses the same tapering distance for all pins.

To specify a different tapering distance for driver pins, use the `-driver_taper_distance` option when you create a nondefault routing rule with the `define_routing_rule` command.

- Uses the default routing width for tapering.

To use the pin width for tapering rather than the default routing width, use the `set_route_zrt_detail_options` command to change the `pin_taper_mode` detail route option to `pin_width` from its default of `default_width` before you perform detail routing.

Note:

Zroute supports pin tapering for both hard and soft nondefault routing rules. The tapering implementation is the same for both types of nondefault routing rules.

To disable all pin tapering, set the `-taper_distance` option to 0 when you create the nondefault routing rule with the `define_routing_rule` command.

To selectively disable pin tapering for specific types of pins, use the `set_route_zrt_detail_options` command to set one or more of the following detail route options to `true`: `use_wide_wire_to_input_pin`, `use_wide_wire_to_output_pin`, `use_wide_wire_to_macro_pin`, `use_wide_wire_to_pad_pin`, and `use_wide_wire_to_port`.

## Defining Nondefault Vias

You use a nondefault routing rule to define the vias to use when routing nets with nondefault routing rules. You can define the nondefault vias either by using the `-cuts` option or by using the `-via_cuts` option. When you use the `-cuts` options, IC Compiler determines the suitable vias from the technology file based on the specification in the `-cuts` option and the rules defined in the technology file. When you use the `-via_cuts` option, you explicitly specify the nondefault vias, including the allowed cut numbers and rotation for each via. The

vias can be via masters defined in the technology file or parameter-based design-specific via masters created by the `create_via_master` command. For information about creating design-specific via masters, see “[Creating Design-Specific Via Masters](#)” on page 8-20.

The syntax for specifying nondefault vias using the `-cuts` option is

```
define_routing_rule rule_name
    -cuts { {cut_layer1 {cut_name1, ncuts} {cut_name2, ncuts} ...}
            {cut_layer2 {cut_name1, ncuts} {cut_name2, ncuts} ...}
            ...
            {cut_layerN {cut_name1, ncuts} {cut_name2, ncuts} ...}
        }
```

The `cut_layer` arguments refer to the via layer names in the technology file and the `cut_name` arguments refer to the cut names defined in the `cutNameTbl` attribute in the associated `Layer` section in the technology file. You can specify multiple cut names per layer. For each cut name, you must specify the minimum number of cuts, which must be an integer between 1 and 255.

IC Compiler searches for the vias defined in the `ContactCode` section of the technology file that meet the rules defined in the technology file for the specified cut name, such as the `cutWidthTbl`, `cutHeightTbl`, and `fatTblFatContactNumber`. If the fat metal contact rule is not defined for a via layer, the tool searches for the default vias that meet the cut width and height requirements. The minimum number of cuts required is the larger of the `ncuts` value in the `-cuts` option and the value defined in the `fatTblFatContactMinCuts` attribute. For the selected vias, IC Compiler always allows both the rotated and the unrotated orientation for the via.

For example, assume the following information is defined in the technology file:

```

Layer "VIA1" {
    fatTblThreshold      = ( 0, 0.181, 0.411 )
    fatTblFatContactNumber = ( "2,3,4,5,6 ", "5,6,20", "5,6,20" )
    fatTblFatContactMinCuts = ( "1,1,1,1,1", "1,1,1", "2,2,2" )

    cutNameTbl   = ( Vsq, Vrect )
    cutWidthTbl  = ( 0.05, 0.05 )
    cutHeightTbl = ( 0.05, 0.13 )
    ...
}

ContactCode "VIA12_LH" {
    contactCodeNumber = 5
    cutWidth          = 0.13
    cutHeight         = 0.05
    ...
}
ContactCode "VIA12_LV" {
    contactCodeNumber = 6
    cutWidth          = 0.05
    cutHeight         = 0.13
    ...
}
ContactCode "VIA12_P" {
    contactCodeNumber = 20
    cutWidth          = 0.05
    cutHeight         = 0.05
    ...
}

```

If you enter the following command,

```
icc_shell> define_routing_rule cut_rule -widths { M1 0.2 M2 0.25 } \
    -cuts {VIA1 {Vrect 1}}
```

IC Compiler selects the following vias: {VIA12\_LH 1x1 R}, {VIA12\_LH 1x1 NR}, {VIA12\_LV 1x1 R}, {VIA12\_LV 1x1 NR}, {VIA12\_LH 1x2 R}, {VIA12\_LH 1x2 NR}, {VIA12\_LH 2x1 R}, {VIA12\_LH 2x1 NR}, {VIA12\_LV 1x2 R}, {VIA12\_LV 1x2 NR}, {VIA12\_LV 2x1 R}, and {VIA12\_LV 2x1 NR}.

The syntax for specifying nondefault vias using the `-via_cuts` option is

```
define_routing_rule rule_name
    -via_cuts { {via_type1 cut_number1 orientation1}
        {via_type2 cut_number2 orientation2}
        ...
        {via_typen cut_numbern orientationn}
    }
```

You can specify multiple via types per layer. For each via, you must explicitly specify the allowed cut numbers and orientation. To specify the orientation, use `NR` to indicate that the via is not rotated or `R` to indicate that the via is rotated. The order of via specification is not important; during routing, Zroute selects the lowest cost nondefault via.

If you do not specify a nondefault via for a layer, Zroute selects a via from the Milkyway technology file based on the design rules.

For example, to specify the vias selected by the `-cuts` option in the previous example, enter

```
icc_shell> define_routing_rule via_rule \
    -via_cuts {{VIA12_LH 1x1 R} {VIA12_LH 1x1 NR} {VIA12_LV 1x1 R} \
                {VIA12_LV 1x1 NR} {VIA12_LH 1x2 R} {VIA12_LH 1x2 NR} \
                {VIA12_LH 2x1 R} {VIA12_LH 2x1 NR} {VIA12_LV 1x2 R} \
                {VIA12_LV 1x2 NR} {VIA12_LV 2x1 R} {VIA12_LV 2x1 NR}}
```

### Defining Shielding Rules

You can use nondefault routing rules to define shielding rules. The syntax for specifying shielding rules is

```
define_routing_rule rule_name
    -shield_widths {layer1 width1 layer2 width2 ... layern widthn}
    -shield_spacings {layer1 spacing1 layer2 spacing2 ... layern spacingn}
```

You can define a single width and spacing value per layer. Zroute uses the default wire width for any layers not specified in the `-shield_widths` option and the default spacing for any layers not specified in the `-shield_spacings` option.

By default, shielding wires are not snapped to the routing tracks. To snap shielding wires to the routing tracks, use the `-snap_to_track` option when you define the nondefault routing rule.

For example, to specify a shielding rule that uses spacing of 0.1 microns and a width of 0.1 microns for metal1 through metal5 and spacing of 0.3 microns and a width of 0.3 microns for metal6, enter the following command:

```
icc_shell> define_routing_rule shield_rule \
    -shield_widths {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3} \
    -shield_spacings {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3}
```

## Summary of `define_routing_rule` Options

[Table 8-1](#) defines the commonly used `define_routing_rule` options.

*Table 8-1 define\_routing\_rule Command Options*

| Command option                                                                                                 | Description                                                                                                          |
|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| <code>rule_name</code><br>("Rule name" box in the GUI)                                                         | Specifies the name of the rule.<br>This argument is required.                                                        |
| <code>-reference_rule_name</code><br><code>-default_reference_rule</code><br>("Reference rule" box in the GUI) | Specifies the name of the reference rule.<br>By default, Zroute uses the default routing rule as the reference rule. |
| <code>-taper_distance</code><br>("Taper distance" in the GUI)                                                  | Specifies the tapering length limit.                                                                                 |
| <code>-driver_taper_distance</code><br>("Driver taper distance" in the GUI)                                    | Specifies the tapering length limit for driver pins.                                                                 |
| <code>-multiplier_width</code><br>("Width multiplier" box in the GUI)                                          | Specifies the layer width multiplier.                                                                                |
| <code>-multiplier_spacing</code><br>("Spacing multiplier" box in the GUI)                                      | Specifies the layer spacing multiplier.                                                                              |
| <code>-shield</code><br>("Specify shielding" check box in the GUI)                                             | Defines shielding with default spacing and default width.                                                            |
| <code>-snap_to_track</code><br>("Snap shielding to track" check box in the GUI)                                | Snaps shielding wires to the track when selected.<br>By default, snapping is not enabled.                            |

*Table 8-1 define\_routing\_rule Command Options (Continued)*

| Command option                     | Description                                                                                                                                                                                              |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -widths                            | Specifies the width and spacing rules.                                                                                                                                                                   |
| -spacings                          | If you select “Specify shielding,” the Width and Spacing columns in the “Metal table” section in the GUI refer to shield width and shield spacing; otherwise, they refer to wire width and wire spacing. |
| -spacing_weights                   |                                                                                                                                                                                                          |
| -shield_widths                     |                                                                                                                                                                                                          |
| -shield_spacings                   | For wire spacing, you can specify multiple spacing values per layer. When you specify multiple values per layer, you must use the -spacing_weights option to specify the strength of each spacing rule.  |
| ("Metal table" section in the GUI) |                                                                                                                                                                                                          |
| -via_cuts                          | Specifies the via types. You can specify multiple via types per layer.                                                                                                                                   |
| ("Via table" section in the GUI)   |                                                                                                                                                                                                          |
| -cuts                              | Specifies the cut definitions. You can specify multiple cut definitions per layer.                                                                                                                       |
| ("Cut table" section in the GUI)   |                                                                                                                                                                                                          |

## Applying Nondefault Routing Rules

IC Compiler provides two commands for assigning nondefault routing rules to nets:

- `set_clock_tree_options`

This command assigns nondefault routing rules to clock nets before clock tree synthesis. During clock tree synthesis, the nondefault routing rules are automatically assigned to the newly created clock nets.

- `set_net_routing_rule`

This command assigns nondefault routing rules to signal nets and to clock nets after clock tree synthesis.

### Applying Nondefault Routing Rules to Clock Nets

To assign a nondefault routing rule to clock nets, use the `-routing_rule` option of the `set_clock_tree_options` command.

Note:

This command works only before clock tree synthesis. If the clock tree has already been synthesized, use the `set_net_routing_rule` command to apply the nondefault routing rules, as described in [“Applying Nondefault Routing Rules to Signal Nets” on page 8-32](#).

For example, to assign a shielding rule called shield\_rule to the nets in the CLK clock tree before clock tree synthesis, enter the following command:

```
icc_shell> set_clock_tree_options -clock_trees CLK \
    -routing_rule shield_rule
```

By default, the shielding rule applies to all nets in the clock tree. To use the default routing rule for the nets closest to the sink pin, use the `-use_default_routing_for_sinks` option. The default routing rules are used for the specified number of clock tree levels closest to the clock sink. For more information about the `set_clock_tree_options` command, see Chapter 7, “Clock Tree Synthesis,” in the *IC Compiler Implementation User Guide*.

### Applying Nondefault Routing Rules to Signal Nets

To apply a nondefault routing rule to one or more nets, use the `set_net_routing_rule` command (or choose Route > Routing Setup > Set Net Routing Rule in the GUI). [Table 8-2](#) defines the `set_net_routing_rule` options.

*Table 8-2 set\_net\_routing\_rule Command Options*

| Command option                                                                                       | Description                                                                     |
|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| <code>list_of_nets</code><br>(Nets box in the GUI)                                                   | Specifies the nets to which to apply the rule.<br>This argument is required.    |
| <code>-rule rule_name</code><br>(“Routing rule” box in the GUI)                                      | Specifies the name of the nondefault rule to apply.<br>This option is required. |
| <code>-top_layer_probe AnyPort   OutPort   AllPort</code><br>(“Top layer probe mode” box in the GUI) | This option is not supported by Zroute.                                         |
| <code>-reroute normal   minorchange   freeze</code><br>(“Net re-routability” box in the GUI)         | Specifies when to reroute nets.<br>The default is <code>normal</code> .         |
| <code>-timing_driven_spacing</code><br>(“Timing driven spacing” check box in the GUI)                | This option is not supported by Zroute.                                         |

## Reporting Nondefault Routing Rules

To report the nondefault routing rules for specific nets, use the `report_net_routing_rules` command.

```
icc_shell> report_net_routing_rules [get_nets *]
```

To output a Tcl script that contains the `define_routing_rule` commands used to define the nondefault routing rules for the specified nets, use the `-output` option when you run the `report_net_routing_rules` command.

The name of the nondefault routing rule for a net is stored in the `var_route_rule` net attribute. You can access the value of this attribute by using the `get_attribute` command.

To report the design-specific nondefault routing rules defined by the `define_routing_rule` command, use the `report_routing_rules` command. By default, this command reports all of the nondefault routing rules for the current design. To limit the report to a specific nondefault routing rule, specify the rule name as an argument to the command.

```
icc_shell> report_routing_rules rule_name
```

To output a Tcl script that contains the `define_routing_rule` commands used to define the specified nondefault routing rule or all nondefault routing rules for the design if you do not specify a routing rule, use the `-output` option when you run the `report_routing_rules` command.

## Removing Nondefault Routing Rules

To remove the nondefault routing rules for specific nets, use the `set_net_routing_rule` command to reset the routing rule for the nets to the default routing rule.

```
icc_shell> set_net_routing_rule -rule default [get_nets my_ndr_nets]
```

---

## Specifying the Routing Layers

IC Compiler lets you specify which layers can be ignored for routing and which layers are to be ignored for RC and congestion estimation. You can also specify the routing layers to use for specific nets (net layer constraints).

By default, when you set a maximum routing layer, it is a hard constraint. You can change it to a soft constraint or you can allow the use of higher layers only for pin connections by using the `set_route_zrt_common_options` command to set the `max_layer_mode` common route option. This option applies to both ignored layers (`set_ignored_layers` command) and net layer constraints (`set_net_routing_layer_constraints` command).

By default, when you set a minimum routing layer, it is a soft constraint. You can change it to a hard constraint or you can allow the use of lower layers only for pin connections by using the `set_route_zrt_common_options` command to set the `min_layer_mode` common route option. This option applies to both ignored layers (`set_ignored_layers` command) and net layer constraints (`set_net_routing_layer_constraints` command).

## Specifying the Ignored Layers

To specify the ignored layers, use the `set_ignored_layers` command (or choose Route > Routing Setup > Set Ignored Layers in the GUI). By default, RC estimation and congestion analysis use the same layers as routing.

To specify the minimum and maximum routing layers, use the `-min_routing_layer` and `-max_routing_layer` options, respectively. If you use only these options, the same layers are used for routing, RC estimation, and congestion analysis. For example, to use layers M2 through M7 for routing, RC estimation, and congestion analysis, use the following command:

```
icc_shell> set_ignored_layers \
    -min_routing_layer M2 -max_routing_layer M7
```

To use fewer layers for RC estimation and congestion analysis than those used for routing, use the `-rc_congestion_ignored_layers` option to specify the layers to be ignored for RC estimation and congestion analysis. For example, to use layers M2 through M7 for routing and layers M3 through M7 for RC estimation and congestion analysis, use the following command:

```
icc_shell> set_ignored_layers \
    -min_routing_layer M2 -max_routing_layer M7 \
    -rc_congestion_ignored_layers {M1 M2 M8 M9}
```

To use more layers for RC estimation and congestion analysis than for routing, use the `remove_ignored_layers` command to remove the layer restriction for RC estimation and congestion analysis. For example, to use layers M2 through M7 for routing and layers M2 through M8 for RC estimation and congestion analysis, use the following commands:

```
icc_shell> set_ignored_layers \
    -min_routing_layer M2 -max_routing_layer M7 \
icc_shell> remove_ignored_layers M8
```

To report the ignored layers, use the `report_ignored_layers` command.

## Specifying Routing Layers for Specific Nets

To specify the routing layers for specific nets, use the `set_net_routing_layer_constraints` command (or choose Route > Routing Setup > Set Net Layer Constraints in the GUI).

To specify the minimum and maximum routing layers for specific nets, use the `-min_layer_name` and `-max_layer_name` options, respectively. For example, to use layers M2 through M7 for routing net n1, use the following command:

```
icc_shell> set_net_routing_layer_constraints [get_nets n1] \
    -min_layer_name M2 -max_layer_name M7
```

To report the routing layer constraints for specific nets, use the `report_net_routing_layer_constraints` command.

```
icc_shell> report_net_routing_layer_constraints [get_nets *]
```

To output a Tcl script that contains the `set_net_routing_layer_constraints` commands that are used to define the routing layer constraints for the specified nets, use the `-output` option when you run the `report_net_routing_layer_constraints` command.

---

## Setting Zroute Options

You can specify global route options, track assignment options, detail route options, and common route options (options that affect all three routing engines). Zroute uses these settings whenever you perform routing functions. When you run a routing command, Zroute writes the settings for any routing options that you have set (or that the tool has set for you) in the routing log. To display the settings for all routing options, not only those that have been set, use the `set_route_zrt_common_options` command to set the `verbose_level` common route option to 1.

```
icc_shell> set_route_zrt_common_options -verbose_level 1
```

## Setting Common Route Options

Common route options are used to define routing options that affect global routing, track assignment, and detail routing. When you save the design in Milkyway format, the common route option settings are saved with the design.

- To set the common route options, use the `set_route_zrt_common_options` command (or choose Route > Routing Setup > Set Common Route Options in the GUI). To reset the options to their defaults, use the `set_route_zrt_common_options -default true` command (or click Default in the GUI).
- To report the settings of all common route options, use the `report_route_zrt_common_options` command.
- To return the value of a specific common route option, use the `get_route_zrt_common_options` command.

**Table 8-3** lists the Zroute common route options.

*Table 8-3 Common Route Options*

| Option                      | Valid values                               | Description                                                                                                                                                                                                                                                                                         |
|-----------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Run control options</b>  |                                            |                                                                                                                                                                                                                                                                                                     |
| reroute_clock_shapes        | true   false                               | Specifies whether the router can reroute fixed clock wires and vias.<br>The default is false.                                                                                                                                                                                                       |
| reroute_user_shapes         | true   false                               | Specifies whether the router can reroute user-created wires and vias.<br>The default is false.                                                                                                                                                                                                      |
| plan_group_aware            | off   all_routing   top_level_routing_only | Specifies whether the plan group constraints are obeyed.<br>The default is off.                                                                                                                                                                                                                     |
| reshield_modified_nets      | off   unshield   reshield                  | Specifies whether to unshield or reshield modified shielded nets automatically during routing.<br>The default is off.                                                                                                                                                                               |
| child_process_net_threshold | int<br>(must be between -1 and 2147483647) | Specifies the threshold number of nets to trigger a separate router process.<br>The default is -1, which means that the tool decides when to trigger a separate router process based on the number of nets in the design and the peak memory of the parent process when the routing command is run. |
| verbose_level               | 0   1                                      | Sets the verbosity level for the routing log file.<br>The default is 0.                                                                                                                                                                                                                             |
| clock_topology              | comb   normal                              | Specifies the clock routing topology.<br>The default is normal.                                                                                                                                                                                                                                     |
| comb_distance               | int<br>(must be between 0 and 50)          | Specifies the number of global routing cells within which to connect clock pins to the clock mesh.<br>The default is 2.                                                                                                                                                                             |

*Table 8-3 Common Route Options (Continued)*

| Option                       | Valid values | Description                                                                                                                                                                            |
|------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pg_shield_distance_threshold | float        | Specifies the distance threshold in microns for the router to consider the existing power and ground structure as shielding when calculating the shielding ratio.<br>The default is 0. |
| connect_floating_shapes      | true   false | Specifies whether to connect floating shapes in addition to the pins.<br>The default is false.                                                                                         |

### Boundary and blockage options

|                                |                                                   |                                                                                                                              |
|--------------------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| read_user_metal_blockage_layer | true   false                                      | Specifies whether shapes on metal blockage layers should be honored (true) or ignored (false).<br>The default is false.      |
| wide_macro_pin_as_fat_wire     | true   false                                      | Specifies whether or not the wide macro or pad pin should have an implicit depth same as its width.<br>The default is false. |
| route_top_boundary_mode        | stay_half_min_space_inside   stay_inside   ignore | Controls the routing behavior near the top boundary.<br>The default is stay_inside.                                          |
| standard_cell_blockage_as_thin | true   false                                      | Specifies whether or not to treat wide blockages in standard cells as thin wires.<br>The default is false.                   |

*Table 8-3 Common Route Options (Continued)*

| Option                                                          | Valid values                                    | Description                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------------------------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Layer options</b>                                            |                                                 |                                                                                                                                                                                                                                                                                                                                               |
| freeze_layer_by_layer_name                                      | <code>{{layer<br/>true   false}...}</code>      | Controls whether routing layers are frozen to prevent them from changing during routing.<br>By default ( <code>false</code> ), routing layers are not frozen.                                                                                                                                                                                 |
| freeze_via_to_frozen_layer_by_layer_name                        | <code>{{layer<br/>true   false}...}</code>      | Controls the treatment of vias that touch a frozen layer on one side.<br>The default is <code>false</code> for all layers.                                                                                                                                                                                                                    |
| forbid_new_metal_by_layer_name                                  | <code>{{layer<br/>true   false}...}</code>      | Controls whether ECO routing can remove, but not add, metal on the specified layers.<br>For all other routing commands, this option acts the same as the <code>freeze_layer_by_layer_name</code> option and controls whether routing cannot add or remove metal on the specified layers.<br>The default is <code>false</code> for all layers. |
| max_layer_mode                                                  | <code>soft   allow_pin_connection   hard</code> | Specifies the strength of the maximum layer constraint.<br>The default is <code>hard</code> .                                                                                                                                                                                                                                                 |
| min_layer_mode                                                  | <code>soft   allow_pin_connection   hard</code> | Specifies the strength of the minimum layer constraint.<br>The default is <code>soft</code> .                                                                                                                                                                                                                                                 |
| extra_preferred_direction_wire_cost_multiplier_by_layer_name    | <code>{{layer int}...}</code>                   | Specifies the cost multiplier for routing in the preferred direction.                                                                                                                                                                                                                                                                         |
| extra_nonpreferred_direction_wire_cost_multiplier_by_layer_name | <code>{{layer int}...}</code>                   | Specifies the cost multiplier for routing in the nonpreferred direction.                                                                                                                                                                                                                                                                      |
| extra_via_cost_multiplier_by_layer_name                         | <code>{{layer int}...}</code>                   | Specifies the cost multiplier for vias.                                                                                                                                                                                                                                                                                                       |

*Table 8-3 Common Route Options (Continued)*

| Option                                    | Valid values                              | Description                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Via options</b>                        |                                           |                                                                                                                                                                                                                                                                                                                                                                              |
| number_of_vias_over_max_layer             | int<br>(must be between 0 and 15)         | Specifies the maximum level of stacked vias that can be used to access pins or fixed routes above the maximum routing layer.<br>The default is 1.                                                                                                                                                                                                                            |
| number_of_vias_under_min_layer            | int<br>(must be between 0 and 15)         | Specifies the maximum level of stacked vias that can be used to access pins or fixed routes below the minimum routing layer.<br>The default is 1.                                                                                                                                                                                                                            |
| via_array_mode                            | off   swap   rotate   all                 | Specifies the types of rotated via arrays that can be used during signal routing and redundant via insertion.<br>The default is all.<br>Zroute uses this option only when routing with default routing rules. For routing with nondefault routing rules, you must explicitly specify all supported via configurations by using the <code>define_routing_rule</code> command. |
| post_detail_route_redundant_via_insertion | off   low   medium   high                 | Enables automatic redundant via insertion after detail routing and ECO routing.<br>The default is off.                                                                                                                                                                                                                                                                       |
| concurrent_redundant_via_mode             | off   reserve_space   insert_at_high_cost | Enables concurrent redundant via insertion during initial routing.<br>The default is off.                                                                                                                                                                                                                                                                                    |
| concurrent_redundant_via_effort_level     | low   medium   high                       | Specifies the effort level for concurrent redundant via insertion during initial routing.<br>The default is low.                                                                                                                                                                                                                                                             |

**Table 8-3 Common Route Options (Continued)**

| Option                                          | Valid values        | Description                                                                                                  |
|-------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------|
| eco_route_concurrent_redundant_via_mode         | off   reserve_space | Enables concurrent redundant via insertion during ECO routing.<br>The default is off.                        |
| eco_route_concurrent_redundant_via_effort_level | low   medium   high | Specifies the effort level for concurrent redundant via insertion during ECO routing.<br>The default is low. |
| rotate_default_vias                             | true   false        | Specifies whether the router can rotate default vias.<br>The default is true.                                |

### Soft rule options

|                                       |                                 |                                                                                                                                                                                |
|---------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| route_soft_rule_effort_level          | off   min   low   medium   high | Specifies the default effort level that is used to rip up and reroute DRC violations for soft spacing rules.<br>The default is medium.                                         |
| routing_rule_effort_level             | rule_effort_list                | Specifies the effort level that is used to rip up and reroute DRC violations for the specified soft spacing routing rules.                                                     |
| post_detail_route_fix_soft_violations | true   false                    | Enables the fixing of soft rule violations, such as bridge rules, after detail routing. This option does not affect the fixing of soft spacing rules.<br>The default is false. |
| post_group_route_fix_soft_violations  | true   false                    | Enables the fixing of soft rule violations, such as bridge rules, after group routing. This option does not affect the fixing of soft spacing rules.<br>The default is false.  |

*Table 8-3 Common Route Options (Continued)*

| Option                                                         | Valid values                                                               | Description                                                                                                                                                                                                             |
|----------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>post_eco_route_fix_soft_violations</code>                | <code>true</code>   <code>false</code>                                     | Enables the fixing of soft rule violations, such as bridge rules, after ECO routing. This option does not affect the fixing of soft spacing rules.<br>The default is <code>false</code> .                               |
| <code>post_incremental_detail_route_fix_soft_violations</code> | <code>true</code>   <code>false</code>                                     | Enables the fixing of soft rule violations, such as bridge rules, after incremental detail routing. This option does not affect the fixing of soft spacing rules.<br>The default is <code>false</code> .                |
| <b>Voltage area options</b>                                    |                                                                            |                                                                                                                                                                                                                         |
| <code>enforce_voltage_areas</code>                             | <code>off</code>   <code>strict</code>   <code>relaxed</code>              | Specifies the level of enforcement for voltage area constraints.<br>The default is <code>relaxed</code> .                                                                                                               |
| <code>voltage_area_weight</code>                               | <code>{}{voltage_area_weight}...</code>                                    | Specifies the weighting for each voltage area.<br>By default, all voltage areas have a weight of <code>medium</code> .                                                                                                  |
| <b>Miscellaneous options</b>                                   |                                                                            |                                                                                                                                                                                                                         |
| <code>single_connection_to_pins</code>                         | <code>off</code>   <code>standard_cell_pins</code>   <code>all_pins</code> | Specifies whether the router can connect to a pin only once.<br>The default is <code>off</code> , except for nets that use a nondefault width routing rule. For those nets, the value is always <code>all_pins</code> . |
| <code>mark_clock_nets_minor_change</code>                      | <code>true</code>   <code>false</code>                                     | Specifies whether only minor changes can be made to clock nets.<br>The default is <code>true</code> .                                                                                                                   |

*Table 8-3 Common Route Options (Continued)*

| Option                            | Valid values                                                                                               | Description                                                                                                                                                          |
|-----------------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| threshold_noise_ratio             | float<br>(must be between 0 and 1)                                                                         | Specifies the noise threshold as a fraction of the operating voltage. The default is 0.35.                                                                           |
| track_auto_fill                   | true   false                                                                                               | Specifies whether or not to fill empty space with routing tracks. The default is true.                                                                               |
| tie_off_mode                      | all   rail_only                                                                                            | Controls whether the router can connect tie-off nets to any power or ground (PG) structure, such as straps, rails, or pins or only to a PG rail. The default is all. |
| connect_within_pins_by_layer_name | {{layer off   via_standard_cell_pins   via_wire_standard_cell_pins   via_all_pins   via_wire_all_pins}...} | Specifies which pin connections must be made within the pins for the specified layer. By default, this option is off for all layers.                                 |

## Setting Global Route Options

Global route options are used to define routing options that affect global routing. When you save the design in Milkyway format, the global route option settings are saved with the design.

- To set the global route options, use the `set_route_zrt_global_options` command (or choose Route > Routing Setup > Set Global Route Options in the GUI). To reset the options to their defaults, use the `set_route_zrt_global_options -default true` command (or click Default in the GUI).
- To report the settings of all global route options, use the `report_route_zrt_global_options` command.
- To return the value of a specific global route option, use the `get_route_zrt_global_options` command.

[Table 8-4](#) lists the Zroute global route options.

*Table 8-4 Global Route Options*

| Option                     | Valid values                  | Description                                                                                                                                                                                                                                               |
|----------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Run control options</b> |                               |                                                                                                                                                                                                                                                           |
| timing_driven              | true   false                  | Enables (true) or disables (false) timing-driven global routing.<br>The default is false.                                                                                                                                                                 |
| timing_driven_effort_level | low   medium   high           | Specifies the effort level for the timing-driven flow.<br>The default is high.                                                                                                                                                                            |
| crosstalk_driven           | true   false                  | Enables (true) or disables (false) crosstalk-driven global routing.<br>The default is false.                                                                                                                                                              |
| congestion_map_only        | true   false                  | If false (the default), create both g-links and a congestion map.<br>If true, create the congestion map without creating g-links.                                                                                                                         |
| layer_based_congestion_map | true   false                  | If true (the default), create a congestion map for each layer in addition to the aggregate congestion map.<br>If false, create only the aggregate congestion map for the design.                                                                          |
| effort                     | minimum   low   medium   high | Specifies the global route effort.<br>The default is medium.                                                                                                                                                                                              |
| force_full_effort          | true   false                  | If false (the default), the global router might stop before the maximum number of iterations, based on the incremental congestion reduction.<br>If true, the global router performs the maximum number of iterations based on the specified effort level. |

*Table 8-4 Global Route Options (Continued)*

| Option                                    | Valid values                              | Description                                                                                                                                                                                                                  |
|-------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Macro options</b>                      |                                           |                                                                                                                                                                                                                              |
| macro_boundary_track_utilization          | <i>int</i><br>(must be between 0 and 100) | Specifies the percentage of tracks to be used along macro boundaries. The default is 100.                                                                                                                                    |
| macro_boundary_width                      | <i>int</i><br>(must be between 0 and 10)  | Specifies the width of the macro boundary in terms of global routing cells. The default is 5.                                                                                                                                |
| macro_corner_track_utilization            | <i>int</i><br>(must be between 0 and 100) | Specifies the percentage of tracks to be used along macro corners. The default is 100.                                                                                                                                       |
| <b>Miscellaneous options</b>              |                                           |                                                                                                                                                                                                                              |
| extra_blocked_layer_utilization_reduction | <i>int</i><br>(must be between 0 and 100) | Specifies an additional utilization reduction to account for the additional routing resources that might be required over potentially difficult-to-route areas during track assignment and detail routing. The default is 0. |
| voltage_area_corner_track_utilization     | <i>int</i><br>(must be between 0 and 100) | Specifies the percentage of tracks to be used along voltage area boundaries. The default is 100.<br>Note that you must set this option from the command line; there is no GUI support for this option.                       |

## Setting Track Assignment Options

Track assignment options are used to define routing options that affect track assignment. When you save the design in Milkyway format, the track assignment option settings are saved with the design.

- To set the track assignment options, use the `set_route_zrt_track_options` command (or choose Route > Routing Setup > Set Track Assign Options in the GUI). To reset the options to their defaults, use the `set_route_zrt_track_options -default true` command (or click Default in the GUI).
- To report the settings of all track assignment options, use the `report_route_zrt_track_options` command.
- To return the value of a specific track assignment option, use the `get_route_zrt_track_options` command.

**Table 8-5** lists the Zroute track assignment options.

*Table 8-5 Track Assignment Options*

| Option                        | Valid values                           | Description                                                                                                                                |
|-------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| <code>timing_driven</code>    | <code>true</code>   <code>false</code> | Enables ( <code>true</code> ) or disables ( <code>false</code> ) timing-driven track assignment.<br>The default is <code>false</code> .    |
| <code>crosstalk_driven</code> | <code>true</code>   <code>false</code> | Enables ( <code>true</code> ) or disables ( <code>false</code> ) crosstalk-driven track assignment.<br>The default is <code>false</code> . |

## Setting Detail Route Options

Detail route options are used to define routing options that affect detail routing. When you save the design in Milkyway format, the detail route option settings are saved with the design.

- To set the detail route options, use the `set_route_zrt_detail_options` command (or choose Route > Routing Setup > Set Detail Route Options in the GUI). To reset the options to their defaults, use the `set_route_zrt_detail_options -default true` command (or click Default in the GUI).
- To report the settings of all detail route options, use the `report_route_zrt_detail_options` command.
- To return the value of a specific detail route option, use the `get_route_zrt_detail_options` command.

**Table 8-6** lists the Zroute detail route options.

*Table 8-6 Detail Route Options*

| Option                                             | Valid values              | Description                                                                                                                              |
|----------------------------------------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Run control options</b>                         |                           |                                                                                                                                          |
| timing_driven                                      | true   false              | Enables (true) or disables (false) timing-driven routing.<br>The default is false.                                                       |
| eco_route_use_soft_spacing_for_timing_optimization | true   false              | Enables (true) or disables (false) soft-rule-based timing optimization during ECO routing.<br>The default is true.                       |
| repair_shorts_over_macros_effort_level             | off   low   medium   high | Specifies the effort level used for repairing shorts over macros.<br>The default is off.                                                 |
| optimize_wire_via_effort_level                     | off   low   medium   high | Specifies the effort level used to optimize wire length and via counts.<br>The default is low.                                           |
| optimize_tie_off_effort_level                      | off   low   high          | Specifies the effort level used to optimize wire length and via counts for tie-off nets.<br>The default is low.                          |
| generate_extra_off_grid_pin_tracks                 | true   false              | Specifies whether to generate extra off-grid routing tracks for pin connections.<br>The default is false.                                |
| generate_off_grid_feedthrough_tracks               | off   low   medium   high | Specifies the effort level used to generate extra off-grid routing tracks for feedthrough nets between blockages.<br>The default is low. |
| save_after_iterations                              | list_of_ints              | Specifies the iterations after which to save the design.<br>The default is {}.                                                           |

**Table 8-6 Detail Route Options (Continued)**

| <b>Option</b>                         | <b>Valid values</b>                               | <b>Description</b>                                                                                                                                                            |
|---------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| save_cell_prefix                      | <i>string</i>                                     | Specifies the prefix to use for intermediate saved designs.<br>The default is <i>DR</i> .                                                                                     |
| force_max_number_iterations           | true   false                                      | Controls whether the maximum number of iterations must be run when design rule checking does not converge.<br>The default is false.                                           |
| drc_convergence_effort_level          | low   medium   high                               | Controls the effort level for performing additional detail routing iterations before early termination when design rule checking does not converge.<br>The default is medium. |
| user_defined_partition                | {llx lly urx ury}                                 | Specifies the coordinates, in database units, of a rectangular partition to be added for routing.                                                                             |
| cpu_limit                             | <i>int</i><br>(must be between -1 and 2147483647) | Specifies the limit for CPU time in minutes.<br>The default is -1, which means there is no limit.                                                                             |
| check_patchable_drc_from_fixed_shapes | true   false                                      | Specifies whether to check for and fix end-of-line spacing, minimum area, and minimum length violations for fixed routes.<br>The default is false.                            |

**Table 8-6 Detail Route Options (Continued)**

| Option                             | Valid values                              | Description                                                                                                                                                        |
|------------------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Antenna options</b>             |                                           |                                                                                                                                                                    |
| antenna                            | true   false                              | Enables (true) or disables (false) antenna analysis.<br>The default is true.                                                                                       |
| antenna_on_iteration               | int<br>(must be between 1 and 19)         | Specifies the routing iteration at which antenna analysis and optimization is turned on.<br>The default is 1.                                                      |
| check_antenna_on_pg                | true   false                              | Enables (true) or disables (false) analysis and optimization of antennas on power and ground nets.<br>The default is false.                                        |
| default_diode_protection           | float<br>(must be between 0.00 and 1e+06) | Specifies the diode protection value used for pins during antenna analysis if the value is not specified in the cell.<br>The default is 0.00.                      |
| default_gate_size                  | float<br>(must be between 0.00 and 1e+06) | Specifies the gate size used for pins during antenna analysis if the gate size is not specified in the cell.<br>The default is 0.00.                               |
| default_port_external_antenna_area | float<br>(must be between 0.00 and 1e+06) | Specifies the antenna area value used for ports (top-level pins) during antenna analysis if the antenna area is not specified in the cell.<br>The default is 0.00. |
| default_port_external_gate_size    | float<br>(must be between 0.00 and 1e+06) | Specifies the gate size used for ports (top-level pins) during antenna analysis if the gate size is not specified in the cell.<br>The default is 0.00.             |
| diode_libcell_names                | list_of_libcells                          | Specifies the diode library cells to use for antenna fixing.<br>By default, Zroute selects the diode cells from the library.                                       |

*Table 8-6 Detail Route Options (Continued)*

| Option                            | Valid values                            | Description                                                                                                                                                                                                                                                             |
|-----------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hop_layers_to_fix_antenna         | true   false                            | Specifies whether layers can be hopped to fix antenna violations.<br>The default is true.                                                                                                                                                                               |
| insert_diodes_during_routing      | true   false                            | Specifies whether the router can use diode insertion to fix antenna violations.<br>The default is false.                                                                                                                                                                |
| antenna_fixing_preference         | hop_layers   use_diodes                 | Specifies the preferred method for fixing antenna violations.<br>The default is hop_layers.                                                                                                                                                                             |
| diode_insertion_mode              | new_and_spare   new   spare             | Specifies whether the router should insert new diodes, reuse existing spare diodes, or use the closest solution.<br>This option has an effect only when the insert_diodes_during_routing option is true.<br>The default is to use the closest solution (new_and_spare). |
| diode_preference                  | none   new   spare                      | Specifies whether the router should insert new diodes, reuse existing spare diodes, or use the closest solution.<br>This option has an effect only when the diode_insertion_mode option is new_and_spare.<br>The default is to use the closest solution (none).         |
| reuse_filler_locations_for_diodes | true   false                            | Specifies whether to reuse filler cell locations for inserting diodes.<br>The default is true.                                                                                                                                                                          |
| max_antenna_pin_count             | int<br>(must be between -1 and 1000000) | Specifies the maximum number of pins on a net on which antenna checking is performed.<br>The default is -1, which means there is no limit.                                                                                                                              |

**Table 8-6 Detail Route Options (Continued)**

| <b>Option</b>                   | <b>Valid values</b>                | <b>Description</b>                                                                                                                            |
|---------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| skip_antenna_fixing_for_nets    | <i>nets</i>                        | Disables antenna fixing for the specified nets. Zroute performs antenna analysis on these nets and reports violations, but does not fix them. |
| merge_gates_for_antenna         | true   false                       | Enables (true) or disables (false) merging gates for antenna analysis. The default is true.                                                   |
| port_antenna_mode               | float   jump   top_layer           | Specifies how the ports (top-level pins) are treated for antenna consideration. The default is float.                                         |
| top_layer_antenna_fix_threshold | int<br>(must be between -1 and 10) | Specifies the threshold for fixing antenna violations on the top routing layer. The default is -1, which means there is no limit.             |
| antenna_verbose_level           | 0   1                              | Sets the antenna checking verbosity level in the routing log file. The default is 1.                                                          |

### Pin and port options

|                                |                                 |                                                                                                                      |
|--------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------|
| check_pin_min_area_min_length  | true   false                    | Enables (true) or disables (false) checking for minimum area and minimum length rules on pins. The default is false. |
| check_port_min_area_min_length | true   false                    | Enables (true) or disables (false) checking for minimum area and minimum length rules on ports. The default is true. |
| pin_taper_mode                 | default_width   pin_width   off | Specifies the pin tapering mode. The default is default_width.                                                       |

**Table 8-6 Detail Route Options (Continued)**

| Option                              | Valid values                        | Description                                                                                                                                                                         |
|-------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| use_wide_wire_to_input_pin          | true   false                        | Specifies whether pin tapering to input pins is disallowed.<br>The default is false.                                                                                                |
| use_wide_wire_to_macro_pin          | true   false                        | Specifies whether pin tapering to macro pins is disallowed.<br>The default is false.                                                                                                |
| use_wide_wire_to_output_pin         | true   false                        | Specifies whether pin tapering to output pins is disallowed.<br>The default is false.                                                                                               |
| use_wide_wire_to_pad_pin            | same_as_macro_pin<br>  true   false | Controls pin tapering to pad pins.<br>The default is same_as_macro_pin.                                                                                                             |
| use_wide_wire_to_port               | same_as_macro_pin<br>  true   false | Controls pin tapering to ports.<br>The default is same_as_macro_pin.                                                                                                                |
| use_lower_hierarchy_for_port_diodes | true   false                        | Controls the logic hierarchy in which diodes are inserted to fix antenna violations of physical ports (terminals).<br>By default (false), the diodes are inserted at the top level. |

### Width and spacing options

|                    |                                                                                                                        |                                                                                                                                        |
|--------------------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| diagonal_min_width | true   false                                                                                                           | Specifies whether to use diagonal or Manhattan distance for minimum width violations.<br>By default (true), diagonal distance is used. |
| ignore_drc         | { { same_net_metal_space<br>  same_net_enclosed_cut_space<br>  all_same_net_drc_for_frozen_net<br>true   false } ... } | Controls whether the router ignores specific design rule checks (DRCs).<br>By default (false), none of the DRCs are ignored.           |

*Table 8-6 Detail Route Options (Continued)*

| Option                                      | Valid values | Description                                                                                                              |
|---------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------|
| ignore_var_spacing_to_blockage              | true   false | Specifies whether variable route rule spacing is ignored against blockages.<br>The default is false.                     |
| ignore_var_spacing_to_pg                    | true   false | Specifies whether variable route rule spacing is ignored against power and ground nets.<br>The default is false.         |
| use_default_width_for_min_area_min_len_stub | true   false | Specifies whether to use default width stubs to fix minimum area and minimum length violations.<br>The default is false. |
| var_spacing_to_same_net                     | true   false | Specifies if variable route rule spacing is to be applied to shapes of the same net.<br>The default is false.            |

## Setting Signal Integrity Options

By default, Zroute does not perform crosstalk reduction. If you enable signal integrity mode, Zroute performs crosstalk reduction during global routing and track assignment. To enable signal integrity mode, enter the following command:

```
icc_shell> set_si_options -route_xtalk_prevention true
```

When you run this command, IC Compiler automatically sets the Zroute global route and track assignment `crosstalk_driven` options to true.

The default crosstalk prevention threshold is 0.35 volts, which is probably too relaxed. If your design has crosstalk violations, you should use the `set_si_options -route_xtalk_prevention_threshold` command to lower the crosstalk prevention threshold during track assignment to a value between in the range of 0.25 to 0.35 volts. When you set the crosstalk prevention threshold, IC Compiler automatically sets the Zroute common `threshold_noise_ratio` option.

When you enable crosstalk prevention, Zroute avoids putting long, parallel wires on adjacent tracks during track assignment. To minimize noise, track assignment estimates the potential noise with a simplified crosstalk checker and reassigns wires to reduce the potential noise using the noise threshold.

---

## Setting Multivoltage Options

A voltage area is a placement area for one or more logic partitions that operate at the same voltage. The cells of the logic partition are associated with the partition's voltage area and are constrained to placement within that area.

By default, Zroute considers voltage area constraints during global routing, track assignment, and detail routing; however, it can violate the voltage area constraints to resolve congestion problems or DRC violations.

[Figure 8-7](#) shows an example of routing a net in a multivoltage design. In the figure on the left, Zroute honors the voltage area constraints and routes around the other voltage area. In the figure on the right, Zroute ignores the voltage area constraints and routes through the other voltage area.

*Figure 8-7 Routing a Net in a Multivoltage Design*



You can control the level of enforcement of voltage area constraints by using the `set_route_zrt_common_options` command to set the `enforce_voltage_areas` common route option. This option supports the following values:

- `relaxed` (the default)

Global routing, track assignment, and detail routing can violate the voltage area constraints to resolve congestion or DRC issues.

- `strict`

Global routing, track assignment, and detail routing strictly follow the voltage area constraints.

- `off`

Zroute ignores the voltage area constraints.

For example, to enable strict enforcement of the voltage area constraints, enter the following command:

```
icc_shell> set_route_zrt_common_options -enforce_voltage_areas strict
```

For critical nets, it might be necessary to ignore the voltage area constraints to achieve the best routing solution, even when voltage area constraints are enforced for the design. To ignore the voltage area constraints for specific nets, set the `ignore_voltage_areas` property on the nets by using the `set_zrt_net_properties` command. You can specify the nets either by using the `-nets` option to specify the nets on the command line or by specifying the nets in a file and using the `-from_file` option.

The following example shows the use of the `-nets` option:

```
icc_shell> set_zrt_net_properties -nets [get_nets my_net] \
-ignore_voltage_areas true
```

To get the value of the `ignore_voltage_areas` property on a net, use the `get_zrt_net_properties` command.

```
icc_shell> get_zrt_net_properties -net [get_nets my_net] \
-property ignore_voltage_areas
```

When voltage area constraints are considered during routing, you can provide routing guidance for disjoint voltage areas by using the `voltage_area_weight` common route option to assign weights to each voltage area. Use the following syntax to assign weights to voltage areas:

```
set_route_zrt_common_options -voltage_area_weight {{VA_name weight} ...}
```

By default, all voltage areas have a weight of `medium`. To increase the cost of routing in a non-native voltage area, set the weight for that voltage area to `high`. To decrease the cost of routing in a non-native voltage area, set the weight for that voltage area to `low`.

When you save the design in Milkyway format, the common route option settings and the net property settings are saved with the design. For more information about setting common route options, see “[Setting Common Route Options](#)” on page 8-35.

---

## Routing Clock Nets

You can use Zroute for initial routing of clock nets, redundant via insertion on clock nets, shielding of clock nets, and ECO routing of clock nets. The following sections describe how to perform these tasks.

Note:

When you use Zroute for clock tree routing, you must use Arnoldi delay calculation for the clock nets. To enable Arnoldi delay calculation for the clock nets, use the following command:

```
icc_shell> set_delay_calculation -clock_arnoldi
```

---

## Clock Net Routing

You can route clock nets before routing the rest of the nets in the design by using the `route_zrt_group -all_clock_nets` command.

```
icc_shell> route_zrt_group -all_clock_nets
```

Note:

If you have an IC Compiler-PC package, use the `route_zrt_clock_tree` command to route the clock nets; the `route_zrt_group` command is not included in the IC Compiler-PC package.

The `route_zrt_group -all_clock_nets` command runs global routing, track assignment, and detail routing on the specified nets. If the design contains existing global routes, by default, these global routes are ignored. To perform incremental global routing by reusing existing global routes, use the `-reuse_existing_global_route true` option. If the design contains existing detail routes for the specified nets, the `route_zrt_group` command performs incremental detail routing. During detail routing, Zroute also performs search and repair. By default, the detail router performs a maximum of 40 iterations. Zroute stops before completing the maximum number of iterations if it determines that all violations have been fixed or that it cannot fix the remaining violations. You can control the maximum number of detail routing iterations by using the `-max_detail_route_iterations` option.

Zroute supports three modes for routing of clock nets:

- Balanced

To use balanced routing, you must perform incremental global routing, which reuses the global route information left by the integrated clock global router during clock tree optimization.

```
icc_shell> set_delay_calculation -clock_arnoldi
icc_shell> clock_opt -only_cts -no_clock_route
icc_shell> route_zrt_group -all_clock_nets \
    -reuse_existing_global_route true
```

- Comb

To use comb routing, use the `set_route_zrt_common_options` command to set the `clock_topology` common route option to `comb` before routing the clock nets.

```
icc_shell> set_delay_calculation -clock_arnoldi
icc_shell> clock_opt -only_cts -no_clock_route
icc_shell> set_route_zrt_common_options -clock_topology comb
icc_shell> route_zrt_group -all_clock_nets
```

When comb routing is enabled, Zroute reports a DRC violation when a clock pin within the comb distance is not connected directly to the clock strap. These errors are saved in the error view, similar to other routing DRC violations.

- Normal

To use normal routing, use the `set_route_zrt_common_options` command to set the `clock_topology` common route option to `normal` before routing the clock nets. Note that this is the default setting for this option.

```
icc_shell> set_delay_calculation -clock_arnoldi
icc_shell> clock_opt -only_cts -no_clock_route
icc_shell> set_route_zrt_common_options -clock_topology normal
icc_shell> route_zrt_group -all_clock_nets
```

---

## Clock Net Redundant Via Insertion

Zroute can insert redundant vias on clock nets either during or after routing. For information about inserting redundant vias during clock routing, see “[Inserting Redundant Vias on Clock Nets](#)” on page 9-25. For information about postroute redundant via insertion, see “[Postroute Redundant Via Insertion](#)” on page 9-29.

---

## Clock Net Shielding

Zroute uses nondefault routing rules to define the shielding width and spacing. For information about nondefault routing rules, see “[Using Nondefault Routing Rules](#)” on page 8-22.

Note:

If you do not define the shielding spacing for clock nets, Zroute adds default spacing as shield spacing on clock nets.

After defining the nondefault routing rules and routing the clock nets, use the `create_zrt_shield` command to shield the clock nets. For information about shielding nets, see “[Shielding Nets](#)” on page 9-41.

---

## Postroute Clock Tree Optimization

When Zroute is enabled and you run the `optimize_clock_tree` command on a routed design, the `optimize_clock_tree` command uses Zroute to perform ECO routing.

If only the clock nets are routed, run the following command to perform postroute clock tree optimization and ECO routing of the clock nets:

```
icc_shell> optimize_clock_tree -routed_clock_stage_detail \
           -buffer_sizing -gate_sizing
```

If both the clock and signal nets are routed, run the following commands to perform postroute clock tree optimization and ECO routing of the clock and signal nets:

```
icc_shell> optimize_clock_tree \
           -routed_clock_stage_detail_with_signal_routes \
           -buffer_sizing -gate_sizing
```

---

## Routing Critical Nets

You can route a group of critical nets before routing the rest of the nets in the design by using the `route_zrt_group` command (or by choosing Route > Net Group Route in the GUI). You can specify the nets to route either by using the `-nets` option to specify the nets on the command line or by specifying the nets in a file and using the `-from_file` option:

```
icc_shell> route_zrt_group -nets collection_of_critical_nets
```

or

```
icc_shell> route_zrt_group -from_file file_name
```

If the specified nets are associated with a routing corridor, the nets are routed within the defined region. Note that Zroute global routing considers routing corridors as a hard constraint, while track assignment and detail routing consider routing corridors as a soft constraint and might route nets slightly outside of the routing corridor to fix DRC violations.

By default, the `route_zrt_group` command ignores existing global routes, reuses dangling wires and existing detail routes on the specified nets, and runs global routing, track assignment, and detail routing on the specified nets.

- To perform incremental global routing, set the `-reuse_existing_global_route` option to `true`.

Note:

You cannot use the `-reuse_existing_global_route true` option when routing the nets in a routing corridor. If you use this option, the global router ignores the routing corridors.

- To disable the reuse of dangling wires, set the `-utilize_dangling_wires` option to `false`.
- To stop after global routing, set the `-stop_after_global_route` option to `true`.

During detail routing, Zroute also performs search and repair. By default, the detail router performs a maximum of 40 iterations. If Zroute determines before then that all violations have been fixed or that it cannot fix the remaining violations, it stops. You can control the maximum number of detail routing iterations by using the `-max_detail_route_iterations` option.

By default, the `route_zrt_group` command does not fix soft DRC violations, such as bridge rule violations. To enable the fixing of soft DRC violations after the final detail routing iteration, use the `set_route_zrt_common_options` command to set the `post_group_route_fix_soft_violations` common route option to `true`.

```
icc_shell> set_route_zrt_common_options \
-post_group_route_fix_soft_violations true
```

---

## Routing Signal Nets

Before you route the signal nets, all clock nets must be routed without violations.

You can route the signal nets by using one of the following methods:

- Use the basic commands to perform the standalone routing tasks.

To perform global routing, use the `route_zrt_global` command. To perform track assignment, use the `route_zrt_track` command. To perform detail routing, use the `route_zrt_detail` command.

When you run a standalone routing command, such as `route_zrt_global` or `route_zrt_detail`, Zroute reads in the design database at the beginning of each routing command and updates the database at the end of each command. The router does not check the input data. For example, if the track assignment step is skipped and you run detail routing directly, Zroute might generate bad routing results.

If you need to customize your routing flow or you need to run a large design step-by-step, you might want to use the standalone routing commands instead of the `route_opt` command or automatic routing.

- Use automatic routing (the `route_zrt_auto` basic command).

The `route_zrt_auto` basic command performs global routing, track assignment, and detail routing.

When you run `route_zrt_auto`, Zroute reads the design database before starting routing and updates the database when all routing steps are done. If you stop automatic routing before it performs detail routing, Zroute checks the input data when you restart routing with this command.

Use the `route_zrt_auto` command when you run routing to verify convergence, congestion, and design rule quality-of-results (QoR). You also might want to use `route_zrt_auto` if congestion QoR is your main goal, rather than timing QoR.

- Use the `route_opt` core command.

The `route_opt` command performs global routing, track assignment, detail routing, and postroute optimization.

Use the `route_opt` command when you are finished with the feasibility runs and want to finalize the routing and perform postroute optimization.

Zroute can insert redundant vias during signal routing. For information about this capability, see [“Inserting Redundant Vias on Signal Nets” on page 9-26](#).

---

## Routing Signal Nets by Using Individual Routing Commands

After you have specified your routing options, you can debug your design or monitor each routing step by performing each routing step individually. Individual routing steps are explained in the following sections:

- [Global Routing](#)
- [Track Assignment](#)
- [Detail Routing](#)

### Global Routing

Before you run global routing, you must define the Zroute common route options, as described in “[Setting Common Route Options](#)” on page 8-35, and the Zroute global route options, as described in “[Setting Global Route Options](#)” on page 8-42.

To perform standalone global routing, use the `route_zrt_global` command (or choose Route > Global Route in the GUI).

The global router divides a design into global routing cells. By default, the width of a global routing cell is the same as the height of a standard cell and is aligned with the standard cell rows.

For each global routing cell, the routing capacity is calculated according to the blockages, pins, and routing tracks inside the cell. Although the nets are not assigned to the actual wire tracks during global routing, the number of nets assigned to each global routing cell is noted. The tool calculates the demand for wire tracks in each global routing cell and reports the overflows, which are the number of wire tracks that are still needed after the tool assigns nets to the available wire tracks in a global routing cell.

Global routing is done in two phases:

- The initial routing phase (phase 0), in which the tool routes the unconnected nets and calculates the overflow for each global routing cell
- The rerouting phases, in which the tool tries to reduce congestion by ripping up and rerouting nets around global routing cells with overflows

The tool might perform several rerouting phases. At the end of each rerouting phase, the tool recalculates the overflows. You should see a reduction in the total number of global routing cells with overflow and in the total overflow numbers. The global router stops and exits from the rerouting phase when the congestion is solved or cannot be solved further or after the maximum number of phases has occurred, as defined by the `-effort` option. You can force the global router to perform the maximum number of phases based on the specified effort level by using the `set_route_zrt_global_options` command to set the

`force_full_effort` global route option to `true`. By default, the tool uses medium effort and performs a maximum of three rerouting phases. You can perform up to four rerouting phases by specifying high effort.

There are four global routing effort levels: `minimum`, `low`, `medium`, and `high`.

- Minimum (`-effort minimum`)

The minimum effort level uses two times larger global routing cells relative to the other effort levels. It also has a much lower congestion cost and runs only one rerouting phase. It should only be used for prototype routing or for an initial congestion evaluation, not for detail routing.

- Low (`-effort low`)

Low effort runs a maximum of two rerouting phases with very similar congestion cost. It is faster in comparison to medium effort and has reasonable QoR. If your design is not very congested, you can use the low effort level.

- Medium (`-effort medium`)

Medium effort is the default effort level and runs a maximum of three rerouting phases. Global routing stops after the third phase or when the overflow is resolved, whichever occurs first.

- High (`-effort high`)

High effort runs up to four rerouting phases. If your design is very congested, use the high effort level.

At the end of global routing, the following information is stored in the Milkyway design database:

- The g-links and g-vias on each routed net

This information is used for the next routing steps. After Zroute performs track assignment and detail routing, it removes these g-links and g-vias from the design database.

- The congestion data

By default, the congestion data for each layer is stored in the Milkyway design database, which enables the tool to generate a layer-based congestion map; however, saving the layer-based information increases the size of the Milkyway design database. If you do not need layer-based congestion maps, you can disable this capability and save only aggregate congestion information by using the `set_route_zrt_global_options` command to set the `layer_based_congestion_map` global route option to `false` before running global routing.

The global router reports design statistics and congestion data after the initial routing phase and after each rerouting phase. When global routing is complete, the global router reports a summary of the wire length and via count.

[Example 8-2](#) shows a global routing report. In the congestion report, the Overflow value is the total number of wires in the design that do not have a corresponding track available. The Max value corresponds to the highest number of overutilized wires in a single global routing cell. The GRCs value is the total number of overcongested global routing cells in the design.

### Example 8-2 Global Routing Report

```

Start Global Route ...
[Init] Elapsed real time: 0:00:00
[Init] Elapsed cpu  time: sys=0:00:00 usr=0:00:00 total=0:00:00
.....
Begin global routing.
Constructing data structure ...
Design statistics:
Design Bounding Box (0.00,0.00,3180.00,1154.00)
Number of routing layers = 10
layer M1, dir Ver, min width = 0.09, min space = 0.09 pitch = 0.24
layer M2, dir Hor, min width = 0.10, min space = 0.10 pitch = 0.20
layer M3, dir Ver, min width = 0.10, min space = 0.10 pitch = 0.30
layer M4, dir Hor, min width = 0.10, min space = 0.10 pitch = 0.30
layer M5, dir Ver, min width = 0.10, min space = 0.10 pitch = 0.30
layer M6, dir Hor, min width = 0.10, min space = 0.10 pitch = 0.30
layer M7, dir Ver, min width = 0.10, min space = 0.10 pitch = 0.30
...
Net statistics:
Total number of nets      = 231242
Number of nets to route   = 231177
Number of single or zero port nets = 64
1 nets are partially routed.
1 nets are partially drouuted.
0 nets are partially grouted.
1 nets are routed.
1 nets are drouuted.
0 nets are grouted.
4 nets have non-default rule non_m2_route_rules_for_noise
12 nets have non-default rule clockRouteRuleCTS
...
phase3. Routing result:
phase3. Both Dirs: Overflow =    453 Max = 4 GRCs =    449 (0.02%)
phase3. H routing: Overflow =    148 Max = 1 (GRCs = 114) GRCs =    202
(0.02%)
phase3. V routing: Overflow =    304 Max = 4 (GRCs =  2) GRCs =    247
(0.03%)
phase3. M1          Overflow =      1 Max = 0 (GRCs =  2) GRCs =      2
(0.00%)
phase3. M2          Overflow =     34 Max = 0 (GRCs =  88) GRCs =     88
(0.01%)
phase3. M3          Overflow =   184 Max = 4 (GRCs =  2) GRCs =   126
(0.01%)
phase3. M4          Overflow =    80 Max = 1 (GRCs =  80) GRCs =    80
(0.01%)

```

```

phase3. M5          Overflow =      0 Max = 0 (GRCs = 0) GRCs =      0
(0.00%)
phase3. M6          Overflow =     34 Max = 1 (GRCs = 34) GRCs =     34
(0.00%)
phase3. M7          Overflow =   119 Max = 1 (GRCs = 119) GRCs =   119
(0.01%)
.....phase3. Total Wire Length = 16820202.00
phase3. Layer M1 wire length = 10412.66
phase3. Layer M2 wire length = 3576314.50
phase3. Layer M3 wire length = 2721198.75
phase3. Layer M4 wire length = 2988112.75
phase3. Layer M5 wire length = 2201333.00
phase3. Layer M6 wire length = 4374871.00
phase3. Layer M7 wire length = 947959.25
phase3. Layer M8 wire length = 0.00
phase3. Layer M9 wire length = 0.00
phase3. Layer M10 wire length = 0.00
phase3. Total Number of Contacts = 1820147
phase3. Via VIA12 count = 749084
phase3. Via VIA23 count = 762968
phase3. Via VIA34 count = 142823
phase3. Via VIA45 count = 91356
phase3. Via VIA56 count = 46191
phase3. Via VIA67 count = 27725
phase3. Via VIA78 count = 0
phase3. Via VIA89 count = 0
phase3. Via VIA910mH count = 0
phase3. completed.

```

Before proceeding to detail routing, display the congestion map in the GUI, and check the overflow distribution. The congestion report and map help you to identify congested areas. For more information about the congestion report and map, see “[Analyzing Congestion](#)” on page 8-90.

### Global Routing During Design Planning

During design planning you can perform exploration-mode global routing by using the `route_zrt_global -exploration true` command.

```
icc_shell> route_zrt_global -exploration true
```

If you are using the hierarchical flow, enable plan-group-aware global routing by using the `set_route_zrt_common_options` command to set the `plan_group_aware` common route option before running the `route_zrt_global` command. When you set the `plan_group_aware` common route option to `all_routing`, Zroute routes all the nets in the design and preserves the hierarchy and pin constraints. You can increase the plan-group-aware routing speed by routing only the top-level nets. To do this, set the

plan\_group\_aware common route option to top\_level\_routing\_only. When the plan\_group\_aware common route option is set to off, which is the default, Zroute ignores the plan groups and routes the design as flat.

```
icc_shell> set_route_zrt_common_options -plan_group_aware all_routing  
icc_shell> route_zrt_global -exploration true
```

### Timing-Driven Global Routing

By default, the route\_zrt\_global command is not timing-driven. To enable timing-driven global routing, use the set\_route\_zrt\_global\_options command to set the timing\_driven global route option before you run the route\_zrt\_global command.

You can control the tradeoff between timing QoR and DRC convergence by using the set\_route\_zrt\_global\_options command to set the timing\_driven\_effort\_level global route option. By default, this option has a setting of high, which favors timing QoR over DRC convergence.

When you enable timing-driven global routing, IC Compiler calculates the net delays before invoking the global router. If the design database contains global route information, IC Compiler uses the global route information to calculate the net delays; otherwise, it uses virtual routing to calculate the net delays. The global routing results can vary depending on whether the initial net delays were calculated by using global route information or virtual routing. To remove existing global route information from the design, use the remove\_route\_by\_type command, as shown in the following example:

```
icc_shell> remove_route_by_type -signal_detail_route
```

### Crosstalk-Driven Global Routing

By default, the route\_zrt\_global command is not crosstalk-driven. To enable crosstalk-driven global routing, set the route\_xtalk\_prevention signal integrity option, as described in [“Setting Signal Integrity Options” on page 8-52](#).

When you enable crosstalk-driven global routing, IC Compiler calculates the net delays before invoking the global router. If the design database contains global route information, IC Compiler uses the global route information to calculate the net delays; otherwise, it uses virtual routing to calculate the net delays. The global routing results can vary depending on whether the initial net delays were calculated by using global route information or virtual routing. To remove existing global route information from the design, use the remove\_route\_by\_type command, as shown in the following example:

```
icc_shell> remove_route_by_type -signal_detail_route
```

## Incremental Global Routing

By default, the global router ignores existing global routes. To perform incremental global routing by reusing the existing global routes, use the `-reuse_existing_global_route true` option when you run global routing. Note that this option affects only the global router and not the net delay calculation that occurs before timing-driven or crosstalk-driven global routing.

## Track Assignment

Before you run track assignment, you must define the Zroute common route options, as described in “[Setting Common Route Options](#)” on page 8-35, and the Zroute track assignment options, as described in “[Setting Track Assignment Options](#)” on page 8-45.

To perform standalone track assignment, run the `route_zrt_track` command (or choose Route > Track Assignment in the GUI).

The main task of track assignment is to assign routing tracks for each global route. During track assignment, Zroute performs the following tasks:

- Assigns tracks in horizontal partitions.
- Assigns tracks in vertical partitions.
- Reroutes overlapping wires.

After track assignment finishes, all nets are routed but not very carefully. There are many violations, particularly where the routing connects to pins. Detail routing works to correct those violations.

Note:

Because track assignment replaces the global routes with actual metal layers, the design no longer contains global routes after track assignment completes.

By default, the `route_zrt_track` command is not timing-driven or crosstalk-driven.

- To enable timing-driven mode, set the `timing_driven` track assignment option.
- To enable crosstalk-driven mode, set the `route_xtalk_prevention` signal integrity option, as described in “[Setting Signal Integrity Options](#)” on page 8-52.

At the end of track assignment, Zroute reports a summary of the wire length and via count. [Example 8-3](#) shows a track assignment report.

### *Example 8-3 Track Assignment Report*

Wire length and via report:

```
-----
Number of metal1 wires: 90644          via01: 0
Number of metal2 wires: 1305119        via12: 1171053
Number of metal3 wires: 823570         via23: 1300628
Number of metal4 wires: 124268         via34: 192435
Number of metal5 wires: 28001          via45: 44130
Number of metal6 wires: 4054           via56: 7644
Number of metal7 wires: 0              via67: 0
Total number of wires: 2375656        vias: 2715890

Total metal1 wire length: 170860.9
Total metal2 wire length: 2493004.5
Total metal3 wire length: 4127489.2
Total metal4 wire length: 2109298.0
Total metal5 wire length: 1584743.5
Total metal6 wire length: 300718.1
Total metal7 wire length: 0.0
Total wire length: 10786114.0

Longest metal1 wire length: 540.7
Longest metal2 wire length: 603.5
Longest metal3 wire length: 729.7
Longest metal4 wire length: 821.1
Longest metal5 wire length: 958.2
Longest metal6 wire length: 935.7
Longest metal7 wire length: 0.0
```

After track assignment, you can display a congestion report and map that are based on the track assignment results. For more information about the congestion report and map, see “[Analyzing Congestion](#)” on page 8-90.

## **Detail Routing**

Before you run detail routing, you must define the Zroute common route options, as described in “[Setting Common Route Options](#)” on page 8-35, and the Zroute detail route options, as described in “[Setting Detail Route Options](#)” on page 8-45.

The detail router uses the general pathways suggested by global routing and track assignment to route the nets, and then it divides the design into partitions and looks for DRC violations in each partition. When the detail router finds a violation, it rips up the wire and reroutes it to fix the violation. During detail routing, Zroute concurrently addresses routing design rules and antenna rules and optimizes via count and wire length. For more information about antenna rules and via count and wire length optimization, see [Chapter 9, “Chip Finishing and Design for Manufacturing.”](#)

To perform standalone detail routing, run the `route_zrt_detail` command (or choose Route > Detail Route in the GUI).

By default, the `route_zrt_detail` command

- Performs detail routing on the whole design

You can restrict the routing to a specific area of the design by using the `-coordinates` option (or by specifying or selecting the bounding box in the GUI).

- Uses one uniform partition for the first iteration and adjusts the partitioning for subsequent iterations

Zroute uses the single uniform partition for the first iteration to generate all DRC violations for the chip at the same time. At the beginning of each subsequent iteration, the router checks the distribution of the DRC violations. If the DRC violations are evenly distributed, the detail router uses a uniform partition. If the DRC violations are located in some local areas, the detail router uses nonuniform partitions.

- Performs iterations until one of the following conditions exists:

- All of the violations have been fixed
- The maximum number of iterations has been reached

By default, the maximum number of iterations is 40. You can change this limit by setting the `-max_number_iterations` option.

```
icc_shell> route_zrt_detail -max_number_iterations 20
```

- It cannot fix any of the remaining violations

You can change the effort that the detail router uses for fixing the remaining violations before it gives up by using the `set_route_zrt_detail_options` command to set the `drc_convergence_effort_level` detail route option.

```
icc_shell> set_route_zrt_detail_options \
           -drc_convergence_effort_level high
```

You can force the detail router to complete the maximum number of iterations, regardless of the DRC convergence status, by using the `set_route_zrt_detail_options` command to set the `force_max_number_iterations` detail route option to `true`.

```
icc_shell> set_route_zrt_detail_options \
           -force_max_number_iterations true
```

- Is not timing-driven

To enable timing-driven detail routing, use the `set_route_zrt_detail_options` command to set the `timing_driven` detail route option.

```
icc_shell> set_route_zrt_detail_options -timing_driven true
```

**Note:**

If you perform detail routing by using the `route_opt` command, the default behavior is timing-driven detail routing.

- Does not fix shorted nets over macro cells

If default detail routing leaves shorted nets over macro cells, analyze the design to determine if the shorts are caused by the availability of only a single layer for routing over the macro cells. If so, enable river routing by creating single-layer route guides over the macros with shorted nets and rerun detail routing. For information about creating route guides, see “[Defining Route Guides](#)” on page 8-8.

If shorted nets remain after using river routing, enable the fixing of shorted nets over macro cells by automatically ripping up and rerouting the shorted nets by using the `set_route_zrt_detail_options` command to set the `repair_shorts_over_macros_effort_level` detail route option to `low`, `medium`, or `high` and running incremental detail routing. The higher the effort level, the more ECO routing iterations are performed, which can reduce the number of DRC violations at the expense of runtime.

```
icc_shell> set_route_zrt_detail_options \
-repair_shorts_over_macros_effort_level high
```

- Does not fix soft DRC violations, such as bridge rule violations

To enable the fixing of soft DRC violations after the final detail routing iteration, use the `set_route_zrt_common_options` command to set the `post_detail_route_fix_soft_violations` common route option to `true`.

```
icc_shell> set_route_zrt_common_options \
-post_detail_route_fix_soft_violations true
```

You can run additional detail routing iterations on a routed design by running incremental detail routing (the `-incremental` option). Be sure to use the `-incremental` option; otherwise, Zroute restarts at iteration 0 with a fixed-size partition.

```
icc_shell> route_zrt_detail -incremental true
```

By default, incremental detail routing does not fix soft DRC violations, such as bridge rule violations. To enable the fixing of soft DRC violations after the final incremental detail routing iteration, use the `set_route_zrt_common_options` command to set the `post_incremental_detail_route_fix_soft_violations` common route option to `true`.

```
icc_shell> set_route_zrt_common_options \
-post_incremental_detail_route_fix_soft_violations true
```

**Note:**

Incremental detail routing does not fix open nets. To fix open nets, you must run ECO routing. For information about ECO routing, see “[Performing ECO Routing](#)” on page 8-85.

If you want to view the DRC violations before postroute optimization, you can save the design after a specified number of iterations by using the `set_route_zrt_detail_options` command to set the `save_after_iterations` detail route option. The saved design is called `DR_itrn`, where `n` is the specified iteration. You can use a string other than DR as the prefix by using the `set_route_zrt_detail_options` command to set the `save_cell_prefix` detail route option.

Zroute generates a DRC violations summary at the end of each iteration. For more information about the DRC violations reported by Zroute, see “[Performing Design Rule Checking Using IC Compiler](#)” on page 8-95. Before reporting the final DRC violations, Zroute merges redundant violations. [Example 8-4](#) shows a detail routing report.

**Example 8-4 Detail Routing Report**

```

Start DR iteration 0: uniform partition
Routed 1/5734 SBoxes, Violations =      0
Routed 28/5734 SBoxes, Violations =     14
...
DRC-SUMMARY:
    @@@@@ TOTAL VIOLATIONS =      437
    @@@ Total number of instance ports with antenna violations = 690
        Diff net spacing : 300
            End of line spacing : 1
            Same net spacing : 6
            Same net via-cut spacing : 2
            Less than minimum area : 20
            Less than minimum edge length : 19
            Needs fat contact : 5
            Needs fat contact on extension : 7
            Internal-only types : 77

        End DR iteration 21 with 198 parts
        @@@@ Total nets not meeting constraints =      1
Stop DR since not converging
...
Information: Merged away 13 aligned/redundant DRCs.
(RT-805)
DR finished with 47 violations and 144 instance ports antenna
violations

        Diff net spacing : 31
        Less than minimum edge length : 1
        Internal-only types : 15

Total Wire Length =          11107954 micron
Total Number of Contacts = 2787466
Total Number of Wires =     2759250
Total Number of PtConns =   598905

```

```
Total Number of Non-Default Contacts = 362
Layer      M1 : 190733 micron
Layer      M2 : 2474471 micron
Layer      M3 : 4106791 micron
Layer      M4 : 2377087 micron
Layer      M5 : 1701419 micron
Layer      M6 : 257452 micron
Layer      M7 : 0 micron
Via       VIA56 : 9778
Via       VIA45 : 76055
```

After detail routing, you can display a congestion report and map that are based on the detail routing results. For more information about the congestion report and map, see “[Analyzing Congestion](#)” on page 8-90.

## Routing Signal Nets by Using Automatic Routing

Before you use automatic routing to route the signal nets, you must define the Zroute routing options (common route, global route, track assignment, and detail route), as described in “[Setting Zroute Options](#)” on page 8-35.

To run automatic routing, use the `route_zrt_auto` command (or choose Route > Auto Route in the GUI). By default, the `route_zrt_auto` command ignores existing global routes and sequentially invokes global routing, track assignment, and detail routing. You can perform incremental global routing by using the `-reuse_existing_global_route true` option. You can stop after track assignment by using the `-stop_after_track_assignment` option.

By default, the `route_zrt_auto` command is not timing-driven or crosstalk-driven.

- To enable timing-driven mode, set the `timing_driven` global route, track assignment, and detail route options.
- To enable crosstalk-driven mode for global routing and track assignment, set the `route_xtalk_prevention` signal integrity option, as described in “[Setting Signal Integrity Options](#)” on page 8-52.

By default, the `route_zrt_auto` command does not fix soft DRC violations, such as bridge rule violations. To enable the fixing of soft DRC violations after the final detail routing iteration, use the `set_route_zrt_common_options` command to set the `post_detail_route_fix_soft_violations` common route option to `true`.

```
icc_shell> set_route_zrt_common_options \
           -post_detail_route_fix_soft_violations true
```

**Table 8-7** describes the `route_zrt_auto` options.

*Table 8-7 route\_zrt\_auto Command Options*

| <b>Command option</b>                                                                                              | <b>Description</b>                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>-stop_after_track_assignment   true   false ("Stop after track assignment" check  box in the GUI)</pre>       | <p>Stops after performing track assignment.<br/>The default is <code>false</code>.</p>                                                                                                                     |
| <pre>-save_after_global_route   true   false ("Save cell after: Global route" check  box in the GUI)</pre>         | <p>Controls whether the design is saved after global routing.<br/>When <code>true</code>, the tool saves the design in a CEL view named <code>auto_GR</code>.<br/>The default is <code>false</code>.</p>   |
| <pre>-save_after_track_assignment   true   false ("Save cell after: Track assignment" check  box in the GUI)</pre> | <p>Controls whether the design is saved after track assignment.<br/>When <code>true</code>, the tool saves the design in a CEL view named <code>auto_TA</code>.<br/>The default is <code>false</code>.</p> |
| <pre>-save_after_detail_route   true   false ("Save cell after: Detail route" check  box in the GUI)</pre>         | <p>Controls whether the design is saved after detail routing.<br/>When <code>true</code>, the tool saves the design in a CEL view named <code>auto_DR</code>.<br/>The default is <code>false</code>.</p>   |
| <pre>-max_detail_route_iterations cnt ("Maximum detail router iterations" box in the GUI)</pre>                    | <p>The maximum number of detail routing iterations.<br/>The default is the 40.</p>                                                                                                                         |
| <pre>-save_cell_prefix string ("Save cell prefix" box in the GUI)</pre>                                            | <p>Specifies the prefix to use for intermediate saved designs.<br/>The default is <code>auto</code>.</p>                                                                                                   |
| <pre>-reuse_existing_global_route   true   false ("Reuse existing global route" check  box in the GUI)</pre>       | <p>Performs incremental global routing.<br/>The default is <code>false</code>.</p>                                                                                                                         |

---

## Routing Signal Nets by Using the `route_opt` Command

Before you use the `route_opt` command to route the signal nets, you must define the Zroute routing options (common route, global route, track assignment, and detail route), as described in “[Setting Zroute Options](#)” on page 8-35 and set the `route_opt` routing and optimization strategy, as described in the following section. If logical DRC violations remain after running the `route_opt` command, you can use focal optimization to address these remaining violations, as described in “[Performing Focal Optimization](#)” on page 8-83.

## Setting the Routing and Optimization Strategy

IC Compiler provides strategy controls that you set to guide how routing and postroute optimizations are run.

To set the routing and optimization strategy, use the `set_route_opt_strategy` command (or choose Route > Set Core Routing and Optimization Strategy in the GUI).

[Table 8-8](#) describes the `set_route_opt_strategy` options.

*Table 8-8 set\_route\_opt\_strategy Options*

| Command option                                                                                                | Description                                                                                                                                                                                                                                           |
|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-fix_hold_mode all   route_base</code><br>(“Fix hold optimization stage” area in the GUI)               | The stages for which hold optimization is performed. You can select prerouting, global routing, and detail routing ( <code>all</code> ) or global routing and detail routing ( <code>route_base</code> ).<br>The default is <code>route_base</code> . |
| <code>-power_aware_optimization true   false</code><br>(“Power aware optimization flow” check box in the GUI) | Controls whether postroute optimizations for setup, hold, and design rule constraints are power-aware.<br>The default is <code>false</code> .                                                                                                         |
| <code>-xtalk_reduction_loops int</code><br>(“Maximum crosstalk reduction cycles” box in the GUI)              | The maximum number of crosstalk reduction optimization iterations.<br>The default is 1.                                                                                                                                                               |
| <code>-search_repair_loops int</code><br>(“Maximum initial route Search and Repair cycles” box in the GUI)    | The maximum number of initial routing iterations.<br>The Zroute default is 10 (the classic router default is 15).                                                                                                                                     |

*Table 8-8 set\_route\_opt\_strategy Options (Continued)*

| Command option                                                                                                                         | Description                                                                                                         |
|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| <code>-eco_route_search_repair_loops int</code><br>("Maximum ECO Search and Repair cycles" box in the GUI)                             | The maximum number of ECO iterations.<br>The Zroute default is 4 (the classic router default is 5).                 |
| <code>-route_drc_threshold int</code><br>("Route violations threshold to trigger the reduction Search and Repair loop" box in the GUI) | The threshold number of routing violations before limiting detail routing to one iteration.<br>The default is 3000. |

To report your settings, use the `report_route_opt_strategy` command.

## Enabling Fixing of Hold Time Violations

The `route_opt` command fixes hold time violations on those clocks that have a `fix_hold` attribute of `true`.

To disable hold fixing, enter the following command to remove the `fix_hold` attribute from all clocks:

```
icc_shell> remove_attribute [get_clocks *] fix_hold
```

To enable hold fixing, use the `set_fix_hold` command to set the `fix_hold` attribute on the clocks on which to perform hold fixing.

For example, to enable hold fixing on clock `clk`, enter the following command:

```
icc_shell> set_fix_hold clk
```

To enable hold fixing on all clocks, enter the following command:

```
icc_shell> set_fix_hold [all_clocks]
```

### Note:

If you enable hold fixing for a multicorner-multimode design, IC Compiler considers the timing from driver to endpoint on a per-scenario basis and fixes hold violations accordingly.

You can specify a list of preferred buffers for hold fixing during postroute optimization by using the `set_prefer` and `set_fix_hold_options` commands. For example, the following commands instruct the tool to use cells BUF1 and BUF2 as the preferred cells during hold fixing. Note that cells BUF1 and BUF2 can also be used to resolve setup and DRC violations.

```
icc_shell> set_prefer -min {BUF1 BUF2}
icc_shell> set_fix_hold_options -preferred_buffer
```

If you use the `set_dont_use` command to set the `dont_use` attribute on cells BUF1 and BUF2 as shown in the following script, IC Compiler uses cells BUF1 and BUF2 to fix hold violations, but not setup and DRC violations.

```
icc_shell> set_dont_use {BUF1 BUF2}
icc_shell> set_prefer -min {BUF1 BUF2}
icc_shell> set_fix_hold_options -preferred_buffer
```

IC Compiler also provides the following variables that control hold fixing:

- `routeopt_allow_min_buffer_with_size_only`

By default, IC Compiler cannot insert buffers during size-only optimization. When you set this variable to `true` and use the `-size_only` option when you run the `route_opt` command, IC Compiler can insert buffers to fix hold violations.

- `psyn_onroute_disable_hold_fix`

This variable disables hold fixing, but preserves the minimum timing on clocks that have the `fix_hold` attribute.

## Setting the Crosstalk Reduction Options

By default, the `route_opt` command does not perform crosstalk reduction. To perform crosstalk reduction, you must enable signal integrity mode and run the `route_opt` command with the `-xtalk_reduction` or `-only_xtalk_reduction` option. For information about enabling signal integrity mode, see “[Setting Signal Integrity Options](#)” on page 8-52.

By default, when you run the `route_opt` command with the `-xtalk_reduction` or `-only_xtalk_reduction` option, Zroute performs crosstalk reduction during detail routing on nets with setup violations and static noise violations.

The default method for reducing crosstalk is to increase the spacing between nets. To further reduce crosstalk and improve timing QoR, IC Compiler can perform cell sizing by using footprint swapping on cells on the victim or aggressor nets in addition to increasing the spacing between nets. To enable cell sizing during crosstalk reduction, set the `routeopt_xtalk_reduction_cell_sizing` variable to `true` before running the `route_opt` command.

You can use the `set_route_opt_zrt_crosstalk_options` command to control net selection for crosstalk reduction based on setup violations, hold violations, transition time violations, and static noise violations. The following sections describe these controls.

To report your settings, use the `report_route_opt_zrt_crosstalk_options` command. To get the value of a specific setting, use the `get_route_opt_zrt_crosstalk_options` command.

### Setup-Based Net Selection

By default, Zroute performs crosstalk reduction to fix the setup violations on all violating nets.

You can limit the number of nets on which setup fixing is performed by

- Setting a slack threshold (`-setup_slack_threshold` option)  
When you use this option, Zroute performs setup fixing only on those nets with a setup slack value that is worse than the specified threshold.
- Setting an individual delta delay threshold (`-setup_one_net_delta_delay_threshold` option)  
When you use this option, Zroute performs setup fixing only on those nets with setup violations and a delta delay value that exceeds the specified threshold.
- Setting a total delta delay threshold (`-setup_total_delta_delay_threshold` option)  
When you use this option and the total delta delay of all nets with setup violations exceeds the specified threshold, Zroute performs setup fixing only on the nets with the top contributions to the threshold delta delay value.
- Setting a maximum net count (`-setup_max_net_count` option)  
When you use this option, Zroute performs setup fixing on, at most, the specified number of nets. If the number of nets with setup violations exceeds the specified number, Zroute performs setup fixing on the nets with the worst slack violations.
- Setting a minimum net count (`-setup_min_net_count` option)  
When you use this option, Zroute performs setup fixing only if the number of nets with setup violations is greater than the specified number.

You can disable setup fixing by setting the `-setup` option to `false`.

## Hold-Based Net Selection

By default, Zroute does not perform crosstalk reduction to fix hold violations. To enable hold fixing, set the `-hold` option to `true`.

You can limit the number of nets on which hold fixing is performed by

- Setting a slack threshold (`-hold_slack_threshold` option)

When you use this option, Zroute performs hold fixing only on those nets with a hold slack value that is worse than the specified threshold.

- Setting a delta delay threshold (`-hold_one_net_delta_delay_threshold` option)

When you use this option, Zroute performs hold fixing only on those nets with hold violations and a delta delay value that exceeds the specified threshold.

- Setting a maximum net count (`-hold_max_net_count` option)

When you use this option, Zroute performs hold fixing on at most the specified number of nets. If the number of nets with hold violations exceeds the specified number, Zroute performs hold fixing on the nets with the worst slack violations.

- Setting a minimum net count (`-hold_min_net_count` option)

When you use this option, Zroute performs hold fixing only if the number of nets with hold violations is greater than the specified number.

## Transition-Based Net Selection

By default, Zroute does not perform crosstalk reduction to fix transition time violations. To enable transition time fixing, set the `-transition` option to `true`.

You can limit the number of nets on which transition time fixing is performed by

- Setting a slack threshold (`-transition_slack_threshold` option)

When you use this option, Zroute performs transition time fixing only on those nets with a transition time slack value that is worse than the specified threshold.

- Setting a delta delay threshold (`-transition_one_net_delta_delay_threshold` option)

When you use this option, Zroute performs transition time fixing only on those nets with transition time violations and a delta delay value that exceeds the specified threshold.

- Setting a maximum net count (`-transition_max_net_count` option)

When you use this option, Zroute performs transition time fixing on at most the specified number of nets. If the number of nets with transition time violations exceeds the specified number, Zroute performs transition time fixing on the nets with the worst slack violations.

- Setting a minimum net count (`-transition_min_net_count` option)

When you use this option, Zroute performs transition time fixing only if the number of nets with transition time violations is greater than the specified number.

### Static-Noise-Based Net Selection

By default, Zroute performs crosstalk reduction to fix static noise violations on all violating nets when the `-static_noise` signal integrity option set by the `set_si_options` command is `true`.

Note:

When the `-static_noise` signal integrity option is `false`, Zroute does not perform static noise fixing, regardless of the `route_opt` crosstalk reduction settings.

You can limit the number of nets on which static noise fixing is performed by

- Setting a maximum net count (`-static_noise_max_net_count` option)

When you use this option, Zroute performs static noise fixing on at most the specified number of nets. If the number of nets with static noise violations exceeds the specified number, Zroute performs static noise fixing on the nets with the worst violations.

- Setting a minimum net count (`-static_noise_min_net_count` option)

When you use this option, Zroute performs static noise fixing only if the number of nets with static noise violations is greater than the specified number.

### Running the `route_opt` Command

To run routing and postroute optimization, use the `route_opt` command (or choose Route > Core Routing and Optimization in the GUI).

By default, the `route_opt` command performs the following tasks:

- Global routing

By default, global routing is timing-driven and does not do crosstalk prevention.

To disable timing-driven global routing, use the `set_route_zrt_global_options -timing_driven false` command (or choose Route > Routing Setup > Set Global Route Options in the GUI and deselect “Timing driven” in the Run Control tab).

To enable crosstalk-prevention mode, use the `set_route_zrt_global_options -crosstalk_driven true` command (or choose Route > Routing Setup > Set Global Route Options in the GUI and select “Crosstalk driven”) and use the `-xtalk_reduction` or `-only_xtalk_reduction` option when you run the `route_opt` command.

- Track assignment

By default, track assignment is timing-driven and does not do crosstalk prevention.

To disable timing-driven track assignment, use the `set_route_zrt_track_options -timing_driven false` command (or choose Route > Routing Setup > Set Track Assign Options in the GUI and deselect “Timing driven”).

To enable crosstalk-prevention mode, use the `set_route_zrt_track_options -crosstalk_driven true` command (or choose Route > Routing Setup > Set Track Assign Options in the GUI and select “Crosstalk driven”) and use the `-xtalk_reduction` or `-only_xtalk_reduction` option when you run the `route_opt` command.

- Detail routing

By default, detail routing is timing-driven and does not do crosstalk reduction.

To disable timing-driven detail routing, use the `set_route_zrt_detail_options -timing_driven false` command (or choose Route > Routing Setup > Set Detail Route Options in the GUI and deselect “Timing driven” in the Run Control tab).

To enable crosstalk-reduction mode, use the `-xtalk_reduction` or `-only_xtalk_reduction` option when you run the `route_opt` command.

By default, the `route_opt` command does not fix soft DRC violations, such as bridge rule violations. To enable the fixing of soft DRC violations after the final detail routing iteration, use the `set_route_zrt_common_options` command to set the `post_detail_route_fix_soft_violations common route` option to `true`.

```
icc_shell> set_route_zrt_common_options \
-post_detail_route_fix_soft_violations true
```

- Postroute optimization

By default, IC Compiler uses medium effort during postroute optimization. You can change the effort level by using the `-effort` option. When you select high effort, IC Compiler is more aggressive during optimization and runs three optimization loops. In addition to controlling the optimization effort, the effort setting also controls the type of sizing performed when you use the `-size_only` option. During low effort optimization, IC Compiler performs footprint swapping. During medium effort optimization, IC Compiler performs in-place size-only optimization. During high effort optimization, IC Compiler performs cell sizing.

For designs that contain block abstraction models, IC Compiler performs top-level interface optimization during postroute optimization. For information about top-level interface optimization, see [“Transparent Interface Optimization” on page 12-38](#).

In addition to performing routing optimization, you can perform the following optimizations: signal integrity, leakage power, and area recovery.

To enable signal integrity optimization, set the signal integrity options as described in [“Setting Signal Integrity Options” on page 8-52](#), and use the `-xtalk_reduction` option when you run the `route_opt` command.

To enable power-aware postroute optimization, use the `set_route_opt_strategy -power_aware_optimization true` command. By default, when power-aware postroute optimization is enabled, leakage power has a lower cost priority than setup, hold, and design rule constraints. You can change these cost priorities by setting the following variables to `true`: `routeopt_leakage_over_setup`, `routeopt_leakage_over_hold`, and `routeopt_leakage_over_drc`.

To enable leakage-power optimization and recovery, use the `-power` option when you run the `route_opt` command. For information about leakage-power optimization, see [Chapter 5, “Power Optimization.”](#)

To enable area recovery, use the `-area_recovery` option when you run the `route_opt` command.

By default, the postroute optimization step generates QoR reports before and after the postroute optimization. If you do not need the QoR reports that are generated after postroute optimization, you can reduce runtime by setting the `routeopt_skip_report_qor` variable to `true`. Setting this variable to `true` prevents generation of QoR reports after postroute optimization; this variable does not affect the generation of QoR reports before postroute optimization. To get more information about the optimization process, you can enable verbose reporting during the hold fixing, DRC fixing, and crosstalk reduction stages by setting the `routeopt_verbose` variable. This variable uses bitwise operation to enable various reporting capabilities. For details about setting this variable, see [SolvNet article 032174](#).

Note:

Although the `route_opt` command performs timing-driven routing by default, the Zroute basic routing commands do not. You must explicitly enable timing-driven routing for the basic routing commands by setting the appropriate `timing_driven` Zroute routing option.

If you want to analyze the routing results before performing postroute optimization, first run the `route_opt` command without postroute optimization (`-initial_route_only` option), and then run the `route_opt` command with postroute optimization only (`-skip_initial_routing` option).

```
icc_shell> route_opt -initial_route_only
# analyze routing results
icc_shell> route_opt -skip_initial_route
```

**Table 8-9** describes the `route_opt` command options.

*Table 8-9 route\_opt Command Options*

| Command option                                                                                    | Description                                                                                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-effort low   medium   high</code><br>("Effort options in the GUI")                         | Specifies the optimization effort level. Higher effort levels provide more aggressive optimization at a runtime cost. The default is <code>medium</code> .                                                                                                                                          |
| <code>-stage global   track   detail</code><br>("Run optimization after" options in the GUI)      | Specifies the last routing stage performed by the <code>route_opt</code> command before performing optimization. If you specify <code>global</code> or <code>detail</code> , only the specified stage is run. If you specify <code>track</code> , both global routing and track assignment are run. |
| <code>-xtalk_reduction</code><br>("Crosstalk reduction and SI optimization" option in the GUI)    | By default, the <code>route_opt</code> command performs optimization after running global routing, track assignment, and detail routing.                                                                                                                                                            |
| <code>-only_xtalk_reduction</code><br>("Crosstalk reduction optimization only" option in the GUI) | Performs crosstalk reduction optimization in addition to signal integrity optimization.<br>By default, the <code>route_opt</code> command does not perform crosstalk reduction or signal integrity optimization.                                                                                    |
| <code>-power</code><br>("Perform power optimization" check box in the GUI)                        | Performs only crosstalk reduction optimization (not signal integrity optimization).<br>By default, the <code>route_opt</code> command does not perform crosstalk reduction or signal integrity optimization.                                                                                        |
| <code>-skip_initial_route</code><br>("Skip initial routing" check box in the GUI)                 | Performs leakage-power optimization and recovery.<br>When you use this option to perform leakage-power optimization, IC Compiler uses low-effort leakage cell selection.<br>By default, the <code>route_opt</code> command does not perform leakage-power optimization.                             |
| <code>-initial_route_only</code><br>("Initial routing only" check box in the GUI)                 | Performs postroute optimization without routing.<br>Performs only initial routing without postroute optimization. This option works in conjunction with the <code>-stage</code> option.<br>A maximum of 10 detail routing iterations are run.                                                       |
| <code>-size_only</code><br>("Sizing only optimization" check box in the GUI)                      | Resolves setup time violations by sizing only.                                                                                                                                                                                                                                                      |

*Table 8-9 route\_opt Command Options (Continued)*

| Command option                                                                                          | Description                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -optimize_wire_via<br>("Optimize wire and via routing" check box in the GUI)                            | This option is not supported by Zroute. Wire and via optimization is done concurrently with detail routing.                                                                                                                                                                                                                        |
| -area_recovery<br>("Recover area for cells that are not on critical timing paths" check box in the GUI) | Recovers area for cells not on critical paths.                                                                                                                                                                                                                                                                                     |
| -wire_size<br>("Use wire sizing to fix setup time violations" check box in the GUI)                     | Determines whether wire sizing is used to fix setup time violations.                                                                                                                                                                                                                                                               |
| -incremental<br>("Incremental mode" check box in the GUI)                                               | Performs incremental postroute optimization.                                                                                                                                                                                                                                                                                       |
| -incremental -only_wire_size<br>("Timing optimization only with wire size" option in the GUI)           | Performs only wire sizing to resolve setup time violations during incremental mode.                                                                                                                                                                                                                                                |
| -incremental -only_hold_time<br>("Hold timing optimization only" option in the GUI)                     | Resolves only hold time violations during incremental mode. Use the <code>set_fix_hold</code> command to enable hold time fixing.                                                                                                                                                                                                  |
| -incremental -only_area_recovery<br>("Area recovery only" option in the GUI)                            | Performs only area recovery during incremental mode.                                                                                                                                                                                                                                                                               |
| -incremental -only_design_rule<br>("Fix design rules only" option in the GUI)                           | Performs only logical design rule fixing during incremental mode.<br><br>By default, timing has a higher cost priority than design rule constraints. When you use this option, you can give a higher cost priority to design rule constraints by setting the <code>routeopt_drc_over_timing</code> variable to <code>true</code> . |

*Table 8-9 route\_opt Command Options (Continued)*

| <b>Command option</b>                                                             | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -incremental<br>-only_power_recovery<br>("Power recovery only" option in the GUI) | Performs only power recovery during incremental mode.<br>When you use this option, the <code>-effort</code> option controls the cell-selection effort level for leakage-power optimization.<br>By default, leakage power has a lower cost priority than setup, hold, and design rule constraints. You can change these cost priorities by setting the following variables to true: <code>routeopt_leakage_over_setup</code> , <code>routeopt_leakage_over_hold</code> , and <code>routeopt_leakage_over_drc</code> . |
| -num_cpus <i>number</i><br>("Number of CPUs" box in the GUI)                      | This option is not supported by Zroute.<br>Zroute uses multithreading rather than distributed routing.<br>For information about enabling multithreading, see " <a href="#">Enabling Multicore Processing</a> " on page 8-7.                                                                                                                                                                                                                                                                                          |

### Saving the Intermediate Results

By default, when you run the `route_opt` command with Zroute, the tool automatically saves the design after two iterations (iteration 1) to allow you to view the DRC violations before postroute optimization. The saved design is called `cell_name_INIT_RT_itr1`. You can select an iteration other than iteration 1 by using the `-save_after_iterations` option. You can use a string other than the cell name as the prefix by using the `-save_cell_prefix` option. These options are supported only when using the `route_opt` command with Zroute.

**Note:**

If you run the `route_opt -initial_route_only` command, the tool does not automatically save the design after two iterations. However, you can force the tool to save the design by using the `-save_after_iterations` option.

In addition, Zroute supports the standard `route_opt` checkpointing. To enable `route_opt` checkpointing, set the `routeopt_checkpoint` variable to true.

If you also use the `-save_after_iterations` and `-save_cell_prefix` options, they are honored only for the first version of the design saved during checkpointing. They are not honored for subsequent checkpoint saves.

## Performing Focal Optimization

You can use the `focal_opt` command to perform aggressive, topology-based optimization on your postroute design that is focused on fixing either the setup, hold, or logical DRC violations that remain after the postroute optimization performed by the `route_opt` command. In addition, you can also use the `focal_opt` command to perform crosstalk reduction or final stage leakage recovery.

For each run, you must specify the focus of the optimization, setup, hold, logical design rule constraints, crosstalk reduction, or final stage leakage recovery, and the paths to work on:

- To fix all setup violations, use the `-setup_endpoints all` option.
- To fix specific setup violations, use the `-setup_endpoints endpoint_file` option. By default, IC Compiler uses the slack specified in the endpoint file during focal optimization. To have IC Compiler use computed slack instead, set the `focalopt_endpoint_margin` variable to `false`. For information about the format of the endpoint file, see “[Endpoint File Format](#)” on page 8-84.”
- To fix all hold violations, use the `-hold_endpoints all` option.
- To fix specific hold violations, use the `-hold_endpoints endpoint_file` option. By default, IC Compiler uses the slack specified in the endpoint file during focal optimization. To have IC Compiler use computed slack instead, set the `focalopt_endpoint_margin` variable to `false`. For information about the format of the endpoint file, see “[Endpoint File Format](#)” on page 8-84.”
- To fix all nets with logical DRC violations, use the `-drc_nets all` option.
- To fix DRC violations on specific nets, use the `-drc_nets net_file` option. For information about the format of the net file, see “[Net File Format](#)” on page 8-85.
- To fix all endpoints with logical DRC violations, use the `-drc_pins all` option.
- To fix DRC violations on specific endpoints, use the `-drc_pins endpoint_file` option. For information about the format of the endpoint file, see “[Endpoint File Format](#)” on page 8-84.
- To perform crosstalk reduction on specific nets, use the `-xtalk_reduction net_file` option. For information about the format of the net file, see “[Net File Format](#)” on page 8-85.
- To perform final stage leakage recovery, use the `-power` option. For more information about final stage leakage recovery, see “[Performing Final Stage Leakage-Power Recovery](#)” on page 5-10.

When you perform final stage leakage recovery, you must enable exactly one leakage scenario. For information about leakage scenarios, see “[Specifying the Scenarios for Leakage-Power Optimization](#)” on page 5-7.

By default, the `focal_opt` command uses medium effort to fix the remaining violations. When using medium effort, the `focal_opt` command explores more solution spaces than the `route_opt` command while fixing the violations, including solutions that exceed the density limit. If medium effort does not fix the remaining violations, you can use high effort (`-effort high` option), which explores even more solution spaces and uses runtime-expensive accurate signal integrity reestimation. Due to the additional runtime required for high effort, you should use this only when you have a few remaining violations to close. Note that the `-effort` option does not apply to final stage leakage recovery.

If your design has remaining violations, and you want to prioritize the fixing of those violations above all other cost priorities, you can use the `-prioritize` option. When you use the `-prioritize` option, the `focal_opt` command might violate other constraints to fix the prioritized violations. Note that the `-prioritize` option does not apply to crosstalk reduction or final stage leakage recovery.

If your design is very sensitive to postroute optimization changes, you can limit the optimizations to sizing-only optimizations by specifying the mode with the `-size_only_mode` option. When you specify this option you must select one of the following sizing modes: density-based sizing (`density`), in-place sizing (`in_place`), or footprint-preservation sizing (`footprint`). Note that the `-size_only_mode` option does not apply to crosstalk reduction or final stage leakage recovery.

If you find that the `focal_opt` command leaves unfixed violations, you can enable verbose reporting during optimization by setting the `routeopt_verbose` variable. This variable uses bitwise operation to enable various reporting capabilities. For details about setting this variable, see [SolvNet article 032174](#).

## Endpoint File Format

To fix setup, hold, or logical DRC violations on specific endpoints, you must specify the endpoints in an endpoint file.

The following formats are supported for specifying an endpoint:

- Endpoint only

I\_STACK\_TOP/I3\_STACK\_MEM/Stack\_Mem\_reg\_2\_\_1\_/D

- Endpoint with a slack value

I\_STACK\_TOP/I3\_STACK\_MEM/Stack\_Mem\_reg\_2\_\_1\_/D 0.58 0.44 r -0.14

Note:

When you use an endpoint file with the `-drc_pins` option, IC Compiler uses only the pin information and does not use the slack information, even if that information is provided.

The best way to generate these lines is by editing the file generated by the `report_constraint` command.

## Net File Format

To fix logical DRC violations on specific nets, you must specify the nets in a net file.

The following formats are supported for specifying a net:

- Net name only

I\_STACK\_TOP/n342

- Net name with a violation

|                  |      |      |       |            |
|------------------|------|------|-------|------------|
| I_STACK_TOP/n342 | 0.70 | 0.89 | -0.19 | (VIOLATED) |
|------------------|------|------|-------|------------|

Note:

When you use a net file with the `-drc_nets` option, IC Compiler uses only the net information and does not use the slack information, even if it is provided.

The best way to generate these lines is by editing the file generated by the `report_constraint` command.

---

## Performing ECO Routing

Whenever you modify the nets in your design, you need to run engineering change order (ECO) routing to reconnect the routing.

To run ECO routing, use the `route_zrt_eco` command (or choose Route > ECO Route in the GUI). Zroute can reserve space for redundant vias during ECO routing. For information about this capability, see “[Concurrent Soft-Rule-Based Redundant Via Insertion](#)” on [page 9-30](#).

By default, the `route_zrt_eco` command connects open nets and then fixes DRC violations in the entire design. To fix DRC violations only in the neighborhood of the open nets, set the `-open_net_driven` option to `true`.

The `route_zrt_eco` command routes the newly added wires by running them sequentially through global routing, track assignment, and detail routing. By default, the `route_zrt_eco` command ignores existing global routes. To perform incremental global routing, use the `-reuse_existing_global_route true` option. If a net has an ECO change, the global router does not reroute detail routed wires to relieve congestion; instead, it reuses the dangling wires of the same net. To disable the reuse of dangling wires, set the `-utilize_dangling_wires` option to `false`.

By default, `route_zrt_eco` reroutes any wires, whether modified or not, to fix DRC violations. You can change the scope of rerouting performed by the ECO router by setting the `-reroute` option:

- To limit rerouting to modified wires, use `-reroute modified_nets_only`.
- To first attempt to fix DRC violations by rerouting modified nets and then reroute other nets if necessary, use `-reroute modified_nets_first_then_others`.

A common use for this option is to route the clock nets affected by an ECO in a fully routed design.

By default, the `route_zrt_eco` command does not fix soft DRC violations, such as bridge rule violations. To enable the fixing of soft DRC violations after the final ECO routing iteration, use the `set_route_zrt_common_options` command to set the `post_eco_route_fix_soft_violations` common route option to `true`.

```
icc_shell> set_route_zrt_common_options \
-post_eco_route_fix_soft_violations true
```

Zroute generates a DRC violations summary at the end of each detail routing iteration. Before reporting the final DRC violations, Zroute merges redundant violations. For more information about the DRC violations reported by Zroute, see “[Performing Design Rule Checking Using IC Compiler](#)” on page 8-95.

Zroute also reports the nets changed during ECO routing. By default, it reports the first 100 changed nets. You can use the `-max_reported_nets` option to set a different limit on the reported nets. To report all changed nets, set the `-max_reported_nets` option to `-1`.

[Table 8-10](#) describes the `route_zrt_eco` options.

*Table 8-10 route\_zrt\_eco Command Options*

| Command option                                                                     | Description                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-nets nets</code><br>("Nets" section in the GUI)                             | The nets on which to run ECO routing. The <code>route_zrt_eco</code> command connects the open nets in this list and then fixes design rule violations in their neighborhood.<br><br>By default, the <code>route_zrt_eco</code> command connects all open nets and then fixes DRC violations in the entire design. |
| <code>-open_net_driven true   false</code><br>("Open net mode" options in the GUI) | Controls whether the ECO router fixes DRC violations for the whole design or only in the neighborhood of open nets.<br><br>By default ( <code>false</code> ), ECO routing fixes DRC violations for the whole design.                                                                                               |

*Table 8-10 route\_zrt\_eco Command Options (Continued)*

| Command option                                                                                                  | Description                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| -max_detail_route_iterations int<br>("Maximum detail route iterations" box in the GUI)                          | The maximum number of detail routing iterations.<br>The default is the 40.                                                  |
| -reroute modified_nets_only   modified_nets_first_then_others   any_nets<br>("Reroute nets" options in the GUI) | Controls which nets can be rerouted to fix DRC violations.<br>The default is any_nets.                                      |
| -utilize_dangling_wires true   false<br>("Utilize dangling wires" check box in the GUI)                         | Controls whether the router tries to reuse existing dangling routes to fix open nets.<br>The default is true.               |
| -reuse_existing_global_route true   false<br>("Reuse existing global route" check box in the GUI)               | Performs incremental global routing.<br>The default is false.                                                               |
| -max_reported_nets<br>("Maximum number of modified nets to be reported" box in the GUI)                         | Specifies the number of changed nets reported during ECO routing.<br>By default, Zroute reports the first 100 changed nets. |

## Cleaning Up Routed Nets

After routing is complete, you can clean up the routed nets by running the `remove_zrt_redundant_shapes` command (or by choosing Route > Remove Redundant Shapes in the GUI).

```
icc_shell> remove_zrt_redundant_shapes
```

By default, this command runs the `verify_zrt_route` command and then removes dangling and floating net shapes from all nets in the design, based on the results. When removing dangling net shapes, the tool does not change topologies or connections and does not touch terminals. In addition, no changes are made to open nets or nets with DRC violations.

You can restrict the removal to

- Specific nets by using the `-nets nets` option
- Specific layers by using the `-layers layers` option
- Fixed or unfixed route types by using the `-route_types fixed_route | nonfixed_route` option

If you have already performed design rule checking, you can skip this step and use the DRC information stored in the CEL view of the design by using the `-initial_drc_from_input false` option.

By default, the `remove_zrt_redundant_shapes` does not report the changes it makes. To report the changes, use the `-report_changed_nets` option.

You can disable the removal of dangling net shapes by using the `-remove_dangling_shapes false` option. You can disable the removal of floating net shapes by using the `-remove_floating_shapes false` option.

In addition to removing dangling and floating net shapes, this command can also remove loops in the specified nets. To remove loops, use the `-remove_loop_shapes true` option.

For example, to remove dangling net shapes, floating net shapes, and loops from the net named `my_net`, enter

```
icc_shell> remove_zrt_redundant_shapes -nets my_net \
           -remove_loop_shapes true
```

After cleaning up the routed nets, you should reverify the routing, as described in “[Performing Design Rule Checking Using IC Compiler](#)” on page 8-95.

---

## Saving the Routing Information

You can save the routing information by using the `write_route` command. This command generates a script file that contains the Tcl commands to generate the current routing. You must specify the name of the generated file by using the `-output` option.

```
icc_shell> write_route -output my_route.tcl
```

By default, the `write_route` command includes the following information in the generated Tcl file:

- The routes for all nets in the design

You can output the routes only for specific nets by using the `-nets` option or for specific wires and vias by using the `-objects` option.

- The route guides

If you do not want to save the route guide information, use the `-skip_route_guide` option.

By default, metal fill information is not written to the generated file. To include metal fill information, use the `-output_metal_fill` option.

---

## Analyzing the Routing Results

You can analyze the routing results by reporting on the cell placement and routing statistics. The following sections describe how to perform these tasks:

- [Reporting Cell Placement and Routing Statistics](#)
- [Analyzing Congestion](#)
- [Performing Design Rule Checking Using IC Compiler](#)
- [Performing Signoff Design Rule Checking](#)
- [Analyzing DRC Violations](#)

---

## Reporting Cell Placement and Routing Statistics

You can report on cell placement and routing statistics to help you determine whether to perform further optimizations to improve timing. For example, if the statistics show that an area has high congestion, an additional optimization might not have room to add or size up standard cells.

To view the place and route summary report, run the `report_design_physical -verbose` command.

---

## Analyzing Congestion

To help you analyze the congestion in your design, IC Compiler can generate both an ASCII congestion report, as shown in [Example 8-5](#) and a visual congestion map, as shown in [Figure 8-8 on page 8-93](#). You can generate the congestion report and congestion map for each routing stage: global routing, track assignment, and detail routing. The more routing stages that have been completed, the more accurate the congestion information is; however, the harder it is to fix the congestion issues.

### Generating a Congestion Report

To generate a congestion report, run the `report_congestion` command.

```
icc_shell> report_congestion
```

By default, this command generates a global route congestion report by running global routing with minimum effort and reports a summary of the overflow information for the entire design, as shown in [Example 8-5](#).

#### *Example 8-5 Default Global Route Congestion Report*

```
Information: Reporting global route congestion data from Milkyway...
```

```
Both Dirs: Overflow = 39 Max = 8 (1 GRCs) GRCs = 14 (0.26%)
H routing: Overflow = 6 Max = 2 (2 GRCs) GRCs = 4 (0.07%)
V routing: Overflow = 33 Max = 8 (1 GRCs) GRCs = 10 (0.18%)
```

In the congestion report, the **Overflow** value is the total number of wires in the design that do not have a corresponding track available. The **Max** value corresponds to the highest number of overutilized wires in a single global routing cell. The **GRCs** value is the total number of overcongested global routing cells in the design.

The generated congestion information is stored in the Milkyway design database; however, the global routing results are not. By default, the congestion data is stored for each layer, which enables the tool to generate a layer-based congestion map; however, saving the layer-based information increases the size of the Milkyway design database. If you do not need layer-based congestion maps, you can disable this capability and save only aggregate congestion information by using the `set_route_zrt_global_options` command to set the `layer_based_congestion_map` global route option to `false`.

To display the congestion report in the design database instead of regenerating a congestion report, use the `-no_reroute` option when you run the `report_congestion` command.

You can report additional information in the congestion report by using the options shown in [Table 8-11](#).

*Table 8-11 Generating Additional Congestion Information*

| Option              | Description                                                                                                                                                              |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -grc_based          | Provides detailed information about the 10 worst global routing cells for each category: total, horizontal, and vertical.                                                |
| -grc_number         | Provides detailed information about the specified number of worst global routing cells for each category.                                                                |
| -overflow_threshold | Provides detailed information about the global routing cells that exceed the specified overflow threshold, up to a maximum of 10 global routing cells for each category. |
| -by_layer           | Generates a congestion report for each routing layer. The type of report, summary or GRC-based, generated for each layer depends on the other options that you specify.  |

[Example 8-6](#) shows a GRC-based congestion report. This same format is used when you specify the -grc\_based, -grc\_number, or -overflow\_threshold options; the only difference is the number of global routing cells reported in each category.

#### *Example 8-6 GRC-Based Global Route Congestion Report*

Information: Reporting global route congestion data from Milkyway...

```
There are 2704 GRCs (Global Route Cell) in this design
*****
***** GRC based congestion report *****
*****
14 GRCs with overflow: 4 with H overflow and 10 with V overflow

++++++ Top 10 congested GRCs +++++++

GRC {624345 676005 650175 701835}:
  H routing capacity/demand = 81/81 (occupy rate = 1.00),
  V routing capacity/demand = 54/62 (occupy rate = 1.15) with overflow 8
GRC {624345 701835 650175 727665}:
  H routing capacity/demand = 74/74 (occupy rate = 1.00),
  V routing capacity/demand = 54/59 (occupy rate = 1.09) with overflow 5
...
GRC {676005 391875 701835 417705}:
  H routing capacity/demand = 12/14 (occupy rate = 1.17),
  V routing capacity/demand = 3/3 (occupy rate = 1.00) with overflow 2
```

```
++++++ Top 10 horizontally congested GRCs ++++++
GRC {650175 391875 676005 417705}:
  H routing capacity/demand = 12/14 (occupy rate = 1.17) with overflow 2
GRC {676005 391875 701835 417705}:
  H routing capacity/demand = 12/14 (occupy rate = 1.17) with overflow 2
...
GRC {727665 882645 753495 908475}:
  H routing capacity/demand = 91/91 (occupy rate = 1.00)
```

```
++++++ Top 10 vertically congested GRCs ++++++
GRC {624345 676005 650175 701835}:
  V routing capacity/demand = 54/62 (occupy rate = 1.15) with overflow 8
GRC {624345 701835 650175 727665}:
  V routing capacity/demand = 54/59 (occupy rate = 1.09) with overflow 5
```

You can generate a congestion report for a portion of the design by using the `-coordinates` option to specify a rectangular area or the `-polygon` option to specify a rectilinear area.

By default, the `report_congestion` command uses minimum effort when running global routing. You can increase the global routing effort by using the `-effort` option to specify a higher effort level of `low`, `medium`, or `high`.

You can also generate congestion reports based on the track assignment and detail routing in the design by setting the `-routing_stage` option to `track` or `detail`, respectively. When you generate these reports, the tool does not run track assignment or detail routing; it uses the existing information in the design. If the track assignment or detail route information does not already exist in the design database, IC Compiler issues an error message and does not generate a congestion report.

## Generating a Congestion Map

To display the global route congestion map, choose Route > Global Route Congestion Map in the GUI. If the design database contains global route congestion information, IC Compiler generates the congestion map based on this information; otherwise, you must click Reload to generate the congestion map. When you click Reload, IC Compiler opens a dialog box that contains the following command:

```
report_congestion -grc_based -by_layer -routing_stage global
```

When you click OK in this dialog box, IC Compiler generates a new congestion map. If you want to use different options for the `report_congestion` command, you can modify this command before clicking OK.

[Figure 8-8](#) shows an example of a congestion map.

*Figure 8-8 Global Route Congestion Map*



The congestion map shows the borders between global routing cells highlighted with different colors that represent different levels of overflow. If you select multiple layers, the overflow values shown in the congestion map represent the total overflow for all selected layers. Underflow is not considered; if a layer has underflow, it contributes zero overflow to the total overflow calculation. If you select a single layer, the exact overflow or underflow information is displayed.

By default, all metal layers are selected in the congestion map, except those specified as ignored layers with the `set_ignored_layers` command. To display the congestion map for a subset of layers, select (or deselect) the layers on the Map Mode panel. For example, if the global routing report shows that the maximum overflow occurs on metal layer 2, you can deselect all layers, except for metal 2, to display only the metal 2 congestion.

The Map Mode panel also displays a histogram showing the number of global routing cells in different ranges (bins) of overflow values for the selected layers. You can select which bins to display in the congestion map by selecting or deselecting them on the Map Mode panel.

If the design shows congested areas, zoom into the congested area to see the overflow number on the global routing cell. For example, in [Figure 8-9](#), the red highlight on the edge of the global routing cell shows 18/9. This means there are 9 wire tracks available, but 18 tracks are needed.

*Figure 8-9 Global Route Overflow on Global Routing Cell*



You can also generate congestion maps based on the track assignment and detail routing in your design. To generate a congestion map based on track assignment, choose Route > Track Assign Congestion Map in the GUI. To generate a congestion map based on detail routing, choose Route > Detail Route Congestion Map in the GUI. When you generate these congestion maps, the tool does not run track assignment or detail routing; it uses the existing information in the design. If the track assignment or detail route information does not already exist in the design database, IC Compiler issues an error message and does not generate a congestion map.

---

## Performing Design Rule Checking Using IC Compiler

To use the IC Compiler DRC engine to check the routing design rules defined in the Milkyway technology file, run the `verify_zrt_route` command (or choose Route > Verify Route in the GUI).

**Note:**

Do not run the `verify_route` command on a design routed with Zroute. The `verify_route` command is based on the classic router, which uses center lines to determine connectivity. Because Zroute does not use center lines to determine connectivity, you will see many DRC violations due to the difference in connectivity models.

By default, the `verify_zrt_route` command checks for routing DRC violations, unconnected nets, antenna rule violations, and voltage area violations on all nets in the design, except those marked as user nets or frozen nets.

To disable checks for routing DRC violations, set the `-drc` option to `false`. To disable checks for unconnected nets, set the `-open_net` option to `false`. To disable checks for antenna rule violations, set the `-antenna` option to `false`. To disable checks for voltage area violations, set the `-voltage_area` option to `false`.

To verify the routing only for specific nets, specify the nets by using the `-nets` option. To check user routes, set the `-check_from_user_shapes` option to `true`. To check frozen routes, set the `-check_from_frozen_shapes` option to `true`.

To save time, you can restrict the routing verification to specific regions of the design by using the `-coordinates` option to specify the lower-left and upper-right coordinates for each rectangular region. When you perform area-based DRC, the `verify_zrt_route` command checks only for DRC violations and voltage area violations. It does not check for unconnected nets, antenna violations, or tie-to-rail violations, as these are net-based violations.

**Note:**

The `-coordinates` option and the `-nets` option are mutually exclusive; you can use only one of these options.

The `verify_zrt_route` command reports the following DRC violations:

- Spacing violations
  - Different-net spacing
  - Different-net variable rule spacing
  - Different-net via-cut spacing
  - Different-net fat extension spacing

- Dog bone spacing
- End-of-line spacing
- Enclosed via spacing
- Same-net spacing
- Same-net via-cut spacing
- Same-net fat extension spacing
- Special notch spacing
- U-shape spacing
- Via-cut to metal spacing
- Soft spacing
- Area violations
  - Less than minimum area
  - Less than minimum enclosed area
  - Fat wire via keepout area
  - Jog wire via keepout area
- Length and width violations
  - Less than minimum width
  - Less than minimum length
  - Less than minimum edge length
  - Protrusion length
- Contact violations
  - Needs fat contact
  - Needs poly contact
  - Needs fat contact on extension
  - Over maximum stack level

- Enclosure violations
  - End-of-line wire via enclosure
  - Jog wire via enclosure
  - T-shape wire via enclosure
- Others
  - Open nets, except when doing area-based DRC

By default, the `verify_zrt_route` command reports a maximum of 200 open nets. To report all open nets, use the `-report_all_open_nets true` option (or select “Report all open nets” in the GUI).

- Antenna violations, except when doing area-based DRC
- Nets crossing the top-cell boundary
- Frozen layers
- Minimum layer
- Maximum layer
- Voltage area violations

Note:

These violations are also reported after each detail route iteration.

After you run the `verify_zrt_route` command, you can use the DRC query commands to get more information about the violations or use the error browser to examine the violations in the GUI. For information about analyzing the DRC violations, see [“Analyzing DRC Violations” on page 8-108](#).

After running `verify_zrt_route`, you can use the following command to run incremental detail routing that uses the `verify_zrt_route` results as input:

```
icc_shell> route_zrt_detail -incremental true \
    -initial_drc_from_input true
```

Note:

Incremental detail routing does not fix open nets. To fix open nets, you must run ECO routing. For information about ECO routing, see the next section, [“Performing ECO Routing.”](#)

---

## Performing Signoff Design Rule Checking

Signoff design rule checking runs the IC Validator or Hercules tool within IC Compiler to check the routing design rules defined in the foundry runset. To perform signoff design rule checking, run the `signoff_drc` command (or choose Verification > Signoff DRC in the GUI). If you use IC Validator to perform signoff design rule checking, you can use the `signoff_autofix_drc` command to automatically fix the DRC violations detected by the `signoff_drc` command. For more information, see “[Automatically Fixing Signoff DRC Violations](#)” on page 8-105.

Note:

An IC Validator or Hercules license is required to run the `signoff_drc` command.

To use `signoff_drc` to perform signoff design rule checking,

- Set up the validation tool environment.
- Set up the physical signoff options.
- Run the `signoff_drc` command (or choose Verification > Signoff DRC in the GUI).

The following sections describe these tasks.

## Setting Up the Validation Tool Environment

You can use either IC Validator or Hercules to perform routing design rule checking with the `signoff_drc` command.

### Setting Up the IC Validator Environment

To use the IC Validator tool when running the `signoff_drc` command, you must have an IC Validator license, and you must specify the location of the IC Validator executable by setting the `ICV_HOME_DIR` environment variable. You can set this variable in your `.cshrc` file. To specify the location of the IC Validator executable, use commands similar to those shown in the following example:

```
setenv ICV_HOME_DIR /root_dir/icv
set path = ($path $ICV_HOME_DIR/bin/AMD.64)
```

You must ensure that the version of the IC Validator executable that you specify is compatible with the version of IC Compiler that you are using.

For more information about IC Validator, see the IC Validator documentation, which is available on SolvNet.

## Setting Up the Hercules Environment

To use the Hercules tool when running the `signoff_drc` command, you must have a Hercules license, and you must specify the location of the Hercules executable by setting the `HERCULES_HOME_DIR` environment variable. You can set this variable in your `.cshrc` file. For example,

```
setenv HERCULES_HOME_DIR /root_dir/hercules
set path = ($path $HERCULES_HOME_DIR/bin/AMD.64)
```

You must ensure that the version of the Hercules executable that you specify is compatible with the version of IC Compiler that you are using.

For more information about Hercules, see the Hercules documentation, which is available on SolvNet.

## Setting Up The Physical Signoff Options

To set up the physical signoff options, use the `set_physical_signoff_options` command (or choose Verification > Set Physical Signoff Options in the GUI).

[Table 8-12](#) shows the physical signoff options that apply to the `signoff_drc` command.

*Table 8-12 Physical Signoff Options for signoff\_drc*

| Command option                                                                      | Description                                                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-exec_cmd icv   hercules</code><br>("Executable name" box in the GUI)         | Specifies the validation tool to use for design rule checking (optional).<br><br>If you do not specify this option, the <code>signoff_drc</code> command uses the value stored in the Milkyway design library. If there is no value stored in the Milkyway design library, an error occurs. |
| <code>-drc_runset file_name</code><br>(DRC box in the GUI "Foundry runset" section) | Specifies the foundry runset to use for design rule checking (required).                                                                                                                                                                                                                    |
| <code>-mapfile file_name</code><br>("Layer mapping file" box in the GUI)            | Specifies the layer mapping file (optional).<br><br>For more information, see " <a href="#">Defining the Layer Mapping Between Milkyway and the Foundry Runset</a> ".                                                                                                                       |

To report the current settings for the physical signoff options, use the `report_physical_signoff_options` command.

## Defining the Layer Mapping Between Milkyway and the Foundry Runset

In general, the Milkyway technology file and the foundry runset file used by IC Validator or Hercules use the same layer numbers. If they do not, you must supply a layer mapping file to map the Milkyway layers to the layers used in the runset file.

The `signoff_drc` command accepts a layer-mapping file in IC Validator, Hercules, or Milkyway format.

The syntax of the mapping information in an IC Validator or Hercules mapping file is

*Milkyway\_layer\_list > validation\_tool\_layer\_list*

The rules for specifying the layer lists are

- Each layer in a layer list must be separated by a space. Or, if specified in a range, the range must consist of a starting layer and an ending layer joined by a dash (-).
- Generally, parentheses should surround the layer list. However, you can omit parentheses if you specify only one layer.

You can include comments in a layer mapping file by preceding the comment with a pound sign (#). All text that follows a pound sign on a given line is a comment.

The syntax of the mapping information in a Milkyway mapping file is:

*Milkyway\_layer validation\_tool\_layer*

## Performing Distributed Design Rule Checking

By default, the `signoff_drc` command uses a single process to perform design rule checking. To reduce the turnaround time used for design rule checking, you can use distributed processing. To enable distributed processing, you must define the distributed processing configuration by using the `set_host_options` command.

If you have defined more than one distributed processing configuration with the `set_host_options` command, the `signoff_drc` command selects the IC Validator processing method in the following order of priority:

1. Job submission through a user-defined distributed processing script

To enable job submission using your own script with the `set_host_options` command, use the `-submit_command` option to specify the location of your job submission script. For example, to specify a configuration named custom4 that enables a maximum of four processes using your job submission script, enter the following command:

```
icc_shell> set_host_options -name custom4 -num_processes 4 \
    -submit_command /usr/local/bin/my_submit_command
```

## 2. Job submission through the Load Sharing Facility (LSF) or the Sun Grid Engine (SGE)

To enable LSF or SGE job submission with the `set_host_options` command, use the `-pool` option to specify the mode and the `-num_processes` option to specify the maximum number of processes.

For example, to specify a configuration named lsf4 that enables a maximum of four processes using LSF, enter the following command:

```
icc_shell> set_host_options -name lsf4 -pool lsf -num_processes 4
```

To specify a configuration named grd4 that enables a maximum of four processes using SGE, enter the following command:

```
icc_shell> set_host_options -name grd4 -pool grd -num_processes 4
```

## 3. Distributed processing on the specified hosts

To enable distributed processing with the `set_host_options` command, specify the hosts to use and use the `-num_processes` option to specify the maximum number of processes on each host. For example, to specify a configuration named dp4 that enables a maximum of four processes, with a maximum of two processes each on machineA and machineB, enter the following command:

```
icc_shell> set_host_options -name dp4 -num_processes 2 \
{machineA machineB}
```

## 4. Multithreading

To enable multithreading on the current machine with the `set_host_options` command, use the `-max_cores` option to specify the number of threads. For example, to specify a configuration named mt4 that enables a maximum of four threads on the current machine, enter the following command:

```
icc_shell> set_host_options -name mt4 -max_cores 4
```

To ensure that you are using the intended distributed processing configuration, you should remove the current configurations by using the `remove_host_options` command before defining the distributed processing configuration for the `signoff_drc` command. To report the current distributed processing configurations, use the `report_host_options` command.

For more information about the `set_host_options` command, see “[Enabling Multicore Processing](#)” on page 2-43.

## Running the signoff\_drc Command

By default, the `signoff_drc` command uses the FRAM view to check all cell types (standard cells, macro cells, and I/O pad cells) on all routing layers of the entire chip for all rules specified in the foundry runset. To use the CEL view instead of the FRAM view, use the `-read_cell_view` option or select the “CEL view” option in the GUI. Using the CEL view can expose problems that are masked by the FRAM view abstraction.

### Note:

The `signoff_drc` command uses the on-disk design information, not the design information in memory. You must save the current state of the design before running the `signoff_drc` command.

You can specify additional options for the Hercules or IC Validator command line by using the `-user_defined_options` option when you run the `signoff_drc` command. The string that you specify in this option is added to the command line used to invoke design rule checking in Hercules or IC Validator. IC Compiler does not perform any checking on the specified string.

By default, IC Validator checks for both top-level and child-level errors and reports a maximum of 1000 DRC errors per rule. To ignore child-level errors, use the `-ignore_child_cell_errors` option. If you are using IC Validator version D-2009.12-SP1 or later, you can override the maximum error count by using the `-max_errors_per_rule` option when you run the `signoff_drc` command.

You can restrict the design rule checking to specific areas of the chip, to specific design rules, to specific layers, and to specific cell types.

- To restrict the checking to specific areas of the chip,
  - If you are using the command line, use the `-bounding_boxes` option to specify the coordinates of each area to check. To exclude checking in specific areas, use the `-excluded_bounding_boxes` option. For either option, you can specify multiple areas by specifying the coordinates for each area.
  - If you are using the GUI, specify the coordinates for each area to check in the “Included bounding boxes” list and specify the coordinates for each area to exclude from checking in the “Excluded bounding boxes” list. To specify an area, either draw the bounding box or enter the x- and y-coordinates of the box. For each area, you can also enable or disable snapping. If snapping is enabled, you can specify that the bounding box should snap to the minimum grid (the default), placement site, routing track, middle routing track, or user grid.

- To restrict the checking to specific rules,
  - To check only the specified rules, specify the rules in the `-select_rule` option (or in the Pattern box in the “To use” section of the Rules area in the GUI).
  - To exclude checks for specific rule, specify the rules in the `-unselect_rule` option (or in the Pattern box in the Excluded section of the Rules area in the GUI).

In either case, you specify the rules by specifying a matching pattern for the rule names. The rule names are specified in the COMMENT section in the runset file. You can use these options together to customize the set of rules checked by the `signoff_drc` command.

For example, to restrict the `signoff_drc` command to route validation, select the metal layer rules and exclude the metal density rules.

- To restrict the checking to specific layers,
  - Specify the layers in the `-select_layers` option (or in the list associated with the “Selected layers” option in the “Check DRC violations on” area in the GUI).
- To restrict the checking to specific cell types,
  - Specify the cell types to exclude in the `-excluded_cell_types` option (or select the associated check box in the “Excluded cell types” area in the GUI).

After you complete design rule checking on the routing layers, you can perform a quick design rule check on the Milkyway database by rerunning the `signoff_drc` command with the `-check_all_layers` option. If you are using the GUI, set this option by selecting the “All runset layers (routing and device layers)” option in the “Check DRC violations on” area. When you use this option, the design information comes from the CEL view and the validation tool checks all layers, including the nonrouting layers.

The `signoff_drc` command creates a Milkyway error view that you can use to report or display the DRC violations. In all Hercules versions and IC Validator versions before D-2009.12, errors that occur inside the child cells are expanded to the top level and the error cell contains errors as if the tool is run in flat mode. Starting with version D-2009.12, the IC Validator error output is enhanced to show child-level errors on only one of the cell instances, which makes it easier to identify lower-level errors. By default, the error view generated by the `signoff_drc` command is saved in a file called `design_sdrc.err`. You can control this name by using the `-error_view` option (or the “Error cell name” box in the GUI).

The `signoff_drc` command can create an additional error view that contains only the DRC violations that are associated with the power and ground (PG) routing shapes, which makes it easier for you to view these PG-related violations in the GUI. To create this additional error view, use the `-categorize_error_types {pg}` option when you run the `signoff_drc` command. The tool names this error view `error_view_PG.err`, where `error_view` is the name

of the standard error view, which is either *current\_design\_sdrc* or the name specified in the *-error\_view* option. For information about using the error view to debug DRC violations, see “[Analyzing DRC Violations](#)” on page [8-108](#).

Note:

The only value supported by the *-categorize\_error\_types* option is `pg` (or `PG`); if you specify another value, IC Compiler issues an error message.

In addition to the error view file, the `signoff_drc` command generates the following files, which you can use for debugging, and places them in a directory called `signoff_drc_run` under the current working directory:

- `design.errsum` or `design.LAYOUT_ERRORS`

These files contain an error summary report.

- `sdrc.ev`

This file contains the runset file, including any options added by the `signoff_drc` command.

- `sdrc.rc`

This file contains the IC Validator environment setup specified by the `signoff_drc` command options.

- `sdrc.log`

This file contains any errors that occurred during the `signoff_drc` run.

- `./run_details/design.sum`

This file contains the detailed log file from the validation tool.

- `./run_details/runset.dp.log`

This file contains information about the runset used to run signoff DRC. It is used as input to the script that generates the configuration file for automatic signoff DRC fixing.

You can control the directory location by using the *-run\_dir* option (or the “Run directory” box in the GUI). You can specify either a relative path, in which case the directory is created under the current working directory, or an absolute path.

## Automatically Fixing Signoff DRC Violations

Zroute can use the IC Validator signoff DRC results to automatically fix the detected design rule violations. To use this capability, you must use IC Validator version E-2010.12 or later. For best results, use IC Validator version F-2011.09-SP1 or later.

To perform automatic fixing of the signoff DRC violations,

1. Set up the IC Validator environment as described in [“Setting Up the Validation Tool Environment” on page 8-98](#).
2. Set up the physical signoff options as described in [“Setting Up The Physical Signoff Options” on page 8-99](#).
3. Run the `signoff_drc` command with the following options:
  - `-ignore_child_cell_errors`
  - `-read_cel_view`
  - `-user_defined_options {-holding_cell}`For details about running the `signoff_drc` command, see [“Running the signoff\\_drc Command” on page 8-102](#).
4. Generate a configuration file that aids in the fixing process.

The configuration file defines the layer-to-DRC-rule mapping. The `signoff_autofix_drc` command processes only those rules that match a line in the configuration file.

Note:

For a given IC Validator DRC runset, you need to generate a configuration file only once. The generated configuration file can be used for all `signoff_autofix_drc` runs that use that runset.

The configuration file has the following format:

```
"mask_layer_name" "full_IC_Validator_DRC_rule_comment"
```

You can put comments in the configuration file by starting the line with the # character.

To generate the configuration file, run the `$ICV_HOME_DIR/contrib/generate_layer_rule_map.pl` script. This script has the following syntax:

```
generate_layer_rule_map.pl
    -dplog IC_Validator_log_file
    -tech_file Milkyway_technology_file
    -o config_file_name
```

The IC Validator log file that you specify in the `-dplog` option is the log file that was generated by the initial `signoff_drc` run. This file is called `runset.dp.log` and is located in the `run_details` subdirectory of the `signoff_drc_run` directory (or the directory specified by the `signoff_drc -run_dir` option).

5. Run the `signoff_autofix_drc` command (or choose Verification > Signoff Autofix DRC in the GUI).

When you run the `signoff_autofix_drc` command, you must specify the following items:

- The location of the configuration file

To specify the location of the configuration file, use the `-config_file` option (or enter the file name in the “Configuration file name” box in the GUI).

- The location of the IC Validator signoff DRC results

To specify the directory that contains the IC Validator signoff DRC results, use the `-init_drc_error_db` option (or enter the directory name in the “Initial error database directory” box in the GUI).

By default, the `signoff_autofix_drc` command runs two repair loops. In each loop, IC Compiler

- a. Fixes the DRC violations based on the previous IC Validator signoff DRC results

For the first loop, regardless of its loop number, this is the IC Validator data in the directory specified by the `-init_drc_error_db` option. For successive loops, this is the IC Validator DRC data from the previous loop, which is stored in the directory specified by the `-run_dir` option (or the `signoff_autofix_drc_run` directory if you do not use this option).

By default, the `signoff_autofix_drc` command performs DRC fixing on the whole design. To reduce runtime, you can perform DRC fixing only in the local area of the DRC violations reported by IC Validator by setting the `-repair_local_areas_only` option to true.

- b. Stores the modified design in a CEL view named `design_ADR_#`

- c. Runs IC Validator signoff DRC on the modified design

By default, the `signoff_autofix_drc` command performs signoff DRC checking only on those portions of the design affected by design rule fixing and checks all rules specified in the foundry runset.

You can run signoff DRC on the entire design by setting the `-incremental_level` option to `off`. Note that setting the `-incremental_level` option to `off` can greatly increase runtime.

You can restrict the checking to specific rules by using the `-select_rule` option to specify rules to check and the `-unselect_rule` option to specify rules to exclude from checking. In either case, you specify the rules by specifying a matching pattern for the rule names. The rule names are specified in the COMMENT section in the runset file. You can use these options together to customize the set of rules checked by the `signoff_autofix_drc` command.

You can specify additional options for the IC Validator command line by using the `-user_defined_options` option when you run the `signoff_autofix_drc` command. The string that you specify in this option is added to the command line used to invoke design rule checking in IC Validator. IC Compiler does not perform any checking on the specified string.

- d. Stores the error information in an error view named `design_ADR_#_sdrc.err`

Note:

The error view generated for the last loop is called `design_ADR_sdrc.err`.

- e. Stores the IC Validator results in the directory specified by the `-run_dir` option (or the `signoff_autofix_drc_run` directory if you do not use this option)

To reduce the overall runtime for this flow, you can streamline the data transfer between IC Compiler and IC Validator by setting the `-incremental_level` option to `high`. This setting passes only the relevant design information between tools, rather than passing all design information. Note that when you set this option to `high`, it automatically sets the `-repair_local_areas_only` option to `true`.

You can change the starting loop by using the `-start_repair_loop` option and change the ending loop by using the `-end_repair_loop` option. The number of the ending loop must always be greater than or equal to the number of the starting repair loop. By default, only the results of the ending loop are retained. To retain the results of all repair loops for debug purposes, use the `-keep_repair_loop_data true` option. Note that you cannot use this option when the `-incremental_level` option is set to `high`.

---

## Verifying the Routing in an External Tool

You can perform design rule checking with the Calibre tool, convert the Calibre DRC error file to a Milkyway error view, and then report or view the errors in IC Compiler. To convert the Calibre DRC error file to a Milkyway error view, use the `read_drc_error_file` command (or choose Verification > Read Third-party DRC Error File in the GUI).

For example,

```
icc_shell> read_drc_error_file Calibre_error_file
```

By default, the command generates a Milkyway error view called `cell_name.err`, where `cell_name` is derived from the Calibre error report. You can specify a name for the Milkyway error view by using the `-error_cell` option.

Note:

The `read_drc_error_file` command supports only flat Calibre DRC error files; it does not support Calibre hierarchy DRC error files.

You can load the Milkyway error view created by the `read_drc_error_file` command into the error browser to report or display the DRC violations. For information about using the error browser, see “[Analyzing DRC Violations](#)” on page 8-108.

---

## Analyzing DRC Violations

After you have generated a Milkyway error view, either by running one of the Synopsys design rule checking commands, by reading a route guidance file, or by converting the Calibre results to an error view, you can analyze the DRC violations by

- Using the DRC query commands
- Using the error browser

The following sections describe these capabilities.

## Using the DRC Query Commands

You can get information about DRC violations by using the `get_drc_errors` command to create a collection of DRC violations and then using the `get_attribute` command to query the attributes of the errors. Some attributes that provide information about DRC errors are `type`, `bbox`, `nets`, and `shapes`. Note that the availability of attribute values depends on the error type and the verification method used. For a list of all attributes associated with DRC errors, use the `list_attributes -application -class drc_error` command.

By default, the `get_drc_errors` command creates a collection that contains all DRC violations detected during the most recent run of the `verify_zrt_route` command. You can modify the query by

- Using the `-type` option to restrict the errors returned by the command to a specific error type. To determine the error type values, use the `list_drc_error_types` or `report_drc_error_type` commands.
- Using the `-bbox` option to restrict the query to a specific region of the design.
- Using the `-error_view` option to query a specific error view.

For example, to create a collection that contains all shorted nets detected by the most recent `verify_zrt_route` run, enter the following command:

```
icc_shell> get_attribute [get_drc_errors -type {Short}] nets
```

To use the DRC query commands on a nondefault error view, such as from a third-party DRC error file, you must first open the error view, either by loading it into the error browser or by using the `open_mw_cel -not_as_current` command. For example,

```
icc_shell> read_drc_error_file -error_cell Route_Opt.err error.file
icc_shell> set cellId [open_mw_cel -not_as_current Route_Opt.err]
icc_shell> report_drc_error_type -error_view $cellId
icc_shell> get_drc_errors -error_view Route_Opt.err
```

## Using the Error Browser

The error browser lets you examine routing design rule errors in the GUI. You select the errors you need to examine by error type or layer, view error information in the error browser, and view error locations in the layout view. You can filter the error list, mark errors as fixed, highlight errors in the layout view, and select errors interactively with the Error Selection tool. You can also save the errors in a file.

For more information about using the error browser, see

- The Error Browser usage help

To view the Error Browser usage help, choose Help > Error Browser in the error browser window.

- The “Examining Routing and Verification Errors” topic in IC Compiler Help

To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

- The “[Examining Routing and Verification Errors](#)” section on [page A-75](#)

---

## Routing Nets and Buses in the GUI

The layout editor in the IC Compiler GUI provides the following routing capabilities:

- [Routing Single Nets](#)
- [Creating Physical Buses](#)
- [Modifying Buses](#)
- [Routing Buses or Multiple Nets](#)
- [Creating Custom Wires](#)

The following sections describe these capabilities.

Note:

When you route nets and buses in the GUI, you can use the editor DRC capability to verify the routing results. For information about the editor DRC capability, see “[Viewing and Fixing Errors](#)” on page A-77.

---

## Routing Single Nets

You can route nets interactively in the active layout view by drawing the route segments with the Create Route tool. To activate the Create Route tool, click the  button on the Edit toolbar or choose Edit > Create > Route Tool. A route can be composed of horizontal and vertical segments. As you draw the route segments, the tool guides you by displaying flylines and target port and pin locations. It can also check for DRC violations and display the estimated resistance of the segments. You can draw individual segments or dual orthogonal segments. By default, the tool snaps the route segments to the routing track edges.

Note:

The Create Route tool routes a single net. If you need to route multiple nets or physical buses, use the Advanced Route tool. For more information, see “[Routing Buses or Multiple Nets](#)” on page 8-115.

After enabling the Create Route tool, you start a route by selecting a net. The default method for selecting a net is to click a physical object with a net connection in the layout view. You can click a net shape, user shape, pin, port, terminal, or via. The Create Route tool automatically sets the net and the routing layer based on the object you click. This capability is called automatic first-click selection. You can disable this capability and explicitly select the net and routing layer.

If the selected net uses a nondefault routing rule, by default, the Create Route tool honors the metal width requirement from the nondefault routing rule. If the selected net does not use a nondefault routing rule or you choose not to honor the nondefault routing rule, the Create Route tool uses the metal width requirement that is defined in the technology file.

To draw route segments, you click points in the layout view. The tool displays flylines and target port and pin locations to guide you in drawing the route segments. You can set options to adjust the routing, control the tool operation, and enable or disable routing aids.

To check for DRC violations as you draw the route segments, you must enable editor DRC by selecting the DRC option on the Mouse Tool Options toolbar or in the Create Route Tool dialog box. When you enable editor DRC, it checks for DRC violations as you draw based on the DRC rules that you set in the Editor DRC Options dialog box. When DRC violations occur, it displays visual cues to alert you to the violation, but does not prevent you from making the changes. If you do not enable editor DRC, you can check for DRC violations after

you finish routing the net by choosing Edit > Editor DRC > Run DRC or Edit > Editor DRC > Run DRC on Selected Nets or by running the `gui_check_drc_errors` command. For more information about using editor DRC, see “[Viewing and Fixing Errors](#)” on page [A-77](#).

To display the estimated resistance values, enable resistance estimation by selecting the Resistance option on the Mouse Tool Options toolbar or in the Create Route Tool dialog box. To adjust the criteria for resistance estimation, click the Options button beside the Resistance option in the Create Route Tool Options dialog box and set options as needed in the Set Resistance per Layer dialog box. For more information about resistance estimation, see the “[Viewing Estimated Wire Resistance](#)” topic in IC Compiler Help.

You can reverse and reapply Create Route tool operations by using the GUI undo and redo capabilities.

If you need assistance while using the Create Route tool, click  to open a Help page in the man page viewer.

For more information about using the Create Route tool, see the “[Routing Single Nets](#)” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

You can also create routes from the command line by using the `create_net_shape` command with the `-type wire` option.

---

## Creating Physical Buses

The layout editor can create physical buses in the following ways:

- Manual bus creation

To manually create a physical bus, you specify and sort the nets that you want to include in the bus.

- Automatic bus creation

To have the layout editor automatically create a physical bus, you define a net name pattern, and then the tool constructs the bus from nets with matching names.

## Manual Bus Creation

You can manually create a physical bus by specifying and sorting the nets that you want to include in the bus. You can specify the nets by selecting them, searching for them by name, or loading their names from a file. You can also set net order and precedence options and select the index delimiter.

To manually create a physical bus,

1. Choose Edit > Create > Physical Buses.

The Physical Buses dialog box appears. If your design already contains physical buses, the bus names appear in the “Bus name” list.

2. Click the Create button.

The Create Physical Bus dialog box appears.

3. Type a unique bus name in the “Bus name” box.
4. Set the net insertion and sorting options as needed.
5. Specify the nets that you want to include in the bus.

You can search for the nets by name, insert selected nets, or load the nets from a file.

The names of the specified nets appear in the “Net name” list.

6. (Optional) Sort or remove nets in the “Net name: list as needed.
7. Click OK or Apply.

The tool displays the bus name in the Physical Buses dialog box.

Alternatively, you can use the `create_physical_bus` command.

For more information about manually creating a physical bus, see the “Creating Buses” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

## Automatic Bus Creation

You can automatically create a physical bus by defining a net name pattern and letting the tool construct the bus from nets with matching names. You define the net name pattern by specifying a name prefix and selecting one or more index delimiters. You can also set the index order, ascending or descending, and bus size constraint options.

To automatically create a physical bus,

1. Choose Edit > Create > Physical Buses.

The Physical Buses dialog box appears. If your design already contains physical buses, the bus names appear in the “Bus name” list.

2. Click the Auto Define button.

The Auto Define Buses dialog box appears.

3. Type a prefix in the “Net name prefix” box.

4. Select a net order option.

The choices are “ascending” and “descending.” The default is “ascending.”

5. Select or deselect bus index delimiter options under “Accept net name patterns” as needed to match the names of the nets that you want to include in the bus.

By default, all of the bus delimiter options are selected. To exclude nets with names that include specific delimiters, deselect the options for those delimiters. The available delimiters are braces ({i}), square brackets ([i]), angle brackets (<i>), underlines (\_i\_), colons (:i:), and parentheses ((i)).

6. Set the bus size constraint options as needed.

- To set the minimum number of nets in the bus, select or type a value in the Min box. The default is 8.
- To set the maximum number of nets in the bus, select or type a value in the Max box. The default is 128.
- To restrict the number of signals permitted in the bus, select or type a value in the “Multiple of” box. The default is 1.

7. Click OK or Apply.

Alternatively, you can use the `create_physical_buses_from_patterns` command.

For more information about automatically creating a physical bus, see the “Defining Buses Automatically” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

---

## Modifying Buses

You can modify a physical bus by specifying and sorting the nets that you want to include in the bus. You can specify the nets by selecting them, searching for them by name, or loading their names from a file. You can also set net order and precedence options and select the index delimiter.

To modify a physical bus,

1. Choose Edit > Create > Physical Buses.

The Physical Buses dialog box appears. The names of the existing buses appear in the “Bus name” list, and the names of their constituent nets appear in the “Net name” list.

2. Select the bus that you want to modify from the “Bus name” list.

3. Click the Modify button.

The Modify Physical Bus dialog box appears. The name of the selected bus appears in the “Bus name” box, and the names of its constituent nets appear in the “Net name” list.

4. Set net insertion and sorting options as needed.

- If you want the tool to sort the nets automatically when you insert them, select the “Before selection” option.

By default, the “After selection” option is selected, which means the tool does not automatically sort the nets when you insert them.

- To set the net order, select a “Sort mode” option.

The choices are Ascending, Descending, and None. The default is Ascending.

- To set the net precedence, select a Precedence option.

The choices are Left and Right. The default is Left.

- To set the index delimiter character for the bus, select a “Bus delimiter” option.

The available delimiters are square brackets ([i]), angle brackets (<i>), braces ({i}), parentheses ((i)), underlines (\_i\_), and colons (:i:). The default is square brackets.

5. (Optional) Add nets to the bus as needed.

You can search for the nets by name, insert selected, or load the nets from a file.

- To search for the nets by name, click the Search button to open the Object Chooser dialog box, set the search parameters as needed, click the Search button, edit the “Search results” list as needed, and click OK.

- To insert selected nets, select the nets and click the Get Selection button. Alternatively, you can control the insertion order by clicking the arrow button beside the Get Selection button and choosing a command on the menu that appears.
- To load the nets from a file and preserve the net ordering specified in the file, click the “Load from file” button to open the “Read nets from file” dialog box, navigate to the directory where the file is located, select the file or type the file name, and click Open.

The names of the nets appear in the “Net name” list.

6. (Optional) Sort or remove nets in the “Net name” list as needed.

- To sort the nets, set “Sort mode” and precedence options as needed, and click the Sort button.
- To remove individual nets, select the nets and click the Remove button.
- To remove all of the nets, click the Remove All button.

7. Click OK or Apply.

The tool displays the bus name in the Physical Buses dialog box.

Alternatively, you can use the `create_physical_bus` command.

For more information about modifying a physical bus, see the “Modifying Buses” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

---

## Routing Buses or Multiple Nets

You can route a physical bus or multiple nets interactively in the active layout view by drawing the routes with the Advanced Route tool. To activate the Advanced Route tool, click the  button on the Edit toolbar or choose Edit > Create > Advanced Route Tool. Each route can be composed of horizontal and vertical segments. As you draw the route segments, the tool guides you by displaying flylines and target port and pin locations. The tool can also interactively check for routing design rule violations as you draw. You can draw individual segments or dual orthogonal segments. By default, the tool snaps the route segments to the routing track edges.

Note:

The Advanced Route tool routes buses or multiple nets. If you need to route individual nets, use the Create Route tool. For more information, see “[Routing Single Nets](#)” on page 8-110.

After enabling the Advanced Route tool, you start a route by selecting a bus or net. The default method for selecting a bus or net is to click a physical object with a net connection in the layout view. You can click a net shape, user shape, pin, port, terminal, or via. The Create

Route tool automatically sets the net and the routing layer based on the object you click. This capability is called automatic first-click selection. You can disable this capability and explicitly select the net and routing layer.

By default, the Advanced Route tool ignores routing blockages defined by the `create_routing_blockage` command. You can force the tool to honor these blockages by changing the setting in the Mouse Tool Options panel or the Advanced Route tool dialog box. The Advanced Route tool does not honor route guides defined by the `create_route_guide` command.

By default, if a selected net uses a nondefault routing rule, the Advanced Route tool honors the metal width and metal spacing requirements from the nondefault routing rule and uses these settings to determine the width and pitch of the routes. Note that the shielding width and shield spacing defined in the nondefault routing rule are not used by the Advanced Route tool. If a selected net does not use a nondefault routing rule or you choose not to honor the nondefault routing rules, the Advanced Route tool uses the metal width and metal spacing requirements defined in the technology file.

To draw route segments, you click points in the layout view. The tool displays flylines and target port and pin locations to guide you in drawing the route segments. It can also check for routing design rule violations as you draw the route segments. You can set options to adjust the routing, control the tool operation, and enable or disable routing aids.

You can reverse and reapply Advanced Route tool operations by using the GUI undo and redo capabilities.

By default, the Advanced Route tool displays error markers for any editor DRC violations that occur as you route the bus or nets. When editor DRC detects DRC violations, it automatically creates an editor DRC error view and loads it into the error browser. Editor DRC provides a limited set of advanced DRC rules that the advanced route editing tools can use to provide immediate visual feedback when a violation occurs during interactive routing. The tools support interactive DRC for advanced technologies as defined in the technology file. You can disable editor DRC or checks for individual DRC rules. If you disable editor DRC, you can check the bus or nets that you routed by choosing **Edit > Editor DRC > Run DRC** or **Edit > Editor DRC > Run DRC on Selected Nets** or by running the `gui_check_drc_errors` command.

If you need assistance while using the Advanced Route tool, click  to open a Help page in the man page viewer.

For more information about using the Advanced Route tool, see the “Routing Buses or Multiple Nets” topic in IC Compiler Help. To view IC Compiler Help, choose **Help > IC Compiler Online Help** in the GUI. For more information about using editor DRC, see [“Viewing and Fixing Errors” on page A-77](#).

---

## Modifying Routed Nets

You can modify routed nets in the GUI by using the following tools:

- Area Push tool

To activate the Area Push tool, click the  button on the Edit toolbar or choose Edit > Area Push. You can use the Area Push tool to move unfixed objects away from a rectangular area on a layer while maintaining their physical connections. You select the layer and control whether the tool complies with nondefault routing rules. The tool supports both interactive and batch push operations.

If you need assistance while using the Area Push tool, click  to open a Help page in the man page viewer.

For more information about using the Area Push tool, see the “Pushing Objects” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

- Spread Wire tool

To activate the Spread Wire tool, click the  button on the Edit toolbar or choose Edit > Spread Wire. You can use the Spread Wire to move selected, unfixed wires evenly between two points on a layer while maintaining their physical connections. You control whether the tool spreads the wires by layer and whether the tool complies with nondefault routing rules.

If you need assistance while using the Spread Wire tool, click  to open a Help page in the man page viewer.

For more information about using the Area Push tool, see the “Spreading Wires” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

- Stretch Wire tool

To activate the Stretch Wire tool, click the  button or choose Edit > Stretch Wire. You can use the Stretch Wire tool to move and stretch unfixed wire shapes while optionally maintaining their physical connections.

If you need assistance while using the Stretch Wire tool, click  to open a Help page in the man page viewer.

For more information about using the Area Push tool, see the “Stretching Wires” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

- Window Stretch tool

To activate the Window Stretch tool, click the  button or choose Edit > Window Stretch. You can use the Window Stretch tool to move or stretch unfixed objects within a rectangular area while optionally maintaining their physical connections. The tool moves all movable objects that are entirely inside the area and stretches all resizable objects that are partially inside the area.

If you need assistance while using the Window Stretch tool, click  to open a Help page in the man page viewer.

For more information about using the Area Push tool, see the “Moving and Stretching Objects” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

The Area Push tool and the Spread Wire tool do not create DRC violations, but might fix existing DRC violations. To check for DRC violations after using these tools, run editor DRC by choosing Edit > Editor DRC > Run DRC or Edit > Editor DRC > Run DRC on Selected Nets or by running the `gui_check_drc_errors` command.

By default, the Stretch Wire tool and the Window Stretch tool display error markers for any editor DRC violations that occur as you route the bus or nets. When editor DRC detects DRC violations, it automatically creates an editor DRC error view and loads it into the error browser. Editor DRC provides a limited set of advanced DRC rules that the advanced route editing tools can use to provide immediate visual feedback when a violation occurs during interactive routing. The tools support interactive DRC for advanced technologies as defined in the technology file. You can disable editor DRC or checks for individual DRC rules. If you disable editor DRC, you can check the bus or nets that you routed by choosing Edit > Editor DRC > Run DRC or Edit > Editor DRC > Run DRC on Selected Nets or by running the `gui_check_drc_errors` command.

For more information about using editor DRC, see “[Viewing and Fixing Errors](#)” on [page A-77](#).

---

## Creating Custom Wires

You can route one or more nets between specific points by using the Custom Wire tool. You specify the points by clicking in the active layout view and define the routes by setting options in the Create Custom Wires dialog box. A route can be composed of one or more horizontal or vertical segments. Each point you click after the first point specifies a route segment.

To route nets with the Custom Wire tool,

1. (Optional) Select a net shape, pin, port, terminal, user shape, or via to identify the net you need to route. If you perform this step, the tool operates in preselection mode.

2. Click the Custom Wire tool icon (  ) in the Edit toolbar or choose Edit > Create > Custom Wires.

The Create Custom Wires dialog box appears. If you preselected the net, the GUI automatically sets the net name, layer, and width options.

3. (Optional) Set options as needed in the Create Custom Wires dialog box.

If you did not select the nets that you need to route before activating the Custom Wire tool, you can select or browse for the nets or type the net names in the Net box.

If you need to reset the Create Custom Wires dialog box options to their defaults, click Default. For details about setting options in the Create Custom Wires dialog box, see the “Setting Route Tool Options” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

4. Click the startpoint for the routes in the active layout view.

If you selected the automatic first-click Bus or Net, Layer, or Width options and the object you click is a net shape, user shape, pin, port, terminal, or via, the tool automatically identifies the net connected to the object and can perform the following actions:

- Select the net and update the Net box in the Create Custom Wires dialog box.
- Identify the preferred routing layer for the net and update the Layer list in the Create Custom Wires dialog box.
- Identify the default wire width for the net and update the Width box in the Create Custom Wires dialog box.

The Net, Layer, and Width options are disabled by default.

5. Draw the first wire segments.

As you move the pointer, a ghost image appears between the initial point and the current pointer position. The color of the ghost image indicates the layer on which you are drawing the routes.

If you are routing multiple nets, the default reference wire is the low end segment, the bottom segment for horizontal routes or the leftmost segment for vertical routes, in the first section of the routes. If you want to use the high end segment instead, select the “High end” option in the Create Custom Wires dialog box.

6. Click a point or press Return when you need to finish the route segments and change the routing direction or the layer.

- To change the layer, press F1 or Shift-F1 repeatedly until the ghost shape color matches the color of the layer you want to use. To move up one layer, press F1. To move down one layer, press Shift-F1. When you change the layer, the tool automatically inserts the appropriate vias.
- To remove the last point, press Backspace or right-click and choose Remove Last Point. You can remove multiple points sequentially.
- To remove the entire route and start over, press Escape or right-click and choose Cancel.

If necessary, you can adjust options in the Create Custom Wires dialog box to control how the routes change direction.

- To switch the reference wire from one end to the other, select the “Switch ends” option.
- To change the number wires that each wire crosses, select or type a value in the “Skip count” box.

7. Repeat steps 5 and 6 as needed.

8. Finish the routes and instantiate the routed nets by doing one of the following:

- Double-click a target pin or port.
- Right-click and choose Apply.
- Click Apply in the Create Custom Wires dialog box.

9. (Optional) Do one of the following:

- To route additional nets, repeat steps 3 through 9.
- To deactivate the Custom Wires Tool, press the Esc key or click OK in the Create Custom Wires dialog box.

For more information about creating custom wires, see the “Creating Custom Wires” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

---

## Postroute RC Extraction

IC Compiler automatically performs postroute RC estimation when you run the `route_opt` command and when you run any of the following timing analysis commands on a routed but not extracted design: `report_timing`, `report_qor`, `report_constraint`, `report_delay_calculation`, `report_net`, `report_clock`, `report_clock_timing`, or `report_clock_tree`. In addition, you can explicitly perform postroute RC extraction by running the `extract_rc` command.

Note:

If the extraction is already done by a timing or extraction command, it does not occur again for the same routed database when you use the reporting commands.

By default, the `extract_rc` command performs RC estimation on any unrouted nets in your design and performs RC extraction on the routed nets in your design. If your design contains a mix of routed and unrouted nets, and you do not want to run RC estimation on the unrouted nets, use the `extract_rc -routed_nets_only` command, which performs only RC extraction.

When there are only a small number of routing changes, such as in the ECO flow, you can use the `extract_rc -incremental` command to perform incremental extraction of only the changed nets. Incremental extraction is performed based on the previous extraction in the same session.

During postroute RC extraction, IC Compiler performs the following tasks:

- Determines the RC coefficients

IC Compiler derives the RC coefficients from the TLUPlus models (for information about attaching the TLUPlus data to your Milkyway design library, see “[Setting Up the TLUPlus Files](#)” on page 3-36).

- Calculates the RC values

If your design contains global routing, IC Compiler uses a global route extraction model to calculate the parasitics. This model uses resistance values derived from the global routing and estimated capacitance values.

If your design contains track assignments or detail routing, IC Compiler uses a detail route extraction model to calculate the parasitics. This model uses resistance and capacitance values derived from the detail postroute geometries.

The tool does not extract the coupling capacitance values unless you have set the delta delay signal integrity option to `true` (`set_si_options -delta_delay true`). To force extraction of these values, run the `extract_rc -coupling_cap` command.

- Saves the timing data and attributes in the Milkyway design library

The parasitics are saved in the Milkyway design library, but a parasitic data file is not saved. To save the parasitics in a data file, run the `write_parasitics` command.

To fine-tune the postroute RC extraction, you specify the scaling factors by using the `set_extraction_options` command and its options, as shown in [Table 8-13](#).

*Table 8-13 set\_extraction\_options Command Options*

| To do this                                                                                                             | Use this                                                                     |
|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| Scale the capacitance coefficients.                                                                                    | <code>-max_cap_scale</code><br><code>-min_cap_scale</code>                   |
| Scale the resistance coefficients.                                                                                     | <code>-max_res_scale</code><br><code>-min_res_scale</code>                   |
| Scale the coupling capacitance coefficients.                                                                           | <code>-max_ccap_scale</code><br><code>-min_ccap_scale</code>                 |
| Specify the coupling capacitance net-to-net filtering threshold (default is 0.003 picofarad).                          | <code>-max_net_ccap_thres</code><br><code>-min_net_ccap_thres</code>         |
| Specify the coupling capacitance net-to-net filtering ratio (default is 0.03 of total capacitance).                    | <code>-max_net_ccap_ratio</code><br><code>-min_net_ccap_ratio</code>         |
| Specify the coupling capacitance average net-to-net filtering ratio (default is 0.25 of average coupling capacitance). | <code>-max_net_ccap_avg_ratio</code><br><code>-min_net_ccap_avg_ratio</code> |
| Specify the process scaling factors (default is 1.0).                                                                  | <code>-max_process_scale</code><br><code>-min_process_scale</code>           |
| Ignore routing obstructions during extraction.                                                                         | <code>-no_obstruction</code>                                                 |
| Disable the breaking of long wire segments during extraction.                                                          | <code>-no_break_segments</code>                                              |

*Table 8-13 set\_extraction\_options Command Options (Continued)*

| To do this                                                                                                                                   | Use this                                                                                  |
|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| Specify the maximum length of wire segments (default is 50 microns). If you use <code>-no_break_segments</code> , this option has no effect. | <code>-max_segment_length</code>                                                          |
| Specify the type of real metal fill extraction to perform. The default is none.                                                              | <code>-real_metalfill_extraction</code><br><code>none   floating   grounded   auto</code> |
| Control whether virtual shield extraction is performed. The default is <code>true</code> .                                                   | <code>-virtual_shield_extraction</code><br><code>true   false</code>                      |
| Specify the fanout threshold. The default is 1000 pins.                                                                                      | <code>-fan_out_thres count</code>                                                         |
| Specify the pattern density outside the block for extraction. The default is 0.0.                                                            | <code>-density_outside_block</code><br><code>density_value</code>                         |
| Reset extraction options.                                                                                                                    | <code>-default</code>                                                                     |

For multicorner-multimode designs, use the `set_extraction_options` command to set the resistance, capacitance, and coupling capacitance scaling values for the current scenario. For information about setting the current scenario see “[Defining Scenarios](#)” on page 3-30. The following options of the `set_extraction_options` command can be specified for the current scenario:

- `-max_res_scale`
- `-min_res_scale`
- `-max_cap_scale`
- `-min_cap_scale`
- `-max_ccap_scale`
- `-min_ccap_scale`

**Note:**

The other options supported by the `set_extraction_options` command are not scenario-specific.

To check the values of the specified scaling factors, use the `report_extraction_options` command.

You can use process scaling factors to adjust RC estimation and extraction for a process shrink, such as shrinking from 90 nm to 65 nm. The lengths and widths of the interconnect wires are scaled by the specified factors, without affecting interconnect wire depths or metal

geometries inside standard cells and macros. You specify the scaling factors with the `-max_process_scale` and `-min_process_scale` options of the `set_extraction_options` command. These factors affect the RC values generated by the `extract_rc` command for maximum-delay and minimum-delay analysis, respectively, for both preroute RC estimation and postroute RC extraction.

**Note:**

The process scaling factors of the `set_extraction_options` command are the only settings that apply to both preroute RC estimation and postroute RC extraction. All other options of the `set_extraction_options` command apply only to postroute RC extraction.

# 9

## Chip Finishing and Design for Manufacturing

---

IC Compiler provides chip finishing and design for manufacturing and yield capabilities that you can apply throughout the various stages of the design flow to address process design issues encountered during chip manufacturing.

This chapter contains the following sections:

- [Overview](#)
- [Inserting Tap Cells](#)
- [Finding and Fixing Antenna Violations](#)
- [Inserting Redundant Vias](#)
- [Optimizing Wire Length and Via Count](#)
- [Reducing Critical Areas](#)
- [Shielding Nets](#)
- [Inserting Filler Cells](#)
- [Inserting Metal Fill](#)

## Overview

[Figure 9-1](#) shows the design for manufacturing and chip finishing tasks supported by IC Compiler and how these tasks fit into the overall IC Compiler design flow. The following sections describe how to perform these tasks.

*Figure 9-1 Design for Manufacturing and Chip Finishing Tasks in the Design Flow*



---

## Inserting Tap Cells

Tap cells are a special nonlogic cell with well and substrate ties. These cells are typically used when most or all of the standard cells in the library contain no substrate or well taps. Generally, the design rules specify the maximum distance allowed between every transistor in a standard cell and a well or the substrate ties.

You can insert tap cells in your design before or after placement:

- You can insert tap cell arrays before placement to ensure that the placement complies with the maximum diffusion-to-tap limit.
- You can insert tap cells after placement to fix maximum diffusion-to-tap violations.

The following sections describe these methods.

---

## Adding Tap Cell Arrays

Before global placement (during the floorplanning stage), you can add tap cells to the design that form a two-dimensional array structure to ensure that all standard cells placed subsequently will comply with the maximum diffusion-to-tap distance limit.

You need to specify the tap distance and offset, based on your specific design rule distance limit. The command has no knowledge of the design rule distance limit. After you run the command, you should visually check to ensure that all standard cell placeable areas are properly protected by tap cells.

To add a tap cell array, use the `add_tap_cell_array` command (or choose Finishing > Add Tap Cell Array in the GUI). This is the command syntax:

```
add_tap_cell_array
  -master_cell_name name
  -distance tap_cell_distance
  [-voltage_area voltage_areas]
  [-plan_group {plan_groups}]
  [-pattern normal | every_other_row | stagger_every_other_row]
  [-offset distance]
  [-tap_cell_identifier tap_cell_prefix]
  [-tap_cell_separator tap_cell_separator]
  [-no_tap_cell_under_layers layer_list]
  [-well_port_name port_name]
  [-well_net_name net_name]
  [-substrate_port_name port_name]
  [-substrate_net_name substrate_tie_net_name]
  [-connect_power_name power_net_name]
  [-connect_ground_name ground_net_name]
  [-fill_boundary_row true | false]
  [-fill_macro_blockage_row true | false]
```

```

[-boundary_row_double_density true | false]
[-macro_blockage_row_double_density true | false]
[-left_macro_blockage_extra_tap_by_rule | must_insert | no_insert]
[-right_macro_blockage_extra_tap_by_rule | must_insert | no_insert]
[-left_boundary_extra_tap_by_rule | must_insert | no_insert]
[-right_boundary_extra_tap_by_rule | must_insert | no_insert]
[-ignore_soft_blockage true | false]
[-at_distance_only true | false]
[-skip_fixed_cells true | false]
[-respect_keepout]
[-no_1x]

```

For example,

```
icc_shell> add_tap_cell_array -master_cell_name Cell1 -distance 30 \
    -pattern normal -voltage_area [get_voltage_areas "V*"] \
    -no_tap_cell_under_layers {M1 M2}
```

You must use the `-master_cell_name` option to specify the name of the reference cell to be used for tap cell insertion and the `-distance` option to specify the required distance, in microns, between tap cells. The specified distance should be approximately twice the maximum diffusion-to-tap value specified in the technology design rule. Use the `-voltage_area` option to restrict tap insertion to specific voltage areas. Use the `-plan_group` option to restrict tap insertion to specific plan groups.

You specify the insertion pattern by using the `-pattern` option: `normal` (the default), `every_other_row`, or `stagger_every_other_row`. “Normal” insertion adds tap cells to every row, using the specified distance limit. “Every other row” insertion adds tap cells in the odd-numbered rows only, which reduces the added tap cells by one-half. “Stagger every other row” insertion adds tap cells in every row with tap cells in even rows offset by half the specified `-offset` setting relative to the odd rows, producing a checkerboard-like pattern.

The command also has options to specify the tap cell naming conventions, well port and net names, substrate port and net names, ground net connections, prohibited placement under specified metal layer preroutes, and tap density adjustments at boundary rows and macro blockage rows. For more information about these options and their default settings, see the man page for the `add_tap_cell_array` command.

For designs that are at the 28-nm process node or less, the foundry spacing rules require no filler insertion of one unit tile. However, by default, the `add_tap_cell_array` command might place tap cells at locations where one-unit-tile gaps can occur. To prevent one-unit-tile violations between tap cells and fixed cells, macros, blockages, or the chip boundaries, set the `-no_1x` option. When you set this option, the command moves tap cells to the next legal locations to avoid creating one-unit-tile gaps. This option cannot be used with the `-skip_fixed_cells` option set to `false`.

---

## Fixing Tap Spacing Violations

You can add tap cells to comply with the diffusion-to-substrate or -well-contact maximum spacing design rule. After global placement (typically), you can insert tap cells “by rules” so that all existing standard cells comply with the maximum diffusion-to-tap distance limit.

To insert tap cells to satisfy to the diffusion-to-tap design rules, use the `insert_tap_cells_by_rules` command (or choose Finishing > Insert Tap Cells By Rules in the GUI). This is the full command syntax:

```
insert_tap_cells_by_rules
  -drc_spacing_check | -tap_cell_insertion
  -tap_distance_based | -drc_spacing_based
  -move | -freeze
  -tap_master physical_lib_cell
  [-tap_layer layer_name]
  [-tap_distance_limit distance]
  [-n_well_layer layer_name]
  [-p_well_layer layer_name]
  [-contact_layer layer_name]
  [-p_diffusion_layer layer_name]
  [-n_diffusion_layer layer_name]
  [-p_Implant_layer layer_name]
  [-n_Implant_layer layer_name]
  [-tap_spacing_design_rule distance]
  [-tap_filler_name_identifier prefix]
  [-ignore_hard_blockage]
  [-ignore_soft_blockage]
  [-ignore_double_back_sharing]
  [-connect_to_power_net power_net]
  [-connect_to_ground_net ground_net]
  [-no_tap_cells_under_metal_layer metal_layers_list]
  [-voltage_area voltage_area_list]
  [-respect_keepout]
```

For example,

```
icc_shell> insert_tap_cells_by_rules -tap_master "MY_TOP" \
  -tap_cell_insertion -tap_distance_based -move \
  -tap_distance_limit 30.0 \
  -no_tap_cells_under_metal_layer {metal1}
```

This example inserts a tap cell named MY\_TOP into a placed design to satisfy the condition that the distance from a standard cell to a tap cell must be no more than 30 microns, with the restriction that tap cells cannot be inserted under layer metal1.

In the command, you must specify the name of the tap cell using `-tap_master cell_name`. In addition, you must use either `-drc_spacing_check` or `-tap_cell_insertion` to specify whether to perform DRC tap distance checking only or to both perform checking and fixing of violations by inserting tap cells.

You must use either `-tap_distance_based` or `-drc_spacing_based` to specify the method of calculating distances between standard cells and tap cells. The “Tap distance based” method uses a simple measurement from the standard cell to the tap, irrespective of the actual metal and contact layers within the cells. This method is used when the actual layout of the standard cells or tap cell is not available in the cell library. You must specify the tap distance limit using `-tap_distance_limit distance`.

The “DRC spacing based” method uses the actual layout of the standard cell and tap cell, with consideration of the diffusion, well, and contact layers in the cells. This method results in the insertion of fewer tap cells because existing taps in standard cells are recognized. You must specify the applicable layer names and design rule distance using command options such as `-n_well_layer` and `-tap_spacing_design_rule`.

You must use either `-move` or `-freeze` to specify whether to allow standard cells to be moved to make room for tap cells. Allowing standard cells to move can help prevent design rule violations and reduce the number of tap cells that must be inserted but can affect the design timing.

The command also has options to specify the tap layer name, tap cell naming conventions, respect for hard and soft blockages, allowance of tap sharing, power and ground net connections, prohibited placement under specified metal layer preroutes, voltage areas in which to perform tap cell insertion, and respect for hard macro keepout margins. For more information about these options and their default settings, see the man page for the `insert_tap_cells_by_rules` command.

---

## Removing Tap Cells

To remove tap cells, use the `remove_stdcell_filler -tap` command or choose Finishing > Remove Fillers in the GUI and select Tap as the filler type to remove. You can optionally specify a bounding box from which to remove the tap cells.

---

## Finding and Fixing Antenna Violations

In chip manufacturing, gate oxide can be easily damaged by electrostatic discharge. The static charge that is collected on wires during the multilevel metallization process can damage the device or lead to a total chip failure. The phenomena of an electrostatic charge being discharged into the device is referred to as either antenna or charge-collecting antenna problems.

To prevent antenna problems, IC Compiler verifies that for each input pin the metal antenna area divided by the gate area is less than the maximum antenna ratio given by the foundry:

$$(\text{antenna-area}) / (\text{gate-area}) < (\text{max-antenna-ratio})$$

The antenna flow consists of the following steps:

1. Define the antenna rules
2. Specify the antenna properties of the pins and ports
3. Analyze and fix the antenna violations

The following sections describe these steps.

## Defining Metal Layer Antenna Rules

You define the metal layer antenna rules by defining both global metal layer antenna rules and layer-specific metal layer antenna rules. You define the global metal layer antenna rules by using the `define_antenna_rule` command. You define the layer-specific antenna rules by using the `define_antenna_layer_rule` command.

The following commands show an example of defining the metal layer antenna rules:

```
set lib [current_mw_lib]
remove_antenna_rules $lib
define_antenna_rule $lib -mode 1 -diode_mode 4 \
    -metal_ratio 300 -cut_ratio 20
define_antenna_layer_rule $lib -mode 1 -layer "M1" \
    -ratio 300 -diode_ratio {0.09 0 123 16880}
define_antenna_layer_rule $lib -mode 1 -layer "M2" \
    -ratio 300 -diode_ratio {0.09 0 123 16880}
define_antenna_layer_rule $lib -mode 1 -layer "M3" \
    -ratio 300 -diode_ratio {0.09 0 123 16880}
define_antenna_layer_rule $lib -mode 1 -layer "M4" \
    -ratio 300 -diode_ratio {0.09 0 123 16880}
define_antenna_layer_rule $lib -mode 1 -layer "M5" \
    -ratio 400 -diode_ratio {0.09 0 123 20000}
define_antenna_layer_rule $lib -mode 1 -layer "VIA1" \
    -ratio 20 -diode_ratio {0.09 0 110 500}
define_antenna_layer_rule $lib -mode 1 -layer "VIA2" \
    -ratio 20 -diode_ratio {0.09 0 110 500}
define_antenna_layer_rule $lib -mode 1 -layer "VIA3" \
    -ratio 20 -diode_ratio {0.09 0 110 500}
define_antenna_layer_rule $lib -mode 1 -layer "VIA4" \
    -ratio 20 -diode_ratio {0.09 0 110 500}
```

The following sections provide details about how to define the metal layer antenna rules.

## Defining the Global Metal Layer Antenna Rules

You use the `define_antenna_rule` command to define the global metal layer antenna rules. These rules apply whenever a layer-specific antenna rule does not exist.

When you define the global metal layer antenna rules, you must specify

- The maximum antenna ratios

You must specify a maximum antenna ratio for metal layers and for via layers.

- To specify the maximum antenna ratio for metal layers, use the `-metal_ratio` option. This is a required option of the `define_antenna_rule` command.
- To specify the maximum antenna ratio for via layers, use the `-cut_ratio` option. This is a required option of the `define_antenna_rule` command.

- The way to calculate the antenna area

The antenna area calculation depends on which area mode to use and which metal segments to consider, which is referred to as the antenna recognition mode. You specify these settings by using the `-mode` option. This is a required option of the `define_antenna_rule` command. For information about setting the `-mode` option, see “[Setting the Antenna Mode](#)” on page 9-8.

- The diode protection mode

IC Compiler supports thirteen diode protection modes. You must specify the diode protection mode by using the `-diode_mode` option. This is a required option of the `define_antenna_rule` command. For information about the diode protection modes, see “[Setting the Diode Protection Mode](#)” on page 9-11.

### Setting the Antenna Mode

IC Compiler supports six antenna modes. The mode value, as set by the `-mode` option, indicates which area calculation mode to use and which metal segments to consider.

[Table 9-2 on page 9-11](#) shows the area calculation mode and the antenna recognition mode selected by each antenna mode value.

IC Compiler supports the following area calculation modes:

- Surface area, which is calculated as  $W \times L$
- Sidewall area, which is calculated as  $(W + L) \times 2 \times \text{thickness}$

Note:

If you use sidewall area calculation, you must define the metal thickness by specifying the `unitMinThickness`, `unitNomThickness`, and `unitMaxThickness` attributes in each `Layer` section of the technology file.

IC Compiler supports the following antenna recognition modes:

- Single-layer mode

In single-layer mode, IC Compiler considers only the metal segments on the current layer; the metal segments on all lower layers are ignored. This mode allows the best routability. In this mode, the antenna ratio is calculated as

$$\text{antenna\_ratio} = \text{connected metal area of the layer} / \text{total gate area}$$

- Accumulative ratio mode

In accumulative ratio mode, IC Compiler considers the metal segments on the current layer and the lower-layer segments to the input pins. In this mode, the antenna ratio is calculated as

$$\text{antenna\_ratio} = \text{accumulation of ratios for the layer and layers below}$$

- Accumulative area mode

In accumulative area mode, IC Compiler considers the metal segments on the current layer and all lower-layer segments. In this mode, the antenna ratio is calculated as

$$\text{antenna\_ratio} = \text{all connected metal areas} / \text{total gate area}$$

[Figure 9-2](#) shows a layout example with a lateral view, which is used to explain these antenna recognition modes. [Table 9-1](#) shows the antenna ratios for each antenna recognition mode for this layout example.

*Figure 9-2 Layout Example*



*Table 9-1 Antenna Recognition Modes and Ratios*

| <b>Considered segments</b> | <b>Antenna ratio</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Single-layer mode          | <p>M1 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: M1b / Gate1</li> <li>• Gate2: M1c / Gate2</li> <li>• Gate3: M1d / Gate3</li> </ul> <p>M2 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: M2b / Gate1</li> <li>• Gate2: M2d / Gate2</li> <li>• Gate3: M2e / Gate3</li> </ul> <p>M3 ratios</p> <ul style="list-style-type: none"> <li>• Gate1, 2: <math>(M3b + M3c) / (Gate1 + Gate2)</math></li> <li>• Gate3: M3d / Gate3</li> </ul> <p>M4 ratios</p> <ul style="list-style-type: none"> <li>• Gate1, 2, 3: <math>(M4a + M4b) / (Gate1 + Gate2 + Gate3)</math></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Accumulative ratio mode    | <p>M1 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: M1b / Gate1</li> <li>• Gate2: M1c / Gate2</li> <li>• Gate3: M1d / Gate3</li> </ul> <p>M2 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: M1b / Gate1 + M2b / Gate1</li> <li>• Gate2: M1c / Gate2 + M2d / Gate2</li> <li>• Gate3: M1d / Gate3 + M2e / Gate3</li> </ul> <p>M3 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: <math>M1b / Gate1 + M2b / Gate1 + (M3b + M3c) / (Gate1 + Gate2)</math></li> <li>• Gate2: <math>M1c / Gate2 + M2d / Gate2 + (M3b + M3c) / (Gate1 + Gate2)</math></li> <li>• Gate3: <math>M1d / Gate3 + M2e / Gate3 + M3d / Gate3</math></li> </ul> <p>M4 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: <math>M1b / Gate1 + M2b / Gate1 + (M3b + M3c) / (Gate1 + Gate2) + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</math></li> <li>• Gate2: <math>M1c / Gate2 + M2d / Gate2 + (M3b + M3c) / (Gate1 + Gate2) + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</math></li> <li>• Gate3: <math>M1d / Gate3 + M2e / Gate3 + M3d / Gate3 + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</math></li> </ul> |

*Table 9-1 Antenna Recognition Modes and Ratios (Continued)*

| Considered segments    | Antenna ratio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Accumulative area mode | <p>M1 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: M1b / Gate1</li> <li>• Gate2: M1c / Gate2</li> <li>• Gate3: M1d / Gate3</li> </ul> <p>M2 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: (M1b + M2b) / Gate1</li> <li>• Gate2: (M1c + M2d) / Gate2</li> <li>• Gate3: (M1d + M2e) / Gate3</li> </ul> <p>M3 ratios</p> <ul style="list-style-type: none"> <li>• Gate1, 2: (M1b + M1c + M2b + M2c + M2d + M3b + M3c) / (Gate1 + Gate2)</li> <li>• Gate3: (M1d + M2e + M3d) / Gate3</li> </ul> <p>M4 ratios</p> <ul style="list-style-type: none"> <li>• Gate1, 2, 3: all metal areas / (Gate1 + Gate2 + Gate3)</li> </ul> |

[Table 9-2](#) shows the area calculation mode and the antenna recognition mode selected by each antenna mode value.

*Table 9-2 Antenna Mode Settings*

| Antenna mode value | Area calculation mode | Antenna recognition mode |
|--------------------|-----------------------|--------------------------|
| 1                  | Surface               | Single-layer             |
| 2                  | Surface               | Accumulative ratio       |
| 3                  | Surface               | Accumulative area        |
| 4                  | Sidewall              | Single-layer             |
| 5                  | Sidewall              | Accumulative ratio       |
| 6                  | Sidewall              | Accumulative area        |

### Setting the Diode Protection Mode

The diode protection mode specifies how much protection the diodes provide. Note that IC Compiler considers all output pins to be diodes. [Table 9-3](#) defines each of the diode protection mode settings.

**Table 9-3 Diode Protection Mode Settings**

| <b>Diode protection mode</b> | <b>Definition</b>                                                                                                                                                                                                   |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                            | The diodes do not provide any protection.                                                                                                                                                                           |
| 1                            | The diodes provide unlimited protection.<br>In this mode, the highest metal layer is not checked for antenna violations because the input-to-output connection is completed when the highest metal layer is formed. |
| 2                            | Diode protection is limited; if more than one diode is connected, the largest value of the maximum antenna ratio for all diodes is used.                                                                            |
| 3                            | Diode protection is limited; if more than one diode is connected, the sum of the maximum antenna ratios for all diodes is used.                                                                                     |
| 4                            | Diode protection is limited; if more than one diode is connected, the sum of the diode-protection values for all diodes is used to compute the maximum antenna ratio.                                               |
| 5                            | Diode protection is limited; the maximum diode-protection value for all diodes is used to calculate the equivalent gate area.                                                                                       |
| 6                            | Diode protection is limited; the sum of the diode-protection values for all diodes is used to calculate the equivalent gate area.                                                                                   |
| 7                            | Diode protection is limited; the maximum diode-protection value for all diodes is used to calculate the equivalent metal area.                                                                                      |
| 8                            | Diode protection is limited; the sum of the diode-protection values for all diodes is used to calculate the equivalent metal area.                                                                                  |
| 9                            | Diode protection is limited; scaling is based on maximum diode protection.                                                                                                                                          |
| 10                           | Diode protection is limited; scaling is based on total diode protection.                                                                                                                                            |
| 11                           | Diode protection is limited; scaling is based on maximum diode protection.                                                                                                                                          |
| 12                           | Diode protection is limited; scaling is based on total diode protection.                                                                                                                                            |

## Defining Layer-Specific Antenna Rules

You use the `define_antenna_layer_rule` command to define a layer-specific antenna rule. Layer-specific antenna rules override the global metal layer antenna rules for the specified layer.

When you define a layer-specific antenna rule, you must specify

- The layer

To specify the layer, use the `-layer` option. The layer can be either a metal layer or a via layer.

- The antenna mode

To specify the antenna mode, use the `-mode` option. The antenna mode should be the same as the one that was used in the `define_antenna_rule` command. For information about the antenna modes, see “[Setting the Antenna Mode](#)” on page 9-8.

- The diode ratios

The diode ratios specify how to perform antenna ratio calculation with diode protection. The calculation is based on the vector that you specify by using the `-diode_ratio` option. For information about specifying the diode ratio vector, see “[Specifying the Diode Ratio Vector](#)” on page 9-13.

### Specifying the Diode Ratio Vector

The diode ratio vector defines the maximum allowable antenna ratio (max-antenna-ratio) of the antenna area to the gate area if the antenna is protected by diodes. The antenna ratio of each metal layer must be less than the allowable max-antenna-ratio (antenna-area / gate-area < max-antenna-ratio).

The format of the diode ratio vector is

```
{v0 v1 v2 v3 [v4]}
```

The `v4` value represents the upper limit of the diode protection and is optional. If you do not specify the `v4` value, it is assumed to be 0, which means there is no upper limit.

Note:

Diode modes 11 and 12 use a second vector, `{s0 s1 s2 s3 s4 s5}` to specify scaling values. In this case, you specify the diode ratio vectors as

```
 {{v0 v1 v2 v3 [v4]} {s0 s1 s2 s3 s4 s5}}
```

The actual usage of the diode ratio vector depends on the diode mode that was specified in the `define_antenna_rule` command. [Table 9-4](#) shows how the diode ratio vector is used for each of the diode modes. In this table,  $dp$  represents the diode protection value specified for an output pin. For information about specifying this value, see [“Specifying Antenna Properties” on page 9-19](#).

*Table 9-4 Antenna Ratio Calculation Based on Diode Mode*

| Diode mode | Calculation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0, 1       | Not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2, 3, 4    | allowable max-antenna-ratio<br><ul style="list-style-type: none"> <li>• If <math>dp &gt; v0</math> and <math>v4 &lt;&gt; 0</math>,<br/> <math>\text{allowable max-antenna-ratio} = \min(((dp + v1) * v2 + v3), v4)</math></li> <li>• If <math>dp &gt; v0</math> and <math>v4 = 0</math>,<br/> <math>\text{allowable max-antenna-ratio} = (dp + v1) * v2 + v3</math></li> <li>• If <math>dp \leq v0</math>,<br/> <math>\text{allowable max-antenna-ratio} = \text{layerMaxRatio}</math></li> </ul>                                                                                                                                                               |
| 5          | $\text{antenna\_ratio} = \text{metal\_area} / (\text{gate\_area} + \text{equi\_gate\_area})$<br><ul style="list-style-type: none"> <li>• If <math>\text{max\_diode\_protection} &gt; v0</math> and <math>v4 &lt;&gt; 0</math>,<br/> <math>\text{equi\_gate\_area} = \min(((\text{max\_diode\_protection} + v1) * v2 + v3), v4)</math></li> <li>• If <math>\text{max\_diode\_protection} &gt; v0</math> and <math>v4 = 0</math>,<br/> <math>\text{equi\_gate\_area} = (\text{max\_diode\_protection} + v1) * v2 + v3</math></li> <li>• If <math>\text{max\_diode\_protection} \leq v0</math>,<br/> <math>\text{equi\_gate\_area} = 0</math></li> </ul>           |
| 6          | $\text{antenna\_ratio} = \text{metal\_area} / (\text{gate\_area} + \text{equi\_gate\_area})$<br><ul style="list-style-type: none"> <li>• If <math>\text{total\_diode\_protection} &gt; v0</math> and <math>v4 &lt;&gt; 0</math>,<br/> <math>\text{equi\_gate\_area} = \min(((\text{total\_diode\_protection} + v1) * v2 + v3), v4)</math></li> <li>• If <math>\text{total\_diode\_protection} &gt; v0</math> and <math>v4 = 0</math>,<br/> <math>\text{equi\_gate\_area} = (\text{total\_diode\_protection} + v1) * v2 + v3</math></li> <li>• If <math>\text{total\_diode\_protection} \leq v0</math>,<br/> <math>\text{equi\_gate\_area} = 0</math></li> </ul> |

*Table 9-4 Antenna Ratio Calculation Based on Diode Mode (Continued)*

| <b>Diode mode</b> | <b>Calculation</b>                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7                 | <pre>antenna_ratio = (metal_area - equi_metal_area) / gate_area • If max_diode_protection&gt;v0 and v4&lt;&gt;0,   equi_metal_area = min (((max_diode_protection + v1) * v2 + v3), v4) • If max_diode_protection&gt;v0 and v4=0,   equi_metal_area = (max_diode_protection + v1) * v2 + v3 • If max_diode_protection&lt;=v0,   equi_metal_area = 0 • If equi_metal_area&gt;metal_area,   equi_metal_area = metal_area</pre>             |
| 8                 | <pre>antenna_ratio = (metal_area - equi_metal_area) / gate_area • If total_diode_protection&gt;v0 and v4&lt;&gt;0,   equi_metal_area = min (((total_diode_protection + v1) * v2 + v3), v4) • If total_diode_protection&gt;v0 and v4=0,   equi_metal_area = (total_diode_protection + v1) * v2 + v3 • If total_diode_protection&lt;=v0,   equi_metal_area = 0 • If equi_metal_area &gt; metal_area,   equi_metal_area = metal_area</pre> |
| 9                 | <pre>antenna_ratio = scale * metal_area / gate_area • If max_diode_protection&gt;v0,   scale = max (1 / ((max_diode_protection + v1) * v2 + v3), v4) • If max_diode_protection&lt;=v0,   scale = 1.0</pre>                                                                                                                                                                                                                              |
| 10                | <pre>antenna_ratio = scale * metal_area / gate_area • If total_diode_protection&gt;v0,   scale = max (1 / ((total_diode_protection + v1) * v2 + v3), v4) • If total_diode_protection&lt;= v0,   scale = 1.0</pre>                                                                                                                                                                                                                       |

*Table 9-4 Antenna Ratio Calculation Based on Diode Mode (Continued)*

| <b>Diode mode</b> | <b>Calculation</b>                                                                                                                                                                                                                                                                                                                                         |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11                | <pre>antenna_ratio = scale * metal_area / gate_area • If max_diode_protection&lt;v0,   scale = s0 • If max_diode_protection&lt;v1,   scale = s1 • If max_diode_protection&lt;v2,   scale = s2 • If max_diode_protection&lt;v3,   scale = s3 • If max_diode_protection&lt;v4,   scale = s4 • If max_diode_protection&gt;=v4,   scale = s5</pre>             |
| 12                | <pre>antenna_ratio = scale * metal_area / gate_area • If total_diode_protection&lt;v0,   scale = s0 • If total_diode_protection&lt;v1,   scale = s1 • If total_diode_protection&lt;v2,   scale = s2 • If total_diode_protection&lt;v3,   scale = s3 • If total_diode_protection&lt;v4,   scale = s4 • If total_diode_protection&gt;=v4,   scale = s5</pre> |

### Example for Diode Modes 2, 3, and 4

Assume that the diode ratio vector is {0.7 0.0 200 2000}; the layerMaxRatio value is 400; and the following diodes are connected to a single net: diode A with a diode-protection value of 0.5, diode B with a diode-protection value of 1.0, and diode C with a diode-protection value of 1.5.

The maximum antenna ratio for each diode is computed by using the diode ratio vector and the formula for diode modes 2 through 4:

- Diode A has a maximum antenna ratio of 400

The diode protection value of 0.5 is less than the  $v0$  value of 0.7; therefore, the maximum antenna ratio is the layerMaxRatio value.

- Diode B has a maximum antenna ratio of 2200

The diode protection value of 1.0 is greater than the  $v0$  value of 0.7, and  $v4$  is equal to 0; therefore, the maximum antenna ratio is  $(1.0+0.0) * 200 + 2000 = 2200$ .

- Diode C has a maximum antenna ratio of 2300

The diode protection value of 1.5 is greater than the  $v0$  value of 0.7, and  $v4$  is equal to 0; therefore, the maximum antenna ratio is  $(1.5+0.0) * 200 + 2000 = 2300$ .

The maximum antenna ratio for the net is computed by using the formula for the diode mode:

- For diode mode 2, the maximum antenna ratio for the net is the largest of the maximum antenna ratio values for the diodes, 2300.
- For diode mode 3, the maximum antenna ratio for the net is the sum of the maximum antenna ratios for the diodes,  $400 + 2200 + 2300 = 4900$ .
- For diode mode 4, the maximum antenna ratio for the net is computed by using the sum of the diode-protection values of the diodes,  $(0.5+1.0+1.5) * 200 + 2000 = 2600$ .

### Example for Diode Modes 5 and 6

Assume that the diode ratio vector is {0.0 0 1 0}; the layerMaxRatio value is 400; the gate area of an input pin is 0.6; and the following diodes are connected to a single net: diode A with a diode-protection value of 0.5, diode B with a diode-protection value of 1.0, and diode C with a diode-protection value of 1.5.

For diode modes 5 and 6, the maximum antenna ratio is computed by dividing the metal area by the sum of the gate area plus the equivalent gate area, where the equivalent gate area is computed by using the diode ratio vector.

- For diode mode 5, the equivalent gate area is computed using the maximum diode protection, which is 1.5, so the maximum antenna ratio for the net is  

$$\text{metal\_area} / 0.6 + ((1.5 + 0) * 1 + 0) = \text{metal\_area}/2.1$$
- For diode mode 6, the equivalent gate area is computed using the total diode protection, which is  $0.5+1.0+1.5=3.0$ , so the maximum antenna ratio for the net is  

$$\text{metal\_area} / 0.6 + ((3.0 + 0) * 1 + 0) = \text{metal\_area}/3.6$$

### Example for Diode Modes 7 and 8

Assume that the diode ratio vector is {0.7 0.0 150 800}; the layerMaxRatio value is 400; and the following diodes are connected to a single net: diode A with a diode-protection value of 0.5, diode B with a diode-protection value of 1.0, and diode C with a diode-protection value of 1.5.

For diode modes 7 and 8, the maximum antenna ratio is computed by dividing the metal area minus the equivalent metal area by the gate area, where the equivalent metal area is computed by using the diode ratio vector.

- For diode mode 7, the equivalent metal area is computed using the maximum diode protection, which is 1.5, so the maximum antenna ratio for the net is  

$$(\text{metal\_area} - ((1.5 + 0) * 150 + 800)) / \text{gate\_area} = (\text{metal\_area} - 1025) / \text{gate\_area}$$
- For diode mode 8, the equivalent metal area is computed using the total diode protection, which is  $0.5+1.0+1.5=3.0$ , so the maximum antenna ratio for the net is  

$$(\text{metal\_area} - ((3.0 + 0) * 150 + 800)) / \text{gate\_area} = (\text{metal\_area} - 1250) / \text{gate\_area}$$

### Reporting Antenna Rules

You can get a report of the metal layer antenna rules by using the `report_antenna_rules` command. For example,

```
icc_shell> report_antenna_rules -output ./antenna.rule design
```

## Removing Antenna Rules

You can remove the metal layer antenna rules you set by using the `remove_antenna_rules` command. For example,

```
icc_shell> remove_antenna_rules design
```

---

## Specifying Antenna Properties

You specify the pin and port antenna properties either in a cell library format (CLF) file or by using the `set_route_zrt_detail_options` command to set the following detail route options:

- `default_diode_protection`
- `default_gate_size`
- `default_port_external_gate_size`
- `default_port_external_antenna_area`
- `port_antenna_mode`

If you are using a hierarchical flow and create an interface logic model (ILM) or block abstraction model for a block, you must use the `extract_zrt_hier_antenna_property` command to extract the antenna information from the block to use at the next level of hierarchy.

You can set external antenna properties for all I/O ports or for a specified I/O port by using the `define_io_gate_size`, `define_io_diode_protection`, and `define_io_antenna_area` commands. To remove the definitions set by these commands, use the `remove_io_antenna_properties` command.

You can report the antenna properties set by these commands by using the `report_io_antenna_properties` command.

---

## Analyzing and Fixing Antenna Violations

If the Milkyway design library contains antenna rules, Zroute automatically analyzes and fixes antenna violations.

Just like other design rules, antenna rules are checked and corrected during detail routing. This concurrent antenna rule correction architecture reduces total runtime by minimizing the iterations.

By default, Zroute

- Checks antenna rules and corrects violations for all clock and signal nets

You can disable fixing of antenna violations on specific nets by using the `set_route_zrt_detail_options` command to set the `skip_antenna_fixing_for_nets` detail route option. Note that Zroute analyzes the antenna rules and reports the antenna violations on these nets, but does not fix the violations.

- Does not check or correct antenna rules for power and ground nets

To check and correct antenna rules for power and ground nets, use the `set_route_zrt_detail_options` command to set the `check_antenna_on_pg` detail route option to `true`.

- Starts fixing antenna violations in the second iteration, after initial routing is complete and the basic DRC violations have been fixed

You can change the iteration in which Zroute starts fixing antenna violations by using the `set_route_zrt_detail_options` command to set the `antenna_on_iteration` detail route option.

- Performs layer hopping to fix antenna violations

Layer hopping decreases the antenna ratio by splitting a large metal polygon into several upper-level polygons. Zroute performs the following types of layer hopping:

- Breaking the antenna with a higher-level metal segment

Zroute uses this technique to fix most antenna violations. For antenna violations happening at metal-N, inserting a small segment of metal-(N+1) close to the gate reduces the ratio between the remaining metal-N, making the ratio much lower. This approach is not suitable for fixing top-metal layer antennas when the output pin can provide only limited protection because there is no way for the router to break antenna violations at the topmost metal layer.

- Moving down to a lower-level metal

Zroute uses this technique to fix only topmost layer antenna violations when output pins provide only limited protection. For antenna violations happening at metal-N, replace part of the metal-N with metal-(N-1 or lower) to reduce the ratio. However, splitting the metal layer into many pieces might have a negative impact on RC and timing delay.

Zroute can also insert diodes to fix antenna violations. To enable the insertion of diodes to fix antenna violations, use the `set_route_zrt_detail_options` command to set the `insert_diodes_during_routing` detail route option to `true`. To force Zroute to fix antenna violations by inserting diodes, you can disable layer hopping by using the `set_route_zrt_detail_options` command to set the `hop_layers_to_fix_antenna` detail route option to `false`. For information about inserting diodes to fix antenna violations, see “[Inserting Diodes During Detail Routing](#)” on page 9-22.

If both layer hopping and diode insertion are enabled, by default, Zroute first tries to use layer hopping to fix the antenna violation. To change the preference to diode insertion, use the `set_route_zrt_detail_options` command to set the `antenna_fixing_preference` detail route option to `use_diodes`.

As with other design rule violations, antenna violations are reported at the end of each detail routing iteration. For example,

```
DRC-SUMMARY:  
@eeeeeee TOTAL VIOLATIONS =      506  
@eee Total number of instance ports with antenna violations =    1107
```

To disable the analysis and correction of antenna rules during detail routing, use the `set_route_zrt_detail_options` command to set the `antenna` detail route option to `false`.

```
icc_shell> set_route_zrt_detail_options -antenna false
```

To check for antenna violations, use the `verify_zrt_route -antenna` command. Due to the different connectivity models, do not use the `report_antenna_ratio` command on designs routed with Zroute. You can also run the `report_design -physical` command to report information about antenna violations.

---

## Inserting Diodes During Detail Routing

One way to protect gates from antenna effects is to provide a discharge path for the accumulated charge to leave the net. However, the discharge path should not allow current to flow during normal chip operation. Discharging can be accomplished by inserting a reverse-biased diode on the net close to the gate that is being protected.

To control diode insertion during detail routing, use the `set_route_zrt_detail_options` command to set various detail route options.

To enable diode insertion during detail routing, set the `insert_diodes_during_routing` detail route option to `true`. To specify a preference for fixing antenna violations by using diode insertion, set the `antenna_fixing_preference` detail route option to `use_diodes`. To require fixing of antenna violations by using diode insertion, you must disable layer hopping by setting the `hop_layers_to_fix_antenna` detail route option to `false`.

By default, when you enable diode insertion, Zroute can fix an antenna violation either by adding a new diode or by using an existing spare diode. Zroute determines which method to use, based on which is closest to the required location: an empty location for a new diode or an existing spare diode. You can specify a preference for using a new diode or using an existing spare diode by setting the `diode_preference` detail route option to `new` or `spare`, respectively.

**Note:**

To take advantage of spare diodes for antenna violation fixing, you need to add the spare diodes either before or after standard cell placement and before routing the areas where antenna violations might occur. For details, see “[Inserting Spare Cells](#)” on page 15-16.

If you want Zroute to use only one of these methods, set the `diode_insertion_mode` detail route option to `new` to force the insertion of new diodes or to `spare` to force the use of existing spare diodes. To reset the diode insertion method to the default behavior, set the `diode_insertion_mode` detail route option to `new_and_spare`.

When inserting new diodes, Zroute selects the diodes from the reference library and inserts them into existing open spaces. You can control which diodes are used by setting the `diode_libcell_names` detail route option. By default, Zroute reuses existing filler cell locations for diode insertion. You can prevent Zroute from reusing these locations by setting the `reuse_filler_locations_for_diodes` detail route option to `false`.

Zroute considers voltage areas when inserting diode cells and also observes the logic hierarchy assignments for diode cells.

- If a pin has an antenna violation, the diode cells are inserted at the same level of logic hierarchy as the violating pin.
- If a top-level port has an antenna violation, by default, the diode cells are inserted at the top level. However, if the port belongs to a voltage area, you can insert the diode cells in the logic hierarchy associated with the voltage area by setting the `use_lower_hierarchy_for_port_diodes` detail route option to true.

For information about setting the detail route options, see “[Setting Detail Route Options](#)” on page 8-45.

---

## Inserting Diodes After Detail Routing

You can fix antenna violations after detail routing by explicitly specifying which violations to fix and providing constraints for fixing them. Based on the specified constraints and the setting of the `diode_insertion_mode` detail route option, Zroute either inserts new diodes or reuses existing spare diodes to fix the specified violations.

To insert diodes after detail routing, use the `insert_zrt_diodes` command. When you use this command, you must specify the location of each antenna violation to fix by specifying the port and cell instance, the reference cell for the diode, the number of diodes to insert, the highest allowed routing layer used for connecting the diode, and the maximum distance from the specified pin that the diode can be inserted.

You use the following format to specify these values:

```
{port_name instance_name diode_reference number_of_diodes  
max_routing_layer max_routing_distance}
```

Note:

You can use this command to insert diodes for top-level ports by specifying the name of the top-level design for the cell instance.

If a diode cannot be inserted or reused within the specified distance, the tool does not insert a diode for that violation.

The `insert_zrt_diodes` command uses detail route options to control diode insertion. Use the `diode_insertion_mode` detail route option to control whether Zroute inserts new diodes or reuses spare diodes. Use the `reuse_filler_locations_for_diodes` detail route option to control whether filler cell locations can be reused. Use the `use_lower_hierarchy_for_port_diodes` detail route option to determine the logic hierarchy in which to insert the diodes for top-level ports. For information about setting the detail route options, see “[Setting Detail Route Options](#)” on page 8-45.

For example, to insert 2 Adiode diode cells to fix an antenna violation on the A port of the CI cell instance, where the diodes must be inserted using no higher layer than Metal5 and within 2.5 microns of the port, enter the following command:

```
icc_shell> insert_zrt_diodes {{A CI Adiode 2 metal5 2.5}}
```

For more information about the `insert_zrt_diodes` command, see the man page.

---

## Removing Diodes

To remove diodes, use the `remove_diode` command or choose Finishing > Remove Diodes in the GUI. The `remove_diode` command first disconnects all the diode ports on all the specified nets; then it removes the diode cells that are fully disconnected. For example,

```
icc_shell> remove_diode -nets net_name
icc_shell> remove_diode -nets [get_nets -hierarchical net_name]
```

---

## Inserting Redundant Vias

Redundant via insertion is an important design-for-manufacturing (DFM) feature that is supported by Zroute throughout the routing flow. In each routing stage, Zroute concurrently optimizes via count as well as wire length. The redundant via result is measured by the redundant via conversion rate, which is defined as the percentage of single vias converted into redundant vias. You should also pay attention to the number of unoptimized single vias. If a design has fewer unoptimized single vias, it is usually better for DFM. The following sections describe how to insert redundant vias:

- [Inserting Redundant Vias on Clock Nets](#)
- [Inserting Redundant Vias on Signal Nets](#)

---

## Inserting Redundant Vias on Clock Nets

Zroute can insert redundant vias on clock nets either during or after routing. This section describes how to insert redundant vias during clock routing. For information about postroute redundant via insertion, see “[Postroute Redundant Via Insertion](#)” on page 9-29.

To insert redundant vias on clock nets during clock routing,

1. Specify the redundant vias in a nondefault routing rule by using the `-via_cuts` option of the `define_routing_rule` command.

```
icc_shell> define_routing_rule clock_via_rule \
    -via_cuts {{V12 2x1 R} {V12 2x1 NR} {V12 1x2 R} {V12 1x2 NR} \
    {V23 2x1 R} {V23 2x1 NR} {V23 1x2 R} {V23 1x2 NR}}
```

Be sure to consider both DFM and routing when you select the redundant vias; otherwise, if you select the redundant vias based only on DFM considerations, you could negatively impact the routability.

In addition to using nondefault routing rules to define the redundant vias for clock nets, you can also use them to define stricter wire width and spacing rules and to define the tapering distance. For more information about nondefault routing rules, see “[Using Nondefault Routing Rules](#)” on page 8-22.

2. Assign the nondefault routing rule to the clock nets by using the `-routing_rule` option of the `set_clock_tree_options` command.

```
icc_shell> set_clock_tree_options -routing_rule clock_via_rule
```

3. Run clock tree synthesis.

```
icc_shell> set_delay_calculation -clock_arnoldi
icc_shell> clock_opt -only_cts -no_clock_route
```

4. Route the clock nets.

```
icc_shell> route_zrt_group -all_clock_nets \
    -reuse_existing_global_route true
```

Zroute reserves space for the redundant vias during global routing and inserts the redundant vias during detail routing.

---

## Inserting Redundant Vias on Signal Nets

You can perform redundant via insertion in the following ways:

- Postroute redundant via insertion
- Concurrent soft-rule-based redundant via insertion
- Near 100 percent redundant via insertion

In general, you should start with postroute redundant via insertion. If postroute redundant via insertion results in a redundant via rate of at least 80 percent, you can try to improve the redundant via rate by using concurrent soft-rule-based redundant via insertion. If postroute redundant via insertion results in a redundant via rate of at least 90 percent, you can try to improve the redundant via rate by using near 100 percent redundant via insertion.

Note:

As the redundant via rate increases, it becomes more difficult to converge on the routing design rules and you might see a reduction in signal integrity; therefore, you should use near 100 percent redundant via insertion only for those designs that truly require such a high redundant via rate. In addition, achieving very high redundant via rates might require you to modify the floorplan utilization to allow enough space for the redundant vias.

The following sections describe the default via mapping table, how to define a customized via mapping table, how to insert redundant vias by using various methods, and how to report the redundant via rate.

## Viewing the Default Via Mapping Table

By default, Zroute reads the default contact codes from the technology file and generates an optimized via mapping table. In most cases you achieve better results if you use a customized mapping table rather than the default mapping table. The following section, “[Defining a Customized Via Mapping Table](#)” describes how to define a customized mapping table.

If you have not previously defined a customized mapping table for the design, you can see the default mapping table by using the `insert_zrt_redundant_vias -list_only` command (or choose Route > Insert Redundant Vias in the GUI and select “List redundant via mappings”).

Note:

After you have created a customized mapping table by using the method described in the following section, “[Defining a Customized Via Mapping Table](#),” this command shows the customized mapping table.

[Example 9-1](#) shows an example of a default via mapping table.

***Example 9-1 Default Via Mapping Table***

```
icc_shell> insert_zrt_redundant_vias -list_only
...
#
# The currently defined command

define_zrt_redundant_vias \
    -from_via { VIA12A VIA12B VIA23 VIA34 VIA45 VIA56 } \
    -to_via { VIA12A VIA12A VIA23 VIA34 VIA45 VIA56 } \
    -to_via_x_size { 2 2 2 2 2 2 } \
    -to_via_y_size { 1 1 1 1 1 1 } \
    -to_via_weights { 1 1 1 1 1 1 } \
    #

#
# The define command with all possible mappings (not recommended)

#define_zrt_redundant_vias \
# -from_via { VIA12A VIA12A VIA12B VIA12B VIA23 VIA34 VIA45 VIA56 \
#   VIA12f VIA23f VIA34f VIA45f VIA56f } \
# -to_via { VIA12A VIA12B VIA12A VIA12B VIA23 VIA34 VIA45 VIA56 \
#   VIA12f VIA23f VIA34f VIA45f VIA56f } \
# -to_via_x_size { 2 2 2 2 2 2 2 } \
#   2 2 2 2 2 } \
# -to_via_y_size { 1 1 1 1 1 1 1 } \
#   1 1 1 1 1 } \
# -to_via_weights { 1 1 1 1 1 1 1 } \
#   1 1 1 1 1 } \
```

**Defining a Customized Via Mapping Table**

To define a customized mapping table, use the `define_zrt_redundant_vias` command (or choose Route > Define Redundant Vias in the GUI). The mappings defined by the `define_zrt_redundant_vias` command are saved in the Milkyway design database. When you run the `define_zrt_redundant_vias` command, any existing mappings are overwritten; only the latest mappings are saved.

The vias listed in the `-from_via` and `-to_via` options can be via masters defined in the technology file or design-specific via masters created by the `create_via_master` command. The vias listed in the `-from_via` option must be parameter-based via masters. The vias listed in the `-to_via` option can be parameter-based via masters or H-shaped rectangle-based via masters. For information about creating design-specific via masters, see “[Creating Design-Specific Via Masters](#)” on page 8-20.

By default, all mappings have the same priority, and Zroute selects the redundant vias to use based on routability. You can specify preferred redundant via mappings by using the `-to_via_weights` option to assign a weight value between 1 and 10 to each redundant via in the mapping table. During redundant via insertion, Zroute uses the higher weighted redundant vias first.

The syntax of the `define_zrt_redundant_vias` command is

```
define_zrt_redundant_vias
  [-from_via {list_of_from_vias}]
  [-from_via_x_size {list_of_number_of_contacts}]
  [-from_via_y_size {list_of_number_of_contacts}]
  [-from_via_array_mode off | swap | rotate | all]
  [-to_via {list_of_to_vias}]
  [-to_via_x_size {list_of_number_of_contacts}]
  [-to_via_y_size {list_of_number_of_contacts}]
  [-to_via_weights {list_of_weights}]
```

[Example 9-2](#) shows an example of using the `define_zrt_redundant_vias` command to define a customized via mapping table. Note that the weights must be integers between 1 and 10, where 1 is the lowest weight and 10 is the highest weight. Via mappings that have a higher weight are preferred over via mappings that have a lower weight.

#### *Example 9-2 Customized Via Mapping Table*

```
icc_shell> define_zrt_redundant_vias \
  -from_via { VIA12 VIA12 VIA23 VIA23 VIA34 VIA34 VIA45 VIA56S \
    VIA6STG VIATGAL VIA12E VIA12E VIA23E VIA23E VIA34E \
    VIA34E VIA45E VIA56SE VIA12T VIA12T VIA23T VIA23T \
    VIA34T VIA34T } \
  -to_via { VIA12T VIA12 VIA23T VIA23 VIA34T VIA34 VIA45 VIA56S \
    VIA6STG VIATGAL VIA12T VIA12 VIA23T VIA23 VIA34T \
    VIA34 VIA45 VIA56S VIA12T VIA12 VIA23T VIA23 \
    VIA34T VIA34 } \
  -to_via_x_size { 2 2 2 2 2 2 2 2 2 \
    2 2 2 2 2 2 2 \
    2 2 2 2 2 2 2 \
    2 2 } \
  -to_via_y_size { 1 1 1 1 1 1 1 1 \
    1 1 1 1 1 1 1 \
    1 1 1 1 1 1 1 \
    1 1 } \
  -to_via_weights { 5 1 5 1 5 1 1 1 \
    1 1 1 1 1 1 1 \
    1 1 1 1 1 1 1 \
    1 1 }
```

For more information about the `define_zrt_redundant_vias` command, see the man page.

To see the via mapping table associated with a design, use the `insert_zrt_redundant_vias -list_only` command (or choose Route > Insert Redundant Vias in the GUI and select “List redundant via mappings”). If you have defined a customized mapping table for the design, this command shows the customized mapping table; otherwise, it shows the default mapping table.

## Postroute Redundant Via Insertion

To perform postroute redundant via insertion, use the `insert_zrt_redundant_vias` command (or choose Route > Insert Redundant Vias in the GUI).

This command can replace single-cut vias with multiple-cut via arrays, single-cut vias with other single-cut vias that have a different contact code, and multiple-cut via arrays with different multiple-cut via arrays. During redundant via insertion, the detail router also checks the design rules within the neighboring partition to minimize DRC violations.

By default, the `insert_zrt_redundant_vias` command inserts redundant vias on all nets. To insert redundant vias only on specific nets, use the `-nets` option to specify the nets. Using net-specific redundant via insertion allows you to further improve the optimized via rate without causing large-scale routing and timing changes.

After the vias are checked and replaced, the detail router rechecks for DRC violations and runs iterations to correct any violations. Specify the number of detail routing iterations by using the `set_route_zrt_detail_options` command to set the `max_number_iterations` detail route option.

### Note:

When you insert redundant vias in a multicorner-multimode design, Zroute uses only the current scenario.

If the percentage of redundant vias is not high enough, you can increase the effort level by using the `-effort` option to get a better redundant via rate. Increasing the effort level to high can increase the redundant via rate by about 3 to 5 percent by shifting the vias to make room for additional vias. However, because high-effort redundant via insertion moves the vias more, it can result in a less lithography-friendly pattern at the 45 nm technology node and below. In this case, you should use concurrent soft-rule-based redundant via insertion to improve the redundant via rate.

You can also try to increase the postroute redundant via rate by using the `set_route_zrt_detail_options` command to set the `optimize_wire_via_effort_level` detail route option to `high`, which reduces the number of single vias and makes more room for redundant vias by reducing wire length.

After you perform the initial postroute redundant via insertion, use the `set_route_zrt_common_options` command to set the `post_detail_route_redundant_via_insertion` common route option to enable automatic insertion of redundant vias after subsequent detail routing or ECO routing. This helps to maintain the redundant via rate in your design.

You can also perform redundant via insertion during the `route_opt` flow by using the `set_route_zrt_common_options` command to set the `post_detail_route_redundant_via_insertion` common route option before running `route_opt`.

## Concurrent Soft-Rule-Based Redundant Via Insertion

Soft-rule-based redundant via insertion can improve the redundant via rate by reserving space for the redundant vias during routing. You can use concurrent soft-rule-based redundant via insertion during both initial routing and ECO routing. The actual via insertion is not done during routing; you must still perform postroute redundant via insertion by using the `insert_zrt_redundant_vias` command.

Note:

Reserving space during routing increases the routing runtime. You should use this method only when needed to improve the redundant via rate beyond that provided by postroute redundant via insertion and the postroute approach resulted in a redundant via rate of at least 80 percent.

To perform concurrent soft-rule-based redundant via insertion,

1. (Optional) Define the via mapping table as described in “[Defining a Customized Via Mapping Table](#)” on page 9-27.
2. Enable concurrent soft-rule-based redundant via insertion.

By default, concurrent redundant via insertion is disabled.

- To enable concurrent soft-rule-based redundant via insertion during initial routing, use the `set_route_zrt_common_options` command to set the `concurrent_redundant_via_mode` common route option to `reserve_space`.

```
icc_shell> set_route_zrt_common_options \
-concurrent_redundant_via_mode reserve_space
```

You can control the effort used to reserve space for the redundant vias during initial routing by using the `set_route_zrt_common_options` command to set the `concurrent_redundant_via_effort_level` common route option. By default, Zroute uses low effort. The higher effort levels result in a better redundant via conversion rate at the expense of runtime. The low and medium efforts affect only global routing and track assignment, while high effort also affects detail routing, which can impact design rule convergence.

Note:

If you set the `placer_enable_enhanced_router` variable to `true` and enable the `concurrent_redundant_via_mode` option before running the `place_opt -congestion` command, the redundant vias are considered during congestion estimation.

- To enable concurrent soft-rule-based redundant via insertion during ECO routing, use the `set_route_zrt_common_options` command to set the `eco_route_concurrent_redundant_via_mode` common route option to `reserve_space`.

```
icc_shell> set_route_zrt_common_options \
-eco_route_concurrent_redundant_via_mode reserve_space
```

You can control the effort used to reserve space for the redundant vias during ECO routing by using the `set_route_zrt_common_options` command to set the `eco_route_concurrent_redundant_via_effort_level` common route option.

**Note:**

Using concurrent soft-rule-based redundant via insertion during ECO routing can impact timing and design rule convergence. In general, you should use this method only when you used near 100 percent redundant via insertion during initial routing.

3. Route the design.

During routing, Zroute reserves space for the redundant vias and fixes hard design rule violations.

4. Perform postroute redundant via insertion.

During postroute redundant via insertion, Zroute inserts the redundant vias in the reserved locations.

## Near 100 Percent Redundant Via Insertion

You can achieve a redundant via rate near 100 percent by using hard-rule-based redundant via insertion. Hard-rule-based redundant via insertion can improve the redundant via rate by treating redundant vias as hard design rules during routing. You can use nearly 100 percent redundant via insertion only during initial routing; this method is not supported during ECO routing. When you use near 100 percent redundant via insertion during initial routing, you should use soft-rule-based redundant via insertion during ECO routing to preserve the redundant via rate achieved during initial routing.

**Note:**

This method can result in a very large runtime increase for congested designs. You should use this method only when needed to improve the redundant via rate beyond that provided by concurrent soft-rule-based redundant via insertion and the soft-rule-based approach resulted in a redundant via rate of at least 90 percent.

To perform concurrent hard-rule-based redundant via insertion,

1. (Optional) Define the via mapping table as described in “[Defining a Customized Via Mapping Table](#)” on page 9-27.
2. Enable nearly 100 percent via insertion by using the `set_route_zrt_common_options` command to set the `concurrent_redundant_via_mode` common route option to `insert_at_high_cost`. (By default, concurrent redundant via insertion is disabled.)

```
icc_shell> set_route_zrt_common_options \
-concurrent_redundant_via_mode insert_at_high_cost
```

You can control the effort used to reserve space for the redundant vias by using the `set_route_zrt_common_options` command to set the `concurrent_redundant_via_effort_level` common route option.

**Note:**

If you enable the `concurrent_redundant_via_mode` option before running the `place_opt -congestion` command, the redundant vias are considered during congestion estimation.

3. Route the design.

During routing, Zroute inserts the redundant vias and fixes hard design rule violations. In general, redundant via insertion has the same priority as other hard design rules; however, if design rule checking does not converge during detail routing, Zroute automatically relaxes the redundant via constraints to improve DRC convergence.

## Preserving Timing During Redundant Via Insertion

When you insert redundant vias, it changes the timing of your design. Short nets tend to slow down due to increased capacitance, whereas long nets tend to speed up due to decreased resistance. Zroute redundant via insertion has a timing-preservation mode that allows you to perform redundant via insertion without impacting the design timing by preventing insertion of redundant vias on critical nets.

To enable timing-preservation mode for redundant via insertion, define the timing preservation constraints by using the following options of the `insert_zrt_redundant_vias` command:

- `-timing_preserve_setup_slack_threshold`
- `-timing_preserve_hold_slack_threshold`
- `-timing_preserve_nets`

You should timing-preservation mode only at the end of the flow, after using the normal redundant via insertion flows, which converge both the redundant via rate and the timing QoR. Timing-preservation mode can slightly increase the redundant via rate while maintaining timing. However, if you use timing-preservation mode earlier in the flow, before timing is met, it might severely reduce the redundant via rate due to critical nets.

## Maximizing the Redundant Via Rate

To maximize the redundant-via insertion rate, use the following flow to insert redundant vias:

1. (Optional) Define the via mapping (`define_zrt_redundant_vias`).
2. Route the design (`route_opt -initial_route_only`).
3. Perform postroute redundant via insertion (`insert_zrt_redundant_vias`).

For details about the postroute redundant via insertion flow, including how to increase the redundant via rate when using this flow, see [“Postroute Redundant Via Insertion” on page 9-29](#).

If postroute redundant via insertion achieves an 80 percent redundant via rate and you need a higher rate, you can try soft-rule-based concurrent redundant via insertion. For details about this flow, see [“Concurrent Soft-Rule-Based Redundant Via Insertion” on page 9-30](#).

If postroute redundant via insertion achieves a 90 percent redundant via rate and you need a higher rate, you can try near 100 percent redundant via insertion. For details about this flow, see [“Near 100 Percent Redundant Via Insertion” on page 9-31](#).

4. Enable concurrent redundant via insertion to maintain the redundant via rate during additional routing operations (`set_route_zrt_common_options -post_detail_route_redundant_via_insertion medium`).

If you used near 100 percent redundant via insertion during initial routing, you should also enable soft-rule-based concurrent redundant via insertion during ECO routing (`set_route_zrt_common_options -eco_route_concurrent_redundant_via_mode reserve_space`).

5. Perform postroute optimization (`route_opt -skip_initial_route`).
6. Perform DFM tasks.
7. Perform incremental postroute optimization (`route_opt -incremental -size_only`)
8. Insert redundant vias using timing-preservation mode.

## Reporting Redundant Via Rates

After redundant via insertion, whether concurrent or postroute, Zroute generates a redundant via report that provides the following information:

- The via conversion rate for nondefault vias

The via conversion rate for nondefault vias is listed at the top of the report as the total optimized via conversion rate.

- The optimized via conversion rate for each layer

The optimized via conversion rate includes both double vias and DFM-friendly bar vias, which have a single cut but a larger metal enclosure.

Note:

The optimized via conversion rate is not useful if you are using bar vias.

- The distribution of optimized vias by weight for each layer

To determine the via conversion rate for conversions above a certain weight, you must add the reported conversion rates for those weights. For example, in [Example 9-3](#), the via conversion rate for weight 5 and above for layer V03 is  $10.75+64.50=75.25\%$ .

For information about assigning weights to redundant via mappings, see “[Defining a Customized Via Mapping Table](#)” on page [9-27](#).

Note:

The conversion rate for nonweighted vias is reported as “Un-optimized.”

- The total double via conversion rate for the design

[Example 9-3](#) shows an example of the redundant via report.

**Example 9-3 Redundant Via Report**

```
Total optimized via conversion rate = 96.94% (1401030 / 1445268 vias)
Layer V01      = 41.89% (490617 / 1171301 vias)
    Weight 10   = 9.64% (112869 vias)
    Weight 5    = 32.25% (377689 vias)
    Weight 1    = 0.01% (59 vias)
    Un-optimized = 58.11% (680684 vias)
Layer V02      = 76.20% (1567822 / 2057614 vias)
    Weight 10   = 43.51% (895270 vias)
    Weight 5    = 28.62% (588805 vias)
    Weight 1    = 4.07% (83747 vias)
    Un-optimized = 23.80% (489792 vias)
Layer V03      = 81.87% (687115 / 839297 vias)
    Weight 10   = 64.50% (541369 vias)
    Weight 5    = 10.75% (90224 vias)
    Weight 1    = 6.62% (55522 vias)
    Un-optimized = 18.13% (152182 vias)
Layer V04      = 81.60% (226833 / 277977 vias)
    Weight 10   = 81.45% (226418 vias)
    Weight 1    = 0.15% (415 vias)
    Un-optimized = 18.40% (51144 vias)
...
Layer V09      = 85.47% (1329 / 1555 vias)
    Weight 10   = 85.47% (1329 vias)
    Un-optimized = 14.53% (226 vias)

Total double via conversion rate = 46.69% (2158006 / 4622189 vias)
```

You can also use the `report_design -physical` command to report the double via rate. This command reports the double via rate per layer, but does not provide any weighting information.

## Optimizing Wire Length and Via Count

During detail routing, Zroute optimizes wire length and via count in the areas where DRC violations occur; however, it does not optimize the layout in areas where no DRC violations occur.

To improve the manufacturing yield, you can use the `optimize_zrt_wire_via` command to perform standalone optimization of wire length and via count after performing detail routing and redundant via insertion.

The syntax for the `optimize_zrt_wire_via` command is

```
optimize_zrt_wire_via
[-nets nets -reroute_all_shapes_in_nets true | false]
[-max_detail_route_iterations count]
```

By default, Zroute selects the nets to reroute based on the overall cost. For each selected net, Zroute determines whether to reroute all the shapes in the net or just a portion of them. If you want to select the nets to reroute, use the `-nets` option to specify the nets. When you specify the nets to optimize, you can also use the `-reroute_all_shapes_in_nets` option to control whether Zroute must reroute all the associated net shapes.

By default, Zroute performs a maximum of 40 detail routing iterations to fix DRC violations that exist after the optimization. You can use the `-max_detail_route_iterations` option to control the maximum number of detail routing iterations.

For more information about the `optimize_zrt_wire_via` command, see the man page.

---

## Reducing Critical Areas

A critical area is a region of the design where, if the center of a random particle defect falls there, the defect causes circuit failure, thereby reducing yield. A conductive defect causes a short fault, and a nonconductive defect causes an open fault.

The following sections describe how to

- Report critical areas
- Display critical area maps
- Reduce critical area short faults by performing wire spreading
- Reduce critical area open faults by performing wire widening

---

## Reporting Critical Areas

After routing is complete, you can report layout-critical areas that are susceptible to random particle defects, which cause shorts and opens during the fabrication process.

The results from the critical area analysis report are output to an `output_heatmap` text file. You can see the critical area results graphically by displaying critical area heat maps.

To report critical areas, use the `report_critical_area` command (or choose Finishing > Report Critical Area Map in the GUI).

**Table 9-5** describes the `report_critical_area` options. For more information, see the man page.

*Table 9-5 report\_critical\_area Command Options*

| Command option                                                                                                  | Description                                                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-fault_type short   open</code><br>("Fault type" options in the GUI)                                      | Specifies the type of fault to check for.<br>The default is <code>short</code> .                                                                                                     |
| <code>-particle_distr_func_file file_name</code><br>("Particle distribution function file" box in the GUI)      | The name of the input file that contains the particle distribution function to be used during the calculation.<br>By default, Zroute uses an internal particle probability function. |
| <code>-suppress_zeros_in_report</code><br>("Suppress zeros in report" check box in the GUI)                     | Prevents reporting of zero results.<br>By default, all results are reported.                                                                                                         |
| <code>-multiparticle_report_format true   false</code><br>("Multi particle report format" check box in the GUI) | Outputs a report containing the critical area analysis result of each individual particle size.<br>By default, Zroute outputs normalized results.                                    |
| <code>-tsmc_encr_particle_distr_file</code><br>("TSMC encrypted format" check box in the GUI)                   | Specifies that the particle distribution function file is in TSMC encrypted format.                                                                                                  |
| <code>-layer_alias_DSD_format {X Y Z T R}</code><br>("Metal scheme directives" boxes in the GUI)                | Specifies the layer alias used for defect size distribution (DSD) of each layer.                                                                                                     |
| <code>-input_layers layers</code><br>("Input layer" list in the GUI)                                            | Specifies the metal layers for which the critical area is calculated.<br>By default, the critical area is calculated for all metal layers.                                           |

Often the particle probability function is considered sensitive data. When security for a sensitive particle distribution file from a foundry is of concern, use the `process_particle_probability_file` command, which provides a way to encrypt and decrypt the particle probability function. Critical area analysis can work with such an encrypted particle probability function.

A secret key is used to encrypt the particle probability function. The encrypted file cannot be decrypted without the key. To encrypt and decrypt a particle probability function file, use the `process_particle_probability_file` command. The syntax of this command is

```
process_particle_probability_file  
-key string  
-input_file file_name  
-output_file file_name
```

Critical area analysis takes the encrypted file as its input and processes it without the key. The output is the heat map based on the encrypted particle probability function; it is in text format. The text format of the particle probability function is still accepted as input to critical area analysis. If an encrypted file is given as input, the file is internally decrypted and used.

Critical area analysis takes the encrypted file as its input and processes it without the key. The output is the heat map based on the encrypted particle probability function; it is in text format. The text format of the particle probability function is still accepted as input to critical area analysis. If an encrypted file is given as input, the file is internally decrypted and used.

---

## Displaying Critical Area Maps

Critical area maps provide an indication of places where a chip might fail due to particle defects, causing shorts and opens.

To display a critical area map for the current design,

1. Specify the type of defect to display by choosing one of the following:
  - Finishing > Short Critical Area Map
  - Finishing > Open Critical Area MapThe Map Mode panel appears.
2. Select a metal layer for which critical area shorts or opens are to be displayed.
3. Modify the critical heat ranges by changing or removing the maximum or minimum threshold values.
4. Adjust other display parameters. You can make text visible in the map.
5. Click **Apply**.

To update the critical area map data after you perform wire spreading, click **Reload**. This action opens the (Re)Calculate Short Critical Area Map Data dialog box, from which you can run the `report_critical_area -fault_type short` command.

To update the critical area map data after you perform wire widening, click Reload. This action opens the (Re)Calculate Open Critical Area Map Data dialog box, from which you can run the `report_critical_area -fault_type open` command.

For more information about using critical area maps, see the “Examining Critical Area Maps” topic in IC Compiler Help.

## Performing Wire Spreading

After you have performed detail routing and redundant via insertion, you can perform wire spreading to increase the average spacing between wires, which reduces the critical area short faults and therefore improves yield.

To perform wire spreading, use the `spread_zrt_wires` command (or choose Finishing > Route Spread Wires in the GUI).

By default, the `spread_zrt_wires` command spreads the signal wires on the same layer by half a pitch in the preferred direction. You can change the spread distance by using the `-pitch` option. By default, the minimum jog length is twice the layer pitch and the minimum jog spacing is the minimum spacing for the layer plus one half the pitch for the layer. You can modify the minimum jog length by using the `-min_jog_length` option. You specify the minimum jog length as the ratio of jog length to layer pitch. You can modify the minimum jog spacing by using the `-min_jog_spacing_by_layer_name` option. You specify the minimum jog spacing in microns for each layer.

[Figure 9-3](#) shows how the jog length and jog spacing values are used in wire spreading.

*Figure 9-3 Wire Spreading Results*



In the following example, the minimum jog length is set to three times the layer pitch, the minimum jog spacing for metal1 is set to 0.07 microns, and the minimum jog spacing for metal2 is 0.08 microns. All other metal layers use the default minimum jog spacing.

```
icc_shell> spread_zrt_wires -min_jog_length 3 \
    -min_jog_spacing_by_layer_name {{metal1 0.07} {metal2 0.08}}
```

After spreading, the `spread_zrt_wires` command performs detail routing iterations to fix any DRC violations caused as a result of spreading.

When you change the layout, it can change the timing of your design. Zroute wire spreading has a timing-preservation mode that allows you to perform wire spreading without impacting the design timing.

To enable timing-preservation mode for wire spreading, define the timing preservation constraints by using the following options of the `spread_zrt_wires` command:

- `-timing_preserve_setup_slack_threshold threshold`
- `-timing_preserve_hold_slack_threshold threshold`
- `-timing_preserve_nets nets`

The threshold values are floating-point numbers in library units. Wire spreading is performed only on nets with slack greater than or equal to the specified values or those specified in the `-timing_preserve_nets` option, as well as adjacent nets on the same layer within two routing pitches.

---

## Performing Wire Widening

After you have performed detail routing, redundant via insertion, and wire spreading, you can perform wire widening to increase the average width of the wires, which reduces the critical area open faults and therefore improves yield.

To perform wire widening, use the `widen_zrt_wires` command (or choose Finishing > Route Widen Wires in the GUI).

When you perform wire widening, the spacing between neighboring wires is decreased, which can reduce the improvement in critical area shorts gained from wire spreading. You can control the tradeoff between wire spreading and wire widening by using the `-spreading_widening_relative_weight` option. By default, wire spreading and wire widening are given equal priority. To weight the priority toward wire widening and reduced critical area open faults, set this option to a value between 0.0 and 0.5. To weight the priority toward wire spreading and reduced critical area short faults, set this option to a value between 0.5 and 1.0.

By default, the `widen_zrt_wires` command widens all wires in the design to 1.5 times their original width. For more flexibility, you can use the `-widen_widths_by_layer_name` option to define up to five possible wire widths to use for each layer. For example, to define possible wire widths of 0.07 and 0.06 microns for metal1; wire widths of 0.08 and 0.07 microns for metal2; and 1.5 times the existing wire width for all other layers, enter the following command:

```
icc_shell> widen_zrt_wires \
    -widen_widths_by_layer_name {{metal1 0.07 0.06} {metal2 0.08 0.07}}
```

After spreading, the `widen_zrt_wires` command performs detail routing iterations to fix any DRC violations caused as a result of widening. Note that the widened wires do not trigger fat wire spacing rules.

When you widen the wires, it changes the timing of your design. Zroute wire widening has a timing-preservation mode that allows you to perform wire widening without impacting the design timing.

To enable timing-preservation mode for wire widening, define the timing preservation constraints by using the following options of the `widen_zrt_wires` command:

- `-timing_preserve_setup_slack_threshold threshold`
- `-timing_preserve_hold_slack_threshold threshold`
- `-timing_preserve_nets nets`

The threshold values are floating-point numbers in library units. Wire widening is not performed on nets with slack less than the specified values or those specified in the `-timing_preserve_nets` option.

---

## Shielding Nets

The router shields routed nets by generating shielding wires that are based on the shielding widths and spacing defined in the shielding rules. In addition to shielding nets on the same layer, you also have the option to shield one layer above or one layer below or the layer above and the layer below. Shielding above or below the layer is called *coaxial shielding*. [Figure 9-4](#) shows an example of coaxial shielding. Coaxial shielding provides even better signal isolation than same-layer shielding, but it uses more routing resources.

*Figure 9-4 Coaxial Shielding*



You can perform shielding either before or after signal routing. Shielding before signal routing, which is referred to as preroute shielding, provides better shielding coverage but can result in congestion issues during signal routing. Preroute shielding is typically used to shield critical clock nets. Shielding after signal routing, which is referred to as postroute shielding, has a very minimal impact on routability, but provides less protection to the shielded nets. [Figure 9-5](#) shows the Zroute shielding flow, which is described in the sections that follow.

*Figure 9-5 Zroute Shielding Flow*



## Defining the Shielding Rules

Before you perform shielding, you must

1. Define the shielding rules.

To define shielding rules, use the `-shield_spacings` and `-shield_widths` options of the `define_routing_rule` command. For example, to specify a shielding rule that uses spacing of 0.1 microns and width of 0.1 microns for metal1 through metal5 and spacing of 0.3 microns and width of 0.3 microns for metal6, enter the following command:

```
icc_shell> define_routing_rule shield_rule \
    -shield_widths {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3} \
    -shield_spacings {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3}
```

For more information about the `define_routing_rule` command, see “[Defining Nondefault Routing Rules](#)” on page 8-22.

## 2. Assign shielding rules to the nets to be shielded.

To avoid congestion issues and achieve the best balance of DRC convergence and timing closure, you should apply shielding rules only to high-frequency or critical clock nets and apply double-spacing rules to the lower-frequency clock nets.

Use the `set_clock_tree_options` command to assign shielding rules to clock nets. For signal nets, use the `set_net_routing_rule` command to assign the shielding rules.

Note:

The `set_clock_tree_options` command assigns shielding rules to clock nets only before clock tree synthesis. After clock tree synthesis, you must use the `set_net_routing_rule` command to assign shielding rules to clock nets.

For more information about these commands, see “[Applying Nondefault Routing Rules](#)” on page 8-31.

---

## Performing Preroute Shielding

To provide the most protection for critical clock nets, perform shielding on those nets after clock tree routing but before signal net routing.

To add shielding to the routed clock nets based on the assigned shielding rules, use the `create_zrt_shield` command (or choose Route > Create Shield in the GUI).

By default, the `create_zrt_shield` command performs same-layer shielding on all nets with predefined shielding rules. The shielding wires are tied to ground, standard cell power and ground pins, and standard cell rails.

To explicitly specify the nets on which to perform shielding, use the `-nets` option. To tie the shielding wires to a named power or ground net, use the `-with_ground` option. To prevent connections to the standard cell power and ground pins, use the `-ignore_shielding_net_pins` option. To prevent connections to the standard cell rails, use the `-ignore_shielding_net_rails` option.

By default, Zroute creates the shielding wires such that they surround the shielded routing shape. To trim the shielding wires so that they align with the shielded routing shape ends, set the `-align_to_shape_end` option to `true`. To force Zroute to create shielding wires only in the preferred direction, set the `-preferred_direction_only` option to `true`. Note that the `-preferred_direction_only` option does not honor route guides to change the preferred routing direction. When you set either of these options to `true`, extra effort is required to connect the shielding wires to the power and ground network and any shielding wires that are not connected to the power and ground network are deleted.

To perform coaxial shielding, use the `-coaxial_above` and `-coaxial_below` options. By default, the `create_zrt_shield` command leaves one routing track open between each used track. For coaxial shielding above the shielded net segment layer (`-coaxial_above true`), you control the number of open tracks between used tracks by using the `-coaxial_above_skip_tracks` option. For coaxial shielding below the shielded net segment layer (`-coaxial_below true`), you control the number of open tracks between used tracks by using the `-coaxial_below_skip_tracks` option. For either of these options, you can specify a value between zero and seven.

If the generated coaxial shielding wires violate minimum area or minimum length rules, Zroute automatically patches the wires to satisfy these design rules.

For example, to perform coaxial shielding below the shielded net segment layer on the clock nets, prevent signal routing below the shielded net segment layer, and tie the shielding wires to VSS, enter

```
icc_shell> create_zrt_shield -nets $clock_nets \
    -coaxial_below true -coaxial_below_skip_tracks 0 \
    -with_ground vss
```

When you run the `create_zrt_shield` command, it reports the shielding ratio achieved for each net, as shown in the following example:

```
Shielded 100% side-wall of (CLK_G1B2I2)
Shielded 100% side-wall of (CLK_G1B2I3)
Shielded 100% side-wall of (CLK_G1B2I6)
Shielded 100% side-wall of (CLK_G1B2I8)
Shielded 100% side-wall of (CLK_G1B2I4)
Shielded 100% side-wall of (CLK_G1B2I7)
Shielded 100% side-wall of (CLK_G1B1I1)
Shielded 100% side-wall of (CLK_G1B1I2)
Shielded 100% side-wall of (CLK)
Shielded 204 nets with average ratio of 100.00%)
```

By default, the power and ground structure is not included in the shielding ratio calculation. To include the power and ground structure within a threshold distance in the shielding ratio calculation, use the `set_route_zrt_common_options` command to set the `pg_shield_distance_threshold` common route option, which specifies the distance threshold in microns.

```
icc_shell> set_route_zrt_common_options \
    -pg_shield_distance_threshold distance
```

Note that this option affects only the shielding ratio calculation and does not change the routing behavior.

---

## Soft Shielding Rules During Signal Routing

Zroute considers shielding rules as soft rules during signal routing. If a net has a shielding rule and is not shielded before signal routing, Zroute reserves shielding space during the whole routing process, global routing, track assignment, and detail routing. At the end of detail routing, it reports the shielding space violations and the locations where shielding wires cannot be established. The following log file example shows shielding soft spacing violations, which are highlighted in bold text:

```
DRC-SUMMARY:  
@{@{@{@@ @@@@ TOTAL VIOLATIONS = 13  
Diff net var rule spacing : 2  
Same net spacing : 2  
Less than minimum area : 4  
Short : 1  
Soft spacing (shielding) : 2
```

Signal routing only reserves space for the shielding; it does not actually insert it. You must run `create_zrt_shield` after signal routing to physically place the shielding wires. The reported soft rule violations help you to understand the shielding rate. Note that the router reserves space only for same-layer shielding and not for coaxial shielding; therefore, postroute coaxial shielding can produce a very low shielding rate.

---

## Performing Postroute Shielding

To perform postroute shielding, you use the same command, `create_zrt_shield`, that is used for preroute shielding.

If you want to use the default spacings and widths from the technology file for postroute shielding, you do not need to define and assign nondefault routing rules. If you specify the nets to be shielded by using the `-nets` option, `create_zrt_shield` shields these nets with the default spacing and widths.

Postroute shielding should introduce few to no DRC violations. If DRC violations are created during shielding, `create_zrt_shield` triggers five detail routing iterations to fix them. If this does not fix the DRC violations, you can fix the remaining violations by running incremental detail routing with the `route_zrt_detail -incremental` command. It is possible that postroute shielding might break some tie-off connections during the shield trimming process. In this case, use `route_zrt_eco` instead of `route_zrt_detail` to rebuild the tie-off connections and to fix the DRC violations.

## Shielding Example

[Example 9-4](#) provides an example of shielding clock nets using preroute shielding and shielding critical nets using postroute shielding.

### Example 9-4 Shielding Flow Example

```
# Define shielding rule
define_routing_rule shield_rule \
    -shield_widths {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3} \
    -shield_spacings {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3}

# Assign shielding rule to clock nets
set_clock_tree_options -clock_trees CLK \
    -routing_rule shield_rule

# Perform clock tree synthesis
set_delay_calculation -clock_arnoldi
clock_opt -no_clock_route

# Route the clock nets, reusing the global routing result from clock_opt
route_zrt_group -all_clock_nets -reuse_existing_global_route true

# Perform preroute shielding for the clock nets
create_zrt_shield -nets $clock_nets \
    -with_ground VSS

# Assign shielding rule to critical nets
set_net_routing_rule -rule shield_rule $critical_nets

# Route signal nets using shielding soft rules
route_zrt_auto

# Perform postroute shielding for critical nets
create_zrt_shield -nets $critical_nets \
    -with_ground VSS
```

## Performing Incremental Shielding

By default, Zroute does not perform incremental shielding on nets that were modified after they were shielded. However, you can enable this capability for nets that were initially shielded with the `create_zrt_shield` command by using the `set_route_zrt_common_options` command to change the `reshield_modified_nets` common route option from its default of `off`.

When you enable incremental shielding, Zroute performs incremental shielding during detail routing by removing the existing shielding from the modified nets and optionally reshielding these nets based on the new topology.

- To remove the existing shielding only, set the `reshield_modified_nets` common route option to `unshield`.
- To remove the existing shielding and reshield the modified nets, set the `reshield_modified_nets` common route option to `reshield`.

Note:

Zroute automatically detects the nets modified within IC Compiler; however, nets modified externally and input by reading a DEF file are not supported by incremental shielding.

---

## Reporting Shielding Information

After you run the `create_zrt_shield` command, you can report the shielding statistics by running the `report_zrt_shield` command.

By default, the power and ground structure is not included in the shielding ratio calculation. To include the power and ground structure within a threshold distance in the shielding ratio calculation, use the `set_route_zrt_common_options` command to set the `pg_shield_distance_threshold` common route option, which specifies the distance threshold in microns.

```
icc_shell> set_route_zrt_common_options \
-pg_shield_distance_threshold distance
```

The default report generated by the `report_zrt_shield` command provides overall statistics, as shown in [Example 9-5](#).

*Example 9-5 Default Shielding Report*

```
icc_shell> report_zrt_shield

*****
Report : Zroute Shielding Ratio
: -with_ground VSS
: -nets specified
: -per_layer false
: -coaxial_below true
: -coaxial_above true
: -coaxial_below_skip_tracks 0
: -coaxial_above_skip_tracks 0
Design : my_design
Version: 1
Date   : Wed Dec  9 11:35:59 2009
*****
```

Shielded 90% side-wall of (CLK\_B5); 297 coaxial shielding wires added  
Shielded 1 nets with average ratio 90%

You can output the statistics for each layer by using the `-per_layer true` option with the `report_zrt_shield` command, as shown in [Example 9-6](#).

*Example 9-6 Layer-Based Shielding Report*

```
icc_shell> report_zrt_shield -per_layer true
```

```
*****
Report : Zroute Shielding Ratio
: -with_ground VSS
: -nets specified
: -per_layer true
: -coaxial_below true
: -coaxial_above true
: -coaxial_below_skip_tracks 0
: -coaxial_above_skip_tracks 0
Design : my_design
Version: 1
Date   : Wed Dec  9 11:40:29 2009
*****
```

Shielded 90% side-wall of (CLK\_B5); 297 coaxial shielding wires added  
Layer M3 : 95%  
Layer M4 : 90%  
Layer M5 : 85%

Shielded 1 nets with average ratio 90%

---

## Inserting Filler Cells

Filler cells fill gaps in the design to ensure that all power nets are connected and the spacing requirements are met.

- Before routing, you can
  - Insert standard cell fillers
  - Insert end cap cells
- After routing, you can
  - Insert well fillers
  - Insert pad fillers

The following sections describe how to insert these cells.

---

### Inserting Standard Cell Fillers

You can fill empty spaces in the standard cell rows with instances of reference filler cells to make sure all power nets are connected. One method of improving the stability of the power supply is to add decoupling capacitors as filler cells.

You insert filler cells by using the `insert_stdcell_filler` command (or by choosing Finishing > Insert Standard Cell Filler in the GUI). Zroute supports filler cells with and without metal and supports both single-height and multiheight filler cells. By default, the tool inserts standard cell fillers in the entire design. Use the `-voltage_area` option to restrict insertion to specific voltage areas. Use the `-plan_group` option to restrict insertion to specific plan groups.

To insert filler cells using Zroute,

1. (Optional) Define the standard cell filler rules by using the `set_left_right_filler_rule` command to define the left and right filler rules. These rules specify the filler cell to insert immediately to the left and right respectively of specific standard cells.
2. Insert filler cells with metal.

When you insert filler cells with metal, you must use the `-cell_with_metal` option to specify the reference filler cells. You connect the inserted filler cells to the power and ground (PG) networks based on the design.

- Single PG network

If the filler cell has a single PG pin, use the `-connect_to_power` and `-connect_to_ground` options to connect the inserted filler cell to PG nets.

- Multiple PG networks

For designs that contain multiple PG pins, choose one of the following methods:

- Let the `insert_stdcell_filler` command automatically derive PG connections based on the IEEE 1801 Unified Power Format (UPF) information.  
Do not use the `-connect_to_power`, `-connect_to_ground`, and `-pin_net` options. Note that this method only applies to designs that contain power domains in a UPF flow.
- Use the `-connect_to_power`, `-connect_to_ground`, and `-voltage_area` options or the `-pin_net` and `-voltage_area` options to connect power domains individually.

When filler cells are inserted by using the `-cell_with_metal` option, Zroute checks for DRC violations automatically:

- If your design has more than one PG network and you do not specify the PG connections, Zroute treats the unconnected pins on the filler cells as violations and removes the filler cells when checking for shorts.
- If a filler cell with metal causes DRC violations, Zroute removes it.

### 3. Insert filler cells without metal.

When you insert filler cells without metal, use the same methods described for inserting filler cells with metal. The only differences are

- You can make PG connections after inserting filler cells by using the `derive_pg_connection` command.
- Zroute does not check for DRC violations when you insert filler cells without metal.

To remove filler cells without metal that cause DRC violations, use the `remove_zrt_filler_withViolation` command. Because removing the filler cells can expose new violations, you sometimes need to run this command multiple times to remove all violating filler cells

For example, to insert filler cells and connect them to the VDD power net and VSS ground net, enter the following commands:

```
icc_shell> insert_stdcell_filler -cell_with_metal $FILLER_CELL_METAL \
    -connect_to_power VDD -connect_to_ground VSS
icc_shell> insert_stdcell_filler -cell_without_metal $FILLER_CELL \
    -connect_to_power VDD -connect_to_ground VSS
```

For more information about the `insert_stdcell_filler` command, see the man page.

## Connecting Multiple Power and Ground Pins

You can use the `-pin_net` option of the `insert_stdcell_filler` command to make power and ground (PG) connections for decoupling capacitors with multiple power pins or for multivoltage designs. The option lets you connect PG pins to PG nets in a specific voltage area.

For example, the pd1 power domain belongs to the va1 voltage area, and the pd2 power domain belongs to the va2 voltage area in the design. The following command connects the pin1 power pin to the net1 power net in the va1 voltage area and the pin2 power pin to the net2 power net in the va2 voltage area.

```
icc_shell> insert_stdcell_filler \
    -pin_net {{pin1 net1 va1}{pin2 net2 va2}}
```

Any PG pins that are not specified by the `-pin_net` option are connected to the primary PG nets based on the UPF information.

For example, if a FILLX filler has vdd and vdda power pins and one ground pin, you only need to specify the connection of the extra power pin, as shown in the following command:

```
icc_shell> insert_stdcell_filler -cell_with_metal {FILLX} \
    -pin_net {{vdda net2 va1}}
```

As a result, the tool connects the vdda power pin to the net2 power net in the va1 voltage area, the vdd power pin to the primary power net, and the ground pin to the primary ground net.

You cannot use the `-pin_net` option with the `-connect_to_power` or `-connect_to_ground` option.

## Avoiding One-Unit-Tile Violations for Overlapping Rows

When you specify the `-no_1x` option of the `insert_stdcell_filler` command, the command checks the gaps against the smallest unit tile to avoid one-unit-tile violations on overlapping rows. This behavior is aligned with the normal standard cell legalization.

The following example sets the `-no_1x` option to prevent the command from inserting filler cells at the locations where one-unit-tile gaps might occur, as shown in [Figure 9-6](#).

```
icc_shell> insert_stdcell_filler -no_1x \
    -cell_without_metal {Fill_3 Fill_2}
```

*Figure 9-6 Overlapping Row With Various Unit Tiles*



When you set the `-no_1x` option, you must also use the `-cell_without_metal` option to specify the two-unit-tile and three-unit-tile reference filler cells but not the one-unit-tile reference filler cells. If you specify the one-unit-tile reference filler cell, the `-no_1x` option has no effect and the tool issues a warning message. If you do not specify the two-unit-tile and three-unit-tile reference filler cells, the tool issues an error message.

## Defining the Filler Rules

The left and right filler rules specify the filler cell to insert to the immediate left and immediate right respectively of specific standard cells. You use the `set_left_right_filler_rule` command to define these rules.

If there is only a single site between two standard cells, the rule used to fill that site depends on whether the references for the standard cells are the same or different. If the references for the two standard cells are the same, IC Compiler uses the rules for the cell on the left, and the rules for the cell on the right are ignored. If the references are different, IC Compiler uses the rule that was defined first.

To report the right and left filler rules defined for your design, run the `report_left_right_filler_rule` command. The report shows the rules and the order in which they were defined.

By default, the left and right filler cells have a north (N) orientation or flipped-south (FS) orientation when the rows are flipped. You can choose to have the left and right filler cells follow the orientation of the standard cell by using the `set_left_right_filler_rule -follow_stdcell_orientation` option.

## Reporting Filler Cells

To report the type of filler cells and their locations, use the `report_filler_placement` command. The syntax is

```
report_filler_placement -lib_cell lib_cell_list [-abut]
```

Use the `-lib_cells` option to specify the type of filler cells that you want to report in your design. To report only the adjacent filler cells that form a consecutive pair in a cell row, use the `-abut` option. For example,

```
icc_shell> report_filler_placement -lib_cell FILL1BWP -abut
```

The example reports only the consecutive filler cells named FILL1BWP and their locations in the design.

## Removing Filler Cells

To remove standard cell fillers, use the `remove_stdcell_filler -stdcell` command (or choose Finishing > Remove Fillers and select “Standard Cell” in the “Filler type” area in the GUI). By default, the filler cells are removed for the whole chip. You can optionally specify a bounding box from which to remove filler cells.

When filler cells are added after signal routing, you can remove all the filler cells that have routing design rule violations. To remove standard cell fillers with violations, use the `remove_filler_withViolation` command (or choose Finishing > Remove Fillers With Violation in the GUI). You can restrict the removal to specific instances by using the `-name` option.

---

## Inserting End Caps

After placing standard cells and before routing, you can add end cap cells at both ends of a cell row. Typically, an end cap cell is a nonlogic cell that serves a certain purpose for the row such as providing a decoupling capacitor for the power rail. Because IC Compiler accepts any standard cell as an end cap, you should specify a suitable end cap cell.

To insert end caps, use the `add_end_cap` command or choose Finishing > Insert End Cap in the GUI. You must specify the cell to use for the end caps by using the `-lib_cell` option. For example,

```
icc_shell> add_end_cap -lib_cell MY_END_CAP
```

By default, the command places the specified library cells in their default orientation at both ends of the horizontal cell rows without considering padding, blockages, or keepouts. To add end caps to only one end, specify which end by using the `-mode` option. To add end caps only at the left end, specify the `-mode bottom_left` option. To add end caps only at the right end, specify the `-mode upper_right` option.

To specify the cells to add as vertical end caps, use the `-vertical_cells` option, which inserts cells in the specified order and avoids unfilled space at the end of a cell row. When you add both horizontal and vertical end cap cells, you can fill the corners where the horizontal and vertical end caps meet by specifying the `-fill_corner` option, changing it from its default of off. The `-fill_corner` option takes effect only when you use it with the `-vertical_cells` option.

By default, if a voltage area has no guard bands, the `add_end_cap` command ignores the voltage area boundaries during end cap insertion. To insert horizontal end caps at both sides of a vertical voltage area boundary, use the `-at_va_boundary` option.

By default, the `add_end_cap` command ignores the plan group boundaries during end cap insertion. To insert horizontal end caps at both sides of a vertical plan group boundary, use the `-at_plan_group_boundary` option.

To flip the orientation of the end cap cells, use the `-mirror` option. The `-mirror` option applies to horizontal end caps only. To prevent the command from placing end caps inside padding areas, blockages, or keepouts, use the `-respect_padding`, `-respect_blockage`, and `-respect_keepout` options respectively.

When you specify the `-next_to_fixed` option, the command treats a fixed cell abutting the boundary as a macro and creates a horizontal end cap next to the fixed cell. Other fixed cells are ignored by this option. This option cannot be used with the `-skip_fixed` option.

During end cap insertion, the `add_end_cap` command ignores both hard and soft blockages by default. If you specify the `-respect_blockage` option, the command respects both hard and soft blockages. To ignore only soft blockages, use the `-ignore_soft_blockage` option. The `-ignore_soft_blockage` option must be used with the `-respect_blockage` option. When you specify both options, the command respects hard blockages but ignores soft blockages. If you specify only the `-ignore_soft_blockage` option, the command issues an error.

For more information about the `add_end_cap` command, see the man page.

## Inserting Well Fillers

After routing is complete, you can fill small gaps that violate the spacing rule for the well layer with well filler cells. You can fill gaps between cells in the same row or between rows.

To insert well fillers, use the `insert_well_filler` command (or choose Finishing > Insert Well Filler in the GUI). This is the command syntax:

```
insert_well_filler
  -layer layer_name_or_number
  [-ignore_PRboundary]
  [-fill_gaps_smaller_than gap_size]
  [-higher_edge min | max]
  [-lower_edge min | max]
  [-gap_type tt | bb | tb | bt]
  [-respect_blockages]
  [-row_overlap row_overlap_value]
  [-min_gap min_gap_distance]
  [-max_gap max_gap_distance]
  [-enclosure_only width]
```

For example,

```
icc_shell> insert_well_filler -layer 10 \
  -fill_gaps_smaller_than 3.0 \
  -higher_edge max -lower_edge min
```

This example adds well filler on layer 10 for gaps smaller than 3.0 microns. If the wells from the two standard cells do not line up, the command creates the largest fill box by using the larger top edge and the smaller bottom edge.

By default, only the gaps between standard cells within a row are filled. To fill gaps between rows, use the `-gap_type` option and set it to `tt`, `bb`, `tb`, or `bt`.

The `-higher_edge` and `-lower_edge` options specify how to align the well filler with the wells in the two standard cells when the wells in the cells do not line up. [Figure 9-7](#) shows the alignments and fill boxes that occur as a result of the various settings.

*Figure 9-7 Filler Alignment*



The `insert_well_filler` command also has options to specify the following:

- Whether to ignore the place and route boundary layer (layer 207) that extends outside a cell
- Whether to respect placement blockages when the `-gap_type` option is used
- The amount of row overlap between the row and the gap when the `-gap_type` option is used
- The minimum and maximum gap sizes that are filled when the `-gap_type` option is used
- Whether to insert a well enclosure instead of well fill and, if so, the enclosure width

To remove well fillers, use the `remove_well_filler` command (or choose Finishing > Remove Well Fillers in the GUI).

---

## Inserting Pad Fillers

After routing is complete, you can fill gaps in the pad ring with instances of pad filler cells. These are dummy pad cells that you can use to control the pad spacing and complement the n-well taps in pads. You should complete the routing process before you add pad filler cells.

To insert pad fillers, use the `insert_pad_filler` command (or choose Finishing > Insert Pad Filler in the GUI). This is the command syntax:

```
insert_pad_filler
  -cell lib_cells
  [-overlap_cell overlap_lib_cells]
  [-voltage_area voltage_area_list]
  [-bounding_box rectangle]
  [-prefix prefix]
  [-no_left]
  [-no_right]
  [-no_bottom]
  [-no_top]
```

For example,

```
icc_shell> insert_pad_filler -cell "PFILL_2X PFILL_1X" \
  -overlap_cell "PFILL_1X" -voltage_area {V1}
```

This example inserts pad filler cells PFILL\_2X and PFILL\_1X on the pad ring, with preference for PFILL\_2X because it is listed first, inside voltage area V1 only. The PFILL\_1X cell is allowed to overlap other pad filler cells to fill gaps that are too small for any pad filler cell.

The command also has options to restrict pad filler insertion to a specified rectangular area or pad ring, to specify pad filler instance naming conventions, and to exclude pad filler insertion from left, right, top, or bottom boundaries.

To remove pad fillers, use the `remove_stdcell_filler -pad` command (or choose Finishing > Remove Fillers in the GUI and select “Pad” in the “Filler type” area). By default, pad fillers are removed for the whole chip. You can optionally specify a bounding box from which to remove pad fillers.

---

## Inserting Metal Fill

After routing, you can fill the empty spaces in the design with metal wires to meet the metal density rules required by most fabrication processes. Before inserting metal fill, the design should be close to meeting timing and have only a very few or no DRC violations.

You insert metal fill by running the `signoff_metal_fill` command (or choosing Finishing > Signoff Metal Fill in the GUI) to invoke the external IC Validator or Hercules metal fill capability. This command requires a Hercules license.

After you insert metal fill,

- You can display the added metal fill in the layout view in the GUI.

Before you can view the added metal fill in the GUI, you must open the FILL view. After opening the FILL view, set the View Level to 1 in the View Settings panel (View > Toolbars > View Settings) and toggle on the Datatypes option under the Layers tab. Toggle on the view of the desired fill layer.

- You can do extraction for timing analysis using the real metal fill.

To enable real metal fill extraction, enter the following command:

```
icc_shell> set_extraction_options -real_metalfill_extraction floating
```

IC Compiler uses non-emulation TLUPPlus files when performing real metal fill extraction. Before enabling real metal fill extraction, ensure that the design contains metal fill and that you have specified TLUPPlus files without any emulation information.

Note:

If you have not yet inserted metal fill, you can perform emulation metal fill extraction by specifying emulation TLUPPlus files with the `-max_emulation_tluplus` and `-min_emulation_tluplus` options of the `set_tlu_plus_files` command.

To use the `signoff_metal_fill` command to insert metal fill,

- Set up the validation tool environment.
- Set up the physical signoff options.
- Set up distributed processing.
- Run the `signoff_metal_fill` command.

The following sections describe these tasks.

---

## Setting Up the Validation Tool Environment

You can use either IC Validator or Hercules to insert metal fill with the `signoff_metal_fill` command. For designs that are at 32-nm process node or less, you should use the IC Validator tool for metal fill.

## Setting Up the IC Validator Environment

To use the IC Validator tool when running the `signoff_metal_fill` command, you must have a Hercules license, and you must specify the location of the IC Validator executable by setting the `ICV_HOME_DIR` environment variable. You can set this variable in your `.cshrc` file. To specify the location of the IC Validator executable, use commands similar to those shown in the following example:

```
setenv ICV_HOME_DIR /root_dir/icv
set path = ($ICV_HOME_DIR/bin/AMD.64 $path)
```

You must ensure that the version of the IC Validator executable that you specify is compatible with the version of IC Compiler that you are using. For more information about IC Validator, see the IC Validator documentation, which is available on SolvNet.

IC Validator can generate a compressed hierarchical FILL view file, instead of the default hierarchical FILL view file. The compressed hierarchical FILL view reduces the size of the FILL view file without increasing runtime or memory requirements. To use the compressed hierarchical FILL view file instead of the default hierarchical FILL view file, set the `ICV_ENABLE_GDSREF` environment variable to 1 before invoking IC Compiler. You can also set this variable in your `.cshrc` file.

```
setenv ICV_ENABLE_GDSREF 1
```

## Setting Up the Hercules Environment

To use the Hercules tool when running the `signoff_metal_fill` command, you must have a Hercules license, and you must specify the location of the Hercules executable by setting the `HERCULES_HOME_DIR` environment variable. You can set this variable in your `.cshrc` file. For example,

```
setenv HERCULES_HOME_DIR /root_dir/hercules
set path = ($path $HERCULES_HOME_DIR/bin/AMD.64)
```

You must ensure that the version of the Hercules executable that you specify is compatible with the version of IC Compiler that you are using. For more information about Hercules, see the Hercules documentation, which is available on SolvNet.

---

## Setting Up the Physical Signoff Options

To prepare for signoff metal fill, use the `set_physical_signoff_options` command to specify the name of the executable, either `icv` or `hercules`, and the runset file for metal fill.

For example,

```
icc_shell> set_physical_signoff_options -exec_cmd icv \
           -fill_runset my_fill_runset_file
```

You can report the option settings by using the `report_physical_signoff_options` command. For more details about the `set_physical_signoff_options` and `report_physical_signoff_options` commands, see the man pages.

---

## Setting Up Distributed Processing

By default, the `signoff_metal_fill` command uses a single process to perform metal fill insertion. To reduce the turnaround time for metal fill insertion, you can use distributed processing. To enable distributed processing, you must define the distributed processing configuration by using the `set_host_options` command.

If you have defined more than one distributed processing configuration with the `set_host_options` command, the `signoff_metal_fill` command selects the IC Validator processing method in the following order of priority:

1. Job submission through a user-defined distributed processing script

To enable job submission using your own script with the `set_host_options` command, use the `-submit_command` option to specify the location of your job submission script. For example, to specify a configuration named `custom4` that enables a maximum of four processes using your job submission script, enter the following command:

```
icc_shell> set_host_options -name custom4 -num_processes 4 \
           -submit_command /usr/local/bin/my_submit_command
```

2. Job submission through the Load Sharing Facility (LSF) or the Sun Grid Engine (SGE)

To enable LSF or SGE job submission with the `set_host_options` command, use the `-pool` option to specify the mode and the `-num_processes` option to specify the maximum number of processes.

For example, to specify a configuration named `lsf4` that enables a maximum of four processes using LSF, enter the following command:

```
icc_shell> set_host_options -name lsf4 -pool lsf -num_processes 4
```

To specify a configuration named grd4 that enables a maximum of four processes using SGE, enter the following command:

```
icc_shell> set_host_options -name grd4 -pool grd -num_processes 4
```

### 3. Distributed processing on the specified hosts

To enable distributed processing with the `set_host_options` command, specify the hosts to use and use the `-num_processes` option to specify the maximum number of processes on each host. For example, to specify a configuration named dp4 that enables a maximum of four processes, with a maximum of two processes each on machineA and machineB, enter the following command:

```
icc_shell> set_host_options -name dp4 -num_processes 2 \  
{machineA machineB}
```

### 4. Multithreading

To enable multithreading on the current machine with the `set_host_options` command, use the `-max_cores` option to specify the number of threads. For example, to specify a configuration named mt4 that enables a maximum of four threads on the current machine, enter the following command:

```
icc_shell> set_host_options -name mt4 -max_cores 4
```

To ensure that you are using the intended distributed processing configuration, you should remove the current configurations by using the `remove_host_options` command before defining the distributed processing configuration for the `signoff_metal_fill` command. To report the current distributed processing configurations, use the `report_host_options` command.

For more information about the `set_host_options` command, see “[Enabling Multicore Processing](#)” on page 2-43.

---

## Running the `signoff_metal_fill` Command

Before you run the `signoff_metal_fill` command, the design must be fully routed and have only a very few or no DRC violations, and you must save the most recent revision of the design in a CEL view. IC Validator or Hercules reads and operates on the design data in CEL, FRAM, and FILL views stored on disk, not on the current design in IC Compiler memory.

You can use the `signoff_metal_fill` command to perform the following tasks, which are described in this section:

- [Standard Metal Fill Insertion](#)
- [Timing-Driven Metal Fill Insertion](#)

- [Metal Fill Removal](#)
- [Post-ECO Metal Fill Cleanup](#)

The following sections describe these tasks.

Note:

When you run the `signoff_metal_fill` command, you can specify additional options for the Hercules or IC Validator command line by using the `-user_defined_options` option. The string that you specify in this option is added to the command line used to invoke metal fill insertion in Hercules or IC Validator. IC Compiler does not perform any checking on the specified string.

## Standard Metal Fill Insertion

Normal metal fill insertion is the default mode for the `signoff_metal_fill` command. If you run the `signoff_metal_fill` command without any options, it performs the following tasks:

- Removes existing metal fill from the entire design.  
You can skip this step and perform incremental metal fill insertion by using the `-append` option (or by selecting “Keep existing metal fills in output view” in the Fill Options tab in the GUI). When you perform incremental metal fill insertion, you must use the default FILL view.

- Inserts metal fill in the empty regions for the whole design using the metal fill mode specified in the runset file, which is either hierarchical or flat.

You can force the use of the flat metal fill mode by using the `-mode flat` option.

- Stores the inserted metal fill information in the default FILL view.

You can specify a different name for the FILL view by using the `-output_view` option (or by entering the name in the “Output FILL view name” text box in the Fill Options tab in the GUI).

You can restrict the metal fill insertion to specific layers or specific regions of the design.

### Specifying the Layers for Metal Fill Insertion

By default, the `signoff_metal_fill` command inserts metal fill on all the metal routing layers. To perform metal fill insertion on a specific set of metal and via layers, specify the layers in the `-select_layers` option (or select them in the list in the “Insert/Remove metal fills in selected layers” area in the GUI).

By default, when you use this option, the `signoff_metal_fill` command removes all existing metal fill from the design and then inserts metal fill only on the specified layers. To keep the existing metal fill on the unspecified layers and to redo metal fill insertion only on the specified layers, use the `-eco` option. If you use the `-eco` option, you must use the default FILL view.

For example, to remove all metal fill on layers M1 and M3 and refill those two layers without affecting the metal fill on other layers, enter the following command:

```
icc_shell> signoff_metal_fill -eco -select_layers {M1 M3}
```

### Specifying the Regions for Metal Fill Insertion

By default, the `signoff_metal_fill` command inserts metal fill for the whole chip. You can restrict metal fill insertion to one or more regions of the design by specifying regions in which to insert metal fill or by specifying regions in which to prevent metal fill insertion or both.

To restrict metal fill insertion to specific regions of the design, use the `-bounding_boxes` option to specify the coordinates of each region in which to insert metal fill. You can specify multiple areas by specifying the coordinates for each area. If you are using the GUI, identify the regions in which to insert metal fill by selecting “Selected areas” and specifying the coordinates of each bounding box in the “Bounding Boxes” list. To specify the coordinates for a region, either draw the bounding box or enter the x- and y-coordinates of the box. For each region, you can also enable or disable snapping. If snapping is enabled, you can specify that the bounding box should snap to the minimum grid (the default), placement site, routing track, middle routing track, or user grid.

Note:

The bounding box coordinates passed to Hercules or IC Validator in the `METAL_FILL_SELECT_WINDOW` parameter are enlarged by 1um to avoid DRC violations on the boundary of the specified regions during metal fill insertion. The actual metal fill insertion occurs within the regions specified by the `-bounding_boxes` option.

In addition, when you use the `-bounding_boxes` option, the `signoff_metal_fill` command always uses flat metal fill mode.

To prevent metal fill insertion in specific regions, use the `-excluded_bounding_boxes` option or select “Excluded areas” and specify the coordinates of each bounding box in the “Bounding Boxes” list in the GUI.

By default, when you use these options, the `signoff_metal_fill` command removes all existing metal fill from the design and then inserts metal fill only in the specified regions. To redo metal fill insertion only on the specified regions and keep the other existing metal fill, use the `-eco` option. If you use the `-eco` option, you must use the default FILL view.

For example, to remove all metal fill from the design and then fill all empty regions outside the bounding box with corners at (100,150) and (300,200), enter the following command:

```
icc_shell> signoff_metal_fill \
    -excluded_bounding_boxes {{100 150} {300 200}}
```

## Timing-Driven Metal Fill Insertion

Note:

Timing-driven metal fill insertion is supported only in IC Validator.

Timing-driven metal fill insertion inserts metal fill in the specified regions of the design, except around timing-critical nets. You can either explicitly specify the timing-critical nets or you can specify slack thresholds that enable IC Compiler to determine the timing-critical nets automatically.

To explicitly specify the critical nets, use the `-timing_preserve_nets` option. To specify a setup slack threshold, use the `-timing_preserve_setup_slack_threshold` option. To specify a hold slack threshold, use the `-timing_preserve_hold_slack_threshold` option. If you are using the GUI, you can set these values in the Timing Preserve tab.

By default, the minimum spacing between a critical net and metal fill is twice the minimum spacing for the layer on which the net occurs. In addition, no metal fill is inserted within the minimum spacing around the vertical extension of the net on the layers above and below the net. You can specify a different same-layer minimum spacing requirement by using the `-space_to_critical_nets` option. You can allow metal fill insertion within the vertical extension of the net on the adjacent layers by using the `-fill_over_critical_nets` option.

Note:

You can specify the regions in which to perform timing-driven metal fill insertion, as described in “[Specifying the Regions for Metal Fill Insertion](#)” on page 9-63; however, you cannot specify the layers. When performing timing-driven metal fill insertion, the `signoff_metal_fill` command inserts metal fill on all routing layers.

During timing-driven metal fill insertion, the `signoff_metal_fill` command

- Performs timing analysis, including multicorner-multimode analysis, to minimize timing impact.
- Identifies timing-critical nets based on the options you specify.
- Invokes IC Validator to perform metal fill insertion.

When you perform timing-driven metal fill insertion, you must always use the default FILL view.

By default, when you run timing-driven metal fill insertion, the `signoff_metal_fill` command removes all existing metal fill from the design and then inserts metal fill in the specified regions, except in the areas around the critical nets. To do timing-driven metal fill insertion on the specified regions and keep the other existing metal fill, use the `-eco` option. You cannot use `-append` option when performing timing-driven metal fill insertion.

## Metal Fill Removal

To remove all metal fill from the design, use the `-purge` option (or select “Remove fills” in the GUI). When you use this option, you must use the default FILL view. You can specify the layers on which to remove the metal fill by using the `-select_layers` option. You can specify the regions from which to remove the metal fill by using the `-bounding_boxes` option. No other options are supported with the `-purge` option. For more information about specifying the layers for metal fill removal, see [“Specifying the Layers for Metal Fill Insertion” on page 9-62](#). For more information about specifying the regions for metal fill removal, see [“Specifying the Regions for Metal Fill Insertion” on page 9-63](#).

## Post-ECO Metal Fill Cleanup

After you perform metal fill insertion and ECO routing, you should use the `signoff_metal_fill` command to remove any metal fill that overlaps a net.

To remove the metal fill that overlaps any net, use the `-remove_overlap_with_nets {*}}` option (or select “Post-ECO fill” in the GUI and select “All nets” in the Post-ECO tab). To remove the metal fill that overlaps specific nets, use the `-remove_overlap_with_nets nets` option (or select “Post-ECO fill” in the GUI and specify the nets in the “Selected nets” box in the Post-ECO tab).

By default, metal fill is removed around each specified net such that there is no metal fill within twice the minimum spacing for the layer on which the net occurs. You can change the spacing requirement by using the `-space_to_critical_nets` option.

### Note:

You can specify the layers on which to remove the metal fill, as described in [“Specifying the Layers for Metal Fill Insertion” on page 9-62](#); however, you cannot specify the regions. When removing overlapping metal fill, the `signoff_metal_fill` command removes the metal fill around the specified nets.

For example, to remove the metal fill on layers M1, M2, and M3 that overlap existing nets, enter the following command:

```
icc_shell> signoff_metal_fill -remove_overlap_with_nets {*} \
    -select_layers {M1 M2 M3} \
    -space_to_critical_nets {M1 0.2 M2 0.2 M3 0.2}
```



## **Part II: Advanced IC Compiler Features**

---

---



# 10

## Signal Integrity

---

Signal integrity is the ability of an electrical signal to carry information reliably and to resist the effects of high-frequency electromagnetic interference from nearby signals. This chapter describes how to use IC Compiler to analyze and correct signal integrity problems.

Crosstalk is the undesirable electrical interaction between two or more physically adjacent nets due to capacitive coupling. Crosstalk can lead to crosstalk-induced delay changes or static noise that causes logic errors.

Electromigration is the permanent physical movement of metal in thin wire connections resulting from the displacement of metal ions by flowing electrons. Electromigration can lead to shorts and opens in wire connections, causing functional failure of the device. The problem is more severe in modern technologies due to smaller wire widths and increased current densities.

IC Compiler supports signal integrity analysis and optimization in either a flat flow or a hierarchical flow. When you create a hierarchical model for use in a hierarchical signal integrity flow, the signal integrity information is automatically included by the `create_block_abstraction` command; however, you must use the `-include_xtalk` option with the `create_ilm` command to include the signal integrity information in an interface logic model (ILM). Signal integrity analysis and optimization also support multivoltage and multimode-multicorner designs.

This chapter contains the following sections:

- [Analyzing and Reducing Crosstalk](#)
- [Analyzing and Reducing Signal Electromigration](#)

---

## Analyzing and Reducing Crosstalk

Crosstalk is the undesirable electrical interaction between two or more physically adjacent nets due to capacitive coupling. The two major effects of crosstalk are crosstalk-induced delay and static noise.

- Crosstalk can affect signal delays by changing the times at which signal transitions occur. That is, it can either speed up or slow down the transition time of the victim net. These changes occur when both the victim and the aggressor nets are switching at the same time. When both are switching in the same direction, the transition time of the victim net decreases and delay is reduced. When the victim and aggressor nets are switching in opposite directions, the transition time of the victim net increases and delay is increased. Therefore crosstalk can affect both setup and hold checking. The noise on the victim net is referred to as switching noise.
- Static noise occurs when the victim net is in a steady state of either a high or low, and the aggressor net is switching. This causes a glitch on the victim net. If a glitch is of sufficient height and width, and if it occurs at the input of a latching structure during a latching operation (possibly as the result of an earlier glitch propagated through combinational logic), a functional failure results.

IC Compiler uses crosstalk prevention techniques during track assignment. After you perform detail routing, IC Compiler performs crosstalk-induced noise and delay analysis to identify any remaining violations, and it fixes these violations during the postroute optimization phases.

- During timing-driven and crosstalk-aware track assignment, IC Compiler minimizes the crosstalk effects by assigning long, parallel nets to nonadjacent tracks. It runs a simplified noise analysis to make sure the noise level from aggressor nets is minimized.
- After detail routing is complete, IC Compiler repairs the remaining problems, first by analyzing the coupling capacitance effects of the circuit and then by crosstalk removal with postroute optimization.

In crosstalk analysis, for each net, IC Compiler extracts parasitic capacitance to the ground as well as any coupling capacitance with neighboring wires. IC Compiler also invokes static timing analysis, using the extracted parasitics to obtain the transition times as well as the arrival time windows of every signal net in the design.

This section contains the following information about the crosstalk capabilities supported by IC Compiler:

- [Setting the Signal Integrity Options](#)
- [Preventing Crosstalk During Placement](#)
- [Preventing Crosstalk During Clock Tree Synthesis](#)

- Preventing and Fixing Crosstalk During Routing
  - Analyzing Crosstalk
  - Preventing Crosstalk During Signoff Optimization
  - Example Scripts
- 

## Setting the Signal Integrity Options

The signal integrity options affect the analysis of crosstalk delay and static noise by the `report_timing` and `report_noise` commands and the optimization of crosstalk delay and static noise in the `route_opt` and `signoff_opt` commands.

You set the signal integrity options by using the `set_si_options` command (or by choosing Timing > Set SI Options in the GUI). **Table 10-1** describes the GUI objects and command-line options used to set the options for various signal integrity tasks.

*Table 10-1 Signal Integrity Options*

| GUI object                                | Command option                                                                                    | Default                  |
|-------------------------------------------|---------------------------------------------------------------------------------------------------|--------------------------|
| <b>Crosstalk prevention options</b>       |                                                                                                   |                          |
| “Enable xtalk prevention” check box       | <code>-route_xtalk_prevention</code>                                                              | false                    |
| “Prevention threshold” box                | <code>-route_xtalk_prevention_threshold</code>                                                    | 0.35                     |
| <b>Crosstalk optimization options</b>     |                                                                                                   |                          |
| “Delta delay” check box                   | <code>-delta_delay</code>                                                                         | false                    |
| “Min delta delay” check box               | <code>-min_delta_delay</code>                                                                     | false                    |
| “Static noise” check box                  | <code>-static_noise</code>                                                                        | false                    |
| “Static noise threshold (voltage)” fields | <code>-static_noise_threshold_above_low</code><br><code>-static_noise_threshold_below_high</code> | 0.35<br>0.35             |
| N/A                                       | <code>-max_transition_mode</code>                                                                 | <code>normal_slew</code> |

**Table 10-1 Signal Integrity Options (Continued)**

| GUI object                               | Command option                                                          | Default      |
|------------------------------------------|-------------------------------------------------------------------------|--------------|
| <b>Crosstalk analysis options</b>        |                                                                         |              |
| “Delta delay” check box                  | -delta_delay                                                            | false        |
| “Min delta delay” check box              | -min_delta_delay                                                        | false        |
| “Static noise” check box                 | -static_noise                                                           | false        |
| “Static noise threshold (voltage) fields | -static_noise_threshold_above_low<br>-static_noise_threshold_below_high | 0.35<br>0.35 |
| N/A                                      | -max_transition_mode                                                    | normal_slew  |
| “Timing window” check box                | -timing_window                                                          | false        |
| “Reselect” list box                      | -reselect                                                               | false        |
| “Analysis effort” list box               | -analysis_effort                                                        | low          |

To report the current signal integrity option settings, run the `report_si_options` command.

---

## Preventing Crosstalk During Placement

To prevent crosstalk at the placement phase, do the following:

- Minimize congestion.

Reducing congestion improves the routability of the design and adds more resources for extra spacing requirements during crosstalk-driven global route and track assignment. Fixing crosstalk on a congested design is very difficult.

- Have good timing closure before crosstalk fixing. If necessary, add more margin before crosstalk fixing.
- Use area recovery on noncritical paths during `place_opt` to reduce congestion and improve routability. Set the `physopt_area_critical_range` variable to a value that is about 15 percent of the clock period to avoid downsizing paths close to zero slack.

- Help prevent crosstalk by controlling the maximum transition constraint defined on the design. The maximum transition constraint is technology and library dependent. You need to find the best tradeoff between a low maximum transition constraint and congestion. The maximum transition constraint can be relaxed during postroute optimization.
- Use the maximum net length constraint in IC Compiler to minimize the crosstalk effect by preventing very long wires. You must determine the best tradeoff between a low `max_net_length` value and congestion. For a design without macros or only small macros, the `max_net_length` value might be 1000.0; for a design with large macros or high utilization, the `max_net_length` value might be 2000.0 or 3000.0.

---

## Preventing Crosstalk During Clock Tree Synthesis

Because clock nets are typically high-frequency nets, they are often strong aggressor nets. You can prevent crosstalk by shielding clock nets with ground wires.

IC Compiler handles clock shielding with nondefault routing rules. For information about the clock shielding flow, see “[Shielding Clock Nets](#)” on page 7-40.

---

## Preventing and Fixing Crosstalk During Routing

During the `route_opt` command, IC Compiler can perform the following signal integrity tasks:

- Crosstalk prevention (during global routing and track assignment)
- Crosstalk fixing (during postroute optimization)

By default, these capabilities are disabled. To enable these capabilities, set the appropriate signal integrity options and then run the `route_opt` command with the `-xtalk_reduction` option.

The `set_route_opt_zrt_crosstalk_options` command sets several options that affect crosstalk fixing by the Zroute router during execution of the `route_opt` command. For details, see “[Setting the Crosstalk Reduction Options](#)” on page 8-74 or the man page for the command.

IC Compiler has two crosstalk reduction engines:

- A fast crosstalk reduction that is fast with good QoR (the default)  
Enable this crosstalk reduction engine by specifying `route_opt -effort medium`.
- A high-performance crosstalk reduction engine that is slower than the default crosstalk engine, but that provides slightly better QoR.  
Enable this crosstalk reduction engine by specifying `route_opt -effort high`.

## Preventing Crosstalk

The `route_opt` command can prevent crosstalk in the following ways:

- Crosstalk prevention during track assignment  
Enable crosstalk prevention by running `set_si_options -route_xtalk_prevention true` and using the `-xtalk_reduction` option when you run `route_opt`.  
You can set the crosstalk prevention threshold voltage by using the `-route_xtalk_prevention_threshold` option with the `set_si_options` command. The lower the threshold voltage, the more that the router tries to prevent crosstalk. The default threshold is 0.45 volts, which could be too relaxed. If your design has crosstalk violations, you should use a lower crosstalk prevention threshold during track assignment, in the range of 0.25 to 0.35 volts.  
When you enable crosstalk prevention, the `route_opt` command avoids putting long, parallel wires on adjacent tracks during track assignment. To minimize noise, track assignment estimates the potential noise with a simplified crosstalk checker and reassigns wires to reduce potential noise exceeding the noise threshold.
- Timing-driven global routing  
Enable timing-driven global routing by using the `set_route_zrt_global_options -timing_driven true` command (or by choosing Route > Routing Setup > Set Global Route Options in the GUI and selecting “Timing driven” in the Run control tab).
- Timing-driven track assignment  
Enable timing-driven track assignment by using the `set_route_zrt_track_options -timing_driven true` command (or by choosing Route > Routing Setup > Set Track Assign Options in the GUI and selecting “Timing driven”).

## Fixing Crosstalk Violations

For best results, use the crosstalk prevention process in conjunction with crosstalk fixing. When crosstalk is prevented in the placement stage and then in the track assignment stage, the routed design has a smaller number of crosstalk violations. Consequently crosstalk fixing in the postroute optimization stage will be more effective and have a shorter runtime.

Some crosstalk violations might still remain unfixed after you run the noise avoidance processes that occur in the track assignment phase. IC Compiler fixes the remaining crosstalk violations in the postroute optimization stage.

During postroute optimization, the `route_opt` command performs the following crosstalk optimizations when you specify the `-xtalk_reduction` option:

- Optimization with crosstalk delta delay

To optimize timing with crosstalk delta delay, run the `set_si_options -delta_delay true` command.

- Hold time optimization with crosstalk delta delay

By default, both setup and hold fixing are performed when the `-delta_delay` option is set to `true`. To perform setup fixing only, set the `-min_delta_delay` option to `false`.

- Total slew optimization

To consider crosstalk-induced slew effects during maximum transition time design rule fixing, use both the `-max_transition_mode total_slew` option and the `-delta_delay true` option with the `set_si_options` command.

- Static noise

To enable static noise reduction, use the `-static_noise true` option together with `-delta_delay true` in the `set_si_options` command. The default threshold (both high and low) for static noise is 0.35 volts.

You can override these threshold values with the

`-static_noise_threshold_above_low` and `-static_noise_threshold_below_high` options of the `set_si_options` command. Specify a threshold value as a fraction of the supply voltage, not as an absolute voltage.

For example, if you specify a threshold value of 0.3, as shown in the following example, this means 30 percent of the voltage.

```
icc_shell> set_si_options -static_noise true \
    -static_noise_threshold_above_low 0.3 \
    -static_noise_threshold_below_high 0.3
```

By default, the tool uses only NLDM noise modeling information. To use CCS noise modeling information, set the `rc_noise_model_mode` variable to `true`. The default is `basic`.

Check the calculated threshold values by using the `report_si_options` command.

```
icc_shell> report_si_options

Static Noise Thresholds:
0.3 (0.49V) above low
0.3 (0.49V) below high
```

---

## Analyzing Crosstalk

After running `route_opt`, you can perform crosstalk analysis on your design. The following sections describe how to prepare for and run crosstalk analysis.

### Preparing for Crosstalk Analysis

Before you run crosstalk analysis or timing analysis to report static noise and crosstalk-induced delay, you must specify the following:

- The logic libraries, as described in “[Setting Up the Logic Libraries](#)” on page 3-3, to ensure that you are using the correct timing and noise models
- The Arnoldi delay calculation algorithm, as described in “[Selecting the Delay Calculation Method](#)” on page 3-44
- The types of crosstalk analysis to perform

You can select delta delay (`set_si_options -delta_delay true`), total slew (`-max_transition_mode total_slew`) and static noise (`-static_noise true`).

- Whether to use fully or partially grounded coupling capacitance during minimum delta delay analysis.

By default, the coupling capacitance is grounded during minimum delta delay analysis. You can improve the correlation for minimum delta delay by using partially grounded coupling capacitance (instead of fully grounded) by setting the `si_use_partial_grounding_for_min_analysis` variable to `true` (default is `false`).

- The electrical filtering parameters

Electrical filtering eliminates aggressor nets from analysis based on the size of the voltage bump induced on the victim net by the aggressor net. These filters are used by crosstalk analysis to reduce runtime and for consistency with PrimeTime SI.

If the default electrical filtering parameters do not meet your requirements, set the following variables:

- `si_filter_accum_aggr_noise_peak_ratio` (default is 0.03)
- `si_filter_per_aggr_noise_peak_ratio` (default is 0.01)
- The global noise thresholds

A crosstalk violation occurs when the crosstalk-induced noise voltage exceeds the specified noise threshold voltage (at or above which a false transition is likely to be triggered). Crosstalk analysis uses the noise threshold to report static noise violations. By default, both the above-low and below-high thresholds are set to 0.35 volts. You can override these thresholds by running the `set_si_options` command with the

`-static_noise_threshold_above_low` and `-static_noise_threshold_below_high` options. Specify a threshold value as a fraction of the supply voltage, not as an absolute voltage.

- Noise modeling

To perform static noise analysis with the `report_noise` command, the logic library should contain information about the drive characteristics and noise immunity of the pins of library cells. To check the noise modeling information, use the `check_noise` command. This command checks for the presence and validity of noise models on the driver and load pins of the design and reports any pins that are not constrained for noise.

If noise modeling information is missing or you want to change the noise models, you can do so by using the following commands:

```
set_steady_state_resistance
set_noise_immunity_curve
set_noise_margin
set_noise_lib_pin
```

The `set_steady_state_resistance` command specifies the drive resistance at an output of a library cell or at an output port of design, which affects the size of noise bumps at that output in the presence of crosstalk noise. For example,

```
icc_shell> set_steady_state_resistance -low 0.042 my_lib/AN2/Z
```

The `set_noise_immunity_curve` command specifies the noise immunity characteristics at the input of a library cell or at an input port in terms of the noise bump width, height, and area that can be tolerated. For example,

```
icc_shell> set_noise_immunity_curve -low \
-width 0.00 -height 0.58 -area 0.0064 my_lib/AN2/A
```

The `set_noise_margin` command specifies the noise immunity characteristics at the input of a library cell or at an input port in terms of the noise bump height that can be tolerated. For example,

```
icc_shell> set_noise_margin -low 0.4 my_lib/AN2/A
```

The `set_noise_lib_pin` command specifies the noise characteristics of a pin as the same as those of an existing library pin. This is useful when a pin does not have noise information defined, but the pin is known to have the same or similar characteristics as another pin that has defined noise characteristics. For example,

```
icc_shell> set_noise_lib_pin \[get_pins macro_cell/A] \
ccs_noise_lib/inv/IN
```

This example causes the pin `macro_cell/A` to have the noise characteristics of library pin `ccs_noise_lib/inv/IN`.

For more information, see the man pages for the `check_noise` command and noise modeling commands. For background information about noise modeling, see the *PrimeTime SI User Guide*, available on SolvNet in the PrimeTime Suite documentation set.

- Whether to include timing windows

The effect of crosstalk between two nets depends largely on the overlap of timing windows between the two nets. For example, if the aggressor switches when the victim is in steady state, it induces a noise bump on the victim. If the aggressor switches when the victim is also switching, it can cause the victim to switch faster or slower. If more than one aggressor switches in the same timing window, the effect of the two is the accumulated effect of each on the victim net.

The edges of a timing window at a particular pin are calculated as the earliest and latest possible arrival times of the signal at that point, considering multiple paths to that point. If there is only one path to that endpoint, the timing window is very narrow.

To include timing windows, use the `-timing_window true` option together with `-delta_delay` or `-static_noise` in the `set_si_options` command. Using timing windows increases the accuracy of crosstalk analysis at the cost of more runtime.

- Whether to use selective net reselection with timing windows

When timing window analysis is selected with the `-timing_window true` option of the `set_si_options` command, crosstalk analysis is run in two iterations. For the initial iteration, IC Compiler uses a conservative model that does not consider transition arrival timing windows, so it can quickly obtain approximate crosstalk delay values. In the second iteration, IC Compiler considers the timing windows and calculates crosstalk effects only when the aggressor and victim windows overlap. This gives a more accurate, less pessimistic analysis of worst-case crosstalk effects.

By default, crosstalk analysis with timing windows is performed on all nets in both analysis iterations. However, it is not actually necessary to spend time analyzing all the nets in the second iteration because the first iteration is pessimistic. Nets evaluated as victims in the first iteration that do not have crosstalk problems do not need be analyzed again, as the results can only improve in the more accurate, less pessimistic second iteration.

To restrict the reselection of nets in the second iteration and thereby reduce runtime, use the `-reselect true` option together with the `-timing_window true` option in the `set_si_options` command. In that case, IC Compiler selects only a subset of nets for analysis in the second iteration.

When the reselection feature is enabled, IC Compiler reselects only the nets that meet any one or more of the following conditions:

- The absolute change in stage delay, whether positive or negative, caused by crosstalk analysis in the first iteration exceeds the amount specified by the `si_xtalk_reselect_delta_delay` variable.

- The relative change in stage delay, whether positive or negative, caused by crosstalk analysis in the first iteration is a ratio that exceeds the amount specified by the `si_xtalk_reselect_delta_delay_ratio` variable. The ratio is calculated by dividing the absolute change in delay by the total stage delay.
- The net slack calculated in the minimum (hold) analysis of the first iteration is less than the threshold set by the `si_xtalk_reselect_min_mode_slack` variable, or the net slack calculated in the maximum (setup) analysis of the first iteration is less than the threshold set by the `si_xtalk_reselect_max_mode_slack` variable.

The `si_xtalk_reselect_delta_and_slack` variable determines whether any one or all three of these conditions must be met for a net to be reselected for analysis. By default, the variable is set to `false`, which means that any one of the three conditions is sufficient for a net to be reselected. If the variable is set to `true` instead, all three conditions must be met for a net to be reselected.

Stage delay is the delay of one stage. A stage consists of one cell and its fanout net. Crosstalk analysis in the first iteration might cause a change in the calculated worst-case delay: a decrease in delay for a minimum analysis or an increase in delay for a maximum analysis. If the amount of change is large enough, the net in that stage is reselected for further analysis. Typically, the change in calculated delay becomes smaller in the second analysis iteration, as the analysis uses windows and becomes less pessimistic.

Reselecting nets based on the amount of delay change is a way to ensure accurate results.

Net slack is the smallest or most negative path slack among all paths through the net. Reselecting nets based on the amount of slack is a way to ensure accurate crosstalk analysis of nets with critical timing.

After an incremental timing update, which is done during execution of the `route_opt` command, new paths with timing violations could emerge due to changes made by optimization. These newly violating paths are not reselected for analysis when the path reselection feature is enabled. To ensure that all paths are analyzed, including any newly violating ones resulting from optimization, disable the reselection feature by using the `set_si_options -reselect false` command.

Net reselection for crosstalk analysis in IC Compiler is similar to that done by PrimeTime SI, but there are some differences. IC Compiler uses at most two crosstalk analysis iterations, whereas PrimeTime SI can use more than two. By default, PrimeTime SI reselects nets in the fanin cone of any reselected nets, whereas IC Compiler does not. If you want PrimeTime SI to behave the same as IC Compiler in this respect, set the variable `si_xtalk_reselect_time_borrowing_path` to `false` in PrimeTime SI. Also, the `si_xtalk_reselect_clock_network` variable in PrimeTime SI must be left at its default setting (`false`) to have the same behavior as IC Compiler.

- Set the analysis effort (low or medium effort)

By default, IC Compiler uses low effort for better runtime by using an adaptive signal integrity calculation. You can better accuracy during crosstalk analysis at the cost of higher runtime by specifying medium effort (`set_si_options -analysis_effort medium`).

## Running Crosstalk Analysis

You can perform crosstalk analysis from the command line or in the GUI.

When you perform crosstalk analysis, ensure that

- The input transition time for all the cells in the design is reasonable (less than 1 ns). This is to avoid pessimism in the calculation of peak noise and crosstalk-induced delta delay.
- You use the `set_driving_cell` command to specify the driving cell instead of specifying the input transition for each input pin. The boundary conditions you specify for the input pins determine the driving resistance calculated for the nets assigned to the pins. Using the `set_driving_cell` approach enables IC Compiler to estimate the driving resistance more accurately and to correlate better with PrimeTime SI.

### Analyzing Crosstalk-Induced Delay Shift

Crosstalk affects the timing of the design when any of the aggressors switch before the transition of the victim signal has finished. When the aggressor and the victim are switching in the same direction, the victim driver can expend less effort on charging the coupling capacitance and more on increasing the switching speed. This can lead to hold time problems. Conversely, when the aggressor and victim switch in opposite directions, the transition time of the victim is longer because of a larger effective capacitance, and could result in a setup time problem. Therefore, to accurately analyze the timing behavior of a circuit, it is necessary to take into consideration the effects of crosstalk.

IC Compiler analyzes the impact on interconnect timing in terms of propagation delay and transition time. The delay shift of a victim net depends on the arrival time window of its aggressors and also affects the net timing windows. During crosstalk-induced delay, IC Compiler takes into account the timing windows of the victim and aggressor nets. For an accurate idea of the true delay shift, you must do iterations between the timing propagation in the static timing analyzer and the net delay calculation, with crosstalk considered.

To display the crosstalk delta delay, use one of the following methods:

- Use the `report_timing -crosstalk_delta` command.
- Use the delta delay visual mode by following these steps:
  1. Choose Timing > Delta Delay Visual Mode.  
The Visual Mode panel appears.
  2. Click Reload.  
The Delta Delay Visual Mode dialog box appears.
  3. Specify the analysis options.
  4. Click OK.

To get detailed information about the crosstalk calculations for a particular victim net, use the `report_delay_calculation -crosstalk` command.

### Analyzing Static Noise

For static noise, crosstalk analysis reports noise violations (above-low and below-high) that are caused by aggressor net transitions. Above-low noise violations occur when the victim net is at the steady state of logic 0 and the aggressor net is switching from logic 0 to logic 1. Similarly, below-high noise violations occur when the victim net is at a steady state of logic 1 and the aggressor is switching from logic 1 to logic 0. When the above-low (rise) and below-high (fall) noise violations exceed the logic thresholds of the technology, they can cause logic failures.

To display static noise violations, use one of the following methods:

- Use the `report_noise` command.
- Use the `get_si_xtalk_bumps` command.
- Use the static noise visual mode by following these steps:
  1. Choose Timing > Static Noise Visual Mode.  
The Visual Mode panel appears.
  2. Click Reload.  
The Static Noise Visual Mode dialog box appears.
  3. Specify the analysis options.
  4. Click OK.

- Display the Static Noise Analysis window by following these steps:

1. Choose Timing > Static Noise Analysis.

The Static Noise Analysis dialog box appears.

2. Specify the analysis options.

3. Click OK.

The Static Noise Analysis window provides detailed information about the victim and aggressor nets in your design. It also provides the ability to cross-highlight the aggressor and victim nets in the layout window.

To get detailed information about the noise calculations, use the `report_noise_calculation` command.

---

## Preventing Crosstalk During Signoff Optimization

During signoff optimization, the `signoff_opt` command performs the following crosstalk optimizations when you specify the `-xtalk_reduction` option:

- Optimization with crosstalk delta delay

To optimize timing with crosstalk delta delay, run `set_si_options -delta_delay true`.

- Hold time optimization with crosstalk delta delay

By default, both setup and hold fixing are performed when `-delta_delay` is set to true. To perform setup fixing only, set the `-min_delta_delay` option to false.

- Static noise

To enable static noise reduction, run `set_si_options -static_noise true`. The default threshold (both high and low) for static noise is 0.35 volts.

You can override these threshold values with the `-static_noise_threshold_above_low` and `-static_noise_threshold_below_high` options of the `set_si_options` command. Specify a threshold value as a fraction of the supply voltage, not as an absolute voltage.

---

## Example Scripts

[Example 10-1](#) shows an example script for running the flat signal integrity flow (or the top-level hierarchical signal integrity flow).

*Example 10-1 Flat Signal Integrity Flow*

```
open_mw_lib design
open_mw_cel block
place_opt
clock_opt
set_si_options -delta_delay true -static_noise true
route_opt -xtalk_reduction
signoff_opt -xtalk_reduction
save_mw_cel
```

[Example 10-2](#) shows an example script for running the block-level hierarchical signal integrity flow with ILMs. [Example 10-3](#) shows an example script for running the block-level hierarchical signal integrity flow with block abstraction models.

*Example 10-2 Block-Level Hierarchical Signal Integrity Flow With ILMs*

```
open_mw_lib design
open_mw_cel block
place_opt
clock_opt
set_si_options -delta_delay true -static_noise true
route_opt -xtalk_reduction
save_mw_cel
create_ilm -include_xtalk
```

*Example 10-3 Block-Level Hierarchical Signal Integrity Flow With Block Abstraction Models*

```
open_mw_lib design
open_mw_cel block
place_opt
clock_opt
set_si_options -delta_delay true -static_noise true
route_opt -xtalk_reduction
create_block_abstraction
save_mw_cel
```

---

## Analyzing and Reducing Signal Electromigration

Signal electromigration problems result from an increase in current density caused by the use of smaller line widths and higher operational speeds in IC designs. Electromigration can lead to shorts or opens due to metal ion displacement caused by the flow of electrons. You can use IC Compiler to analyze and correct electromigration in your design.

[Figure 10-1](#) shows the signal electromigration flow described in the following sections.

*Figure 10-1 Signal Electromigration Flow*



The following IC Compiler script example shows the signal electromigration flow:

```

# open design library and design cell
open_mw_lib design_library
open_mw_cel design_cell
read_sdc design.sdc

# load switching information
read_saif -input switching_info.saif

# optional override of default switching activity
set_switching_activity -toggle_rate 1.0 \
    -static_probability 0.5 [get_nets net_name]

# perform signal electromigration analysis
report_signal_em -violated -verbose > signal_em.rpt

# fix signal electromigration violations
fix_signal_em

```

---

## Loading Signal Electromigration Constraints

The first step is to load the signal electromigration constraints into the design library. You can do this either in Milkyway or in IC Compiler.

In the Milkyway Environment, to load the signal electromigration constraints in .plib format into the design library, use a command similar to the following:

```
Milkyway> read_plib -lib_name my_designlib \
    -tech_plib_files signal_em_constraintsplib \
    -overwrite_existing_tech
```

If the electromigration constraints are in Advanced Library Format (ALF), you can read them into the Milkyway library with the an IC Compiler command similar to the following:

```
icc_shell> set_mw_technology_file -alf my_alf_file.alf my_designlib
```

The existing technology data in the current design library is not affected. However, if the existing design library has electromigration data, that information is completely replaced by the new information read from the ALF file.

The `set_mw_technology_file` command accepts only one of the options `-technology`, `-plib`, or `-alf` in any one usage of the command. To load in a technology file and a separate ALF file, two commands are required. For example,

```
icc_shell> set_mw_technology_file -technology mytech.tf my_designlib
icc_shell> set_mw_technology_file -alf my_alf.alf my_designlib
```

To load in a .plib file and a separate ALF file, two commands are required. For example,

```
icc_shell> set_mw_technology_file -technology myplibplib my_designlib
icc_shell> set_mw_technology_file -alf my_alf.alf my_designlib
```

In this example, if the .plib file contains electromigration rules, those rules are completely replaced by the ones read in from the .alf file.

If the signal electromigration constraints are not defined in the design library, you can get an updated incremental .plib file containing the electromigration data from your vendor, and then read it into the Milkyway database with the following IC Compiler command:

```
icc_shell> set_mw_technology_file -plib plib_file_name design_lib_name
```

## Verifying the Electromigration Constraints

To perform a check on the signal electromigration constraints in the library, use the following commands:

```
icc_shell> set_check_library_options -signal_em  
1  
icc_shell> check_library  
  
#BEGIN_CHECK_LIBRARY  
...  
#BEGIN_CHECK_SIGNALEM  
  
... (signal electromigration checking results here) ...  
  
#END_CHECK_SIGNALEM  
...  
#END_CHECK_LIBRARY
```

## Verifying the Current Unit

To verify that the current unit is defined in the design library, use the `report_units` command.

```
icc_shell> report_units
```

If the current units are not defined, add the following lines to the header section of the technology file, and then update the design library, as described in “[Changing Physical Library Information](#)” on page 3-9:

```
unitCurrentName = "mA"  
currentPrecision = 10000
```

## Validating the Design

To perform signal electromigration analysis, the design must have timing constraints and parasitic information. If your design does not yet have timing constraints, see “[Setting Timing Constraints](#)” on page 3-43. If your design does not yet have parasitic information, either back-annotate the data, as described in “[Back-Annotating Delay or Parasitic Data](#)” on page 3-45; or extract the data, as described in “[Postroute RC Extraction](#)” on page 8-121.

---

## Loading the Net Switching Information

You must define net switching information to be able to perform accurate electromigration analysis. (The more frequently a net switches, the more susceptible it is to electromigration.) To load the net switching activity information, either read in a SAIF file with the `read_saif` command or annotate the switching activity information on the design nets with the `set_switching_activity` command. If you do both, the annotated switching activity has priority.

**Important:**

You must reload the net switching information every time the netlist changes. If you do load the switching activity, IC Compiler generates a warning message and uses  $1/time\_unit$  as the net switching frequency, where *time\_unit* is the main library time unit.

## Reading a SAIF File

To read in a SAIF file, use the `read_saif` command.

```
icc_shell> read_saif -input saif_file
```

[Example 10-4](#) shows an example SAIF file. For more information about the SAIF file, see the *Power Compiler User Guide*.

*Example 10-4 Example SAIF File*

```
(SAIFILE
  (SAIFVERSION "2.0")
  (DIRECTION "backward")
  (DATE "Thu Dec 12 15:44:56 2002")
  (VENDOR "Synopsys, Inc")
  (PROGRAM_NAME "Power Compiler PLI")
  (VERSION "3.4")
  (DIVIDER / )
  (TIMESCALE 1 ns)
  (DURATION 22500.00)
  (INSTANCE tb
    (INSTANCE u_A7S
      (NET
        (U_TAP_DBG\U_DBG\address_d_25_
          (T0 22490) (T1 0) (TX 10)
          (TC 0) (IG 0)
        )))))
  ))))
```

## Annotating the Switching Activity

To annotate the switching activity on design nets, use the `set_switching_activity` command with the `-static_probability`, `-toggle_rate`, and `-period` options. After annotating the switching activity, use the `propagate_switching_activity` command to propagate the static probability and toggle rate information to unannotated design objects.

A simple switching activity definition consists of the static probability and the toggle rate. The static probability is the probability that the value of the design object has logic value 1. The toggle rate is the rate at which the design object switches between logic values 0 and 1.

The following example shows how to specify that the value of the `net1` net is logic 1 for 20 percent of the time, and that it transitions between logic values 0 and 1 an average of 10 times in 1,000 time units.

```
icc_shell> set_switching_activity [get_net net1] \
    -static_probability 0.2 -toggle_rate 10 -period 1000
icc_shell> propagate_switching_activity
```

The time unit used for the toggle rate is the main library time unit. The `-period` option is optional, and a default of 1 is used when it is not specified.

---

## Performing Signal Electromigration Analysis

After you prepare the design library and load the net switching activity information, you can perform signal electromigration analysis. You use signal electromigration analysis at the postroute stage to fix electromigration violations.

Use the `report_signal_em` command to perform signal electromigration analysis for each net by calculating the current on every edge and comparing this data with the library-defined current-density thresholds. For example,

```
icc_shell> report_signal_em -violated -verbose
```

The `report_signal_em` command performs a timing update, if needed, and analyzes all nets for electromigration. The `-verbose` option causes the report to show detailed electromigration analysis information, which usually produces a very large report when used by itself. To get a report with a reasonable size, use the `-violated` option as well, which limits the report to only the nets with electromigration violations.

To use the IC Compiler GUI to perform electromigration analysis, choose Route > Signal Electromigration > Analyze Signal EM. The dialog box offers the same options as the `report_signal_em` command.

The electromigration analysis produces an error view, which you can read into the IC Compiler GUI to graphically view the locations of the violations. To see the error view in the GUI, choose Verification > Error Browser, which opens the Open Error View dialog box. Toggle on the Signal EM check box and enter the name of the error view, then click OK. The default name of the error view is *current\_cell\_name\_signalem.err*. The *-error\_view* option of the `report_signal_em` command lets you explicitly specify the name of the error view created by electromigration analysis.

You can also view a color-coded analysis map showing the local amount of current for a net. To display the map, choose Route > Signal Electromigration > Signal EM Analysis Map. In the Signal EM Analysis window, choose the type of electromigration value (RMS, Avg, or Peak), the number of bins, and the value range. Click Reload to read the electromigration data for a specified net. Then click Apply to display the analysis map and a histogram of current values for the net.

You can specify the electromigration healing factor, the types of violation rules observed (mean, root mean square, peak, and so on), the type of library (maximum or minimum) used in electromigration calculations, and the analysis effort (low or medium). Set these options with the `set_em_options` command. For example,

```
icc_shell> set_em_options -violation_rule_types {peak rms}
```

This is the full syntax of the command:

```
set_em_options
  [-healing_factor float]
  [-violation_rule_types {mean | abs_avg | rms | peak | auto}]
  [-min]
  [-max]
  [-analysis_effort low | medium]
```

For more information, see the man page for the `set_em_options` command. To view the current settings, use the `report_em_options` command.

When you perform signal electromigration analysis, the tool computes three current values:

- Average

The average current is calculated by using the following equation:

$$I_{avg} = \frac{\alpha}{2} \int_0^{T/2} I_p(t) dt - \gamma \frac{\alpha}{2} \int_0^{T/2} I_n(t) dt$$

where alpha ( $\alpha$ ) is the number of rise or fall transitions that occur in a half-clock cycle time, T is the clock period, and gamma ( $\gamma$ ) is the healing factor (as specified by the `-healing_factor` option).

- Root mean square

The root mean square current is calculated by using the following equation:

$$I_{rms} = \sqrt{\frac{\alpha}{2} \left[ \int_0^{T/2} I_p^2(t) dt + \int_0^{T/2} I_n^2(t) dt \right]}$$

where alpha ( $\alpha$ ) is the number of rise or fall transitions that occur in a half-clock cycle time and T is the clock period.

- Peak

The peak current is calculated by using the following equation:

$$I_{peak} = MAX(MAX(I_p) \cdot \sqrt{D_p}, MAX(I_n) \cdot \sqrt{D_n})$$

where D is the duty cycle, defined as 50 percent of the peak width multiplied by half of the switching activity, as shown in the following equation:

$$D_p = Width(I_p) \cdot (\alpha/2)$$

$$D_n = Width(I_n) \cdot (\alpha/2)$$

where alpha ( $\alpha$ ) is the number of rise or fall transitions that occur in a half-clock cycle time. The subscripts p and n denote the rise and fall transitions, respectively.

The default report generated by the `report_signal_em` command lists the number of nets with electromigration violations and the types of constraints violated (mean, absolute average, RMS, or peak). If you use the `-verbose` option, the report displays detailed information about the violations, as shown in the following example.

```
icc_shell> report_signal_em -violated -verbose
*****
Units:
...
*****
Net name:          net_577
Switching activity: 1.500000
Driver pin name (Transitions rise_min fall_min rise_max fall_max):
                    buff_a/Z (0.024464 0.0242115 0.0244641 0.0242115)
Violation:         RMS
*****
LAYER  METAL LAYER      CENTER      WIDTH   MODE      CURRENT
NAME    VIA    ID       COORDINATE    VIA CUT    Mean(Limit, Violated)  RMS(Limit, Violated)  Peak(Limit, Violated)
-----
M4     Metal 34  [ 293.97,  1857.80] 0.07  min  6.66e-16 (2.57e-01,-)  6.70e-01 (5.23e-01,v)  5.67e-01 (8.68e-01,-)
M4     Metal 34  [ 293.97,  1857.80] 0.07  max  5.83e-16 (2.57e-01,-)  6.70e-01 (5.23e-01,v)  5.67e-01 (8.68e-01,-)
M3     Metal 33  [ 292.57,  1857.66] 0.10  min  7.08e-16 (3.82e-01,-)  6.72e-01 (7.12e-01,-)  5.69e-01 (1.29e+00,-)
M3     Metal 33  [ 292.57,  1857.66] 0.10  max  6.97e-16 (3.82e-01,-)  6.72e-01 (7.12e-01,-)  5.69e-01 (1.29e+00,-)
VIA3   Via    53   [ 293.97,  1857.73] 2    min  1.04e-17 (5.50e-01,-)  6.71e-01 ( -, -)  5.68e-01 ( -, -)
VIA3   Via    53   [ 293.97,  1857.73] 2    max  4.37e-16 (5.50e-01,-)  6.71e-01 ( -, -)  5.68e-01 ( -, -)
VIA4   Via    54   [ 293.97,  1857.87] 2    min  5.83e-16 (5.50e-01,-)  6.70e-01 ( -, -)  5.67e-01 ( -, -)
VIA4   Via    54   [ 293.97,  1857.87] 2    max  3.33e-16 (5.50e-01,-)  6.70e-01 ( -, -)  5.67e-01 ( -, -)
```

The report shows the layer name, metal layer or via ID number, location coordinates, metal width or via cut number, analysis mode (min or max), electrical current value, and electromigration constraint value. The Mean, RMS, and Peak columns show the limit on the current imposed by the electromigration constraints and the actual current calculated for the wire segment or via at that location. The letter “v” indicates a violation and a hyphen indicates no violation for that location. A hyphen appearing in the Limit position means that there is no electromigration constraint for that metal or via layer.

To determine how the electromigration results were calculated for a particular net, use the `report_signal_em_calculation` command. For example,

```
icc_shell> report_signal_em_calculation n278
```

The report is similar to the report shown by the `report_signal_em -verbose` command, but the report applies only to the single specified net.

## Identifying Unfixable Violations

If a signal electromigration violation cannot be fixed due to a user-specified setting, IC Compiler categorizes it as an unfixable violation. An unfixable violation can be caused by the violation being on a net that is frozen, a routing layer that is frozen, or a net shape that

is frozen. If your design has unfixable violations, the `report_signal_em` command lists the total number of nets with unfixable violations. It also lists the number of nets in each category (frozen net, frozen layer, or frozen shape), as shown in the following example:

```
Warning: '2' nets with EM violation are unfixable because
      'they are frozen by NDR'.  (SI-145)
Warning: '7' nets with EM violation are unfixable because
      'the violations happen on frozen layers'.  (SI-145)
Warning: '3' nets with EM violation are unfixable because
      'the violations happen on frozen shapes'.  (SI-145)
```

If you use the `report_signal_em -violated -verbose` command, the generated report includes additional information for each unfixable violation, as shown in the following example:

```
Warning: Signal EM violation on net 'n51' is unfixable because it is
      'layer frozen'.  (SI-146)
```

A net can be frozen as a result of a routing rule specified by using the `set_net_routing_rule` command with the `-reroute frozen` option. To confirm this, use the `report_net_routing_rules` command.

```
icc_shell> report_net_routing_rules net_name -freeze
```

You can change the routing rule by reapplying the `set_net_routing_rule` command.

```
icc_shell> set_net_routing_rule net_name -reroute normal
```

A routing layer can be frozen as a result of routing options specified by using the `set_route_zrt_common_options` command with the `-freeze_layer_by_layer_name`, `-freeze_via_to_frozen_layer_by_layer_name`, and `-forbid_new_metal_by_layer_name` options. To confirm which layers and vias are frozen, use the `get_route_zrt_common_options` command.

```
icc_shell> get_route_zrt_common_options -name freeze_layer_by_layer_name
icc_shell> get_route_zrt_common_options \
      -name freeze_via_to_frozen_layer_by_layer_name
icc_shell> get_route_zrt_common_options \
      -name forbid_new_metal_by_layer_name
```

You can change the routing options by reapplying the `set_route_zrt_common_options` command.

```
icc_shell> set_route_zrt_common_options \
      -freeze_layer_by_layer_name {{layer_name false}} \
      -freeze_via_to_frozen_layer_by_layer_name {{layer_name false}} \
      -forbid_new_metal_by_layer_name {{layer_name false}} \
```

A net shape can be frozen as a result of its `route_type` attribute being set to `User Enter`. To confirm this, use the `get_attribute` command.

```
icc_shell> get_attribute -class shape \
[get_net_shapes -of [get_nets net_name]] route_type
```

You can change the `route_type` attribute by using the `set_attribute` command.

```
icc_shell> set_attribute -class shape \
[get_net_shapes -of [get_nets net_name]] route_type "Signal Route"
```

---

## Electromigration Fixing

The `fix_signal_em` command performs electromigration analysis and fixes any violations by modifying the problem nets using segment sizing, nondefault routing rules, or driver cell resizing. This command makes it unnecessary to manually run a repair file or to manually perform incremental routing to fix violations.

Before running the `fix_signal_em` command, make sure that the design is detail routed, the signal electromigration constraints are defined in the Milkyway design library, the switching activity is defined for all boundary nets, crosstalk analysis is enabled, and there are no timing or DRC violations. You can optionally use `report_signal_em` first to report electromigration violations before attempting to fix them.

This is the `fix_signal_em` command syntax:

```
fix_signal_em
[-max_number_iterations count]
[-only_segment_size]
[-only_net_ndr]
[-only_cell_based]
[list_of_nets]
```

The command invokes electromigration analysis for nets, which calculates the current on every edge of the net and compares it with the current thresholds defined in the design library, and then attempts to fix any violations found while observing the DRC rules. The command options let you specify the maximum number of fixing iterations attempted and the types of fixing strategy applied: segment sizing, nondefault routing rules, or driver cell resizing. For more information, see the man page for the command.

To use the IC Compiler GUI to perform electromigration fixing, choose Route > Signal Electromigration > Fix Signal EM. The dialog box offers the same options as the `fix_signal_em` command.

# 11

## Physical Datapath With Relative Placement

---

The IC Compiler physical datapath with relative placement capability provides a way for you to create structures in which you specify the relative column and row positions of instances. During placement and legalization, these structures, which are placement constraints called relative placement structures, are preserved and the cells in each structure are placed as a single entity. Relative placement is also called physical datapath and structured placement.

Note:

Relative placement is available in the IC Compiler package and IC Compiler-PC package, but not in the IC Compiler-XP package. Design Compiler in topographical mode also supports relative placement.

The concepts and tasks necessary for doing relative placement within IC Compiler are described in these sections:

- [Introduction to Physical Datapath With Relative Placement](#)
- [Benefits of Relative Placement](#)
- [Flow for Relative Placement](#)
- [Considerations for Using Relative Placement](#)
- [Creating Relative Placement Groups](#)
- [Adding Objects to a Group](#)
- [Placement of Relative Placement Groups](#)

- Postplacement Optimization of Relative Placement Groups
- Analyzing the Relative Placement Results
- Working With Relative Placement Groups in the GUI
- Querying Relative Placement Groups and Objects
- Saving Relative Placement Information
- Ignoring Relative Placement Constraints
- Removing Relative Placement Groups
- Changing Relative Placement Information
- Deriving Relative Placement Groups
- Summary of Relative Placement Commands
- Limitations of Relative Placement

## Introduction to Physical Datapath With Relative Placement

You perform relative placement by using a set of dedicated commands that specify the relative placement constraints, apply them to a gate-level netlist, check the constraints, remove the constraints, and write the annotated relative placement constraints to a script.

Relative placement is usually applied to datapaths and registers, but you can apply it to any cells in your design, controlling the exact relative placement topology of gate-level logic groups and defining the circuit layout. You can use relative placement to explore QoR benefits, such as shorter wire lengths, reduced congestion, better timing, skew control, fewer vias, better yield, and lower dynamic and leakage power.

The relative placement constraints that you create and annotate implicitly generate a matrix structure of the instances and control the placement of the instances. You use the resulting annotated netlist for physical optimization, during which IC Compiler preserves the structure and places it as a single entity or group, as shown in [Figure 11-1](#).

*Figure 11-1 Relative Placement in a Floorplan*

Relative placement groups  
can be floating or fixed.



---

## Benefits of Relative Placement

Along with being technology-independent and having the ability to improve routability, relative placement provides the following benefits:

- Reduces the placement search space in critical areas of the design, meaning greater predictability of QoR (wire length, timing, power, area) and congestion.
- Maintains relative placement during optimization, placement and legalization, clock tree synthesis, and routing.
- Provides a method for maintaining structured placement for legacy or intellectual property (IP) designs.
- Provides easy-to-use GUI support for datapath creation, analysis, and modification.
- Handles flat and hierarchical designs.

For complex designs, a typical design can have many engineers working on it and many blocks. Hierarchical relative placement makes it possible to place those blocks together relative to each other more easily. Any number of hierarchical levels is allowed.

- Allows sizing of relative placement cells while maintaining relative placement.

## Flow for Relative Placement

A typical relative placement flow is shown in [Figure 11-2](#).

*Figure 11-2 Relative Placement Flow*



The flow for using relative placement follows these major steps:

1. Read a gate-level netlist into IC Compiler.
2. Specify and apply the gate-level relative placement constraints.
3. Generate the placed netlist.
4. Perform clock tree synthesis with the relative placement structures fixed in place.
5. Perform routing with the relative placement structures fixed in place.

You can also use Design Compiler to perform relative placement. For more information, see the Design Compiler topographical technology chapter in the *Design Compiler User Guide*.

---

## Methodology for the Relative Placement Flow

The methodology for the relative placement flow follows these major steps:

1. Read the gate-level netlist into IC Compiler by using the `open_mw_cel` command.
2. Define the relative placement constraints.
  - Create the relative placement groups by using the `create_rp_group` command.  
See “[Creating Relative Placement Groups](#)” on page 11-10.
  - Add relative placement objects to the groups by using the `add_to_rp_group` command.  
See “[Adding Objects to a Group](#)” on page 11-19.

IC Compiler annotates the netlist with the relative placement constraints.

3. Prevent relative placement cells from being removed during optimization by using `psynopt_option`. For example, enter

```
icc_shell> set_rp_group_options \
           -psynopt_option size_only \
           [get_rp_groups *]
```

See “[Preserving Relative Placement Structures](#)” on page 11-58.

4. Read the floorplan information. For example, enter

```
icc_shell> read_def top.def
```

5. Perform placement for the design by using the `place_opt` command.

Note:

Before running `place_opt`, you can use the `create_placement` command to validate the relative placement results. After you achieve the desired relative placement results, run `place_opt` to perform placement and optimization.

6. Analyze the relative placement results.

You can analyze the relative placement results with either `icc_shell` or the IC Compiler GUI. See “[Analyzing the Relative Placement Results](#)” on page 11-61.

If the relative placement is not what you want, modify the relative placement constraints and run this procedure again.

7. Perform clock tree synthesis and physical optimization with the relative placement structures fixed in place. For example, enter

```
icc_shell> set_rp_group_options -cts_option fixed_placement \
           [get_rp_groups *]
icc_shell> clock_opt
```

See “[Postplacement Optimization of Relative Placement Groups](#)” on page 11-58.

8. Perform routing with the relative placement structures fixed in place. For example, enter

```
icc_shell> set_rp_group_options -route_opt_option fixed_placement \
           [get_rp_groups *]
icc_shell> route_opt
```

See “[Postplacement Optimization of Relative Placement Groups](#)” on page 11-58.

---

## Script for a Relative Placement Flow

[Example 11-1](#) shows a script for running a relative placement flow.

### *Example 11-1 Script for the Relative Placement Flow*

```
# Set library and design paths
source setup.tcl
open_mw_cel design_name

# Create relative placement constraints
create_rp_group ...
...
add_to_rp_group ...
...

# Apply design constraints
source constraints.tcl
# Read floorplan information
read_def top.def
```

```
# Perform placement, routing, and optimization on the design
place_opt

# Preserve relative placement during clock tree synthesis
set_rp_group_options -cts_option fixed_placement \
[get_rp_groups *]

# Perform clock tree synthesis, routing, and optimization on the design
clock_opt

# Preserve relative placement during routing
set_rp_group_options -route_opt_option fixed_placement \
[get_rp_groups *]

# Perform routing and optimization on the design
route_opt
```

The example uses

- The `set_rp_group_options -cts_option fixed_placement` command to preserve relative placement during clock tree synthesis  
To allow cell sizing, you can specify the `size_only` keyword for the `-cts_option` option.
- The `set_rp_group_options -route_opt_option fixed_placement` command to preserve relative placement during routing  
To allow cell sizing only when there is enough space, you can specify the `in_place_size_only` keyword for the `-route_opt_option` option.

---

## Relative Placement Flow in Design Compiler Topographical Mode

You can perform relative placement in Design Compiler topographical mode. You specify relative placement constraints by using a dedicated set of Tcl commands that are similar to the commands in IC Compiler. In addition, you can place relative placement constraints in an RTL design, a GTECH netlist, or a mapped netlist by using the HDL compiler directives. Topographical mode annotates the netlist with the relative placement constraints. To save these constraints for subsequent IC Compiler sessions, use the `write_rp_groups` command.

For detailed information about using Design Compiler to perform relative placement, see the *Design Compiler User Guide*.

**Figure 11-3** shows the relative placement flow in Design Compiler topographical mode.

*Figure 11-3 Relative Placement Flow in Design Compiler Topographical Mode*



## Considerations for Using Relative Placement

When you use relative placement, keep the following points in mind:

- Relative placement requires a gate-level netlist. The format can be any format that IC Compiler can read.
- A design can contain both structured and unstructured objects (leaf cells, keepouts, hierarchical groups), and you can control which cells are to be structured by including the cells you want to structure in a relative placement group.

You must determine which portions of the design require a relative placement structure. Overly restricting the placement can produce poor results.

- Some designs, such as datapaths, are appropriate for structured placement, whereas others are more appropriate for usual placement by IC Compiler. You must ensure that relative placement is applicable to your design.
- Relative placement is supported in multivoltage designs. In such designs, a relative placement group cannot cross voltage regions. For more information about multivoltage designs, see [Chapter 14, “Multivoltage Design Flow.”](#)

## Creating Relative Placement Groups

A relative placement group is an association of cells, other groups, and keepouts. A group is defined by the number of rows and columns it uses.

The basic syntax for creating a relative placement group is

```
create_rp_group group_name
    [-design design_name
     [-columns col_cnt] [-rows row_cnt]]
```

IC Compiler creates a relative placement group named *design\_name*::*group\_name*, where *design\_name* is the design specified by the `-design` option, or the current design if you do not use the `-design` option. You must use this name (or a collection of relative placement groups) when referring to this group in other relative placement commands.

If you do not specify any options, the tool creates a relative placement group that has one column and one row but does not contain any objects. To add objects (leaf cells, relative placement groups, or keepouts) to a relative placement group, use the `add_to_rp_group` command, which is described in “[Adding Objects to a Group](#)” on page 11-19.

For example, to create a group named `designA::rp1`, having six columns and six rows, enter

```
icc_shell> create_rp_group rp1 -design designA -columns 6 -rows 6
```

[Figure 11-4](#) shows the positions of columns and rows in a relative placement group.

*Figure 11-4 Relative Placement Column and Row Positions*

|       |       |       |       |       |       |       |
|-------|-------|-------|-------|-------|-------|-------|
| row 5 | 0 5   | 1 5   | 2 5   | 3 5   | 4 5   | 5 5   |
| row 4 | 0 4   | 1 4   | 2 4   | 3 4   | 4 4   | 5 4   |
| row 3 |       | 1 3   | 2 3   | 3 3   | 4 3   | 5 3   |
| row 2 | 0 2   | 1 2   | 2 2   | 3 2   | 4 2   | 5 2   |
| row 1 | 0 1   | 1 1   | 2 1   | 3 1   |       | 5 1   |
| row 0 | 0 0   | 1 0   | 2 0   | 3 0   | 4 0   | 5 0   |
|       | col 0 | col 1 | col 2 | col 3 | col 4 | col 5 |

In this figure,

- Columns count from column 0 (the leftmost column).
- Rows count from row 0 (the bottom row).

- The width of a column is the width of the widest cell in that column.
- The height of a row is the height of the tallest cell in that row.
- Not using all positions in the structure. For example, positions 0 3 (column 0, row 3) and 4 1 (column 4, row 1) are not used.

In addition to the size of the relative placement group, you can also specify attributes of the group. [Table 11-1](#) describes the attributes that you can set on a relative placement group.

*Table 11-1 Relative Placement Group Attributes*

| To do this                                                                                                                                                                                                                                                     | Use this option                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| <p>Specify the type of alignment used by the group.<br/>You can specify either <code>bottom-left</code> (the default), <code>bottom-right</code>, or <code>bottom-pin</code>.<br/>See “<a href="#">Aligning Leaf Cells Within a Column</a>” on page 11-21.</p> | <code>-alignment</code>                  |
| <p>Allow keepouts over tap cells.<br/>See “<a href="#">Adding Keepouts</a>” on page 11-45.</p>                                                                                                                                                                 | <code>-allow_keepout_over_tapcell</code> |
| <p>Allow nonrelative placement cells in relative placement groups.<br/>See “<a href="#">Exposing Unused Space in Relative Placement Groups</a>” on page 11-57.</p>                                                                                             | <code>-allow_non_rp_cells</code>         |
| <p>Specify a corner for the anchor point set by the <code>-x_offset</code> and <code>-y_offset</code> options.<br/>See “<a href="#">Specifying a Corner for an Anchored Relative Placement Group</a>” on page 11-16.</p>                                       | <code>-anchor_corner</code>              |
| <p>Prevent inserting buffers inside the areas of placed relative placement groups.<br/>See “<a href="#">Buffering Strategy for Relative Placement Groups</a>” on page 11-60.</p>                                                                               | <code>-auto_blockage</code>              |
| <p>Specify if the tool can automatically orient the cells in the specified relative placement group.<br/>See “<a href="#">Orientation of Relative Placement Groups</a>” on page 11-27.</p>                                                                     | <code>-cell_orient_opt</code>            |
| <p>Specify the clock tree synthesis preservation attribute.<br/>You can specify <code>fixed_placement</code> or <code>size_only</code>.<br/>See “<a href="#">Postplacement Optimization of Relative Placement Groups</a>” on page 11-58.</p>                   | <code>-cts_option</code>                 |

*Table 11-1 Relative Placement Group Attributes (Continued)*

| To do this                                                                                                                                                                                                    | Use this option          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Prevent inserting buffers into nets inside relative placement groups.<br>See “Buffering Strategy for Relative Placement Groups” on page 11-60.                                                                | -disable_buffering       |
| Specify the orientation of relative placement groups. You can specify default, N, FN, S, or FS. See “Orientation of Relative Placement Groups” on page 11-27.                                                 | -group_orient            |
| Ignore this relative placement group.<br>See “Ignoring Relative Placement Constraints” on page 11-87.                                                                                                         | -ignore                  |
| Legalize relative placement groups.<br>You can specify low, medium, or high.<br>See “Controlling Movement When Legalizing Relative Placement Groups” on page 11-55.                                           | -move_effort             |
| Specify the group alignment pin.<br>See “Aligning Leaf Cells Within a Column” on page 11-21.                                                                                                                  | -pin_align_name          |
| Specify how to treat fixed cells in the floorplan during legalization.<br>See “Handling Fixed Cells During Relative Placement” on page 11-49.                                                                 | -place_around_fixed_cell |
| Specify a placement type for relative placement groups. You can specify bit_slice, vertical_compression, or compression.<br>See “Applying Compression to Relative Placement Groups” on page 11-17.            | -placement_type          |
| Specify the physical optimization preservation attribute.<br>You can specify fixed_placement, size_only, or all_optimization.<br>See “Postplacement Optimization of Relative Placement Groups” on page 11-58. | -psynopt_option          |
| Specify the routing preservation attribute.<br>You can specify fixed_placement or in_place_size_only.<br>See “Postplacement Optimization of Relative Placement Groups” on page 11-58.                         | -route_opt_option        |

*Table 11-1 Relative Placement Group Attributes (Continued)*

| To do this                                                                                                 | Use this option        |
|------------------------------------------------------------------------------------------------------------|------------------------|
| Specify the utilization percentage (default is 100 percent).                                               | -utilization           |
| Specify the anchor location.<br>See “ <a href="#">Anchoring Relative Placement Groups</a> ” on page 11-13. | -x_offset<br>-y_offset |

## Anchoring Relative Placement Groups

By default, IC Compiler can place a relative placement group anywhere within the core area. You can control the placement of a top-level relative placement group by anchoring it.

To anchor a relative placement group, use the `create_rp_group` or the `set_rp_group_options` command with the `-x_offset` and `-y_offset` options. The offset values are float values, in microns, relative to the lower-left corner in the core area.

If you specify both the x- and y-coordinates, the group is anchored at that location. If you specify only one coordinate, IC Compiler can determine the placement by maintaining the specified coordinate and sliding the group along the line passing through the unspecified coordinate.

**Note:**

If you try to anchor a group that is not a top-level group or that causes an invalid placement, IC Compiler generates a warning and continues relative placement. If you specify an anchor point that is outside the design boundary (or an anchor point that causes cells in the relative placement group to be outside the design boundary), IC Compiler generates a warning message and clusters the cells inside the design boundary.

For example, to specify a relative placement group anchored at (100, 100), as shown [Figure 11-5](#), enter the following command:

```
icc_shell> create_rp_group misc1 -design block1 \
-columns 3 -rows 10 -x_offset 100 -y_offset 100
```

*Figure 11-5 Anchored Relative Placement Group*

The script in [Example 11-2](#) defines the locations of 12 relative placement groups that are aligned and anchored vertically at four coordinates, as shown in [Figure 11-6](#). For brevity, not every group is listed in the example.

#### *Example 11-2 Definitions for Locations of Vertically Aligned and Anchored Groups*

```
create_rp_group block1 -design misc1 -columns 3 -rows 10 -x_offset 100
create_rp_group block2 -design misc1 -columns 3 -rows 10 -x_offset 100
create_rp_group block3 -design misc1 -columns 3 -rows 10 -x_offset 100
create_rp_group block4 -design misc1 -columns 3 -rows 10 -x_offset 200
create_rp_group block5 -design misc1 -columns 3 -rows 10 -x_offset 200
create_rp_group block6 -design misc1 -columns 3 -rows 10 -x_offset 200
...
create_rp_group block12 -design misc1 -columns 3 -rows 10 -x_offset 400
```

Figure 11-6 Relative Placement Groups Aligned and Anchored Vertically



---

## Specifying a Corner for an Anchored Relative Placement Group

To avoid obstructions, such as blockages, fixed cells, and tap arrays, you can set a corner for an anchored relative placement group. To specify a bottom-left or bottom-right corner for the anchor point set by the `-x_offset` and `-y_offset` options, use the `create_rp_group` or `set_rp_group_options` command with the `-anchor_corner` option.

You can specify

- The `-anchor_corner bottom-left` option

The anchor point of the relative placement group is set to the bottom-left corner. The default is the bottom-left corner.

- The `-anchor_corner bottom-right` option

The anchor point of the relative placement group is set to the bottom-right corner.

For example, the following command specifies the bottom-right corner for the (100, 100) anchor point of the TOP::RP1 relative placement group.

```
icc_shell> set_rp_group_options TOP::RP1 \
    -anchor_corner bottom-right -x_offset 100 -y_offset 100
```

*Figure 11-7 Bottom-Left and Bottom-Right Anchor Corners*




---

## Aligning Relative Placement Rows With the Site Row

By default, IC Compiler aligns relative placement rows with the site rows of the design. Site rows can be either horizontal or vertical. If designs contain horizontal site rows, the tool places relative placement rows in the horizontal direction, following the specified anchor corner and alignment methods. For designs with vertical site rows, the tool places relative placement cells in a row lining up vertically such that the row is vertical and the column is horizontal for a relative placement group. Note that the `-alignment bottom-right` option of the `create_rp_group` and `set_rp_group_options` commands does not support vertical site rows.

[Figure 11-8](#) shows a relative placement group in the original matrix that is aligned in the horizontal direction and in the vertical direction.

*Figure 11-8 Aligning Relative Placement in the Horizontal Direction and in the Vertical Direction*

## Applying Compression to Relative Placement Groups

By default, IC Compiler places relative placement groups using bit-slice placement. In addition to bit-slice placement, you can apply compression to relative placement groups in the vertical direction or in the horizontal direction. To change the placement method or apply compression, set the `-placement_type` option to one of the following keywords with the `create_rp_group` or `set_rp_group_options` command:

- `bit-slice`

Setting the `-placement_type` option to `bit_slice` enables the placer to place the next row after the tallest object in the row and the next column after the widest object in the column. Both row alignment and column alignment are preserved. The default is `bit_slice`.

- `compression`

Setting the `-placement_type` option to `compression` enables bit-stack placement, which places each row in a relative placement group without any gaps between leaf cells, lower-level hierarchical relative placement groups, and keepouts, as shown in [Figure 11-9](#). Column alignment is not preserved.

*Figure 11-9 Bit-Slice Placement Versus Compression*

If you specify the `-utilization` option and set the `-placement_type` option to `compression`, IC Compiler observes the utilization constraint but leaves gaps between leaf elements in a relative placement row. If you set the `-placement_type` option to `compression` and the `-alignment` option to `bottom-right` or `bottom_pin`, IC Compiler issues an error message. To disable compression, set the `-placement_type` option to an appropriate keyword, such as `bit_slice`, with the `set_rp_group_options` or `create_rp_group` command.

- `vertical_compression`

Setting the `-placement_type` option to `vertical_compression` enables vertical compression such that no gap is allowed between leaf cells, lower-level hierarchical relative placement groups, and keepouts in a column, as shown in [Figure 11-10](#). Applying vertical compression reduces the wire lengths of routes in a column. Row alignment is not preserved.

*Figure 11-10 Bit-Slice Placement Versus Vertical Compression*

For example, the following command sets vertical compression to the `d::rp` relative placement group:

```
icc_shell> set_rp_group_options d::rp \
-placement_type vertical_compression
```

The setting of the `-placement_type` option does not propagate from a parent group to child groups.

## Supporting Compression With Mixed Alignment

You can place relative placement groups with alignment and relative placement groups with a compression constraint in the same top-level group, as shown in [Figure 11-11](#). The individual groups of the top level are aligned with compression only if you set the `-placement_type` option to `compression`. Note that the compression specified at the top level does not propagate to the child groups. Bottom-left alignment is the default for the top-level groups.

*Figure 11-11 Compression of Relative Placement Groups with Mixed Alignment*



## Adding Objects to a Group

You can add leaf cells, other relative placement groups, and keepouts to relative placement groups that have been created with the `create_rp_group` command. You can add objects from the command line, using the `add_to_rp_group` command, in the relative placement hierarchy browser, or in the relative placement editing dialog box. For information about the relative placement hierarchy browser, see [“Using the Relative Placement Hierarchy Browser” on page 11-65](#). For information about the relative placement editing dialog box, see [“Editing and Creating Relative Placement Groups” on page 11-69](#).

When you add an object to a relative placement group, keep the following points in mind:

- The relative placement group to which you are adding the object must exist.
- The object must be added to an empty location in the relative placement group.

---

## Adding Leaf Cells

When you add leaf cells to a relative placement group, you specify their column position, row position, and orientation within the relative placement group. By default, relative placement respects the intercell spacing rules that are defined for standard cells.

To add leaf cells in the relative placement hierarchy browser (Placement > New RP Hierarchy View),

1. Select the group you want to add to in the left pane.
2. Select the Grid tab in the right pane.
3. Select the desired location in the grid view.

When you add leaf cells, make sure that the selected location is empty.

4. Right-click and choose Add Object.

The Add Objects to RP dialog box appears.

5. Select Add Leaf Cell, specify the leaf cell name, and select the possible orientations.
6. Click OK.

Alternatively, you can use the `add_to_rp_group` command. The syntax for adding a leaf cell to a relative placement group by using the `add_to_rp_group` command is

```
add_to_rp_group group_list -leaf cell_name
[-column col_number] [-row row_number]
[-num_columns number_of_columns] [-num_rows number_of_rows]
[-orientation direction]
[-alignment bottom-left | bottom-right | -pin_align_name pin_name]
```

You can also add leaf cells by using the relative placement editing dialog box in the GUI. For more information, see “[Editing and Creating Relative Placement Groups](#)” on page 11-69.

In a relative placement group, a leaf cell can occupy multiple column positions or multiple row positions, which is known as leaf cell straddling. You can create a more compact relative placement group by straddling leaf cells. To define straddling, you specify multiple column or row positions by using the `-num_columns` or `-num_rows` options respectively. You can specify a maximum of 255 rows and 255 columns. If you do not set these options, the default is 1 for both column and row positions. For example, to create a leaf cell of two columns and one row, enter

```
icc_shell> add_to_rp_group rp_group_name -leaf cell_name \
           -column 0 -num_columns 2 -row 0 -num_rows 1
```

You should not place a relative placement keepout at the same location of a straddling leaf cell. In addition, straddling is for leaf cells only, but not for hierarchical groups or keepouts.

**Note:**

You should not apply compression to a straddling leaf cell that has either multiple column positions, multiple row positions, or both. You can apply right alignment or pin alignment to a straddling leaf cell with multiple row positions, but not to a cell with multiple column positions.

## Specifying Orientation for Leaf Cells

You can specify orientations for leaf cells when you add them to a relative placement group. If you do not specify a leaf cell orientation, IC Compiler automatically assigns a legal orientation for the leaf cells.

To specify the orientation for leaf cells,

- Select the possible orientations in the Add Objects to RP dialog box.  
or
- Include the `-orientation` option with a list of possible orientations when you add the cells to the group with the `add_to_rp_group` command.  
or
- Set the `rp_orientation` attribute on leaf cells by using the `set_attribute` command.

The tool chooses one legal orientation from the list of orientations that you provide.

For more information about setting orientations for leaf cells, see “[Controlling Relative Placement Cell Orientations](#)” on page 11-30.

## Aligning Leaf Cells Within a Column

You can align the leaf cells in a column of a relative placement group by using the following alignment methods:

- Bottom left (default)
- Bottom right
- Pin alignment
- Via region alignment

Controlling the cell alignment can improve the timing and routability of your design.

## Aligning by Bottom-Left Corners

By default, IC Compiler aligns the leaf cells by aligning the bottom-left corners. (To explicitly specify this alignment method, use the `-alignment bottom-left` option of the `create_rp_group` or `set_rp_group_options` command.)

```
icc_shell> set_rp_group_options -alignment bottom-left [get_rp_groups *]
```

The script in [Example 11-3](#) defines a relative placement group that is bottom-left aligned. The resulting structure is shown in [Figure 11-12](#).

### *Example 11-3 Definition for Bottom-Left-Aligned Relative Placement Group*

```
create_rp_group rp1 -design pair_design -columns 1 -rows 4
  add_to_rp_group pair_design::rp1 -leaf U1 -column 0 -row 0
  add_to_rp_group pair_design::rp1 -leaf U2 -column 0 -row 1
  add_to_rp_group pair_design::rp1 -leaf U3 -column 0 -row 2
  add_to_rp_group pair_design::rp1 -leaf U4 -column 0 -row 3
```

*Figure 11-12 Bottom-Left-Aligned Relative Placement Group*



## Aligning by Bottom-Right Corners

To align a group by aligning the bottom-right corners, use the `-alignment bottom-right` option of the `create_rp_group` or `set_rp_group_options` command.

```
icc_shell> set_rp_group_options -alignment bottom-right \
  [get_rp_groups *]
```

Note:

For hierarchical relative placement groups, the bottom-right alignment does not propagate through the hierarchy.

The script in [Example 11-4](#) defines a relative placement group that is bottom-right aligned. The resulting structure is shown in [Figure 11-13](#).

**Example 11-4 Definition for Bottom-Right-Aligned Relative Placement Group**

```
create_rp_group rp1 -design pair_design -columns 1 -rows 4 \
    -alignment bottom-right
add_to_rp_group pair_design::rp1 -leaf U1 -column 0 -row 0
add_to_rp_group pair_design::rp1 -leaf U2 -column 0 -row 1
add_to_rp_group pair_design::rp1 -leaf U3 -column 0 -row 2
add_to_rp_group pair_design::rp1 -leaf U4 -column 0 -row 3
```

**Figure 11-13 Bottom-Right-Aligned Relative Placement Group****Aligning by Pin Location**

To align a group by pin location, use the `-alignment bottom-pin` and `-pin_align_name` options of the `create_rp_group` or `set_rp_group_options` command.

```
icc_shell> set_rp_group_options -alignment bottom-pin \
    -pin_align_name align_pin
```

IC Compiler looks for the specified alignment pin in each cell in the column. If the alignment pin exists in a cell, the cell is aligned by use of the pin location. If the specified alignment pin does not exist in a cell, the cell is aligned at the bottom-left corner, and IC Compiler generates an information message. If the specified alignment pin does not exist in any cell in the column, IC Compiler generates a warning message.

If you specify both pin alignment and cell orientation, IC Compiler resolves potential conflicts as follows:

- User specifications for cell orientation take precedence over the pin alignment performed by IC Compiler.
- Pin alignment done by IC Compiler takes precedence over the cell-orientation optimization done by IC Compiler.

The script in [Example 11-5](#) defines a relative placement group that is aligned by pin A. The resulting structure is shown in [Figure 11-14](#).

*Example 11-5 Definition for Relative Placement Group Aligned by Pins*

```
create_rp_group rp1 -design pair_design -columns 1 -rows 4 \
    -pin_align_name A
add_to_rp_group pair_design::rp1 -leaf U1 -column 0 -row 0
add_to_rp_group pair_design::rp1 -leaf U2 -column 0 -row 1
add_to_rp_group pair_design::rp1 -leaf U3 -column 0 -row 2
add_to_rp_group pair_design::rp1 -leaf U4 -column 0 -row 3
```

*Figure 11-14 Relative Placement Group Aligned by Pins*



When you specify an alignment pin for a group, the pin applies to all cells in the group. You can override the group alignment pin for specific cells in the group by specifying the `-pin_align_name` option when you use the `add_to_rp_group` command to add the cells to the group.

**Note:**

You cannot specify a cell-specific alignment pin when you add a leaf cell from the relative placement hierarchy browser.

The script in [Example 11-6](#) defines relative placement group misc1, which uses pin A as the group alignment pin; however, instances I5 and I6 use pin B as their alignment pin, rather than the group alignment pin. The resulting structure is shown in [Figure 11-15](#).

**Example 11-6 Definition for Aligning a Group and Leaf Cells by Pins**

```
create_rp_group misc1 -design block1 -columns 3 -rows 10 \
    -pin_align_name A
add_to_rp_group block1::misc1 -leaf I3 -column 0 -row 0
add_to_rp_group block1::misc1 -leaf I4 -column 0 -row 1
add_to_rp_group block1::misc1 -leaf I5 -column 0 -row 2 \
    -pin_align_name B
add_to_rp_group block1::misc1 -leaf I6 -column 0 -row 3 \
    -pin_align_name B
add_to_rp_group block1::misc1 -leaf I7 -column 0 -row 4
add_to_rp_group block1::misc1 -leaf I8 -column 0 -row 5
```

**Figure 11-15 Relative Placement Group Aligned by Pins**



### Aligning by Via Regions

IC Compiler aligns cells at the center of the specified alignment pins. When via regions are available for the specified alignment pins in a relative placement group, the tool automatically aligns cells based on the individual via regions of the pins rather than the center of the pins.

Alignment by via regions provides the following benefits:

- Makes straight routes easier for the router.

[Figure 11-16](#) shows the alignment of two cells, using methods that are based on the center of the specified pins and on the via regions of the specified pins.

*Figure 11-16 Alignment by Pins Versus Alignment by Via Regions*



- Minimizes the column width of a relative placement group when a pin has more than one via region.

[Figure 11-17](#) shows the alignment of three cells where the middle cell has two via regions.

*Figure 11-17 Alignment by Pins Versus Alignment by the Right Via Region*



---

## Orientation of Relative Placement Groups

The orientation of relative placement groups is determined according to the data flow. If the data flow is from left to right, the first column is placed on the left side, and subsequent columns are placed toward the right. If the data flow is from right to left, the first column is placed on the right side, and subsequent columns are placed toward the left. Normally, row position is from bottom to top: that is, the first row is placed at the bottom, and subsequent rows are placed toward the top. If the row position of the data flow is from top to bottom, the first row is placed at the top, and subsequent rows are placed toward the bottom.

## Relative Placement Group Orientations

IC Compiler allows relative placement groups to be oriented in any of the following ways:

- North (N)

The column position of the relative placement group is from left to right, and the row position is from bottom to top. This orientation is considered as north (N).

- Flipped north (FN)

The column position of the relative placement group is from right to left, and the row position is from bottom to top; that is, the orientation of the group is flipped with respect to its north orientation. This orientation is considered as flipped north (FN).

- South (S)

The column position of the relative placement group is from right to left, and the row position is from top to bottom. This orientation is considered as south (S).

- Flipped south (FS)

The column position of the relative placement group is from left to right, and the row position is from top to bottom; that is, the group is flipped with respect to its south orientation. This orientation is considered as flipped south (FS).

[Figure 11-18](#) shows how the column and row positions in a relative placement group are placed for the four orientations.

*Figure 11-18 Orientation of Relative Placement Groups*

The orientation of relative placement groups is automatically set by the tool to minimize wire length. You can also choose to set the orientation of relative placement groups by using the `set_rp_group_options` command.

For example, the following command sets the relative placement group orientation to north.

```
icc_shell> set_rp_group_options [get_rp_groups design::rp] \
-group_orient N
```

For designs with hierarchical relative placement groups, the orientation settings are propagated down to the lowest level in hierarchy.

Note that when the orientation of a relative placement group is changed, the constraints on the relative placement group, such as alignment and utilization, are preserved according to the specifications that you provide.

## Relative Placement Cell Orientations

By default, the tool places relative placement cells according to the orientation of the relative placement group that contains the relative placement cells. When the orientation of the relative placement group is changed, the relative placement cell orientations are changed automatically to minimize wire length.

For example,

- When the relative placement group is flipped from a north (N) to flipped-north (FN) orientation or south (S) to flipped-south (FS) orientation, the relative placement cell orientations are also flipped accordingly.
- When the relative placement group is changed from a north (N) to south (S) orientation, the tool rotates the relative placement cells 180 degrees counterclockwise if the rotation is legal. If a relative placement cell was previously in its north orientation, it is in its south orientation after the change of orientation of the relative placement group.
- When the relative placement group is changed from a north (N) to flipped-south (FS) orientation, the relative placement cells are rotated 180 degrees counterclockwise if the rotation is legal and then flipped. If a relative placement cell was previously in its north orientation, it is in its flipped-south orientation after the change of orientation of the relative placement group.

[Figure 11-19](#) shows the orientations of relative placement cells when the orientation of the relative placement group that contains the relative placement cells is changed.

*Figure 11-19 Orientations of Relative Placement Cells*



## Controlling Relative Placement Cell Orientations

By default, the tool orients relative placement cells according to the orientation of the relative placement group that contains the relative placement cells. You can enable the tool to place the cells automatically in the most appropriate orientation to optimize wire length. To enable this capability, you specify the `-cell_orient_opt` option of the `create_rp_group` or `set_rp_group_options` command. The `-cell_orient_opt` option is disabled by default.

To remove the setting of automatic cell orientation, use the `-cell_orient_opt` option of the `remove_rp_group_options` command.

You can explicitly set the orientations of relative placement cells by using the `set_attribute` command with the following syntax:

```
set_attribute rp_cell_name rp_orientation direction
```

For example, the following command allows the tool to choose N or FS orientation for the relative placement cell U14 in the relative placement group that has the north orientation.

```
icc_shell> set_attribute U14 rp_orientation {N FS}
```

For more information, see “[Changing the Attributes of Relative Placement Cells](#)” on page 11-96.

---

## Adding Relative Placement Groups

Hierarchical relative placement allows relative placement groups to be embedded within other relative placement groups. The embedded groups then are handled similarly to leaf cells.

You can use hierarchical relative placement to simplify the expression of relative placement constraints. With hierarchical relative placement, you do not need to provide relative placement information multiple times for a recurring pattern.

There are two methods for adding a relative placement group to a hierarchical group:

- Include the group

If the relative placement group to be added is in the same design as its parent group, it is an included group. You can include groups in either flat or hierarchical designs. See “[Including Relative Placement Groups](#)” on page 11-32.

- Instantiate the group

If the relative placement group to be added is in an instance of a subdesign of its parent group, it is an instantiated group. You can instantiate groups only in hierarchical designs. See “[Instantiating Relative Placement Groups](#)” on page 11-34.

The following sections describe these aspects of hierarchical relative placement groups:

- [Benefits of Hierarchical Relative Placement Groups](#)
- [Including Relative Placement Groups](#)
- [Instantiating Relative Placement Groups](#)
- [Using Hierarchical Relative Placement for Straddling](#)
- [Using Hierarchical Relative Placement for Compression](#)
- [Effect of Ungrouping on Hierarchical Relative Placement](#)
- [Effect of Uniquifying on Hierarchical Relative Placement](#)

## Benefits of Hierarchical Relative Placement Groups

Using hierarchical relative placement provides these benefits:

- Allows you to organize your relative placement in a manner that is easier to maintain and understand. For example, you can create the relative placement group to parallel your Verilog or VHDL organization.
- Allows reuse of a repeating placement pattern, such as an adder.
- Can reduce the number of lines of relative placement information you need to write.
- Allows integrating blocks.
- Provides flexibility for the configuration you want.

## Including Relative Placement Groups

To include relative placement groups in the relative placement hierarchy browser (Placement > New RP Hierarchy View),

1. Select the group you want to add to in the left pane.
2. Select the Grid tab in the right pane.
3. Select the desired location in the grid view.

To include relative placement groups, make sure that the selected location is empty.

4. Right-click and choose Add Object.

The Add Objects to RP dialog box appears.

5. Specify the row and column position, specify the alignment method, select Add Hierarchical RP, and specify the relative placement group name.
6. Click OK.

Alternatively, you can use the `add_to_rp_group` command. The syntax for including a group in a hierarchical group by using `add_to_rp_group` is

```
add_to_rp_group hier_group -hierarchy group_name
[-column col_number] [-row row_number]
[-alignment bottom-left | bottom-right]
```

The group specified in the `-hierarchy` option must be in the same design as the hierarchical group in which you are including it.

When you include a relative placement group in a hierarchical group, it is as if the included group is directly embedded within its parent group. An included group can be used only in a group of the same design and only once. However, a group that contains an included group can be further included in another group in the same design or can be instantiated in a group of a different design.

You can also add relative placement groups by using the relative placement editing dialog box. For more information, see [“Editing and Creating Relative Placement Groups” on page 11-69](#).

The script in [Example 11-7](#) creates a hierarchical group (rp4) that contains three included groups (rp1, rp2, and rp3). Groups rp1, rp2, rp3, and rp4 are all in the design top. The contents of groups rp1, rp2, and rp3 are treated as leaf cells when they are included in group rp4. You can further include group rp4 in another group in the design top, or you can instantiate group rp4 in a group of a different design.

The construction of the resulting hierarchical relative placement group is shown in [Figure 11-20](#).

*Example 11-7 Including Groups in a Hierarchical Group*

```
create_rp_group rp1 -design top -columns 2 -rows 1
    add_to_rp_group top::rp1 -leaf U1 -column 0 -row 0
    add_to_rp_group top::rp1 -leaf U4 -column 1 -row 0

create_rp_group rp2 -design top -columns 2 -rows 1
    add_to_rp_group top::rp2 -leaf U2 -column 0 -row 0
    add_to_rp_group top::rp2 -leaf U5 -column 1 -row 0

create_rp_group rp3 -design top -columns 2 -rows 1
    add_to_rp_group top::rp3 -leaf U3 -column 0 -row 0
    add_to_rp_group top::rp3 -leaf U6 -column 1 -row 0

create_rp_group rp4 -design top -columns 1 -rows 3
    add_to_rp_group top::rp4 -hierarchy top::rp1 \
        -column 0 -row 0
    add_to_rp_group top::rp4 -hierarchy top::rp2 \
        -column 0 -row 1
    add_to_rp_group top::rp4 -hierarchy top::rp3 \
        -column 0 -row 2
```

*Figure 11-20 Including Groups in a Hierarchical Group*



## Instantiating Relative Placement Groups

The syntax for instantiating a group in a hierarchical group is

```
add_to_rp_group hier_group
  -hierarchy group_name -instance instance_name
  -orientation direction
  [-column col_number] [-row row_number] ]
```

Note:

You cannot instantiate relative placement groups from the relative placement hierarchy browser; you must do this from the command line.

The group specified in the *-hierarchy* option must be defined in the reference design of the instance specified in the *-instance* option. In addition, the specified instance must be in the same design as the hierarchical group in which you are instantiating the specified group.

Note:

If you define a relative placement group in a subdesign that has been instantiated multiple times, only those instances that are instantiated in a hierarchical relative placement group have relative placement. Instances that are not instantiated in a hierarchical relative placement group do not have relative placement.

Using an instantiated group is a useful way to replicate relative placement information across multiple instances of a design and to create relative placement relationships between those instances. An instantiated group can be used multiple times and in multiple places. For example, use instantiated groups for these cases:

- You have multiple relative placement layouts you want to use for different instances of a design.
- You have only one layout but want to specify relative placement between instances of that layout or between instances and other cells and groups.

The script in [Example 11-8](#) creates a hierarchical group (rp2) that contains three instances of group rp1. Group rp1 is in the design pair\_design and includes leaf cells U1 and U2. Group rp2 is a hierarchical group in the design mid\_design that instantiates group rp1 three times (mid\_design must contain at least three instances of pair\_design). Group rp2 is treated as a leaf cell. You can instantiate rp2 multiple times and in multiple places, up to the number of times mid\_design is instantiated in your netlist.

The construction of the resulting hierarchical relative placement group is shown in [Figure 11-21](#).

*Example 11-8 Instantiating Groups in a Hierarchical Group*

```
create_rp_group rp1 -design pair_design -columns 2 -rows 1
    add_to_rp_group pair_design::rp1 -leaf U1 -column 0 -row 0
    add_to_rp_group pair_design::rp1 -leaf U2 -column 1 -row 0

create_rp_group rp2 -design mid_design -columns 1 -rows 3
    add_to_rp_group mid_design::rp2 \
        -hierarchy pair_design::rp1 -instance I1 -column 0 -row 0
    add_to_rp_group mid_design::rp2 \
        -hierarchy pair_design::rp1 -instance I2 -column 0 -row 1
    add_to_rp_group mid_design::rp2 \
        -hierarchy pair_design::rp1 -instance I3 -column 0 -row 2
```

*Figure 11-21 Instantiating Groups in a Hierarchical Group*

## Setting the Orientation of an Instantiated Relative Placement Group

To specify the orientation of an instantiated relative placement group in a hierarchical relative placement group, set the `-orientation`, `-hierarchy`, and `-instance` options with the `add_to_rp_group` command. You can set the orientation to one of the following four ways: north (N), flipped north (FN), south (S), and flipped south (FS). If you do not specify the orientation, the instantiated relative placement group assumes its orientation from the definition by default. You cannot use the `-orientation` option on included groups.

For example, the following command adds the `grp::ripple` relative placement group that is instantiated with the `U2` name and set for the flipped-north orientation to the `top::rp` hierarchical relative placement group:

```
icc_shell> add_to_rp_group top::rp \
    -hierarchy grp::ripple -instance U2 -orientation FN
```

[Figure 11-22](#) shows the orientation of the `U2` relative placement group before and after the command performs the flipped-north operation.

*Figure 11-22 Example of Setting the Orientation of An Instantiated Relative Placement Group*



## Changing the Structures of Relative Placement Groups

To modify the structures of existing relative placement groups, use the `modify_rp_groups` command to add, remove, swap, and flip rows and columns.

The syntax is

```
modify_rp_groups rp_groups
[-add_rows_at integer]
[-add_columns_at integer]
[-remove_rows_at integer]
[-remove_columns_at integer]
[-number integer]
[-flip_row integer]
[-flip_column integer]
[-swap_rows list]
[-swap_columns list]
```

To add a row or column to a relative placement group, use the `-add_rows_at` or `-add_columns_at` option respectively. To remove a row or column, use the `-remove_rows_at` or `-remove_columns_at` option respectively. To flip a row or column, use the `-flip_row` or `-flip_column` option respectively. To specify multiple rows or columns to be removed or added, set the `-number` option to a value greater than one. The default is one. To swap two rows or columns, use the `-swap_rows` or `-swap_columns` option respectively.

For example, to swap the first and third columns of the `design::my_rp_group` relative placement group, as shown in [Figure 11-23](#), enter

```
icc_shell> modify_rp_groups [get_rp_groups design::my_rp_group] \
    -swap_columns {0 2}
```

*Figure 11-23 Swapping Columns of a Relative Placement Group*



To flip the second column of the design::my\_rp\_group relative placement group, as shown in [Figure 11-23](#), enter

```
icc_shell> modify_rp_groups [get_rp_groups design::my_rp_group] \
    -flip_column 1
```

*Figure 11-24 Flipping a Column of a Relative Placement Group*



Alternatively, you can perform these operations by using the relative placement view window in the GUI. For more information, see [“Editing the Structures of Relative Placement Groups” on page 11-77](#).

## Using Hierarchical Relative Placement for Straddling

A cell can occupy multiple column positions or multiple row positions, which is known as straddling. To define cells for straddling, use the method for including a relative placement group, as described in “[Including Relative Placement Groups](#)” on page 11-32. For more information about leaf cell straddling, see also “[Adding Leaf Cells](#)” on page 11-20

[Figure 11-25](#) shows a relative placement group in which cells straddle columns (instance U2) and rows (instance U7).

*Figure 11-25 Hierarchical Relative Placement Group With Straddling*



[Figure 11-26](#) shows the process of using hierarchical relative placement to build this structure. First, define relative placement groups that contain the leaf cells: rp1 contains U1 and U4, rp2 contains U2, and rp3 contains U3 and U6. Then define a group (rp4) that contains these groups. Finally, define a group that contains the hierarchical group rp4 and the leaf cell U7. The resulting group includes both the column and the row straddle.

[Example 11-9](#) shows the commands used in this process.

*Figure 11-26 Straddling With Hierarchical Relative Placement*



**Example 11-9 Straddling With Hierarchical Relative Placement**

```

create_rp_group rp1 -design top -columns 2 -rows 1
    add_to_rp_group top::rp1 -leaf U1 -column 0 -row 0
    add_to_rp_group top::rp1 -leaf U4 -column 1 -row 0

create_rp_group rp2 -design top -columns 1 -rows 1
    add_to_rp_group top::rp2 -leaf U2 -column 0 -row 0

create_rp_group rp3 -design top -columns 2 -rows 1
    add_to_rp_group top::rp3 -leaf U3 -column 0 -row 0
    add_to_rp_group top::rp3 -leaf U6 -column 1 -row 0

create_rp_group rp4 -design top -columns 1 -rows 3
    add_to_rp_group top::rp4 -hierarchy top::rp1 -column 0 -row 0
    add_to_rp_group top::rp4 -hierarchy top::rp2 -column 0 -row 1
    add_to_rp_group top::rp4 -hierarchy top::rp3 -column 0 -row 2

create_rp_group rp5 -design top -columns 2 -rows 1
    add_to_rp_group top::rp5 -hierarchy top::rp4 -column 0 -row 0
    add_to_rp_group top::rp5 -leaf U7 -column 1 -row 0

```

## Using Hierarchical Relative Placement for Compression

By default, construction for relative placement aligns cells from their bottom-left corner. Compression removes empty space in rows to create a more compact structure. The compressed columns are no longer aligned, and utilization is higher in the area of the compressed cells. To define a compressed structure, use the method for including a relative placement group (see “[Including Relative Placement Groups](#)” on page 11-32).

[Figure 11-27](#) shows the same cells aligned without compression and with compression. To define the compressed structure, first define relative placement groups that contain the rows of leaf cells: rp1 contains U1 and U4, rp2 contains U2 and U5, and rp3 contains U3 and U6. Then define a group (rp4) that contains these groups. [Example 11-10](#) shows the commands used to build the compressed structure.

**Figure 11-27 Bottom-Left Alignment Construction and Compression****Example 11-10 Compression With Hierarchical Relative Placement**

```

create_rp_group rp1 -design top -columns 2 -rows 1
    add_to_rp_group top::rp1 -leaf U1 -column 0 -row 0
    add_to_rp_group top::rp1 -leaf U4 -column 1 -row 0

create_rp_group rp2 -design top -columns 2 -rows 1
    add_to_rp_group top::rp2 -leaf U2 -column 0 -row 0
    add_to_rp_group top::rp2 -leaf U5 -column 1 -row 0

create_rp_group rp3 -design top -columns 2 -rows 1
    add_to_rp_group top::rp3 -leaf U3 -column 0 -row 0
    add_to_rp_group top::rp3 -leaf U6 -column 1 -row 0

create_rp_group rp4 -design top -columns 1 -rows 3
    add_to_rp_group top::rp4 -hierarchy top::rp1 -column 0 -row 0
    add_to_rp_group top::rp4 -hierarchy top::rp2 -column 0 -row 1
    add_to_rp_group top::rp4 -hierarchy top::rp3 -column 0 -row 2

```

Alternatively, you can apply compression in the horizontal direction by setting the `-placement_type` option to `compression` with the `create_rp_group` or `set_rp_group_options` command. See “[Applying Compression to Relative Placement Groups](#)” on page 11-17.

## Effect of Ungrouping on Hierarchical Relative Placement

The `ungroup` command changes the hierarchical relative placement structure. When you ungroup the current design, use `ungroup -flatten -all`, to ensure that the relative placement gets flattened properly.

After you ungroup, instantiated relative placement groups are converted to included relative placement groups, because the design is flattened and all the groups are now of the same design. Instantiation of hierarchical modules no longer exists.

Relative placement groups affected by an `ungroup` command are renamed to show the path to the group before flattening, followed by a slash (/) and the original group name. If this results in a name collision, a numbered suffix is added to create a unique name.

For example, [Figure 11-28](#) shows a hierarchical relative placement group that contains multiple instantiations of group rp1 before and after ungrouping. Before ungrouping, the relative placement definition is as shown in [Example 11-11](#). After ungrouping, the relative placement definition is as shown in [Example 11-12](#).

### *Example 11-11 Instantiated Groups Before Ungrouping*

```
create_rp_group rp1 -design pair_design -columns 2 -rows 1
  add_to_rp_group pair_design::rp1 -leaf U1 -column 0 -row 0
  add_to_rp_group pair_design::rp1 -leaf U2 -column 1 -row 0

create_rp_group rp2 -design mid_design -columns 1 -rows 3
  add_to_rp_group mid_design::rp2 -hierarchy pair_design::rp1 \
    -instance I1 -column 0 -row 0
  add_to_rp_group mid_design::rp2 -hierarchy pair_design::rp1 \
    -instance I2 -column 0 -row 1
  add_to_rp_group mid_design::rp2 -hierarchy pair_design::rp1 \
    -instance I3 -column 0 -row 2
```

### *Example 11-12 Instantiated Groups After Ungrouping*

```
create_rp_group I1/rp1 -design mid_design -columns 2 -rows 1
  add_to_rp_group mid_design::I1/rp1 -leaf I1/U1 -column 0 -row 0
  add_to_rp_group mid_design::I1/rp1 -leaf I1/U2 -column 1 -row 0

create_rp_group I2/rp1 -design mid_design -columns 2 -rows 1
  add_to_rp_group mid_design::I2/rp1 -leaf I2/U1 -column 0 -row 0
  add_to_rp_group mid_design::I2/rp1 -leaf I2/U2 -column 1 -row 0

create_rp_group I3/rp1 -design mid_design -columns 2 -rows 1
  add_to_rp_group mid_design::I3/rp1 -leaf I3/U1 -column 0 -row 0
  add_to_rp_group mid_design::I3/rp1 -leaf I3/U2 -column 1 -row 0

create_rp_group rp2 -design mid_design -columns 1 -rows 3
  add_to_rp_group mid_design::rp2 -hierarchy mid_design::I1/rp1 -column 0 -row 0
  add_to_rp_group mid_design::rp2 -hierarchy mid_design::I2/rp1 -column 0 -row 1
  add_to_rp_group mid_design::rp2 -hierarchy mid_design::I3/rp1 -column 0 -row 2
```

*Figure 11-28 Instantiating Groups in a Hierarchical Group*

## Effect of Uniquifying on Hierarchical Relative Placement

The `uniquify_fp_mw_cel` command can change each instantiation of hierarchical relative placement structures.

The following example shows a typical uniquifying flow:

```
...
icc_shell> read_verilog my_non_uniquified_design.v
icc_shell> source my_rp_constraint.tcl
icc_shell> uniquify_fp_mw_cel
icc_shell> read_def my_floorplan.def
icc_shell> create_placement
or
icc_shell> place_opt
...
```

For example, uniquifying

```
create_rp_group grp_ripple -design ripple
...
create_rp_group grp_top -design top -columns 1 -rows 2
add_to_rp_group top::grp_top -hierarchy ripple::grp_ripple -instance u1 \
    -column 0 -row 0
add_to_rp_group top::grp_top -hierarchy ripple::grp_ripple -instance u2 \
    -column 0 -row 1
```

results in

```
create_rp_group grp_ripple -design ripple
...
create_rp_group grp_ripple -design ripple_0
...
create_rp_group grp_top -design top -columns 1 -rows 2
add_to_rp_group top::grp_top -hierarchy ripple::grp_ripple \
    -instance u1 -column 0 -row 0
add_to_rp_group top::grp_top -hierarchy ripple_0::grp_ripple \
    -instance u2 -column 0 -row 1
```

---

## Adding Keepouts

You can add soft, hard, or space keepouts within relative placement groups either in the relative placement hierarchy browser or from the command line.

All hard, soft, and space keepouts prevent the placement of relative placement cells in that location during both placement and legalization. The differences between the three keepout types are

- How the nonrelative placement cells are handled during legalization

Nonrelative placement cells can be placed in both soft and space keepouts, but not in hard keepouts.

- How the nonrelative placement cells are handled during placement

Nonrelative placement cells can be placed in space keepouts, but not in hard or soft keepouts. To preserve space for nonrelative placement cells inside a relative placement group, such as buffers and control flip-flops, choose the space keepout type.

To fill empty space in rectilinear relative placement groups with nonrelative placement cells, you can create space keepouts to place the nonrelative placement cells in the rectilinear region as shown in [Figure 11-29](#).

*Figure 11-29 Space Keepout in a Rectilinear Relative Placement Group*



- How the keepout width and height are handled during optimization

For hard and space keepouts, the width and height do not change, although the location might, as a result of optimization performed on the relative placement group. Upsizing of relative placement cells can cause an increase column width.

For soft keepouts, the width and height might change as a result of optimization performed on the relative placement group. The column width is maintained, even during upsizing of relative placement cells.

- Their ability to place keepouts over tap cells

Soft keepouts can be placed over tap cells.

By default, hard and space keepouts cannot be placed over tap cells.

To allow placement of hard and space keepouts over tap cells for a relative placement group, use the `-allow_keepout_over_tapcell true` option of the `create_rp_group` or `set_rp_group_options` command.

When you specify keepouts, keep the following points in mind:

- You can specify whether the keepout is a hard, soft, or space keepout.  
If you do not specify the keepout type, IC Compiler creates a hard keepout.
- You can specify the width and height of a keepout.
  - The unit of width for a keepout is the number of placement sites. If you do not specify the width, the default width is the width of the widest cell in that column.
  - The unit of height for a keepout is one row. If you do not specify the height, the default height is the height of the tallest cell in that row.
- You can add a cell, a hard keepout, or a soft keepout, but not a space keepout at the same position in the relative placement group.

When a cell and a keepout occupy the same position, the cell is placed first and the keepout is placed to the right of the cell.

To add keepouts in the relative placement hierarchy browser (Placement > New RP Hierarchy View),

1. Select the group you want to add to in the left pane.
2. Select the Grid tab in the right pane.
3. Select a location in the grid view.

Keepouts can be added in open or occupied locations.

4. Right-click and choose Add Object.  
The Add Objects to RP dialog box appears.
5. Specify the keepout name, width, height, and type.
6. Click OK.

Alternatively, you can use the `add_to_rp_group` command. For more information about `add_to_rp_group`, see the man page.

For example, to create a hard keepout named gap1, enter

```
icc_shell> add_to_rp_group TOP::misc -keepout gap1 \
           -column 0 -row 2 -width 15 -height 1
```

You can also add keepouts by using the relative placement editing dialog box in the GUI. For more information, see “[Editing and Creating Relative Placement Groups](#)” on page 11-69.

---

## Placement of Relative Placement Groups

During placement and legalization, the structure of the relative placement groups is preserved and the cells in each group are placed as a single entity. The following sections describe these aspects of relative placement:

- [Performing Relative Placement in a Design Containing Obstructions](#)
  - [Performing Relative Placement in a Design Containing Tap Cells](#)
  - [Handling Fixed Cells During Relative Placement](#)
  - [Handling Physical-Only Cells During Relative Placement](#)
  - [Using Move Bounds to Constrain Relative Placement](#)
  - [Supporting Relative Placement Groups in Virtual Flat Placement](#)
  - [Propagating Relative Placement Groups in Physical Hierarchy](#)
- 

### Performing Relative Placement in a Design Containing Obstructions

During placement, relative placement groups avoid placement blockages (obstructions) that are defined in the DEF file or created by the `create_placement_blockage` command. A relative placement group can be broken into pieces that straddle obstructions, yet maintain the relative placement structure.

If the height of the obstruction is below a certain threshold, the relative placement cells are shifted vertically; otherwise, the relative placement cells are shifted horizontally.

[Figure 11-30](#) shows the placement of relative placement cells in a design containing obstructions that were either defined in the DEF file or created by `create_placement_blockage`. The obstruction in columns one and two is below the threshold, so IC Compiler shifts the cells vertically. The obstruction in column four is greater than the threshold, so IC Compiler shifts the cells horizontally.

*Figure 11-30 Relative Placement in a Design Containing Obstructions*

|       |       |                    |       |       |
|-------|-------|--------------------|-------|-------|
|       | 1 4   | 2 4                |       |       |
| row 4 | 0 4   | 1 3                | 2 3   | 3 4   |
| row 3 | 0 3   | 1 2                | 2 2   | 3 3   |
| row 2 | 0 2   | <b>Obstruction</b> |       | 3 2   |
| row 1 | 0 1   | 1 1                | 2 1   | 3 1   |
| row 0 | 0 0   | 1 0                | 2 0   | 3 0   |
|       | col 0 | col 1              | col 2 | col 3 |
|       |       |                    |       | col 4 |

## Performing Relative Placement in a Design Containing Tap Cells

Tap cells are special nonlogic cells with well and substrate ties. Tap cells can be defined in the DEF file or created by a tap cell command such as `add_tap_cell_array`. For more information about tap cells, see [Chapter 9, “Chip Finishing and Design for Manufacturing.”](#)

During placement, the cells or columns of a relative placement group are automatically shifted to avoid tap cells while maintaining the relative positions of the cells in the relative placement group.

[Figure 11-31](#) shows how placement of a relative placement group is affected by a tap cell array. The design on the left contains tap cells in every other row, and the design on the right contains tap cells in every row. In both cases, the columns of the relative placement group are shifted to avoid the tap cells but the alignment of the relative placement group is maintained.

*Figure 11-31 Shifting Columns to Avoid Tap Cell Array*

## Handling Fixed Cells During Relative Placement

To specify how to treat fixed cells in the floorplan during legalization of relative placement groups, use the `-place_around_fixed_cells` option of the `create_rp_group` or `set_rp_group_options` command. This option applies to top-level relative placement groups but not to hierarchical relative placement groups.

[Table 11-2](#) shows how the placer handles fixed cells when you specify the `-place_around_fixed_cells` option with a different keyword.

*Table 11-2 Keywords for the -place\_around\_fixed\_cells Option*

| To do this                                                                                                              | Use this keyword |
|-------------------------------------------------------------------------------------------------------------------------|------------------|
| Legalize relative placement groups around fixed standard cells and avoid fixed physical-only cells.                     | standard         |
| Legalize relative placement groups around fixed physical-only cells and avoid fixed standard cells.                     | physical_only    |
| Legalize relative placement groups around both fixed standard cells and fixed physical-only cells. This is the default. | all              |
| Avoid both fixed standard cells and fixed physical-only cells.                                                          | none             |

The following command places the rp relative placement group around fixed standard cells but avoids fixed physical-only cells during legalization.

```
icc_shell> create_rp_group rp -design d1 -rows 2 -columns 2 \
    -place_around_fixed_cells standard
```

The following command avoids both fixed standard cells and fixed physical-only cells during the legalization of the d1::rp relative placement group.

```
icc_shell> set_rp_group_options d1::rp -place_around_fixed_cells none
```

## Handling Physical-Only Cells During Relative Placement

Physical-only cells are nonlogic cells that have only PG pins or no pin at all, such as tap cells and decoupling capacitors. During the placement of relative placement groups, physical-only cells are not recognized and can cause possible overlapping with relative placement groups. By default, the alignment of relative placement groups is preserved during placement and legalization. However, the alignment of relative placement groups that are overlapped by physical-only cells is often disturbed after the `legalize_placement` step.

For better alignment, IC Compiler allows both physical-only cells and relative placement cells in a relative placement group by default. You can place physical-only cells just like logic cells by specifying the alignment methods, cell orientation, anchor location, bit-stack placement, and so forth.

For example, to add a physical-only cell named PO\_cell to a relative placement group, enter

```
icc_shell> add_to_rp_group design::rp_group -leaf PO_cell \
    -column 0 -row 0
```

To remove the PO\_cell from the relative placement group, enter

```
icc_shell> remove_from_rp_group design::rp_group -leaf PO_cell
```

To return a collection of physical-only cells in a relative placement group, use the `rp_group_references -physical_only` command.

Note that the `extract_rp_group` command does not support physical-only cells.

## Using Move Bounds to Constrain Relative Placement

You can constrain the placement of relative placement cells by defining move bounds with fixed coordinates (relative placement does not support group bounds). Both soft bounds and hard bounds are supported for relative placement cells, and both rectangular bounds and rectilinear bounds are supported.

**Caution:**

If you use move bounds to constrain relative placement, all cells in a relative placement group must be in the same move bound; otherwise, the tool issues an error message and ignores the relative placement constraints.

To constrain relative placement by using move bounds, use the `create_bounds` command and specify the individual cell names as provided in an `add_to_rp_group` command as the command argument. You cannot specify a relative placement group as the command argument.

For example, enter

```
icc_shell> create_bounds -coordinate {100 100 200 200} \
   "U1 U2 U3 U4" -name bound1
```

For details about the `create_bounds` command, see the man page.

---

## Supporting Relative Placement Groups in Virtual Flat Placement

You can place relative placement groups during virtual flat placement in the design planning flow. To achieve better correlation between the `create_fp_placement` and `create_placement` commands, the `create_fp_placement -no_legalize` command supports three types of relative placement groups that contain macros only, standard cells only, and both macros and standard cells.

During the design planning flow, you can perform the following relative placement functions:

- Specify bit-slice placement, compression, or vertical compression by using the `-placement_type` option with the `bit_slice`, `compression`, or `vertical_compression` keyword respectively.
- Specify the anchor location by using the `-x_offset` and `-y_offset` options.
- Specify the utilization percentage by using the `-utilization` option.
- Ignore the relative placement group by using the `-ignore` option.

However, you should not use the following relative placement functions:

- Specify the group alignment pin by using the `-pin_align_name` option.
- Specify the right alignment by using the `-alignment bottom_right` option.
- Allow keepouts over tap cells by using the `-allow_keepout_over_tapcell` option.
- Specify the orientation of relative placement groups by using the `-group_orient` option.

For designs containing relative placement groups that have either only macros or standard cells, use the following flow:

1. Define the relative placement constraints.
  - Create the relative placement groups by using the `create_rp_group` command.
  - Add relative placement objects to the groups by using the `add_to_rp_group` command.
2. Run virtual flat placement by using the `create_fp_placement -no_legalize` command.
3. Mark all macros with the `is_fixed` attribute.
4. Legalize your design by using the `legalize_placement` command.
5. Mark all relative placement cells with the `is_fixed` attribute.
6. Perform physical placement by using the `place_opt` command.

You can skip Steps 4 and 5 if the relative placement group contains standard cells only.

For designs containing relative placement groups that have mixed macros and standard cells, the flow to perform virtual flat placement follows these steps:

1. Run virtual flat placement by using the `create_fp_placement -no_legalize` command.
2. Mark all macros with the `is_fixed` attribute.
3. Legalize your design by using the `legalize_placement` command.
4. Mark all macros and standard cells in the relative placement groups with the `is_fixed` attribute.
5. Continue the design planning flow.

For more information about performing relative placement in the design planning flow, see the virtual flat placement information in the *IC Compiler Design Planning User Guide*.

---

## Propagating Relative Placement Groups in Physical Hierarchy

During the commit and uncommit hierarchy steps of the design planning flow, the `commit_fp_plan_groups` and `uncommit_fp_soft_macros` commands support relative placement groups, including hierarchical relative placement groups. Before you run the `commit_fp_plan_groups` command, you should perform initial virtual flat placement. For more information, see “[Supporting Relative Placement Groups in Virtual Flat Placement](#)” on page 11-51.

The `commit_fp_plan_groups` command converts plan groups into new soft macros. If the plan group includes relative placement groups, they are propagated to soft macros. The `uncommit_fp_soft_macros` command converts soft macros into top-level plan groups. If the soft macro includes relative placement groups, they are propagated to the plan group in the top level.

Use the following flow for designs containing relative placement groups:

1. Place and legalize the design with relative placement groups by using the `create_fp_placement -no_legalize` and `legalize_placement` commands.

During the `legalize_placement` step, the relative placement groups remain intact inside the plan groups that they belong.

2. Convert plan groups into soft macros, also called a child cell or a physical block, by using the `commit_fp_plan_groups` command.

The command removes relative placement groups that belong to the plan group from the top CEL view and pushes them down to soft macros. Each soft macro is a CEL view of the block in the same Milkyway design library.

3. Fix the locations of the relative placement groups that include macros by setting the `is_fixed` attribute.

4. Perform place and route on each soft macro independently.

5. (Optional) Convert all soft macros into plan groups by using the `uncommit_fp_soft_macros` command.

During uncommit hierarchy, the soft macro child cell instances are pushed back up to the top CEL view.

6. (Optional) Validate the relative placement groups by performing the following commands.

```
write_rp_groups -all -nosplit -output afu.tcl  
check_rp_groups -all -verbose  
report_rp_group_options
```

Note that if you need to place the design after the design planning flow, both the `create_placement` and `refine_placement` commands respect relative placement groups that are inside plan groups during placement.

For more information, see the relative placement information in the *IC Compiler Design Planning User Guide*.

---

## Postplacement for Relative Placement Groups

After placement, you can add incremental relative placement groups to a placed design without disturbing the initial placement. You can also improve the quality of results in relative placement by controlling movement, legalizing relative placement groups, and allowing nonrelative placement cells in relative placement groups. The following sections describe how to perform these tasks.

- [Adding Incremental Relative Placement Groups](#)
  - [Controlling Movement When Legalizing Relative Placement Groups](#)
  - [Legalizing Relative Placement Groups in a Placed Design](#)
  - [Exposing Unused Space in Relative Placement Groups](#)
- 

### Adding Incremental Relative Placement Groups

You can create relative placement groups of cells in an already placed design and place the relative placement groups incrementally where the `refine_placement` command does not disturb the initial placement significantly. Note that if you select cells that are placed far apart in the initial placement for the same relative placement group, performing incremental relative placement might degrade the QoR.

The following script shows an example of how to add incremental relative placement groups:

```
icc_shell> create_placement
icc_shell> legalize_placement
icc_shell> create_rp_group new_rp -design design1 -columns 1 -rows 4
icc_shell> add_to_rp_group design1::new_rp -leaf U1 -column 0 -row 0
icc_shell> add_to_rp_group design1::new_rp -leaf U2 -column 0 -row 1
...
icc_shell> refine_placement
```

For more information about the `refine_placement` command, see “[Refining Placement](#)” on page 6-69.

For a placed design, if you create a new relative placement group using the `-x_offset` and `-y_offset` options and then run `legalize_placement`, the tool places and legalizes the newly created group anchored by the specified x- and y-coordinates.

---

## Controlling Movement When Legalizing Relative Placement Groups

You can control the movement of a relative placement group during legalization by using the `-move_effort` option of the `create_rp_group` command. Coarse placement estimates an initial location for every top-level relative placement group. The `-move_effort` option controls the extent to which a relative placement group can be moved from its initial location to preserve the relative placement without violating relative placement constraints. When you change the option setting from a higher effort level to a lower effort level, you reduce the size of the region searched for placement of a relative placement group.

For example, to place relative placement groups close to the initial location returned by the coarse placement, enter

```
icc_shell> create_rp_group grp_ripple -design ripple -move_effort low
```

The `set_rp_group_options` command also supports the `-move_effort` option.

For more information about the `-move_effort` option, see the `create_rp_group` or `set_rp_group_options` man page.

---

## Legalizing Relative Placement Groups in a Placed Design

You can improve the placement of relative placement groups in an already placed design by legalizing only the relative placement groups. To legalize the detailed placement of relative placement groups but not nonrelative placement cells, use the `legalize_rp_placement` command.

The following command legalizes all relative placement groups in the design.

```
icc_shell> legalize_rp_placement
```

You can also specify a list of relative placement groups to be legalized. For example, the following command legalizes the TOP::RP1 and TOP::RP2 relative placement groups.

```
icc_shell> legalize_rp_placement {TOP::RP1 TOP::RP2}
```

Using the `legalize_rp_placement` command for incremental relative placement groups reduces the turnaround time. The following script shows an example of how to legalize incremental relative placement groups with this command.

```
...
#Create RP1 and add cells to RP1
create_rp_group RP1 -design TOP ...
add_to_rp_group TOP::RP1 ...

#Create RP2 and add cells to RP2
create_rp_group RP2 -design TOP ...
add_to_rp_group TOP::RP2 ...

#Run placement using create_placement, refine_placement, or place_opt
create_placement
...
#Create RP3 and add cells to RP3
create_rp_group RP3 -design TOP ...
add_to_rp_group TOP::RP3 ...

#Legalize relative placement groups using legalize_rp_placement or
#legalize_rp_placement -legalize_over_rp
legalize_rp_placement -legalize_over_rp RP3
legalize_placement
...
```

You can specify relative placement groups to be legalized over other unspecified relative placement groups by using the `-legalize_over_rp` option with the `legalize_rp_placement` command. Before running the `legalize_rp_placement` command, you need to perform an initial placement.

For example, the following command legalizes the RP3 relative placement group over the RP1 and RP2 relative placement groups. [Figure 11-32](#) shows the placement before and after running the command.

```
icc_shell> legalize_rp_placement -legalize_over_rp RP3
```

*Figure 11-32 Legalizing the RP3 Relative Placement Group Over Other Groups*



Because the command legalizes relative placement groups only, you might need to run the `legalize_placement` command to legalize nonrelative placement cells after running the `legalize_rp_placement` command. You should also legalize the overlapping nonrelative placement cells and relative placement groups, if any. In this example, the RP1 and RP2 relative placement groups are overlapped by the RP3 relative placement group.

You might need to legalize the RP1 and RP2 relative placement groups by performing the following tasks in sequence:

1. Set new anchor points by using the `-x_offset` and `-y_offset` options or control the movement by using the `-move_effort` option of the `set_rp_group_options` command.
2. Run the `legalize_rp_placement {TOP::RP1 TOP::RP2}` or `legalize_placement` command.

## Exposing Unused Space in Relative Placement Groups

To allow the placer to use unused space in relative placement groups for nonrelative placement cells, you can specify the `-allow_non_rp_cells` option of the `create_rp_group` or `set_rp_group_options` command. When this option is set, the `refine_placement` and `place_opt` commands fix the relative placement cells in the specified relative placement groups so that the unused space is shown. During placement optimization, the coarse placer can consider the unused space for nonrelative placement cells to reduce congestion and improve QoR. This option applies to top-level relative placement groups, but not to hierarchical relative placement groups.

To reset this option setting, specify the `-allow_non_rp_cells` option of the `remove_rp_group_options` command.

---

## Postplacement Optimization of Relative Placement Groups

During postplacement optimization, relative placement cells can be modified, moved, or removed, and buffering can occur. The following sections describe the preservation, buffering strategy, and optimization for relative placement groups:

- [Preserving Relative Placement Structures](#)
  - [Optimizing Relative Placement Cells](#)
  - [Buffering Strategy for Relative Placement Groups](#)
- 

### Preserving Relative Placement Structures

When a relative placement cell is modified or moved, the relative placement structure can be disturbed. When a relative placement cell is removed during optimization, the relative placement information attached to the instance is also removed, disrupting the relative placement structure.

To preserve the relative placement structures during various postplacement optimization processes, use the `create_rp_group` or `set_rp_group_options` command to specify the `fixed_placement` or `size_only` keyword with the appropriate option as shown in [Table 11-3](#). The `fixed_placement` attribute keeps the relative placement structures fixed. The `size_only` attribute prevents relative placement cells from being removed but allows cell sizing during optimization.

For clock tree synthesis and physical optimization, you specify the preservation attribute by using the `fixed_placement` or `size_only` keyword. For routing optimization, you specify the preservation attribute by using the `fixed_placement` or `in_place_size_only` keyword.

[Table 11-3](#) shows the options that mark the relative placement cells as `fixed_placement`, `size_only`, or `in_place_size_only` during the affected commands.

*Table 11-3 Options to Preserve Relative Placement Structures*

| <b>Process</b>        | <b>Option</b>     | <b>Affected commands</b>                               |
|-----------------------|-------------------|--------------------------------------------------------|
| Clock tree synthesis  | -cts_option       | clock_opt<br>compile_clock_tree<br>optimize_clock_tree |
| Physical optimization | -psynopt_option   | psynopt<br>clock_opt -only_psyn                        |
| Routing               | -route_opt_option | route_opt                                              |

By default, the tool allows relative placement cells to be sized during

- The `psynopt` and `place_opt` steps.
- The embedded `psynopt` step of the `clock_opt -only_psyn` command.

If relative placement cells are upsized or downsized, the relative placement cell alignment is maintained for placement.

To set the `size_only` attribute on all relative placement cells during physical optimization, enter

```
icc_shell> set_rp_group_options -psynopt_option size_only \
    [get_rp_groups *]
```

To size the relative placement cells during clock tree synthesis and physical optimization, enter

```
icc_shell> set_rp_group_options -cts_option size_only \
    -psynopt_option size_only [get_rp_groups *]
```

You can reduce waste space in relative placement groups by specifying the `-cts_option size_only` option during the `clock_opt` step or during clock tree synthesis and optimization. You use this option only when there is enough space for sizing.

To size the relative placement cells during postroute optimization, enter

```
icc_shell> set_rp_group_options -route_opt_option in_place_size_only \
    [get_rp_groups *]
```

---

## Optimizing Relative Placement Cells

To allow all optimizations on relative placement cells during placement performed by the `psynopt` and `place_opt` commands, specify the `all_optimization` keyword of the `-psynopt_option` option when you run the `create_rp_group` or `set_rp_group_options` command. To preserve relative placement cells during physical optimization, specify the `fixed_placement` or `size_only` keyword of the `-psynopt_option` option. For more information about preserving relative placement cells, see “[Preserving Relative Placement Structures](#)” on page 11-58.

When you specify the `-psynopt_option all_optimization` option, the tool performs all optimizations on the relative placement cells in the specified relative placement groups. After the optimizations, the relative placement cells remain inside the relative placement groups and the structures of the relative placement groups are preserved. However, some empty areas in the relative placement groups might occur because of the removal of relative placement cells. You should check whether removing the relative placement cells is acceptable for the specified relative placement groups on which the tool performs all optimizations.

---

## Buffering Strategy for Relative Placement Groups

During optimization, buffers that are inserted in relative placement groups can increase congestion and degrade the quality of results (QoR). To avoid the situation, IC Compiler provides a buffering strategy for relative placement groups.

To prevent the `psynopt` and `route_opt` steps from inserting buffers inside the areas of placed relative placement groups, specify the `-auto_blockage` option. To prevent the `psynopt` and `route_opt` steps from inserting buffers into relative placement nets, specify the `-disable_buffering` option. Relative placement nets are nets that connect relative placement cells within a relative placement group or nets that connect two lower-level hierarchical groups in the same top-level relative placement group.

If you do not specify the `-auto_blockage` or `-disable_buffering` option of the `set_rp_group_options` command, buffer insertion inside the relative placement groups or into relative placement nets is allowed by default.

For example, the following command prevents nonrelative placement cells from being placed inside the areas of relative placement groups and prevents buffers from being inserted into relative placement nets.

```
icc_shell> set_rp_group_options -auto_blockage \
           -disable_buffering [get_rp_groups *]
```

---

## Analyzing the Relative Placement Results

The following sections explain methods for analyzing your relative placement results:

- [Checking Relative Placement Constraints](#)
  - [Locating a Relative Placement Group](#)
  - [Analyzing Relative Placement Groups in the GUI](#)
- 

### Checking Relative Placement Constraints

To check whether the relative placement constraints have been met, run the `check_rp_groups` command.

The `check_rp_groups` command checks for the following failures:

- One or more cells in the relative placement group cannot be legally placed.
- The relative placement group cannot be placed as a whole.
- The height or width of the relative placement group is greater than the height or width of the core area.
- The user-specified orientation cannot be met.

The generated report contains separate sections for critical and noncritical failures. If the failure does not prevent placement but causes relative placement constraints to be violated, such as an alignment, utilization, or orientation failure, the failure is considered noncritical. If a failure prevents the group from being placed as a single entity that is defined by the relative placement constraints, the failure is considered a critical failure. To check the specified relative placement groups that cannot be placed, use the `-critical` option.

You can check all relative placement groups by specifying the `-all` option, or you can specify a list of relative placement groups to check. For example,

```
icc_shell> check_rp_groups -all
...
*****
RP GROUP: example3::gp_2_in_example3
-----
Warning: The alignment has not been respected for RP group
example3::gp_2_in_example3
```

To report more details of failures in cell orientation, alignment, and utilization with the exact locations, use the `-verbose` option.

For example, the following report contains an alignment failure:

```
icc_shell> check_rp_groups -all -verbose
...
*****
RP GROUP: example3::gp_2_in_example3
-----
Warning: The alignment has not been respected for RP group
example3::gp_2_in_example3

Location details of alignment failure inside RP Group example3::gp_2_in_example3:
-----
RP Group          Row  Column  Failed Alignment
-----
example3::gp_1_in_example3  1    0        bottom-right(specified on RP cell U18)
example3::gp_2_in_example3  1    1        bottom-left
-----
(RPGP-038)
{example3::gp_2_in_example3}
```

The following example shows a report that contains a utilization failure:

```
icc_shell> check_rp_groups -all -verbose
...
RP GROUP: example3::gp_2_in_example3
-----
Warning: The utilization has not been respected for the RP group
example3::gp_2_in_example3

Utilization is not met at the following columns inside RP Group
example3::gp_2_in_example3:
-----
RP Group          Column
-----
example3::gp_2_in_example3      1
example3::gp_2_in_example3      0
-----
(RPGP-039)
{example3::gp_2_in_example3}
```

By default, the report is output to the screen. To save the report to a file, specify the file name by using the `-output` option. For example, to check the relative placement constraints for the compare17::seg7 and compare17::rp\_group3 relative placement groups and to save the output in a file named `rp_failures.log`, use the following command:

```
icc_shell> check_rp_groups "compare17::seg7 compare17::rp_group3" \
    -output rp_failures.log
...
*****
RP GROUP: compare17::seg7
-----
Warning: Possible placement failure of relative placement group
'compare17::seg7'. (RPGP-027)
...
...
*****
RP GROUP: compare17::rp_group_3
-----
Warning: The utilization has not been respected for the RP group
'compare17::rp_group_3'. (RPGP-039)
```

You can also check the relative placement constraints in the GUI by choosing Placement > Check RP Groups. When you check the constraints in the GUI, all relative placement groups are checked. In the generated report, critical failures are indicated by an exclamation mark (!). When you select reported violations, the location of the violation is displayed in the layout view.

Note that the `check_rp_groups` command does not check for the failure that keepouts are not created correctly in the relative placement group.

## Locating a Relative Placement Group

You use the `get_location` command with its `-rp_group` option to get the grid location of a relative placement cell or group.

The syntax is

```
get_location cell_or_group_list
    -rp_group containing_rp_group
```

The command returns a list of the x- and y-values of each object specified within the containing relative placement group that you specify.

If a group is instantiated multiple times within the group that contains it, a sublist of all locations is returned within the returned list of locations for each object.

If a group does not contain any of the objects, a message appears.

For example, to get the location of cell U11 in relative placement group my\_group, enter the following commands:

```
icc_shell> set cell_rp_location \
    [get_location [get_cell U11] -rp_group my_group]
icc_shell> set x_rp_loc [lindex $cell_rp_location 0]
icc_shell> set y_rp_loc [lindex $cell_rp_location 1]
```

---

## Analyzing Relative Placement Groups in the GUI

To analyze relative placement groups before placement, you can use the relative placement window in the GUI to check the hierarchy and net connections. For more information, see “[Using the Relative Placement Window](#)” on page 11-71.

---

## Working With Relative Placement Groups in the GUI

The GUI provides the following methods of viewing and editing the relative placement groups:

- [Using the Relative Placement Hierarchy Browser](#)
- [Viewing Relative Placement Groups](#)
- [Viewing Relative Placement Group Net Connections](#)
- [Viewing Net Connectivity Between Relative Placement Groups](#)
- [Moving Relative Placement Groups](#)
- [Editing and Creating Relative Placement Groups](#)
- [Using the Relative Placement Window](#)
- [Viewing the Hierarchy of Relative Placement Groups](#)
- [Viewing Logical Connections in a Relative Placement Group](#)
- [Editing Relative Placement Groups in a Relative Placement View Window](#)
- [Editing the Structures of Relative Placement Groups](#)

## Using the Relative Placement Hierarchy Browser

The relative placement hierarchy browser displays information about the relative placement groups in the current design.

To open the relative placement hierarchy browser, choose Placement > New RP Hierarchy View.

As shown in [Figure 11-33](#), the left pane of the relative placement hierarchy browser lists the relative placement groups in the current design. When you select a relative placement group in the left pane, its contents are listed in the right pane. When you select a group in the relative placement hierarchy browser in either the right or left pane, it is highlighted in the layout view.

*Figure 11-33 Relative Placement Hierarchy Browser*

The screenshot shows the Relative Placement Hierarchy Browser interface. On the left is a 'Grid' pane containing a table with four columns: 'name', 'design', 'rows', and 'columns'. The table lists several relative placement groups under the 'ORCA' design. The group 'ORCA::Oprnd\_Reg' is selected, highlighted in blue. On the right is a 'List' pane showing a tree view of 'full\_name' entries, also highlighting 'ORCA::Oprnd\_Reg'.

| name                    | design      | rows     | columns  |
|-------------------------|-------------|----------|----------|
| ORCA::Crnt_Instr_reg    | ORCA        | 1        | 2        |
| ORCA::Current_State_reg | ORCA        | 3        | 1        |
| ORCA::Lachd_Result_reg  | ORCA        | 16       | 1        |
| <b>ORCA::Oprnd_Reg</b>  | <b>ORCA</b> | <b>1</b> | <b>2</b> |
| ORCA::PCint_reg         | ORCA        | 8        | 1        |
| ORCA::PopDataOut_reg    | ORCA        | 11       | 1        |
| ORCA::s_op_reg          | ORCA        | 1        | 8        |
| ORCA::Stack_Mem_reg     | ORCA        | 1        | 8        |

## Viewing Relative Placement Groups

Relative placement groups are visible and selectable in the layout view. In addition, the layout view provides a relative placement visual mode for displaying the relative placement groups and net connections.

To view relative placement groups in the visual mode,

1. Invoke relative placement visual mode by choosing Placement > Color By RP Groups.

The Visual Mode panel appears. The relative placement groups are listed by number, along with the number of cells in each group. If the design or the relative placement constraints have changed since you last invoked relative placement visual mode, this information might be out-of-date.

2. Update the relative placement information by clicking the Reload in the Visual Mode panel.

The Update Relative Placement Visual Mode dialog box appears.

3. Select “Color by RP groups” in the Update Relative Placement Visual Mode dialog box and click OK.

Each relative placement group is displayed in a different color in the layout view. If the design has not been placed, you do not see the relative placement groups in the layout view but the information in the Visual Mode panel is correct.

---

## Viewing Relative Placement Group Net Connections

To view the net connections of a relative placement group in the visual mode,

1. Invoke relative placement visual mode by choosing Placement > Color By RP Net Connections.
2. Enter the relative placement group name in the Visual Mode panel.
3. Click the Reload button.

The RP Net Connections Visual Mode shows the number of pin-to-pin connections of the specified relative placement group. The pin-to-pin connections can be displayed in either flylines or routes. Two types of flyline connections that are highlighted in the visual mode view are called the local and global connections: the local is in red and the global is in green, as shown in [Figure 11-34](#). A histogram-like bar graph shows the number of connections for each type.

*Figure 11-34 Net Connections in Visual Mode*



A dialog box that is displayed by clicking the List nets button lets you choose the local and global connections that are to be listed. You can also choose to display the local or global connections by checking the respective option in the Visual Mode panel.

## Viewing Net Connectivity Between Relative Placement Groups

To generate a layout view showing the number of net connections between one selected relative placement group and other relative placement groups, macros, or plan groups, choose View > Net Connectivity in the GUI. An example of this is shown in [Figure 11-35](#).

*Figure 11-35 Relative Placement Net Connectivity*



---

## Moving Relative Placement Groups

You can move relative placement groups in an active layout view by following these steps:

1. Click the  button on the Edit toolbar or choose Edit > Move/Resize.
2. Select all objects in a top-level relative placement group and drag them to a new location with the left mouse button.  
Every object inside the selected relative placement group, including hierarchical relative placement groups, keepouts, and relative placement cells, is moved to the new location.
3. Run the `legalize_placement` command to legalize the relative placement group.

The following restrictions apply:

- You can move only top-level relative placement groups but not lower-level relative placement groups.
- You cannot move a relative placement group that contains relative placement cells marked as `is_fixed`.
- You cannot move a relative placement group that has an anchor point.

---

## Editing and Creating Relative Placement Groups

To edit an existing relative placement group,

1. Use either of the following two ways to open an RP Editing dialog box:
  - From a layout window, choose Placement > Edit RP Group.
  - From a relative placement window, choose RP > Edit RP Group.The RP Editing dialog box appears.
2. Enter the relative placement group name in the RP group name box.

Alternatively, you can click the  button to display the pop-up menu. Select a relative placement group in the menu, and click OK.

3. Click the Edit option to edit an existing relative placement group.  
If you want to create a new relative placement group, click the Create option.
4. Specify how many column and row numbers should be in the Columns and Rows boxes respectively.

5. Specify the object type by clicking the Cell, Keepout, or RP Group option.

If you click the Cell option, a dialog box appears.

6. (Optional) Set cell options in the dialog box before you select cells in the layout view or add cells manually in the table.

- Choose the Cell options tab in the dialog box.
- Choose the possible orientations and alignment methods for the selected cells.

7. (Optional) Set options in the dialog box to add cells.

Choose Add cells from selection tab in the dialog box to

- Allow automatic expansion of row and column numbers for the relative placement group to accommodate all the selected cells.

This option is available only when you click the Create option. If you do not specify this option, the relative placement group is limited by the column and row numbers you specify in Step 4.

- Add the selected cells in the table according to their physical locations.
- Add the selected cells to the specified locations in the table.
- Add the selected cells to the existing empty locations in the table.

Click the Add button in the dialog box to add cells.

Note:

When the number of the selected cells exceeds the available space in the table, it is undetermined which cells the tool chooses to put in the table.

8. Click the Add button.

You can add objects to the table by entering the object names in the table.

9. Click OK or Apply.

You can remove objects from the table by clicking the Remove button. You can also drag an object from one location to another. To switch two selected objects between two columns or rows in the table, click the Switch button. To restart editing, click the Reset button. You can only add or create one relative placement group at any time by using the relative placement editing dialog box.

The relative placement editing dialog box allows you to cross-highlight objects between the table and layout view. [Figure 11-36](#) shows an example of using the relative placement editing dialog box to create a relative placement group of four columns and two rows. The layout view highlights the eight selected cells that are added to the relative placement group.

*Figure 11-36 Relative Placement Editing Dialog Box*



For more information about using the relative placement editing dialog box, see IC Compiler Help.

Alternatively, you can edit relative placement groups in a relative placement view window. See “[Editing Relative Placement Groups in a Relative Placement View Window](#)” on page 11-76 and “[Editing the Structures of Relative Placement Groups](#)” on page 11-77.

## Using the Relative Placement Window

The relative placement window allows you to analyze the hierarchy and net connections of relative placement groups before running placement.

To open the relative placement window, you can choose one of the following two ways.

- From a top-level window, choose Window > New RP Window.
- From a layout window, choose Placement > New RP Window.

From a relative placement window, you can perform the following tasks:

- Edit existing relative placement groups or create new relative placement groups.  
For more information, see [“Editing and Creating Relative Placement Groups” on page 11-69.](#)
- Display the hierarchy of relative placement groups.  
For more information, see [“Viewing the Hierarchy of Relative Placement Groups” on page 11-72.](#)
- View net connections in a relative placement group.  
For more information, see [“Viewing Logical Connections in a Relative Placement Group” on page 11-73.](#)

---

## Viewing the Hierarchy of Relative Placement Groups

To view the hierarchy of relative placement groups, you can open a relative placement hierarchy view window by choosing one of the following two ways.

- From a relative placement window, choose View > RP Hierarchy Browser.
- From a layout window, choose Placement > New RP Hierarchy View.

[Figure 11-37](#) is an example that displays the hierarchy of relative placement groups.

*Figure 11-37 Relative Placement Hierarchy View Window*



For more information about using the relative placement hierarchy view window, see IC Compiler Help.

## Viewing Logical Connections in a Relative Placement Group

To view logical connections in a relative placement group, you can select a relative placement group and then open a relative placement view window by choosing View > New RP View of Selected RP from a relative placement window. [Figure 11-38](#) shows an example of a relative placement view window that displays relative placement cells in logical symbol view.

*Figure 11-38 Relative Placement View Window*



The relative placement view window displays one relative placement group and includes a relative placement group that contains any level of hierarchical relative placement groups. Objects inside the relative placement group are displayed with respect to their relative physical locations in grids. You have the options either to display cells in logical symbol view or to display them in the actual physical cell view. The relative placement view allows you to cross-select objects in other open views, such as the layout view.

In the relative placement view window, you can perform the following tasks:

- Open a relative placement hierarchy view window.
- View cells in logical symbol or physical cell view.
- See net connectivity in grid view.
- Cross-select between all views.
- Zoom in or out of a hierarchical relative placement group.

- Expand or collapse a hierarchical relative placement group at any level.
- Edit relative placement groups.
- Change the structures of relative placement groups.

To view the settings of the selected relative placement group in a relative placement view window, choose View > Toolbar > View Settings in the GUI. The relative placement view setting toolbar, as shown in [Figure 11-39](#), lets you select objects, change the visibility, brightness, and color of objects, and display cells in either logical symbol view or physical cell view.

*Figure 11-39 New Relative Placement View Setting Toolbar*



## Editing Relative Placement Groups in a Relative Placement View Window

To open a relative placement view window, choose View > New RP View of Selected RP in a relative placement window. You can add, remove, drag, and switch relative placement objects in a relative placement view window.

To add relative placement groups, use the following steps:

1. Select the grid locations of the relative placement objects that you want to edit.
2. Right-click and choose Add, or click the  button from the toolbar.  
The Add To RP Group dialog box appears, as shown in [Figure 11-40](#).
3. Add leaf cells, relative placement groups, or keepouts to that location.
4. Click OK or Apply.

*Figure 11-40 Add to RP Group Dialog Box*



To remove relative placement objects from the selected relative placement group, use the following steps:

1. Select relative placement objects to be removed.
2. Right-click to choose Remove, or click the  button from the toolbar.

To drag a relative placement object from one location to another, use the following steps:

1. Click the  button from the toolbar.
2. Select a relative placement object.  
The selected object is highlighted in orange.
3. Drag the relative placement object to a new location.

If the new location contains an existing object, a warning dialog box appears.

To switch two relative placement objects between two locations, use the following steps:

1. Select two relative placement objects.
2. Click the  button from the toolbar.

To edit objects inside a hierarchical relative placement group, you need to display the hierarchical relative placement group in a relative placement view window. You can edit included relative placement groups but not instantiated relative placement groups in the hierarchical relative placement group. For more information about included and instantiated relative placement groups, see “[Adding Relative Placement Groups](#)” on page 11-31.

For more information about using the relative placement view window, see IC Compiler Help.

---

## Editing the Structures of Relative Placement Groups

You can insert, remove, swap, and flip rows and columns to change the structures of existing relative placement groups in a relative placement view window. To open a relative placement view window, choose View > New RP View of Selected RP in a relative placement window. For information about relative placement window, see “[Using the Relative Placement Window](#)” on page 11-71.

To insert a row below a selected row,

1. Select a row where you want to insert a new row.
2. Choose Edit > Insert Row/Column Before.

A new row appears below the selected row.

To insert a column to the left of a selected column,

1. Select a column where you want to insert a new column.
2. Choose Edit > Insert Row/Column Before.

A new column appears to the left of the selected column.

To insert a row above a selected row,

1. Select a row where you want to insert a new row.
2. Choose Edit > Insert Row/Column After.

A new row appears above the selected row.

To insert a column to the right of a selected column,

1. Select a column where you want to insert a new column.
2. Choose Edit > Insert Row/Column After.

A new column appears to the right of the selected column.

To remove a row or column,

1. Select a row or column that you want to remove.
2. Choose Edit > Remove.

The selected row or column is removed from the relative placement group.

To swap two rows or columns,

1. Select two rows or columns that you want to swap.
2. Choose Edit > Switch.

The selected two rows or columns are swapped.

To flip rows or columns,

1. Select the rows or columns that you want to flip the objects.
2. Choose Edit > Flip Rows/Columns.

The objects inside the selected rows or columns are flipped.

## Querying Relative Placement Groups and Objects

You can query relative placement groups and relative placement objects by using the relative placement attributes and query commands. The following sections describe how to query relative placement groups and objects.

- [Displaying Relative Placement Group Attributes](#)
- [Displaying Relative Placement Cell Attributes](#)
- [Displaying Relative Placement Keepout Attributes](#)
- [Reporting the Total Net Lengths of Relative Placement Groups](#)
- [Querying Relative Placement Groups](#)
- [Querying Objects in Relative Placement Groups](#)
- [Query Commands for Relative Placement Groups and Objects](#)

The examples in these sections use the relative placement group that contains a top-level block ORCA::top outlined in green and a lower level block ORCA::hier1 outlined in hot pink, as shown in [Figure 11-41](#).

The ORCA::top block consists of cell U59, cell U129, one keepout ORCA::top:k3, and one hierarchical relative placement group ORCA::hier1. The ORCA::hier1 block consists of cells U84, U79, U55, and one keepout ORCA::hier1:k2.

*Figure 11-41 Relative Placement Group ORCA::top After Placement*



You can use the following script to generate this relative placement group:

*Example 11-13 Script for Creating the ORCA::top Relative Placement Group*

```
create_rp_group hier1 -design ORCA -columns 2 -rows 2 \
    -utilization 1.000000
add_to_rp_group ORCA::hier1 -leaf U79 -column 0 -row 0
add_to_rp_group ORCA::hier1 -leaf U84 -column 0 -row 1
add_to_rp_group ORCA::hier1 -leaf U55 -column 1 -row 0
add_to_rp_group ORCA::hier1 -keepout k2 -column 1 -row 1 -width 25
create_rp_group top -design ORCA -columns 2 -rows 2 -utilization 1.000000
add_to_rp_group ORCA::top -leaf U129 -column 0 -row 0
add_to_rp_group ORCA::top -leaf U59 -column 1 -row 1
add_to_rp_group ORCA::top -keepout k3 -column 0 -row 1
add_to_rp_group ORCA::top -hierarchy ORCA::hier1 -column 1 -row 0
```

## Displaying Relative Placement Group Attributes

To report one relative placement group attribute, use the `get_attribute` command. For example, to report the value of the `compress` attribute of the ORCA::top relative placement group, enter

```
icc_shell> get_attribute ORCA::top compress
```

To report all relative placement group attributes, use the `report_attribute -application` command. For example, the following command reports all the attributes of the ORCA::top relative placement group:

```
icc_shell> report_attribute -application ORCA::top
```

| Design | Object    | Type    | Attribute Name   | Value           |
|--------|-----------|---------|------------------|-----------------|
| ORCA   | ORCA::top | string  | alignment        | bottom-left     |
| ORCA   | ORCA::top | string  | bbox             | Not placed      |
| ORCA   | ORCA::top | int     | cell_id          | 8               |
| ORCA   | ORCA::top | int     | columns          | 2               |
| ORCA   | ORCA::top | boolean | compress         | false           |
| ORCA   | ORCA::top | string  | cts_option       | fixed_placement |
| ORCA   | ORCA::top | string  | design           | ORCA            |
| ORCA   | ORCA::top | boolean | ignore           | false           |
| ORCA   | ORCA::top | boolean | is_top           | true            |
| ORCA   | ORCA::top | string  | move_effort      | medium          |
| ORCA   | ORCA::top | string  | name             | ORCA::top       |
| ORCA   | ORCA::top | string  | object_class     | rp_group        |
| ORCA   | ORCA::top | int     | object_id        | 953373          |
| ORCA   | ORCA::top | string  | pin_align_name   | Unknown         |
| ORCA   | ORCA::top | string  | psynopt_option   | size_only       |
| ORCA   | ORCA::top | string  | route_opt_option | fixed_placement |
| ORCA   | ORCA::top | int     | rows             | 2               |

You can also display the attributes of a selected relative placement group in the GUI by right-clicking the relative placement group and choosing Properties.

## Displaying Relative Placement Cell Attributes

To report one relative placement cell attribute, use the `get_attribute` command. For example, the following command reports the `rp_orientation` attribute of the U59 relative placement cell:

```
icc_shell> get_attribute U59 rp_orientation
```

To report all relative placement cell attributes, use the `report_attribute -application` command. For example, the following command reports all the attributes of the U59 relative placement cell:

```
icc_shell> report_attribute -application U59
```

| Design | Object | Type   | Attribute Name    | Value        |
|--------|--------|--------|-------------------|--------------|
| <hr/>  |        |        |                   |              |
| ...    |        |        |                   |              |
| ORCA   | U59    | string | rp_alignment      | bottom-right |
| ORCA   | U59    | int    | rp_column         | 1            |
| ORCA   | U59    | string | rp_group_name     | ORCA::top    |
| ORCA   | U59    | int    | rp_num_columns    | 0            |
| ORCA   | U59    | int    | rp_num_rows       | 0            |
| ORCA   | U59    | string | rp_orientation    | S            |
| ORCA   | U59    | string | rp_pin_align_name | Z            |
| ORCA   | U59    | int    | rp_row            | 1            |
| <hr/>  |        |        |                   |              |

Note that the attributes with an `rp_` prefix are a subset of the entire relative placement cell attributes. This subset, which describes the status of a cell in a relative placement group, exists only if the cell is contained in a relative placement group.

You can also display the attributes of a selected relative placement cell in the GUI by right-clicking the relative placement cell and choosing Properties.

To list all the attributes of relative placement cells in alphabetical order, use the `list_attributes` command. The command lists the following attributes: `rp_group_name`, `rp_row`, `rp_column`, `rp_num_rows`, `rp_num_columns`, `rp_alignment`, `rp_pin_align_name`, and `rp_orientation`.

---

## Displaying Relative Placement Keepout Attributes

To report one relative placement keepout attribute, use the `get_attribute` command. For example, to report the `type` attribute of the ORCA::top::k3 relative placement keepout, enter

```
icc_shell> get_attribute ORCA::top::k3 type
```

To report all relative placement keepout attributes, use the `report_attribute -application` command. For example, the following command reports all the attributes of the ORCA::top::k3 relative placement keepout:

```
icc_shell> report_attribute -application ORCA::top::k3
```

| Design | Object        | Type   | Attribute Name | Value            |
|--------|---------------|--------|----------------|------------------|
| ORCA   | ORCA::top::k3 | string | bbox           | Not placed       |
| ORCA   | ORCA::top::k3 | int    | cell_id        | 8                |
| ORCA   | ORCA::top::k3 | string | height         | Not specified    |
| ORCA   | ORCA::top::k3 | string | name           | ORCA::top::k3    |
| ORCA   | ORCA::top::k3 | string | object_class   | rp_group_keepout |
| ORCA   | ORCA::top::k3 | int    | object_id      | 958721           |
| ORCA   | ORCA::top::k3 | string | type           | hard             |
| ORCA   | ORCA::top::k3 | string | width          | Not specified    |

You can also display the attributes of a selected relative placement keepout in the GUI by right-clicking the relative placement keepout and choosing Properties.

---

## Reporting the Total Net Lengths of Relative Placement Groups

To report the total net lengths of relative placement groups, use the `get_rp_groups_net_length` command. The command returns a list of the total net lengths of each specified relative placement group. If your design is not routed, the command returns estimated values.

For example, the following command reports a list of total net lengths of individual relative placement groups, design::rp1 and design::rp2:

```
icc_shell> get_rp_groups_net_length {design::rp1 design::rp2}
{100.001 1200.23}
```

---

## Querying Relative Placement Groups

To query relative placement groups that contain specific objects or attribute values, use the `get_rp_groups` command with the following options:

- The `-of_objects` option

To find the relative placement group that contains leaf cell U129, enter

```
icc_shell> get_rp_groups -of_objects U129
{ORCA::top}
```

To find the relative placement group that contains the ORCA::hier1 hierarchical relative placement group, enter

```
icc_shell> get_rp_groups -of_objects ORCA::hier1
{ORCA::top}
```

To find the relative placement group that contains the ORCA::hier1::k2 relative placement keepout, enter

```
icc_shell> get_rp_groups -of_objects ORCA::hier1::k2
{ORCA::hier1}
```

- The `-filter` option

To find the relative placement group that is marked with the `is_top` attribute, enter

```
icc_shell> get_rp_groups -filter "is_top == TRUE"
{ORCA::top}
```

---

## Querying Objects in Relative Placement Groups

You can use the following commands to find objects, including leaf cells, hierarchical relative placement groups, and keepouts that are in a relative placement group. Except the `rp_group_references` command, the other commands report relative placement objects in a single hierarchy level only.

- `rp_group_references`

To find all leaf cells that are directly included in the ORCA::top relative placement group, enter

```
icc_shell> rp_group_references -leaf ORCA::top
{U59 U129}
```

Alternatively, you can use the following command to find all leaf cells in the ORCA::top relative placement group:

```
icc_shell> get_cells -all -of_objects ORCA::top
{U59 U129}
```

To find all leaf cells in the ORCA::top relative placement group and down the hierarchy, enter

```
icc_shell> rp_group_references -all_leaf ORCA::top  
{U59 U129 U55 U79 U84}
```

- `rp_group_inclusions`

To find all hierarchical relative placement groups in the ORCA::top relative placement group, enter

```
icc_shell> rp_group_inclusions ORCA::top  
{ORCA::hier1}
```

- `get_rp_group_keepouts -of_objects`

To find all relative placement keepouts in the ORCA::top relative placement group, enter

```
icc_shell> get_rp_group_keepouts -of_objects ORCA::top  
{ORCA::top::k3}
```

To find relative placement objects that have specific attribute values, use the following commands with the `-filter` option:

- `get_cells -filter`

To find the leaf cells that occupy column position 1 in all relative placement groups, enter

```
icc_shell> get_cells -filter {rp_column==1} -hierarchical  
{U59 U55}
```

- `get_rp_group_keepouts -filter`

To find the relative placement keepouts whose width equals 25, enter

```
icc_shell> get_rp_group_keepouts -filter "width==25"  
{ORCA::hier1::k2}
```

To find the relative placement object at a specific location or vice versa, use the following commands:

- `get_cells -filter`

To find the leaf cell at position 0 0 (column 0, row 0) in the ORCA::top relative placement group, enter

```
icc_shell> get_cells \  
  -filter {rp_group_name=="ORCA::top" && rp_column==0 && rp_row==0}  
{U129}
```

If the leaf cell is not in the current hierarchy, specify the `-hierarchical` option.

- `get_location`

To get the grid location of the U129 relative placement cell in the ORCA::top relative placement group, enter

```
icc_shell> get_location U129 -rp_group ORCA::top
0 0
```

For more information about getting the grid location of a relative placement cell or group, see “[Locating a Relative Placement Group](#)” on page 11-63.

## Query Commands for Relative Placement Groups and Objects

[Table 11-4](#) lists the commands available for querying particular types of relative placement groups to annotate, edit, and view. For detailed information, see the man pages.

*Table 11-4 Commands for Querying Relative Placement Groups*

| To return collections for this                                                                                                                                                                                                                                                                                                | Use this command                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| Relative placement groups that match certain criteria                                                                                                                                                                                                                                                                         | <code>get_rp_groups</code>            |
| Total net lengths of individual relative placement groups                                                                                                                                                                                                                                                                     | <code>get_rp_groups_net_length</code> |
| All or specified relative placement groups and the included and instantiated groups they contain in their hierarchies                                                                                                                                                                                                         | <code>all_rp_groups</code>            |
| All or specified relative placement groups that contain included or instantiated groups                                                                                                                                                                                                                                       | <code>all_rp_hierarchicals</code>     |
| All or specified relative placement groups that contain included groups                                                                                                                                                                                                                                                       | <code>all_rp_inclusions</code>        |
| All or specified relative placement groups that contain instantiated groups                                                                                                                                                                                                                                                   | <code>all_rp_instantiations</code>    |
| All or specified relative placement groups that directly embed leaf cells (added to a group by <code>add_to_rp_group -leaf</code> ) or instantiated groups (added to a group by <code>add_to_rp_group -hierarchy -instance</code> ) in all or specified relative placement groups in a specified design or the current design | <code>all_rp_references</code>        |
| Directly embedded included groups (added to a group by <code>add_to_rp_group -hierarchy</code> ) in all or specified groups                                                                                                                                                                                                   | <code>rp_group_inclusions</code>      |
| Directly embedded instantiated groups (added to a group by <code>add_to_rp_group -hierarchy -instance</code> ) in all or specified groups                                                                                                                                                                                     | <code>rp_group_instantiations</code>  |

*Table 11-4 Commands for Querying Relative Placement Groups (Continued)*

| To return collections for this                                                                                                                                                                                                                                                                                     | Use this command                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Directly embedded leaf cells (added to a group by <code>add_to_rp_group -leaf</code> ), directly embedded included cells that contain hierarchically instantiated cells (added to the included group by <code>add_to_rp_group -hierarchy -instance</code> ), or both in all or specified relative placement groups | <code>rp_group_references</code>   |
| Create a collection of the specified relative placement group keepouts                                                                                                                                                                                                                                             | <code>get_rp_group_keepouts</code> |

## Saving Relative Placement Information

The relative placement information is automatically saved in the Milkyway design database when you save the design in Milkyway format using the `save_mw_cel` command.

You can also save the relative placement information to a file, creating a Tcl script for re-creating relative placement groups and their objects on the same design. To do this, use the `write_rp_groups -output script` command. You must either specify which relative placement groups to write commands for or specify the `-all` option to write commands for all relative placement groups.

For example, to save all the relative placement groups to disk, remove the information from the design, and then re-create the information on the design, enter the following commands:

```
icc_shell> get_rp_groups
{mul::grp_mul ripple::grp_ripple example3::top_group}
icc_shell> write_rp_groups -all -output my_groups.tcl
1
icc_shell> remove_rp_groups -all -quiet
1
icc_shell> get_rp_groups
Error: Can't find objects matching '*'. (UID-109)
icc_shell> source my_groups.tcl
{example3::top_group}
icc_shell> get_rp_groups
{example3::top_group ripple::grp_ripple mul::grp_mul}
```

Alternatively, you can save the relative placement information from the relative placement view window by choosing RP > Write RP Groups. For information about opening a relative placement view window, see “[Using the Relative Placement Window](#)” on page 11-71.

By default, the `write_rp_groups` command writes out commands for creating the specified relative placement groups and to add leaf cells, hierarchical groups, and keepouts to these groups. The commands for generating subgroups within hierarchical groups are not written. You can modify the default behavior by using the options described in [Table 11-5](#).

To remove all relative placement information from relative placement groups, use the `remove_placement` command.

*Table 11-5 write\_rp\_groups Options*

| To do this                                                                                                                                         | Use this option |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Write all the relative placement groups within the hierarchy of the relative placement groups. If you omit this option, subgroups are not written. | -hierarchy      |
| Write only <code>create_rp_group</code> commands to the script.                                                                                    | -create         |
| Write only <code>add_to_rp_group -leaf</code> commands to the script.                                                                              | -leaf           |
| Write only <code>add_to_rp_group -keepout</code> commands to the script.                                                                           | -keepout        |
| Write only <code>add_to_rp_group -hierarchy -instance</code> commands to the script.                                                               | -instance       |
| Write only <code>add_to_rp_group -hierarchy</code> commands to the script.                                                                         | -include        |

## Ignoring Relative Placement Constraints

You can direct the tool to ignore relative placement constraints annotated to the design. An example of this is when you want to confirm that relative placement is helpful to the QoR. To skip structured placement for relative placement groups that you specify, use the `-ignore` option with either the `create_rp_group` or `set_rp_group_options` command.

When you direct the tool to ignore relative placement constraints, it places the parts of the relative placement groups as if the group had no relative placement information.

To remove the `ignore` attribute and cause the tool to consider the relative placement constraints, use the `remove_rp_group_options -ignore` command.

---

## Removing Relative Placement Groups

You can remove relative placement groups in the relative placement hierarchy browser, relative placement editing dialog box, relative placement view window, or from the command line.

To remove relative placement groups in the relative placement hierarchy browser,

1. Select the groups you want to remove in the left pane.
2. Right-click and choose Delete Selected RP Groups from the pop-up menu.

For more information about the relative placement hierarchy browser, see “[Using the Relative Placement Hierarchy Browser](#)” on page 11-65.

To remove relative placement groups in the relative placement group editing dialog box, choose Placement > Edit RP Group in the GUI. For more information, see “[Editing and Creating Relative Placement Groups](#)” on page 11-69.

To remove relative placement groups in the relative placement view window, see “[Editing Relative Placement Groups in a Relative Placement View Window](#)” on page 11-76 for more information.

To remove relative placement groups from the command line, run the `remove_rp_groups` command. You can remove all relative placement groups (by specifying the `-all` option), or you can specify which relative placement groups to remove. If you specify a list of relative placement groups, only the specified groups (and not groups included or instantiated within the specified group) are removed. To remove the included and instantiated groups of the specified groups, you must specify the `-hierarchy` option.

Note:

When you remove a relative placement group, the memory it occupies is freed to be reused by this same process. However, memory is not returned to the operating system until you exit `icc_shell`.

For example, to remove the relative placement group named `grp_ripple` and confirm its removal, enter

```
icc_shell> get_rp_groups
{mul::grp_mul ripple::grp_ripple example3::top_group}
icc_shell> remove_rp_groups ripple::grp_ripple
Removing rp group 'ripple::grp_ripple'
1
icc_shell> get_rp_groups *grp_ripple
Error: Can't find object 'grp_ripple'. (UID-109)
icc_shell> remove_rp_groups -all
Removing rp group 'mul::grp_mul'
Removing rp group 'example3::top_group'
```

---

## Changing Relative Placement Information

You can change a relative placement group. For example, you can

- Change the attributes of a relative placement group (anchor location, alignment, utilization, preservation during clock tree synthesis, and preservation during routing)
- Rename a group
- Remove objects from a group
- Change objects within a group
- Change the attributes of cells within a group
- Change the dimensions of keepouts within a group

---

## Reporting the Attributes of a Relative Placement Group

To report the attributes of one or more relative placement groups (as set by the `create_rp_group` or `set_rp_group_options` command), use the `report_rp_group_options` command.

```
icc_shell> report_rp_group_options rp_groups
```

You can also use the `report_attribute` command to report the attributes of all relative placement groups in your design.

```
icc_shell> report_attribute -application -class rp_group rp_group
```

In addition to the attributes reported by the `report_rp_group_options` command, the `report_attribute` command also lists the number of rows and columns of each relative placement group.

---

## Changing the Options of a Relative Placement Group

When you create a relative placement group by using the `create_rp_group` command, you set the attributes for the relative placement group. To change the attributes, you use one of the following two methods:

- Set the attribute values.
- Reset the attributes to their defaults by using the `remove_rp_group_options` command.

## Setting Relative Placement Group Attributes

You can set relative placement group attributes either in the relative placement hierarchy browser or from the command line.

To set relative placement group attributes in the relative placement hierarchy browser,

1. Select the groups you want to modify in either the left or right pane (relative placement groups are identified by the  icon).
2. Right-click and choose “Set RP Options.”  
The “Set RP Options” dialog box appears.
3. Update the attributes, as described in [Table 11-6 on page 11-91](#).

For more information about the relative placement hierarchy browser, see [“Using the Relative Placement Hierarchy Browser” on page 11-65](#).

To set relative placement group attributes from the command line, run the `set_rp_group_options` command. You must specify the group name and at least one option; otherwise, this command has no effect.

For example, to specify that all cells in the ORCA::top relative placement group can be compressed during placement, enter

```
icc_shell> set_rp_group_options ORCA::top -placement_type compression
```

To skip optimization for leaf cells in the ORCA::top relative placement group during the `psynopt` command, enter

```
icc_shell> set_rp_group_options ORCA::top -psynopt_option fixed_placement
```

To set the utilization to 80 percent for the block1::misc1 group, enter

```
icc_shell> set_rp_group_options block1::misc1 -utilization .80  
{block1::misc1}
```

The command returns a collection of relative placement groups for which attributes have been changed. If no attributes change for any object, an empty string is returned.

**Table 11-6** describes the relative placement group attributes and the Set RP Options dialog box fields or command options used to change them.

*Table 11-6 Relative Placement Group Attributes*

| Attribute                                                                                                                                                                                                                | Dialog box fields  | Command line options |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------------|
| Specify an alignment method.<br>See “ <a href="#">Aligning Leaf Cells Within a Column</a> ” on page 11-21.                                                                                                               | Alignment          | -alignment           |
| Allow nonrelative placement cells in relative placement groups.<br>See “ <a href="#">Exposing Unused Space in Relative Placement Groups</a> ” on page 11-57.                                                             | Allow non rp cells | -allow_non_rp_cells  |
| Specify a bottom-left or bottom-right corner for the anchored relative placement group.<br>See “ <a href="#">Specifying a Corner for an Anchored Relative Placement Group</a> ” on page 11-16.                           | Anchor corner      | -anchor_corner       |
| Prevent inserting buffers inside the areas of placed relative placement groups.<br>See “ <a href="#">Buffering Strategy for Relative Placement Groups</a> ” on page 11-60.                                               | Auto blockage      | -auto_blockage       |
| Specify if IC Compiler can automatically orient the cells in the specified relative placement group.<br>See “ <a href="#">Orientation of Relative Placement Groups</a> ” on page 11-27.                                  | Cell Orient Opt    | -cell_orient_opt     |
| Specify clock tree synthesis preservation.<br>You can specify <code>fixed_placement</code> or <code>size_only</code> .<br>See “ <a href="#">Postplacement Optimization of Relative Placement Groups</a> ” on page 11-58. | CTS option         | -cts_option          |
| Prevent inserting buffers into nets inside relative placement groups.<br>See “ <a href="#">Buffering Strategy for Relative Placement Groups</a> ” on page 11-60.                                                         | Disable buffering  | -disable_buffering   |

*Table 11-6 Relative Placement Group Attributes (Continued)*

| <b>Attribute</b>                                                                                                                                                                                                      | <b>Dialog box fields</b> | <b>Command line options</b> |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------|
| <p>Specify the orientation of relative placement groups. You can specify default, N, FN, S, and FS.</p> <p>See “Orientation of Relative Placement Groups” on page 11-27.</p>                                          | Group orientation        | -group_orient               |
| <p>Ignore relative placement constraints.</p> <p>See “Ignoring Relative Placement Constraints” on page 11-87.</p>                                                                                                     | Ignore placement         | -ignore                     |
| <p>Legalize relative placement groups.</p> <p>You can specify low, medium, or high.</p> <p>See “Controlling Movement When Legalizing Relative Placement Groups” on page 11-55.</p>                                    | Effort                   | -move_effort                |
| <p>Specify the group alignment pin.</p> <p>See “Aligning Leaf Cells Within a Column” on page 11-21.</p>                                                                                                               | Pin alignment            | -pin_align_name             |
| <p>Specify how to treat fixed cells in the floorplan during legalization.</p> <p>See “Handling Fixed Cells During Relative Placement” on page 11-49.</p>                                                              | Place around fixed cells | -place_around_fixed_cells   |
| <p>Specify a placement type for relative placement groups.</p> <p>You can specify bit_slice, vertical_compression, and compression.</p> <p>See “Applying Compression to Relative Placement Groups” on page 11-17.</p> | Placement type           | -placement_type             |
| <p>Apply compression in the horizontal direction to a relative placement group.</p> <p>See “Applying Compression to Relative Placement Groups” on page 11-17.</p>                                                     | Compress                 | -placement_type compression |

*Table 11-6 Relative Placement Group Attributes (Continued)*

| <b>Attribute</b>                                                                                                                                                                                                                                                                    | <b>Dialog box fields</b>         | <b>Command line options</b>                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------|
| <p>Specify the physical optimization preservation attribute.</p> <p>You can specify <code>fixed_placement</code>, <code>size_only</code>, or <code>all_optimization</code>.</p> <p>See “<a href="#">Postplacement Optimization of Relative Placement Groups</a>” on page 11-58.</p> | Psynopt option                   | <code>-psynopt_option</code>                     |
| <p>Specify the routing preservation attribute.</p> <p>You can specify <code>fixed_placement</code> or <code>in_place_size_only</code>.</p> <p>See “<a href="#">Postplacement Optimization of Relative Placement Groups</a>” on page 11-58.</p>                                      | <code>route_opt</code><br>option | <code>-route_opt_option</code>                   |
| <p>Allow keepouts over tap cells.</p> <p>See “<a href="#">Adding Keepouts</a>” on page 11-45.</p>                                                                                                                                                                                   | Allow keepout over tapcell       | <code>-allow_keepout_over_tapcell</code>         |
| <p>Specify the utilization percentage.</p>                                                                                                                                                                                                                                          | Utilization                      | <code>-utilization</code>                        |
| <p>Specify the anchor location.</p> <p>See “<a href="#">Anchoring Relative Placement Groups</a>” on page 11-13.</p>                                                                                                                                                                 | X offset<br>Y offset             | <code>-x_offset</code><br><code>-y_offset</code> |

## Removing Relative Placement Group Attributes

You can remove relative placement group attributes either in the relative placement hierarchy browser or from the command line.

To remove relative placement group attributes in the relative placement hierarchy browser (Placement > New RP Hierarchy View),

1. Select the groups you want to modify in either the left or right pane (relative placement groups are identified by the  icon).
  2. Right-click and choose “Set RP Options.”
- The “Set RP Options” dialog box appears.
3. Remove the attributes by setting them to empty values.

To remove relative placement group attributes from the command line, run the `remove_rp_group_options` command. You must specify the group name and at least one option; otherwise, this command has no effect.

For example, to remove the `x_offset` attribute for the `block1::misc1` relative placement group, enter

```
icc_shell> remove_rp_group_options block1::misc1 -x_offset
{block1::misc1}
```

The command returns a collection of relative placement groups for which attributes have been changed. If no attributes change for any object, an empty string is returned.

To remove the compression constraint set for the `ORCA::top` relative placement group, enter

```
icc_shell> remove_rp_group_options ORCA::top -compress
```

[Table 11-7](#) describes changes you can make with the `remove_rp_group_options` command.

*Table 11-7 remove\_rp\_group\_options Options*

| To do this                                                                                                                                                                                                                               | Use this option        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| Reset the anchor location. Removing an offset attribute resets that coordinate to 0.<br><br>See “ <a href="#">Anchoring Relative Placement Groups</a> ” on page 11-13.                                                                   | -x_offset<br>-y_offset |
| Remove the ignore setting for this relative placement group.<br><br>See “ <a href="#">Ignoring Relative Placement Constraints</a> ” on page 11-87.                                                                                       | -ignore                |
| Remove the compression setting in the horizontal direction.<br><br>See “ <a href="#">Applying Compression to Relative Placement Groups</a> ” on page 11-17.                                                                              | -compress              |
| Remove the automatic cell orientation setting in the specified relative placement group.<br><br>See “ <a href="#">Orientation of Relative Placement Groups</a> ” on page 11-27.                                                          | -cell_orient_opt       |
| Remove the buffering setting inside relative placement groups during the <code>psynopt</code> and <code>route_opt</code> steps.<br><br>See “ <a href="#">Buffering Strategy for Relative Placement Groups</a> ” on page 11-60.           | -auto_blockage         |
| Remove the buffering setting into nets inside relative placement groups during the <code>psynopt</code> and <code>route_opt</code> steps.<br><br>See “ <a href="#">Buffering Strategy for Relative Placement Groups</a> ” on page 11-60. | -disable_buffering     |

---

## Renaming a Group

You cannot rename a group directly. If you need to rename a group, you must remove it, and then create a new group that duplicates the removed group but has the new name.

---

## Removing Objects From a Group

You can remove objects from a relative placement group in the relative placement hierarchy browser, in the RP Editing dialog box, or from the command line.

To remove objects from a relative placement group in the relative placement hierarchy browser (Placement > New RP Hierarchy View),

1. Select the objects you want to remove in the right pane (relative placement groups are identified by the  icon, leaf cells are identified by the  icon, keepouts are identified by the  icon, and locations containing both a leaf cell and a keepout are identified by the  icon).
2. Invoke the pop-up menu by right-clicking.
3. Right-click and choose “Remove Selected Cells and RP Groups” or “Remove Selected Keepouts”.

For more information about the relative placement hierarchy browser, see [“Using the Relative Placement Hierarchy Browser” on page 11-65](#).

To remove objects from a relative placement group from the command line, use the `remove_from_rp_group` command. You can remove leaf cells (`-leaf`), included groups (`-hierarchy`), instantiated groups (`-hierarchy -instance`), and keepouts (`-keepout`).

When you remove objects from a group, the space previously occupied by the removed objects is left unoccupied.

For example, to remove leaf cell `carry_in_1` from `grp_ripple`, enter

```
icc_shell> remove_from_rp_group ripple::grp_ripple -leaf carry_in_1
```

To remove objects from a relative placement group in the RP Editing dialog box, see [“Editing and Creating Relative Placement Groups” on page 11-69](#).

---

## Changing Specific Objects Within a Group

You can change a specific cell within a group. For example, you can move a cell from one position to another or change its alignment pin name or orientation.

To change an object within a group,

1. Remove the object from the group by using the `remove_from_rp_group` command.
  2. Reinsert the object by using the appropriate `add_to_rp_group` command.
- 

## Changing the Attributes of Relative Placement Cells

You specify the following constraints for a relative placement group on a per-cell basis: column, row, alignment, pin alignment, orientation, row position, and column position. You use the `add_to_rp_group` command with the appropriate options to set these constraints. Among these constraints, you can modify the alignment, pin alignment, and orientation constraints by changing the `rp_alignment`, `rp_pin_align_name`, and `rp_orientation` relative placement cell attributes respectively. You cannot change the other attributes after they are created. To change them, you must use the `remove_from_rp_group` command followed by the `add_to_rp_group` command.

To change the `rp_alignment`, `rp_pin_align_name`, and `rp_orientation` attributes of one or more relative placement cells, use the `set_attribute` command. For example, to set a flipped-north (FN) orientation for the U98 relative placement cell, enter

```
icc_shell> set_attribute U98 rp_orientation FN
```

You can remove the `rp_alignment`, `rp_pin_align_name`, and `rp_orientation` attributes from relative placement cells by using the `remove_attribute` command. For example, to remove the `rp_orientation` attribute from the U59 relative placement cell, enter

```
icc_shell> remove_attribute U59 rp_orientation
```

---

## Changing the Dimensions of Relative Placement Keepouts

To change the width and height of a relative placement keepout, specify the `width` and `height` attributes with the `set_attribute` command.

For example, the following command changes the height of all relative placement keepouts to 2 site heights:

```
icc_shell> set_attribute [get_rp_group_keepouts *] height 2
```

---

## Deriving Relative Placement Groups

You can derive relative placement groups from your design by either specifying the cells contained in the group or specifying the physical location of the group.

Note:

IC Compiler does not derive hierarchical relative placement groups. Derived relative placement groups are always flat.

You can use this capability to migrate and reuse structured netlists.

To derive relative placement groups from your design,

- Use the `extract_rp_group` command, which generates a script containing `create_rp_group` commands for the extracted groups.
- Use the `order_rp_groups` command to order the extracted groups to create a linear placement of groups.

This capability does not generate all possible relative placement groups but can serve as a starting point in many cases. You can refine the resulting groups by editing the script generated by `extract_rp_group`.

---

## Extracting a Relative Placement Group

The `extract_rp_group` command helps you create relative placement structures at an abstract level. You can extract a group by either specifying the cells in the group with the `-objects` option or specifying a bounding box from which to extract the group with the `-coordinates` option. Alternatively, you can use the relative placement editing dialog box to extract a relative placement group. For more information, see “[Editing and Creating Relative Placement Groups](#)” on page 11-69.

The `extract_rp_group` command annotates the extracted relative placement group to the design and generates the `create_rp_group` and `add_to_rp_group` commands to define the relative placement group. By default, these commands are written to the screen. To write the commands to a script file, use the `-output` option. To append the commands to an existing script file, specify the `-append` option in addition to the `-output` option. You can refine the extracted group by editing the script file.

By default, IC Compiler creates one column and as many rows as the number of cells that are specified. To change the default behavior, specify the desired number of rows with the `-rows` option and columns with the `-columns` option. The specified cells are added from left to right starting from the bottom row according to the cell names alphabetically.

For example, to create a relative placement group for a bank of registers whose names start with Crnt\_Instrn\_1\_reg, annotate the group to the design, and save the script to a file called rp.tcl, enter

```
icc_shell> extract_rp_group \
    -group_name Crnt_Instrn_1_reg \
    -objects [get_cells -hierarchical Crnt_Instrn_1_reg*] \
    -output rp.tcl
```

To create a relative placement group containing the cells within the bounding box with coordinates (0,0) and (100,100) and annotate the group to the design, enter

```
icc_shell> extract_rp_group -group_name ph1 \
    -physical -coordinates { 0 0 100 100 }
```

Alternatively, you can use the GUI to extract a relative placement group by choosing Placement > Extract RP Group.

## Ordering Extracted Relative Placement Groups

You can use the `order_rp_groups` command to create a linear placement of the specified top-level relative placement groups.

The `order_rp_groups` command generates the `create_rp_group` and `add_to_rp_group` commands to define the hierarchical relative placement group. The generated relative placement group has one row and as many columns as the number of the hierarchical relative placement groups that are specified. By default, these commands are written to the screen. To write the commands to a script file, use the `-output` option. To append the commands to an existing script file, specify the `-append` option in addition to the `-output` option. You can refine the group by editing the script file.

For example, to define a hierarchical relative placement group for a related set of register banks, enter

```
icc_shell> extract_rp_group \
    -group_name Crnt_Instrn_1_reg \
    -objects [get_cells -hierarchical Crnt_Instrn_1_reg*] \
    -output Crnt_Instrn.tcl
icc_shell> extract_rp_group \
    -group_name Crnt_Instrn_2_reg \
    -objects [get_cells -hierarchical Crnt_Instrn_2_reg*] \
    -output Crnt_Instrn.tcl -append
icc_shell> order_rp_groups \
    -group_name Crnt_Instrn_Reg \
    {ORCA::Crnt_Instrn_1_Reg ORCA::Crnt_Instrn_2_Reg} \
    -output Crnt_Instrn.tcl -append
```

---

## Summary of Relative Placement Commands

[Table 11-8](#) shows some of the key commands used to perform relative placement.

*Table 11-8 Relative Placement Commands*

| Command                 | Described in section                                                                           |
|-------------------------|------------------------------------------------------------------------------------------------|
| create_rp_group         | See “ <a href="#">Creating Relative Placement Groups</a> ” on page 11-10.                      |
| add_to_rp_group         | See “ <a href="#">Adding Objects to a Group</a> ” on page 11-19.                               |
| modify_rp_groups        | See “ <a href="#">Changing the Structures of Relative Placement Groups</a> ” on page 11-37.    |
| legalize_rp_placement   | See “ <a href="#">Legalizing Relative Placement Groups in a Placed Design</a> ” on page 11-55. |
| check_rp_groups         | See “ <a href="#">Checking Relative Placement Constraints</a> ” on page 11-61.                 |
| write_rp_groups         | See “ <a href="#">Saving Relative Placement Information</a> ” on page 11-86.                   |
| remove_rp_groups        | See “ <a href="#">Removing Relative Placement Groups</a> ” on page 11-88.                      |
| report_rp_group_options | See “ <a href="#">Reporting the Attributes of a Relative Placement Group</a> ” on page 11-89.  |
| set_rp_group_options    | See “ <a href="#">Changing the Options of a Relative Placement Group</a> ” on page 11-89.      |
| remove_rp_group_options | See “ <a href="#">Removing Relative Placement Group Attributes</a> ” on page 11-93.            |
| remove_from_rp_group    | See “ <a href="#">Removing Objects From a Group</a> ” on page 11-95.                           |
| extract_rp_group        | See “ <a href="#">Extracting a Relative Placement Group</a> ” on page 11-97.                   |
| order_rp_groups         | See “ <a href="#">Ordering Extracted Relative Placement Groups</a> ” on page 11-98.            |

---

---

## Limitations of Relative Placement

Relative placement has these limitations:

- When IC Compiler estimates that the size of a relative placement group is not suitable to the given floorplan, IC Compiler can fail to maintain the relative placement constraints during placement. To maintain relative placement information precisely, there must be enough space for relative placement groups without overlapping placement obstructions in the design floorplan.
- If your design contains multiheight cells, relative placement constraints might not be honored, because the legalizer might move relative placement cells to a valid site and leave an unintended gap.
- There is no limit on the number of cells in a relative placement group. However, if your design has many relative placement groups, coarse placement returns overlapping group locations at times, resulting in misalignment. In such cases, a warning appears after coarse placement.

# 12

## Using Hierarchical Models

---

This chapter describes how to generate and use hierarchical models in IC Compiler. You can create hierarchical models of various types, including interface logic models (ILMs) and block abstraction models.

In this chapter, the term hierarchical models refers to both ILMs and block abstraction models.

Using hierarchical models in IC Compiler is described in the following sections:

- [Overview of Hierarchical Models](#)
- [Interface Logic Models](#)
- [Block Abstraction Models](#)
- [Viewing Hierarchical Models in the GUI](#)
- [Using Hierarchical Models in a Multicorner-Multimode Flow](#)
- [Transparent Interface Optimization](#)

For information about extracted timing models, see the Extracted Timing Models chapter in the *PrimeTime Modeling User Guide*.

## Overview of Hierarchical Models

Hierarchical models are used in IC Compiler to reduce the number of design objects and the memory requirements when the tool performs top-level optimization on large designs. In hierarchical models, the gate-level netlist for a block is modeled by a partial gate-level netlist that contains only the required interface logic of the block and possibly the logic that you manually associate with the interface logic. All other logic is removed.

A block abstraction model is an extension of an ILM. Unlike an ILM, which creates a separate Milkyway view, block abstraction information is annotated into the CEL view without creating a separate Milkyway view. In addition, a block abstraction model supports optimization of the interface logic within the blocks during top-level optimization.

[Figure 12-1](#) shows a block and its hierarchical model, where the logic is preserved between

- The input port and the first register of each timing path
- The last register of each timing path and the output port

Logic associated with pure combinational input-port-to-output-port timing paths (A to X) is also preserved. Clock connections to the preserved registers are kept as well. The register-to-register logic is discarded.

*Figure 12-1 A Block and Its Hierarchical Model*



IC Compiler supports using hierarchical models in a variety of flows, including those with

- Channeled or abutted layout styles

In a channeled layout style, channels can exist between blocks in the design, whereas in an abutted layout style, they cannot.

- IEEE 1801 Unified Power Format (UPF)

IC Compiler retains the following UPF objects in a hierarchical model:

- All power-switch cell instances, irrespective of whether they are part of the interface logic or not, for proper supply net connectivity and always-on synthesis.
- All retention registers, irrespective of whether they are part of the interface logic or not.
- Level-shifter cells and isolation cells that are part of the interface logic.
- Control logic for the power-switch cells, retention registers, isolation cells, and level-shifter cells retained.

When IC Compiler removes a UPF netlist object, it either removes or updates the associated UPF constraint. The tool ensures that the UPF strategies stored in the hierarchical model are consistent with the UPF netlist objects.

When the tool links the top-level netlist, it automatically propagates the UPF objects in the hierarchical model to the top level.

- Multicorner-multimode

IC Compiler automatically detects the presence of multiple corners and multiple modes and retains the interface logic involved in the interface timing paths of each scenario.

- Hierarchical signal integrity

IC Compiler can create hierarchical models with coupling capacitance and signal integrity information for use with top-level signal integrity analysis and optimization. In this flow, the hierarchical models are shielded at the top level to prevent crosstalk between the hierarchical model nets and top-level nets.

You can use IC Compiler to create ILMs for the following design configurations:

- Designs with multiple levels of physical hierarchy

Nested ILMs can be used to model designs with multiple levels of physical hierarchy. For more information about nested ILMs, see “[Creating ILMs for Blocks With Nested ILMs](#)” on page 12-9.

---

## Interface Logic Models

An interface logic model (ILM) is a structural model that describes the interface logic of a block. Logic that is not required for modeling boundary timing is discarded, reducing the memory and CPU time needed to analyze the block. The ILM retains the cells whose timing is affected by or affects the external environment of the block; therefore, ILMs are highly accurate timing representations of the original block. Names of cells and data paths are retained in the model, which makes debugging easy.

The use of ILMs in IC Compiler is described in the following sections:

- [Information Stored in Interface Logic Models](#)
  - [Creating ILMs](#)
  - [Validating ILMs](#)
  - [Reporting Information About ILMs](#)
  - [Using ILMs](#)
- 

## Information Stored in Interface Logic Models

By default, ILMs include the following netlist objects:

- Leaf cells and macro cells in the four critical timing paths that lead from input ports to edge-triggered registers, edge-triggered registers to output ports and combinational input-to-output paths
- Abstracted clock trees that include clock paths to interface registers, minimum and maximum clock paths that could also be connected to non interface registers, and the clock tree synthesis exceptions that are a part of these clock paths

IC Compiler treats generated clocks like clock ports. IC Compiler retains interface registers that are driven by a generated clock. However, internal registers driven by generated clocks are not retained. When the design contains generated clocks, the logic along the timing path between the master clock and the generated clock is also retained in the hierarchical model.

- Clock-gating circuitry if it is driven by external ports
- Side-load cells of all non-ideal and non-DRC disabled nets

Side-load cells are cells that can affect the timing of an interface path but are not directly part of the interface logic.

- IEEE 1801 Unified Power Format (UPF) objects that are required at the top level

Note:

By default, latches are treated as combinational logic.

Apart from the netlist objects, the following information is also stored in ILMs:

- Cell and pin location information
- Parasitic information

By default, IC Compiler stores the parasitic information in an ILM. If signal integrity options are specified, then the ILM is generated with coupling capacitances.

- Timing constraints

- Pin-to-pin delay for internal nets

This information is used when the top-level design is not routed.

- UPF constraints

- Power consumption

[Figure 12-2](#) shows the elements contained in an ILM, emphasizing the clock tree. The darkly shaded elements are the elements on the clock path; the lightly shaded elements are the side-load cells. Unshaded elements are not included in the model.

*Figure 12-2 Interface Logic Model*



## Creating ILMs

This section describes how to use the `create_ilm` command to create ILMs and how to control the type and quantity of logic in an ILM in the following subsections:

- Creating ILMs for Multiple Blocks
  - Creating ILMs for Multicorner-Multimode Usage
  - Creating ILMs for Rotated and Mirrored Instances
  - Creating ILMs for Blocks With Nested ILMs
  - Controlling the Logic Included in an ILM
  - Storing Parasitic Information in the ILM
  - Storing Signal Integrity Information in the ILM
  - Milkyway Database Compatibility

Figure 12-3 shows the basic steps for creating ILMs in IC Compiler.

*Figure 12-3 Basic Steps for Creating an ILM in IC Compiler*



To create an ILM,

1. Read in the implemented block design from the Milkyway design library (CEL view). At a minimum, the design must be placed. You can also create ILMs after clock tree synthesis or routing.

### Note:

At a minimum, a block must be track assigned if it needs to be used for signal integrity analysis at the top level.

2. Define the block-level timing constraints, such as clocks, input delays, output delays, and timing exceptions. Note that timing exceptions specified on the core logic (register-to-register paths) of the block design are not retained when the design becomes an ILM because this core logic is not part of the ILM.

Note:

For noncompact ILM creation, you do not have to define the timing constraints for the block. You should specify all clocks by using the appropriate commands, such as the `create_clock` or the `create_generated_clock` command.

3. Create the ILM by using the `create_ilm` command with the appropriate options.

When you create an ILM, IC Compiler

- Performs the following checks on the block:
  - If you use the `create_ilm -compact none` option, IC Compiler checks for the presence of sequential elements in the block. If there are no sequential elements, the tool creates the ILM, but issues a warning message indicating that the ILM is the same size as the original design.
  - Verifies that all cells and ports of the design have defined locations. If the locations are not defined, the tool does not create an ILM and terminates with an error message.
- Creates an ILM by retaining the interface logic and discarding the internal register-to-register logic.
- Applies the `dont_touch` attribute to the created ILM and the `is_interface_model` attribute to the model.
- Saves the ILM model to the ILM view in the database.

You do not need to use the `save_mw_cel` command to save the ILM.

Note:

The design in the memory after using the `create_ilm` command is the CEL view of the block and not the ILM view.

After you create an ILM in IC Compiler, you must create a FRAM view for the block, using the `create_macro_fram` command.

If you do not create a FRAM view for the block or if you fail to change to the block FRAM view, the routing blockage information is not available to the top level. In this case, the ILM area is not available for over-the-block routing.

## Creating ILMs for Multiple Blocks

Create multiple ILMs from blocks in the design by using the `create_ilm_models` command. This command is similar to the `create_ilm` command, except that you specify a list of blocks in the command, which creates one ILM for each listed block. For example, to create ILMs for blocks `blk1` and `blk2`, use

```
icc_shell> create_ilm_models {blk1 blk2}
```

The `create_ilm_models` command has many of the same options as the `create_ilm` command to control the model creation. These option settings apply to all the ILMs created by the command. For a summary of the ILM creation options, see “[Controlling the Logic Included in an ILM](#)” on page 12-10.

Before you can use the `create_ilm_models` command, CEL views must exist for the blocks from which ILMs are created.

## Creating ILMs for Multicorner-Multimode Usage

If you are using a multicorner-multimode flow, the `create_ilm` command automatically detects the presence of multiple corners and multiple modes and retains the interface logic involved in the critical interface timing paths for each scenario. Using the following command, specify a list of scenarios to consider when creating an ILM for multicorner-multimode flows:

```
create_ilm -scenarios scenario_list
```

The scenario list must contain all scenarios that are required for the top-level flow.

The `create_ilm` command saves all the scenarios from the scenario list to the ILM view. The scenarios that are not part of the list are ignored. When you run the `create_ilm` command with `-scenarios scenario_list` option, you do not have to activate all the scenarios. Instead, the `create_ilm` command activates these scenarios one after another for the purpose of creating an ILM. If you do not specify scenarios using the `-scenarios` option; all the scenarios are considered when creating an ILM.

You must create an ILM by using the `create_ilm -compact none -traverse_disabled_arcs` command if both of the following conditions are met:

- The ILM is instantiated multiple times in the top-level design.
- You are using one instance of the ILM in a mode that is different from the other instances of the same ILM in the top-level scenario.

Do not use different modes of the same ILM reference block at the same time in a multiply instantiated module design in IC Compiler.

## Creating ILMs for Rotated and Mirrored Instances

IC Compiler supports rotated and mirrored ILMs. You do not need to extract a separate ILM for each orientation of a block because IC Compiler allows all orientations of the ILM.

IC Compiler propagates the leaf cell locations and the port locations of each ILM instance to the top-level design, based on the location and orientation of the ILM instances.

All eight orientations—north, flipped (mirrored) north, south, flipped (mirrored) south, east, flipped (mirrored) east, west, and flipped (mirrored) west—are allowed. The default orientation is N (north with 0-degree rotation).

You must define the orientation of an ILM block in the floorplan. You can also specify the orientation in the DEF file or as attributes in the Milkyway top-level design. When an ILM block is instantiated in the top-level design, the physical area that it occupies in the core area depends on the orientation of the block.

## Creating ILMs for Blocks With Nested ILMs

A nested ILM is an ILM that is contained in another ILM. When you run the `create_ilm` command on a block that contains nested ILMs, the tool retains only the interface logic for the current block. Logic from a nested ILM is retained only if it is involved in the interface paths for the current block.

In the following example, the MID block contains an instance of the BOT block. [Figure 12-4](#) shows the ILM for the BOT block.

*Figure 12-4 Interface Logic Model for the BOT Block*



[Figure 12-5](#) shows the CEL view for the MID block, which contains the ILM for the BOT block.

*Figure 12-5 MID Block That Contains the ILM for the BOT Block*



When you run the `create_ilm` command on the MID block, the tool discards the logic connected to the B and X pins of the BOT ILM, because it is not part of the interface logic for the MID block. [Figure 12-6](#) shows the ILM for the MID block. The dotted line indicates the logical hierarchy.

*Figure 12-6 Interface Logic Model for the MID Macro*



## Controlling the Logic Included in an ILM

This section describes, in the following topics, the various options of the `create_ilm` command that are used to control the logic retained in an ILM when creating it:

- [Changing the Compaction Level](#)
- [Retaining Additional Logic](#)
- [Additional Controls for Noncompact ILMs](#)

## Changing the Compaction Level

The compaction level controls the amount of logic retained in the ILM. Specify the compaction level by using the `-compact` option when you run the `create_ilm` command. **Table 12-1** describes the various arguments that are available with the `-compact` option.

*Table 12-1 The create\_ilm Command Options for Compaction*

| Option                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-compact all</code><br>(default) | Performs compaction on all input paths and all output paths and results in the smallest ILM, while still maintaining timing accuracy.<br><br>The created ILM contains the interface logic only for the four critical timing paths (minimum rise, minimum fall, maximum rise, and maximum fall) from each input port and to each output port. Additionally, if there are input-to-output combinational paths in a block, the minimum rise, minimum fall, maximum rise, and maximum fall paths for input-to-output combinational paths are included in the compact ILM. This is the default ILM model. |
| <code>-compact output</code>           | Performs compaction only on the output paths and retains all interface logic on the input paths, resulting in a larger ILM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <code>-compact none</code>             | Disables compaction and retains all interface logic on both the input paths and the output paths and results in the largest ILM.<br><br>If your design does not have complete and correct SDC files, you must use this option because compaction is slack-based for each port.                                                                                                                                                                                                                                                                                                                       |

The amount of compaction also depends on the design style.

- Designs with registered inputs and outputs have the greatest reduction in size when the original netlist is compared to its ILM netlist.
- Some design types, such as pure combinational logic blocks or latch-based designs, do not show much reduction. The interface logic for such designs tends to contain much of the original design.

## Retaining Additional Logic

IC Compiler provides several options that enable you to retain logic in addition to the default interface logic. [Table 12-2](#) describes these options.

*Table 12-2 The create\_ilm Command Options for Retaining Additional Logic*

| Option                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-keep_full_clock_tree</code>  | By default, IC Compiler retains abstracted clock trees that include the minimum and maximum clock paths, the clock path to the interface registers, and the clock tree synthesis exceptions that are a part of these paths. To keep the entire clock trees, use the <code>-keep_full_clock_tree</code> option.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <code>-keep_macros</code>           | By default, IC Compiler retains only the macro cells that are part of the interface logic. To retain all macros in the design, use the <code>-keep_macros</code> option. A cell is considered to be a macro cell if it is specified as a macro in the physical library or if it is a large black box cell.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <code>-include_all_logic</code>     | By default, IC Compiler retains only the interface logic. To retain all the design logic in the ILM, use the <code>-include_all_logic</code> option. You should use this option only when you need to retain the entire logic in the ILM, such as for a clock generator block or for a very small block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <code>-must_connect_ports</code>    | Use the <code>-must_connect_ports</code> option to specify a list of ports, such as scan enable or reset ports, that must be connected to already identified logic for functional correctness of design.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <code>-case_controlled_ports</code> | If you apply case-analysis constraints on a block, the disabled logic is removed from the ILM even if the port is specified as a must-connect port because that logic is usually not needed. However, if the case-analysis values on an input or inout port change when linked to the top-level design, you must retain all interface logic that is associated with this port.<br><br>To retain all the interface logic on case-controlled ports, use the <code>-case_controlled_ports</code> option to specify the affected ports. When you use this option, the ILMs that are created are independent of any block-level case-analysis constraints placed on these ports.<br><br>After creating an ILM that is case-analysis independent for the specified ports, apply case-analysis constraints from the top level to the ILM cell as desired for the particular application. |

## Controlling Side-Load Cells

By default, IC Compiler retains the side-load cells for all nets. [Table 12-3](#) describes the various arguments of the `create_ilm -include_side_load` command for including side-load cells in the ILM.

*Table 12-3 ILM Creation Command Options for Controlling Side-Load Cells*

| Option                                           | Description                                                                                                                                 |
|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-include_side_load all</code><br>(default) | This option includes all side-load cells. Although using this option increases the ILM size, it can improve the timing accuracy of the ILM. |
| <code>-include_side_load boundary</code>         | This option includes only boundary side-load cells.                                                                                         |
| <code>-include_side_load none</code>             | This option includes no side-load cell. This option creates the smallest ILM, but it is also the least accurate.                            |

The side-load cells for nets that are routed and extracted are always included in the ILM, regardless of which side-load type you select.

**Note:**

User-controlled handling of side-load cells can affect the timing of an interface path, even when side-load cells are not in the interface logic.

[Figure 12-7](#) shows an example of a side-load cell and a boundary side-load cell. In this figure, cell U1 is a side-load cell because it places a load capacitance on the interface logic net n1. Cell U2 is a boundary side-load cell because it places a load capacitance on the boundary interface logic net out1. Net out1 is considered a boundary net because it is directly connected to the out1 output port.

**Figure 12-7 Side-Load Cell and Boundary Side-Load Cell**

### Controlling the Number of Latch Levels

By default, IC Compiler assumes that all transparent latches found in the interface logic are potential time borrowers. Path tracing continues from the input ports through these latches until an edge-triggered register is encountered. Similarly, path tracing continues from the output registers through the latches to the output ports.

Control the number of latch levels included in the model by using the `-latch_level` option when you run the `create_ilm` command:

```
icc_shell> create_ilm -latch_level 1
```

**Table 12-4 ILM Creation Command Option for Controlling Latch Levels**

| Option                    | Description                                               |
|---------------------------|-----------------------------------------------------------|
| <code>-latch_level</code> | Control the number of latch levels included in the model. |

If your design does not have any time borrowing across the latches, you should set the `-latch_level` option to 0. In this case, the first latch encountered in a timing path is treated as an edge-triggered cell and is considered an endpoint for a timing path from an input port or a startpoint for a timing path to an output port.

[Figure 12-8](#) shows a default ILM model and latch levels. [Figure 12-9](#) shows the results of specifying latch level 1 and latch level 0.

*Figure 12-8 Interface Logic Model and Latch Levels**Figure 12-9 Results of Specifying Latch Level 1 and Latch Level 0*

## Additional Controls for Noncompact ILMs

If you are generating a noncompact ILM by using the `create_ilm -compact none` command, you can also control the retention of the following logic:

- The fanin and fanout of chip-level networks
- The logic disabled by timing exceptions

### Retaining the Fanin and Fanout of Chip-Level Networks

By default, when you generate a noncompact ILM, IC Compiler ignores high-fanout input and inout ports. A port is considered high-fanout if the percentage of the total registers in the design in the transitive fanout of the port is greater than or equal to the value set by the `ilm_ignore_percentage` variable, which has a default of 25. Typically these ports are associated with a chip-level network, such as a scan-enable, set, or reset network.

If you want more control over which ports are ignored, use the `-no_auto_ignore` option and explicitly specify the ignored ports by using the `-ignore_ports` option.

```
icc_shell> create_ilm -compact none \
-no_auto_ignore -ignore_ports [get_ports scan_enable]
```

*Table 12-5 ILM Creation Command Option for Retaining Fanin and Fanout*

| Option                     | Description                                                                                                                                                                    |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-ignore_ports</code> | Specify the ports to ignore when identifying the interface logic.<br>This option applies only to noncompact ILMs and is supported only by the <code>create_ilm</code> command. |

The connectivity from all ignored ports, whether automatically ignored or explicitly ignored, to already-identified interface logic is retained. Minimum and maximum paths and connectivity from all ports are also included in the model.

## Retaining Logic on Disabled Paths

By default, when you generate a noncompact ILM, IC Compiler removes the interface logic that is disabled by the `set_case_analysis` command that you apply on the block because that logic is usually not needed.

To retain the disabled logic, use the `-traverse_disabled_arcs` option with the `create_ilm -compact none` command.

```
icc_shell> create_ilm -compact none -traverse_disabled_arcs
```

*Table 12-6 ILM Creation Command Option for Retaining Logic on Disabled Paths*

| Option                               | Description                                                                                                                                                                 |
|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-traverse_disabled_arcs</code> | Retain the interface logic from disabled timing arcs and pins.<br>This option applies only to noncompact ILMs and is supported only by the <code>create_ilm</code> command. |

**Note:**

The `create_ilm` command ignores the `-traverse_disabled_arcs` option unless you also specify the `-compact none` option.

If you use the `-traverse_disabled_arcs` option, you must apply the timing exceptions from the top-level design onto the block because constraints are not automatically propagated from the block level to the top level. Not doing so could lead to including additional timing paths that would need to be disabled for timing analysis when the ILMs are employed at the top level.

## Storing Parasitic Information in the ILM

To perform top-level routing or postroute optimization using ILMs, you must store the parasitic data in the ILM by using the `create_ilm -keep_parasitics` command.

When you create an ILM, IC Compiler automatically enables the `-keep_parasitics` option. The `create_ilm` command runs the `extract_rc` command in the background (only if you have not run the `extract_rc` command before running the `create_ilm` command) and back-annotates the postroute detailed parasitic data onto ILM.

To use the generated ILM in the top-level flow with coupling capacitances, the generated ILM must have coupling capacitances. To generate an ILM with coupling capacitances, do one of the following,

- Run the `extract_rc -coupling_cap` command before running the `create_ilm` command.
- Enable the signal integrity options before generating the ILM.
- Specify the `-include_xtalk` option when you run the `create_ilm` command.

Note:

To generate an ILM with coupling capacitances, the design must be either track assigned or detail routed.

## Storing Signal Integrity Information in the ILM

ILMs can be used in a hierarchical signal integrity flow.

Use the `create_ilm -include_xtalk` command to generate an ILM with signal integrity information, such as boundary net aggressor data, effective net resistance, total capacitance, and coupling capacitances.

ILM support for a hierarchical signal integrity flow requires the following steps:

- Use the IC Compiler design planning tool to carry out signal integrity budgeting.
- In the block-level optimization, use signal-integrity-aware optimization with the `route_opt` command to fix all block timing and signal integrity issues and provide block shielding for the ILM.
- At the block level, run the `create_ilm -include_xtalk` command to generate signal-integrity-aware ILMs.
- At the top level, perform signal integrity analysis and optimization. In this flow, the ILMs are shielded at the top level to prevent crosstalk between the ILM nets and top-level nets. For more information, see [Chapter 10, “Signal Integrity.”](#)

## Milkyway Database Compatibility

ILMs created in IC Compiler are stored in a Milkyway database and have the following compatibility limitations of the Milkyway database between the different versions of the tool:

- ILMs created using some older versions of IC Compiler are not forward compatible. In this situation, the tool issues the following error message:

Error: The block ILM's data model version is older than what is supported by this application. You must recreate the ILM using this version of the application. (ILM-302).

To use these ILMs, you must open the original CEL view where the ILM was created and re-create the ILM using the same version of IC Compiler.

- ILMs created using some recent versions of IC Compiler are not backward compatible. In this situation, the tool does not issue any error or warning message.

To use these ILMs, you must transfer the original design from which the ILM was created to the earlier IC Compiler version by using the recommended ASCII method and re-create the ILM using the desired version of IC Compiler.

- ILMs created using certain recent versions of IC Compiler can be used in the current version by using one of the following methods:
  - One time conversion of all Milkyway libraries, including ILM Milkyway libraries, by using the `convert_mw_lib` command.
  - Automatic conversion, which occurs when the ILM is opened or linked. In this case, the changes to the ILM are not saved to the disk and the conversion happens every time the ILM is opened for linking. This method is easy, but it is not preferred because an additional runtime penalty occurs for repeated conversions.

Note:

To take advantage of the latest ILM enhancements, you must re-create the ILMs by using the latest version of the tool.

- ILMs created using IC Compiler version F-2011.09 are compatible with IC Compiler version E-2010.12.

---

## Validating ILMs

Validate an interface logic model against the original gate-level netlist or compare any two valid timing models in IC Compiler by using the following commands:

- `write_interface_timing`
- `compare_interface_timing`

The `write_interface_timing` command generates an ASCII report containing interface timing information for a gate-level netlist or an ILM. The command performs an implicit timing update if necessary.

[Table 12-7](#) lists the options supported by the `write_interface_timing` command.

*Table 12-7 Options Supported by the write\_interface\_timing Command*

| Option                           | Description                                                                                                                                                                                              |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-file_name</code>          | Specifies the type of the file to which the interface timing information is to be written.                                                                                                               |
| <code>-ignore_ports</code>       | Specifies a list of ports that are to be excluded from the timing file. By default, all ports are included.                                                                                              |
| <code>-nosplit</code>            | Prevents line-splitting.                                                                                                                                                                                 |
| <code>-significant_digits</code> | Specifies the number of digits to the right of the decimal point that are to be reported following the method used in the <code>report_timing</code> command. Allowed values are 0-13. The default is 3. |

The `write_interface_timing` command writes a report on the interface timing of a specified netlist or model. The report contains the following sections:

- Worst Slack: This section contains the slack values of critical paths either starting from input ports or ending at output ports. For each critical path, it reports the slack values for the following arc types: minimum rise, minimum fall, maximum rise, and maximum fall.
- Type: This section contains maximum or minimum arc values for critical paths either starting from input ports or ending at output ports. For each path timing relationship, it reports one of the following possible arc types: minimum rise, minimum fall, maximum rise, and maximum fall.

The `compare_interface_timing` command compares two interface timing files called the reference file and the comparison file, previously generated by the `write_interface_timing` command. The result is “pass” if the timing parameter values in the two files are the same or within a specified tolerance. And the result is “fail” if both the columns have data and the tolerance is exceeded. If either file format does not conform to the `write_interface_timing` command standard, the command issues a warning message.

**Table 12-8** lists the command options supported by the `compare_interface_timing` command.

*Table 12-8 Options Supported by the compare\_interface\_timing Command*

| Option                       | Description                                                                          |
|------------------------------|--------------------------------------------------------------------------------------|
| <code>ref_timing_file</code> | Specifies the name of the timing file to be used as the reference in the comparison. |
| <code>cmp_timing_file</code> | Specifies the name of the timing file to be compared in the comparison.              |

**Table 12-8 Options Supported by the compare\_interface\_timing Command (Continued)**

| Option              | Description                                                                                                                                                                                 |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -output             | Specifies the name of the output file for which the results of the comparison are to be written.                                                                                            |
| -absolute_tolerance | Specifies an absolute error tolerance for time data. The default is “0.1” timing unit of the current design unit.                                                                           |
| -nosplit            | Prevents line-splitting.                                                                                                                                                                    |
| -significant_digits | Specifies the number of digits to the right of the decimal point that are to be reported following the method used in the report_timing command. Allowed values are 0-13. The default is 3. |

[Example 12-1](#) shows how to use these commands to validate the CEL view of a multicorner-multimode block against its generated ILM in a non-signal-integrity flow.

[Example 12-2](#) shows an example of the report generated by the compare\_interface\_timing command.

#### *Example 12-1 Validating the CEL View of a Multimode-Multicorner Block*

```
open_mw_cel my_mcmm_block
set_si_options -delta_delay false -static_noise false \
    -min_delta_delay false
extract_rc
update_timing

foreach scenario [all_active_scenarios] {
    current_scenario ${scenario};
    write_interface_timing -significant_digits 3 ${scenario}.cel.rpt
}

create_ilm -scenarios [all_active_scenarios]
close_mw_cel

open_mw_cel my_mcmm_block.ILM
set_si_options -delta_delay false -static_noise false \
    -min_delta_delay false

foreach scenario [all_active_scenarios] {
    current_scenario ${scenario};
    write_interface_timing -significant_digits 3 ${scenario}.ilm.rpt;
    compare_interface_timing ${scenario}.cel.rpt ${scenario}.ilm.rpt \
        -significant_digits 3 -absolute_tolerance 0.1 \
        -output ${scenario}.compare_IF_timing.rpt
}

close_mw_cel
```

**Example 12-2 compare\_interface\_timing Report**

| From    | To           | Type     | Worst Ref | Slack Model | Difference | Status |
|---------|--------------|----------|-----------|-------------|------------|--------|
| tdi     | INPUTS       | max_rise | 1.283     | 1.345       | -0.062     | PASS   |
| tdi     | INPUTS       | max_fall | 1.364     | 1.389       | -0.035     | PASS   |
| tdi     | INPUTS       | min_rise | 0.033     | 0.032       | 0.001      | PASS   |
| tdi     | INPUTS       | min_fall | 0.026     | 0.027       | -0.001     | PASS   |
| OUTPUTS | DataSdram[6] | max_rise | 2.081     | 2.037       | 0.044      | PASS   |
| OUTPUTS | DataSdram[6] | max_fall | 2.132     | 2.031       | 0.101      | FAIL   |
| OUTPUTS | DataSdram[6] | min_rise | 1.329     | 1.328       | 0.001      | PASS   |
| OUTPUTS | DataSdram[6] | min_fall | 1.347     | 1.345       | 0.002      | PASS   |

**Debugging Differences Reported by the compare\_interface\_timing Command**

If the report generated by the `compare_interface_timing` command contains FAIL compare points, debug the causes of the timing differences by considering the following issues:

- Make sure that the timing and crosstalk setup is consistent in the CEL and ILM views.
  - Usage of the `set_si_options` command must be consistent in the reference (CEL) and model (ILM) flows.
  - The same delay calculation model must be used in both CEL and ILM views.
  - Input and output delay constraints must be specified by using the `set_input_delay` and `set_output_delay` commands.
- If the failure is not related to the setup consistency, you might want to generate a timing report for a particular port and the path type, such as maximum fall, and perform the following checks:
  - The path should have the same elements (leaf cell pins and nets) in the CEL and ILM views.

If they are different, you should find the path with the same elements in the other view and compare the paths.

- Using the pins of the path found in the ILM view, query for a path in the CEL view that passes through the same pins by using the `report_timing -through` command. (This path should always exist.)
- Using the pins of the path found in the CEL view, query for a path in the ILM view with the same pins. (This path might not always exist.)
- Each net in the ILM view should have the same fanout as the corresponding net in the CEL view.
- RC values must be same for the nets.

Because signal integrity modeling in an ILM results in pessimism, if all the previous steps do not resolve the timing difference, recheck the correlation by turning off the signal integrity effects and recreating the ILM.

---

## Reporting Information About ILMs

The `report_ilm` command reports information either on ILMs present in the design or on the current ILM. You can use this command from the top-level design in which the ILMs are instantiated or from the current ILM. By using the `report_ilm` command, you can print the following details for each ILM:

- The full path of the library from which the ILMs are loaded, including the name of the ILM and the library.
- The date and time at which the ILMs are created.
- The `create_ilm` command options that are used to create an ILM. The options include the explicit options that you have set and also the implicit options set or adjusted by the tool.
- Leaf cell count and compression statistics of an ILM.
- Top-level and ILM multicorner-multimode scenario mapping that you specify.
- TLUPlus file settings of an ILM that include minimum and maximum TLUPlus files, minimum and maximum emulation TLUPlus files, and the technology-file-to-ITF mapping file. For multicorner-multimode designs, the TLUPlus file settings are listed for each scenario. The command also includes TLUPlus signature file information and parasitic data information that is in the report.

Note:

To check the block-level scenario-related information in multicorner-multimode designs, run the `report_ilm` command after creating the scenarios at the top level.

- Crosstalk information.
- UPF information such as power domain name, scope, elements, supply connections, isolation strategies, retention strategies, and power switches.

When you use the `report_ilm` command to report on the current ILM, the following information is not included in the report:

- ILM instance name
- ILM location and the orientation in the top-level design
- Top cell count and compression statistics
- Top-level and ILM multicorner-multimode scenario mapping that you specify

[Example 12-3](#) shows an example of the block-level information reported by the `report_ilm` command.

*Example 12-3 Block-Level Information Reported by report\_ilm*

```
#####
Reference ILM : my_ilm_ref
#####
Library name: my_mw_lib
Date & Time of ILM creation(mm/dd/yyyy hr:min:sec) : 6/19/2009 4:30:51
Options used in ILM creation:
-----
Option           Value used*
-----
verbose          on
identify_only    off
extract_only     off
include_all_logic on
no_auto_ignore   on
keep_macros      off
keep_boundary_cells off
keep_full_clock_tree off
keep_parasitics   on
include_xtalk     on
latch_level      not specified
include_side_load boundary
ignore_ports      not specified
compact          all
traverse_disabled_arcs off
case_controlled_ports not specified
must_connect_ports not specified
scenarios         not specified
-----
* Some of the options may have been automatically set/reset by the tool
Leaf cell count statistics:
-----
ILM cell count      : 11503
Block cell count    : 274399
Compression percentage : 95.8
TLU+ files used:
-----
```

```
ILM scenario #0: ilm_scenario01 (mapped from top-level scenario
top_scenario1)
  Max TLU+ file           : TLU_Plus/max.tluplus
  Tech2ITF mapping file   : TLU_Plus/mapfile
ILM scenario #1: scenario2 (mapped from top-level scenario scenario2)
  Max TLU+ file           : TLU_Plus/max.tluplus
  Tech2ITF mapping file   : TLU_Plus/mapfile

Parasitics data present in the ILM:
-----
RC data          : Available
                  The ILM has parasitics information. It can be
used with partially or fully routed top level design
CC data          : Available
                  The ILM has coupling information. It can be
used during top-level SI flow
-----
TLU+ file used                         Temperature(s)
-----
max.tluplus                           125.00, -40.00
-----
SI aggressor data          : Available
                  The ILM has SI aggressor information. It can
be used during top-level SI flow
```

In addition, the following top-level design details are also printed:

- Location and orientation of each ILM instance.
- Leaf cell count and compression statistics of the top-level design.

[Example 12-4](#) shows an example of the top-level information reported by the `report_ilm` command.

***Example 12-4 Top-Level Information Reported by report\_ilm***

```

-----  

ILM Instance           Reference   Orient   Location  

-----  

my_ilm_inst           my_ilm_ref  0        (43.40, 30.80)  

-----  

Top design leaf cell count statistics:  

-----  

    ILM instance count      : 1  

    Top only cell count     : 134256  

    Top + ILM cell count    : 453367  

    Top + Block cell count  : 7713418  

    Compression percentage  : 94.12  

Top-level and ILM scenario mapping:  

-----  

Top-level scenario     Reference ILM       ILM scenario  

-----  

top_scenario1          my_ilm_ref      ilm_scenario1  

-----  

(Only user-specified mappings are reported)

```

You can use the commands listed in [Table 12-9](#) to provide additional information about ILMs.

**Table 12-9 Commands That Report Information About Interface Logic Models**

| Command                                                             | Reports                                                                                                                                                                               |
|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| get_ilms<br>or<br>get_cells -hierarchical -filter<br>"is_ilm==true" | The ILM blocks that are defined as part of the current design. You can prevent this command from issuing messages by using the <code>-quiet</code> option.                            |
| get_ilm_objects                                                     | Objects in the current design that are identified as belonging to interface logic.                                                                                                    |
| get_location                                                        | Location of the pins of an ILM.                                                                                                                                                       |
| report_area                                                         | Statistics for both the original netlist and the ILM netlist to let you know how much reduction occurred for each of the design objects and the total area reduction for ILM designs. |
| report_design                                                       | Information that the design is an ILM.                                                                                                                                                |

For the complete syntax of these commands, see the man pages.

---

## Using ILMs

ILMs are stored in the ILM view of the Milkyway design library rather than in the CEL view. The models can be stored in either the current Milkyway design library or in a Milkyway reference library that is linked to the current Milkyway design library. This section describes how to use an ILM in the following topics:

- [Using ILMs in the Top-Level Design](#)
- [Linking ILMs to the Top-Level Design](#)
- [Applying Top-Level Constraints](#)
- [Checking ILMs](#)
- [Running the place\\_opt Command on the Top-Level Design](#)
- [Running the clock\\_opt Command on the Top-Level Design](#)
- [Running the route\\_opt Command on the Top-Level Design](#)

### Using ILMs in the Top-Level Design

To use ILMs in the top-level design, follow these steps:

1. Read in the top-level design. Use the `open_mw_cel` command.

```
icc_shell> open_mw_cel top_design
```

Note:

For information about reading the top-level design in ASCII format, see “[Reading a Design in ASCII Format](#)” on page 3-13.

2. Link ILMs to the top-level design.

For more information about linking ILMs to the top-level design, see “[Linking ILMs to the Top-Level Design](#)” on page 12-29.

3. For a third-party tool flow, read the floorplan data from the top-level DEF file. In a Synopsys tool flow, this information already resides in the Milkyway design library.
4. Make the placement and routing resources available at the top level by using the `change_macro_view` command to change to the FRAM view for the ILMs.
5. Use the `read_sdc` command to read the top-level constraints.

For more information about this step, see “[Applying Top-Level Constraints](#)” on page 12-29.

6. Propagate timing constraints or other constraints using the `propagate_constraints` command.

For more information about propagating constraints, see “[Using the propagate\\_constraints Command](#)” on page 12-30.

7. Validate the top-level design setup using the `check_physical_design -stage pre_place_opt` command.

You can use the `check_ilm -stage pre_place_opt` command to check the ILM only.

For more information about using the `check_ilm` command, see “[Checking ILMs](#)” on page 12-31.

8. Place all the cells of the top-level design and perform placement-based optimization, using the `place_opt` command.

For more information about using the `place_opt` command, see “[Running the place\\_opt Command on the Top-Level Design](#)” on page 12-32.

9. Validate the top-level design setup using the `check_physical_design -stage pre_clock_opt` design command.

You can use the `check_ilm -stage pre_clock_opt` command to check the ILM only.

For more information about using the `check_ilm` command, see “[Checking ILMs](#)” on page 12-31.

10. Perform top-level clock tree synthesis and post clock tree synthesis optimization, by using the `clock_opt` command.

For more information about using the `clock_opt` command, see “[Running the clock\\_opt Command on the Top-Level Design](#)” on page 12-32.

11. Validate the top-level design using the `check_physical_design -stage pre_route_opt` command.

You can use the `check_ilm -stage pre_route_opt` command to check the ILM only.

For more information about using the `check_ilm` command, see “[Checking ILMs](#)” on page 12-31.

12. Perform routing and postroute optimization, by using the `route_opt` command.

For more information about using the `route_opt` command, see “[Running the route\\_opt Command on the Top-Level Design](#)” on page 12-33.

Because an ILM is a `dont_touch` cell:

- Optimization is not performed on the cells within an ILM.
- A path originating in an ILM and ending in an abutted ILM cannot be optimized at the top level. Optimization must be done at the block level to ensure that timing is met in a path that spans abutted ILMs.

## Linking ILMs to the Top-Level Design

IC Compiler automatically links in ILMs that are referenced in the top-level design. During the link process, IC Compiler first searches for each reference name in the libraries specified in the `link_library` variable. If references remain unresolved after this search, IC Compiler searches the Milkyway design library and Milkyway reference libraries for ILM views that match the unresolved reference names.

Note:

If a .db file corresponding to a macro (an extracted timing model) is specified in the `link_library`, the link process chooses that model and does not search for the ILM in the Milkyway library because higher precedence is given to explicitly specified files.

The link process also incorporates automatic propagation of ILM data, such as placement, and UPF constraints, to the top-level design.

## Applying Top-Level Constraints

You can apply timing constraints to the top-level design by using the `read_sdc` command to read the golden SDC file.

When you apply the golden SDC file to the top-level design with ILMs, you might get errors and warnings because constraints are set on objects that exist in the hierarchical blocks, but not in their ILM models. You must verify each error and warning to ensure that it can safely be ignored. To prevent these errors and warnings, you can remove these constraints from the golden SDC file to create an ILM-compatible SDC file; however, you must be careful not to eliminate any valid constraints.

During block-level implementation, if you are using timing exceptions or case-analysis constraints, you must set the same timing exceptions and case-analysis constraints at the top level. If the constraints and exceptions are not set, the ILM might not correctly represent the block-level design.

For example, if the case-analysis set at the top level on an ILM boundary pin does not match the case-analysis value set on the corresponding port of the block, IC Compiler reports the ILM-123 error message indicating the mismatch. This error occurs because the ILM might not have the timing paths corresponding to the top-level constraints.

You might also get this error when the ILM boundary pin has a case-analysis value set at the top level, but the corresponding port of the block from which the ILM was created does not have a case-analysis value.

In a compact ILM that is created with the `-case_controlled_ports` option of the `create_ilm` command, you can change the case-analysis setting at the top level, irrespective of whether the value at the block-level is 0, 1, or not defined.

In a noncompact ILM, you can change the case-analysis setting at the top-level if the case-analysis value at the block-level is not defined. However, if the case-setting value at the block level is either 0 or 1, you can change the value at the top-level if the ILM is created using either of the following `create_ilm` command options:

- `-case_controlled_ports`
- `-traverse_disabled_arcs`

### **Using the `propagate_constraints` Command**

The timing and other constraints data are stored in the ILM. You can use the `propagate_constraints` command to

- Propagate block-level operating conditions to the current design in a multivoltage design flow, using the `propagate_constraints -operating_conditions` command.
- Propagate case-analysis constraints to the current design, using the `propagate_constraints -case_analysis` command.

Note:

You can use the `check_physical_design` command to check whether the `propagate_constraints -case_analysis` option must be run.

The `propagate_constraints` command can propagate other timing constraints as well. For more information, see the command man page.

Due to limitations of the `propagate_constraints` command, you might have to apply clocks and constraints from the top level instead of propagating them from the subblocks.

An example of this limitation occurs when you use the `propagate_constraints` command on a design in which two or more instances of ILM blocks share a common clock name, such as when there are multiple instances of an ILM block or when there are different ILM blocks that share a common clock name. The `propagate_constraints` command cannot propagate these same name clocks to the top-level design. In addition, top-level latency information is partially or entirely lost in this situation.

## Checking ILMs

You can use the `check_ilm` command to check the ILMs before placement optimization, clock tree synthesis, and routing optimization. The syntax for the `check_ilm` command is

```
check_ilm -stage pre_place_opt | pre_clock_opt | pre_route_opt
```

The `check_ilm` command checks if the ILMs linked to the top-level design are ready for various stages of the top-level flow such as `place_opt`, `clock_opt`, `route_opt`. If none of the stages are specified, the following general checks are performed:

- ILM leaf cell location check
- Multicorner-multimode checks
- ILM/CEL/FRAM consistency check
- PG boundary pin consistency and PG pin connection checks
- The `dont_touch` attribute check
- Case analysis consistency check

The `check_ilm -stage pre_place_opt` command performs an ILM location check in addition to the general checks.

The `check_ilm -stage pre_clock_opt` command performs clock tree synthesis checks in addition to the general and `pre_place_opt` checks.

The `check_ilm -stage pre_route_opt` command performs the following checks in addition to the general and `pre_clock_opt` checks:

- TLUPlus settings checks
- Parasitic data checks
- Crosstalk data checks

## Running the `place_opt` Command on the Top-Level Design

You can run the `place_opt` command to place all the cells of the top level. When you run the `place_opt` command, the tool uses and considers ILM objects, such as leaf cell locations, pin locations, and parasitics or delay values, that have been propagated to the top-level design.

You have to define x- and y-coordinates for the ILM block in the top-level DEF file because IC Compiler does not perform block placement. The tool treats cells inside an ILM as fixed cells. It adjusts the locations of the cells within the ILM with respect to the coordinates and orientation that describe how the ILM is placed in the top-level floorplan.

For more information about placement, see [Chapter 6, “Placement.”](#)

## Running the `clock_opt` Command on the Top-Level Design

After placing the top-level cells, you can run the `clock_opt` command to perform top-level clock tree synthesis. Before creating ILMs for use with top-level clock tree synthesis, you must perform clock tree synthesis on the blocks.

When you run the `clock_opt` command, IC Compiler

- Identifies any ILMs inside a clock tree.
- Does not insert any cells beyond the input clock port of an ILM.
- Honors explicit stop pins, exclude pins, and sink pins on an ILM port or inside an ILM.
- Times the clock subtrees inside the ILM to calculate the phase and transition delays for the ILM.

IC Compiler uses the timing information for the clock trees within the ILM to perform skew balancing and insertion delay minimization up to the ILM clock input pins and beyond the ILM clock output pins.

If there are multiple subtrees after an ILM, IC Compiler synthesizes each subtree independently and does not balance the insertion delay between them, which can result in large skew between them. To reduce this skew, run the `optimize_clock_tree` command after performing clock tree synthesis.

- Honors clocks defined on an ILM port or a pin internal to the ILM.

## Running the route\_opt Command on the Top-Level Design

When you run the `route_opt` command on a top-level design with instantiated ILMs, you must use FRAM views for all the blocks modeled by ILMs. To change to the FRAM view, use the `change_macro_view` command for the blocks.

The tool treats the ILMs as placement blockages while routing resources are taken from the FRAM view of all the blocks. The tool also honors any keepout margins that you have specified.

The detailed parasitic data stored in the ILM is automatically used when you run top-level routing, the `extract_rc` command, or the `route_opt` command.

You can perform late-stage, top-level on-route optimization by running the `route_opt` command.

---

## Block Abstraction Models

A block abstraction model is a structural interface logic model that enables optimization of the interface logic within the blocks during top-level optimization. This increases the scope for postroute optimization at the top level, and is useful when top-level optimization alone cannot achieve timing closure. For more details about interface optimization, see [“Transparent Interface Optimization” on page 12-38](#).

Apart from interface optimization, the IC Compiler top-level flow supports block abstraction models similar to ILMs.

Block abstraction is described in the following sections:

- [Creating a Block Abstraction](#)
- [Linking to Block Abstraction Models](#)
- [Reporting Block Abstraction Models](#)
- [Checking Block Abstraction Models](#)

---

## Creating a Block Abstraction

To generate a block abstraction model for the current design, use the `create_block_abstraction` command. When you create a block abstraction model, the interface logic in the design's CEL view is annotated on the design.

After a block abstraction model has been created, you must use the `save_mw_cel` command to save it.

When a block abstraction is created, the `create_block_abstraction` command

- Determines the interface logic. The following netlist objects are part of interface logic:
  - All cells, pins, and nets in timing paths from input ports to registers or output ports.
  - All cells, pins, and nets in timing paths to output ports from registers or input ports.
  - Any logic in the connection from a master clock to generated clocks.
  - The clock trees that drive interface registers, including any logic in the clock tree.
  - The longest and shortest clock paths from the clock ports.
  - The side-load cells of all non-ideal and non-DRC disabled nets.
- Ignores an input or inout port if the percentage of the total registers in the transitive fanout of the port is greater than or equal to the threshold percentage that is specified by using the `ilm_ignore_percentage` variable. The following netlist objects are retained for ports that are ignored:
  - Connections to the already identified interface logic of the other ports.
  - Minimum and maximum critical timing paths.
- Ignores any case analysis settings. Any case analysis settings that are required must be specified at the top level by using the `set_case_analysis` command.
- Assumes all latches found in interface logic are potential borrowers; thus, all logic from I/O ports to flip-flops or output ports are identified as belonging to interface logic.
- Extracts and stores detailed parasitics as part of the abstraction information for each specified TLUPlus file and temperature.
- Signal integrity (SI) and coupling capacitance information is retained when the design is track assigned or detail routed.
- Calculates power consumption of the design and stores that information as attributes on the design. This information is used by the `report_power` command during the final assembly step of the entire chip.

## Creating a Block Abstraction Model for Multicorner-Multimode Usage

The `create_block_abstraction` command automatically detects the presence of multiple scenarios (multiple modes or corners) and determines the interface logic for each scenario. The interface logic identified for each scenario is retained as the interface logic of the block abstraction model. If an interface timing path is disabled in one scenario but enabled in another, the path is included in the interface logic.

---

## Linking to Block Abstraction Models

Block abstraction models can be used in the IC Compiler top-level flow. The IC Compiler top-level flow supports block abstraction models, similar to ILMs.

To specify a list of block references that are to be linked with block abstraction models, use the `set_top_implementation_options -block_references ref_names` command. During linking, the tool loads only the block abstraction information annotated in the CEL view to the top level, and does not load the complete CEL.

To verify the options that are set by using the `set_top_implementation_options` command, use the `report_top_implementation_options` command. The command reports the options in the following format:

```
-----  
Block OptimizeOptimizeSize OnlyHost  
ReferenceInterfaceShared LogicModeOptions  
-----  
block1true false off fortio  
block2true false off fortio  
-----
```

---

## Reporting Block Abstraction Models

To report on block abstraction models that are linked to the current design, use the `report_block_abstraction` command, which reports the following information:

- Block reference name
- Block instance name
- Block version
- Full path of the library from which the block was loaded
- Date and time of last modification of the block
- Cell count and compression statistics for each of the blocks
- Cell count and compression statistics for the top design with blocks
- TLUPlus settings
- Parasitics data of the block
- User-defined multicorner-multimode scenario mappings between the top level and blocks.
- UPF information

---

## Checking Block Abstraction Models

Use the `check_block_abstraction` command to check the readiness of the block abstraction models before placement optimization, clock tree synthesis, and routing optimization. The syntax for the `check_block_abstraction` command is

```
check_block_abstraction
    -stage pre_place_opt | pre_clock_opt | pre_route_opt
```

The `check_block_abstraction` command checks if the blocks linked to the top-level design are ready for placement, clock, and route optimizations. If the `-stage` option is not specified, the command performs the default checks.

*Table 12-10 Checks Performed by the `check_block_abstraction` Command*

| Checks                                            | Default | pre_place_opt | pre_clock_opt | pre_route_opt |
|---------------------------------------------------|---------|---------------|---------------|---------------|
| CEL FRAM consistency                              | x       | x             | x             | x             |
| PG boundary pin consistency and PG pin connection | x       | x             | x             | x             |
| Don't touch attribute                             | x       | x             | x             | x             |
| Block leaf cell location                          | x       | x             | x             | x             |
| Multicorner-multimode                             | x       | x             | x             | x             |
| Block location                                    |         | x             | x             | x             |
| Clock tree synthesis                              |         |               | x             | x             |
| Parasitic data                                    |         |               |               | x             |
| Signal integrity aggressor data                   |         |               |               | x             |

---

## Viewing Hierarchical Models in the GUI

In the IC Compiler GUI, a hierarchical model instance is displayed as a level of physical hierarchy: a rectangular or rectilinear shape with a fill pattern. The View Settings panel provides additional control over the ILM display.

- To display the hierarchical model pins, select the Pin visibility option.
- To expand the hierarchical model to show the leaf cells, pins, nets, and macros within, type or select a positive integer in the “View level” box, click the Settings tab, and then select ILM or CEL in the Child View Name list.

Select and highlight the hierarchical model objects, such as leaf cells, pins, and nets of selected objects, in the layout view.

- To reset the display to the default, unexpanded view, type or select 0 in the “View level” box.

---

## Using Hierarchical Models in a Multicorner-Multimode Flow

You can use blocks modeled using ILMs or block abstraction models in IC Compiler multicorner-multimode flow.

The following requirements apply to using blocks that are modeled using ILMs or block abstraction with multicorner-multimode scenarios:

- For each top-level multicorner-multimode scenario, an identically named scenario must exist in each of the blocks used in the design.

If there is a mismatch, use the `select_block_scenario` command to map the scenarios in the blocks to the top-level design. A block can have additional scenarios that are not used at the top level.

The syntax for using the `select_block_scenario` command is:

```
select_block_scenario
  [-scenarios top_scenarios]
  [-block_references list_design_names]
  -block_scenario block_scenario_name | -reset
```

To reset user-specified multicorner-multimode scenario mapping, use the `-reset` option. For more information, see the command man page.

- By default, in a top-level design without multicorner-multimode scenarios, only blocks without multicorner-multimode scenarios can be used.

To use multicorner-multimode blocks with non multicorner-multimode top-level designs, specify the scenario mapping by using the `select_block_scenario` command.

- For each TLUPlus file, a block stores the extraction data at the specified temperature, which is an operating condition. For accurate results during parasitic extraction at the top level, the TLUPlus files and temperature corners at the top level should match the TLUPlus and temperature corners used during block-level implementation. However, you can use additional TLUPlus and temperatures at the top level.

For more information about multicorner-multimode support in IC Compiler, see [“Setting Up for Multicorner-Multimode Analysis and Optimization” on page 3-29](#).

---

## Transparent Interface Optimization

A top-level flow using ILMs allows optimization of only the top-level logic. This is insufficient for interface timing when

- The top-level design has limited scope for optimization, such as in a design with an abutted or narrow-channel floorplan.
- Budgeting is incomplete or inaccurate, causing a jump in interface path delays when the blocks are assembled at the top level.
- Changes to blocks are needed in the postroute stage, making timing closure difficult.

Transparent interface optimization is a process that optimizes the interface logic within the blocks during top-level postroute optimization and thus achieve timing closure.

Transparent interface optimization is described in the following sections:

- [Enabling Interface Optimization](#)
- [Specifying Block-Specific Size-Only Settings](#)
- [Reporting Implementation Options](#)
- [Example Scripts](#)

---

## Enabling Interface Optimization

Topology-based postroute optimization performed by using the `route_opt` command supports interface optimization of the blocks.

Use the `set_top_implementation_options` command to specify a list of blocks whose interface logic is to be optimized during postroute optimization by using the `route_opt` command. The blocks must be detail-routed and present in the same library as the top-level design for postroute interface optimization. Before performing interface optimization by using the `route_opt` command, use the `check_interface_optimization_setup` command to check the setup for performing interface optimization. After interface

optimization is done, the `route_opt` command updates blocks in parallel through distributed processing. Consequently, you must define the distributed processing setup by using the `set_host_options` command:

```
icc_shell> set_host_options -name for_tio
icc_shell> set_top_implementation_options \
    -block_references blocks \
    -host_options for_tio \
    -optimize_block_interface true
icc_shell> check_interface_optimization_setup
icc_shell> route_opt
```

When you enable interface optimization, the `route_opt` command

- Optimizes both top-level logic and block interface logic during topology-based optimization.

The following `route_opt` command options support interface optimization:

```
[-power] [-size_only] [-area_recovery]
[-only_hold_time] [-only_design_rule]
[-only_power_recovery] [-only_area_recovery]
```

The following `route_opt` command options do not support interface optimization:

```
[-xtalk_reduction] [-only_xtalk_reduction]
[-optimize_wire_via] [-wire_size] [-only_wire_size]
-stage global | detail
```

- Performs sizing optimization on UPF objects, in multivoltage designs, such as isolation cells, level-shifter cells, and always-on cells that drive the always-on nets.
- Updates the in-memory representation of the top-level and block netlists after topology-based optimization.
- Runs legalization, ECO routing, and block abstraction on each of the updated blocks.

To enable multicore execution of legalization, ECO routing, and block abstraction commands, use the `set_host_options -name for_tio -max_cores N` command.

To execute legalization, ECO routing, and block abstraction in parallel on various blocks in a distributed processing environment, use either of the following two methods.

- Specifying a queuing system such as GRD or LSF

```
set_host_options -name for_tio -pool lsf | grd
    -submit_options options
```

Ensure that your UNIX search path has a path to either `qsub` or `bsub`. Define all the settings in the `.cshrc` file that is associated with the queuing system.

Ensure that the settings related to the queuing system are defined before statements similar to the following:

```
if ($?USER == 0 || $?prompt == 0) exit
```

If you use UNIX shells other than `csh`, you must update the appropriate initialization file.

- Specifying a list of named hosts

```
set_host_options -name for_tio {host1 host2 ... hostH}  
set_host_options -name for_tio {hostname}
```

By default, IC Compiler uses `rsh` as the submission program. To use `ssh` as the submission program, use the following command:

```
set_host_options -name for_tio hostname -submit_command ssh
```

Set up the environment such that `ssh` works without requiring a password.

- Relinks the top-level design with the updated blocks and runs the `report_qor` command at the top level.

Note:

Specify absolute paths for the top-level link, target libraries, and the TLUPlus files used during block-level implementation.

---

## Specifying Block-Specific Size-Only Settings

Use the `set_top_implementation_options -size_only_mode` command to restrict the scope of optimization inside the blocks to only sizing based changes. The sizing can further be restricted to in-place and footprint sizing.

Different settings can be specified for different blocks. Block-specific size-only settings are ignored when you use the `route_opt -size_only` command.

---

## Reporting Implementation Options

Use the `report_top_implementation_options` command to verify the options that are set by using the `set_top_implementation_options` command. The command reports the options in the following format:

| Block Reference | Optimize Interface | Optimize Shared Logic | Size Only Mode | Host Options |
|-----------------|--------------------|-----------------------|----------------|--------------|
| block1          | true               | false                 | off            | fortio       |
| block2          | true               | false                 | off            | fortio       |

---

## Example Scripts

### Creating Block Abstraction Models

```
set blocks "block1 block2"
foreach block $blocks {
    open_mw_cel $block
    create_block_abstraction
    save_mw_cel
    close_mw_cel
}
```

### Top-Level Flow With Block Abstraction Models

```
set blocks "block1 block2"
open_mw_cel TOP
# must run the following before using GUI/collections or linking
set_top_implementation_options -block_references $blocks
foreach block $blocks { change_macro_view -reference $block -view FRAM }
read_sdc top.sdc
place_opt
clock_opt
route_opt
```

## Top-Level Flow With Block Abstraction Models and Transparent Interface Optimization

```
set blocks "block1 block2"
open_mw_cel TOP
# must run the following before using GUI/ collections or linking
set_top_implementation_options -block_references $blocks
foreach block $blocks { change_macro_view -reference $block -view FRAM }
read_sdc top.sdc
place_opt
clock_opt
set_host_options -max_cores 4
set_host_options -name for_tio -max_cores 4 -pool grd \
    -submit_options "-l mem_avail=1G,mem_free=1G"
set_top_implementation_options -host_options for_tio \
    -optimize_block_interface true -block_references $blocks
check_interface_optimization_setup
route_opt
save_mw_cel -hierarchy
```

# 13

## In-Design Rail Analysis

---

The PrimeRail tool is integrated with IC Compiler through In-Design rail analysis. You can use In-Design rail analysis to run rail integrity checking, voltage drop analysis, and electromigration analysis in the IC Compiler environment. In-Design rail analysis also supports advanced analysis features such as inrush current analysis and decoupling capacitance analysis. When the checking and analysis processes are complete, you can display the generated resistivity map, voltage drop map, and electromigration map. These maps help you to discover problem areas and determine corrective action without leaving the IC Compiler environment. Error cells are also available for display through the IC Compiler error browser.

This chapter includes the following sections:

- [Overview](#)
- [Preparing for In-Design Rail Analysis](#)
- [Performing Power Network Integrity Analysis](#)
- [Performing Voltage Drop Analysis](#)
- [Performing Electromigration Analysis](#)
- [Performing Inrush Current Analysis](#)
- [Performing Decoupling Capacitance Analysis and Insertion](#)
- [Loading and Deleting PrimeRail Analysis Maps](#)

---

## Overview

In-Design rail analysis supports a complete set of gate-level rail analysis capabilities, including both static and dynamic rail analysis. Supported capabilities include

- Static rail analysis
  - Rail integrity checking
  - Static voltage drop analysis
  - Static electromigration analysis
- Dynamic rail analysis
  - Dynamic voltage drop analysis
  - Dynamic electromigration analysis
  - Inrush current analysis
  - Decoupling capacitance analysis

[Figure 13-1](#) shows where you would use these analysis capabilities in the typical design flow.

*Figure 13-1 In-Design Rail Analysis in the IC Compiler Design Flow*



[Figure 13-2](#) shows the basic flow for running an In-Design rail analysis.

*Figure 13-2 Basic In-Design Rail Analysis Flow*



You use the `set_rail_options` command (or choose Rail > Set Rail Options in the GUI) to set the rail analysis options. You can set environment options, input options, and analysis options. Required options for the various analysis capabilities are described in the following sections. For details about all available options, see the man page. You can use the `report_rail_options` command (or choose Rail > Report Rail Options in the GUI) to report the current rail option settings.

You use the `analyze_rail` command with the appropriate option (or choose Rail > Analyze Rail) to perform rail analysis using PrimeRail. (The following sections describe which option to use for each type of analysis.) When you run this command, it generates setup data for PrimeRail and runs a PrimeRail script within the IC Compiler session. When the analysis is finished, it writes output files to the PrimeRail run directory. By default, the PrimeRail run directory is called `pr_design_name`. To change the name of the PrimeRail run directory, use the `set_rail_options -output_dir` command.

You use the `read_rail_maps` command (or choose the appropriate map from the Rail menu in the GUI) to display the generated parasitics, resistivity, power, voltage drop, or electromigration map.

---

## Preparing for In-Design Rail Analysis

Before you run In-Design rail analysis, you should

- Check the library robustness for In-Design rail analysis
  - Check the power network robustness for In-Design rail analysis
  - Check the voltage settings on the supply nets
  - Set up the PrimeRail and PrimeTime PX environments
- 

### Checking the Library Robustness

Rail analysis requires libraries characterized with power data. You can use either CCS-Power or nonlinear power model (NLPM) libraries. CCS-Power is the recommended library style. For more information about the library requirements for rail analysis, see the *PrimeRail User Guide*.

Before running In-Design rail analysis, use the `check_library` command to check the robustness of the Milkyway design library for rail analysis. To perform the rail analysis library checks, enter the following commands:

```
icc_shell> set_check_library_options -rail view_data  
icc_shell> check_library -mw_library_name my_mw_lib
```

When you enable the rail analysis checks, the `check_library` command checks for rail data consistency between the CONN and FRAM views in the Milkyway design library. If the `check_library` command finds mismatches for the PG port type, net type, or number, it generates warning messages.

For more information about the `check_library` command, see the *Library Data Preparation for IC Compiler User Guide*.

---

### Checking the Power Network Robustness

After loading the design, you should check the integrity of the power network in preparation for running In-Design rail analysis by using the `check_rail` command.

The `check_rail` command checks the design for the following common logical connectivity issues:

- Supply nets that do not connect to any instances
- Power nets with a zero or unassigned voltage

- Floating power and ground pins
- Power pins that connect to a ground or signal net
- Ground pins that connect to a power or signal net

By default, the `check_rail` command purges and rebuilds the RAIL view to ensure consistency between the CEL and RAIL design views. To use the existing RAIL view generated by a previous run of the `analyze_rail` command without purging, use the `set_rail_options -reuse setup_variables` command.

---

## Checking the Voltage Settings

In-Design rail analysis uses the operating voltages set by the `set_voltage` command to apply and propagate voltage state values on the supply nets. Before running In-Design rail analysis, use the `report_supply_net` command to check the voltage settings on the supply nets.

---

## Setting Up the Environment

In-Design rail analysis runs both the PrimeRail and PrimeTime PX tools.

At a minimum, you must have the following license keys to invoke PrimeRail within IC Compiler: PrimeRail, MDataPrep, Milkyway.

Note:

If you are running only cell-level static analysis, you can use the PrimeRail-static license key instead of the PrimeRail license key.

You do not need to have a PrimeTime PX license to invoke PrimeRail inside IC Compiler, because a limited version of PrimeTime PX is invoked within PrimeRail to generate the necessary power and timing information without requiring a PrimeTime license key.

You must also specify the directory paths for the PrimeRail and PrimeTime PX executable files either by adding these locations to your Linux or UNIX PATH environment variable or by specifying the locations by using the `set_rail_options` command.

---

## Performing Power Network Integrity Analysis

Power network integrity analysis checks the connectivity of the power network structure. You should perform power network integrity analysis after completing the power structure and before running the `place_opt` command.

Power network integrity analysis checks the following power network issues:

- Missing connections
- Missing vias
- Floating segments
- Unconnected power or ground pins

To run power network integrity analysis, use the `analyze_rail -integrity` command (or choose Rail > Analyze Rail and select “PG network weakness analysis” in the GUI).

When you run this command, PrimeRail generates the following output in the PrimeRail run directory:

- A connectivity report

The connectivity report is stored in a file named `design_PGnet_integrity_err.txt`. It contains the connectivity errors detected during power network integrity analysis.

- A parasitics map and a resistivity map for the specified power and ground nets

The map data is stored in a file named `rail_map_data/design_PGnet.map`.

The parasitics map displays the parasitic resistors of a given power and ground net in the design. It shows the resistance for any given polygon of the net. To view the parasitics map in the GUI, choose Rail > PrimeRail Parasitics (or run the `read_rail_maps` command). For more information about viewing the parasitics map, see the “Displaying the PrimeRail Parasitics Map” topic in IC Compiler Help.

The resistivity map displays each node and edge on the power and ground network with a color that corresponds to its resistivity value. It shows the “minimum resistance” from an ideal voltage source to any given point in the network. To view the resistivity map in the GUI, choose Rail > PrimeRail Resistivity (or run the `read_rail_maps` command). For more information about viewing the resistivity map, see the “Displaying the PrimeRail Resistivity Map” topic in IC Compiler Help.

To perform advanced resistivity checking in PrimeRail, you must provide a user-defined script to the `analyze_rail -primerail_script_file` command. For more information about advanced resistivity checking, see the *In-Design Rail Analysis Tutorial and Methodology Guide* ([SolvNet article 030497](#)). This article also provides information about how to fix issues reported by PrimeRail power network integrity analysis.

- The PrimeRail setup data

The PrimeRail setup data is stored in a directory named synopsys\_rail\_setup.

- The PrimeRail script file

The PrimeRail script file is stored in a file named analyze\_rail.cmd. It contains the PrimeRail commands that were used to run the analysis. If an error occurs, you can modify the script file and use it in a subsequent run. For debugging purposes, you can also run the script in PrimeRail outside of the IC Compiler environment.

- The PrimeRail log file

The PrimeRail log file is stored in a file named analyze\_rail.log.

PrimeRail also creates an error view named *design\_PGnet\_integrity* in the Milkyway design library. The error view contains the locations of the issues found during power network integrity analysis. You can use the error browser to examine the errors in the GUI by choosing Rail > Error Browser. For more information about the error browser, see “[Examining Routing and Verification Errors](#)” on page A-75 and the “Examining Routing and Verification Errors” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

---

## Performing Voltage Drop Analysis

Voltage drop analysis reports the voltage drop on a power net. Voltage drop can cause delay variations across the chip and can affect clock skew. Analyzing voltage drop without vectors is called static voltage drop analysis, while analyzing voltage drop with vectors is called dynamic voltage drop analysis. You can perform static voltage drop analysis after the design is placed. You can perform dynamic voltage drop analysis after the design is routed.

To perform voltage drop analysis, use the `analyze_rail -voltage_drop` command (or choose Rail > Analyze Rail and select “Voltage drop analysis” in the GUI). By default, the `analyze_rail -voltage_drop` command performs static voltage drop analysis. To perform dynamic voltage drop analysis, enable dynamic analysis mode by running the `set_rail_options` command with the `-analysis_mode dynamic` option (or choose Rail > Set Rail Options in the GUI) before running the `analyze_rail` command.

```
icc_shell> set_rail_options -analysis_mode dynamic
icc_shell> analyze_rail -voltage_drop VDD
```

In multivoltage designs, rail analysis involves multiple power nets. To analyze an individual power net or a group of power nets, specify the nets as an argument to the `analyze_rail` command.

```
icc_shell> analyze_rail -voltage_drop {VDD VDDG VDDGS}
icc_shell> analyze_rail -voltage_drop {VSS}
```

In power-gating designs, it is useful to analyze the entire power network of a power domain including the effects of power switches. You can perform combined voltage drop analysis on both the primary and virtual power nets, treating them, along with the switches, as a single power network. To enable the combined analysis, specify both the primary and virtual power nets, in double quotation marks, with the `analyze_rail` command.

```
icc_shell> analyze_rail -voltage_drop "VDDG VDDGS"
```

When you run this command, PrimeRail loads the rail setup information and then performs power analysis, PG extraction, and rail analysis. It generates the following output in the PrimeRail run directory:

- A voltage drop violation report

The voltage drop violation report is stored in a file named *design\_PGnet\_vd\_err.txt*. It contains the voltage drop violations detected during voltage drop analysis.

- A voltage drop map and a parasitics map for the specified power and ground nets

The map data is stored in a file named *rail\_map\_data/design\_PGnet.map*.

The voltage drop map is a visual display of the colored range of voltage drop values overlaid on the physical supply nets. To view the voltage drop map in the GUI, choose Rail > PrimeRail Voltage Drop (or run the `read_rail_maps` command). For static analysis, the map displays average voltage drop values. For dynamic analysis, the map can display peak voltage drop values, average voltage drop values, or peak voltage rise values. For more information about viewing the voltage drop map, see the “Displaying the PrimeRail Voltage Drop Map” topic in IC Compiler Help.

The parasitics map displays the parasitic resistors of a given power and ground net in the design. It shows the resistance for any given polygon of the net. To view the parasitics map in the GUI, choose Rail > PrimeRail Parasitics (or run the `read_rail_maps` command). For more information about viewing the parasitics map, see the “Displaying the PrimeRail Parasitics Map” topic in IC Compiler Help.

- A power map for the design

The power map data is stored in a file named *rail\_map\_data/design.map*.

The power map displays the power distribution for a design. To view the power map in the GUI, choose Rail > PrimeRail Voltage Drop (or run the `read_rail_maps` command). For more information about viewing the power map, see the “Displaying the PrimeRail Power Map” topic in IC Compiler Help.

- The PrimeRail setup data

The PrimeRail setup data is stored in a directory named *synopsys\_rail\_setup*.

- The PrimeRail script file

The PrimeRail script file is stored in a file named analyze\_rail.cmd. It contains the PrimeRail commands that were used to run the analysis. If an error occurs, you can modify the script file and use it in a subsequent run. For debugging purposes, you can also run the script in PrimeRail outside of the IC Compiler environment.

- The PrimeRail log file

The PrimeRail log file is stored in a file named analyze\_rail.log.

PrimeRail also creates an error view called *design\_PGnet\_vd* in the Milkyway design library. The error view contains the locations of the voltage drop violations found during voltage drop analysis. You can use the error browser to examine the errors in the GUI by choosing Rail > Error Browser. For more information about the error browser, see “[Examining Routing and Verification Errors](#)” on page A-75 and the “Examining Routing and Verification Errors” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

---

## Performing Electromigration Analysis

You can perform electromigration analysis at any implementation stage after placement. However, the recommended methodology is to perform electromigration analysis after detail routing, perform any necessary corrections, and then rerun electromigration analysis after chip finishing.

In multivoltage designs, rail analysis involves multiple power nets. You can run electromigration analyses separately on individual power nets or on a group of power nets.

To perform electromigration analysis, use the `analyze_rail -electromigration` command (or choose Rail > Analyze Rail and select “Electromigration analysis” in the GUI). By default, the `analyze_rail -electromigration` command performs static electromigration analysis. To perform dynamic electromigration analysis, enable dynamic analysis mode by running the `set_rail_options` command with the `-analysis_mode dynamic` option (or choose Rail > Set Rail Options in the GUI) before running the `analyze_rail` command.

```
icc_shell> set_rail_options -analysis_mode dynamic
icc_shell> analyze_rail -electromigration
```

When you run this command, PrimeRail loads the rail setup information and then performs power analysis, PG extraction, and rail analysis. It generates the following output in the PrimeRail run directory:

- An electromigration report

The electromigration violation report is stored in a file named *design\_PGnet\_em\_err.txt*. It contains the voltage drop violations detected during voltage drop analysis.

- An electromigration map

The electromigration map data is stored in a file named *rail\_map\_data/design\_PGnet.map*.

The electromigration map is a visual display of the colored range of electromigration values overlaid on the physical supply nets. To view the electromigration map in the GUI, choose Rail > PrimeRail Electromigration (or run the `read_rail_maps` command). For static analysis, the map displays average electromigration values. For dynamic analysis, the map can display average electromigration values, peak electromigration values, or root mean square electromigration values. For more information about viewing the electromigration map, see the “Displaying the PrimeRail Electromigration Map” topic in IC Compiler Help.

- The PrimeRail setup data

The PrimeRail setup data is stored in a directory named *synopsys\_rail\_setup*.

- The PrimeRail script file

The PrimeRail script file is stored in a file named *analyze\_rail.cmd*. It contains the PrimeRail commands that were used to run the analysis. If an error occurs, you can modify the script file and use it in a subsequent run. For debugging purposes, you can also run the script in PrimeRail outside of the IC Compiler environment.

- The PrimeRail log file

The PrimeRail log file is stored in a file named *analyze\_rail.log*.

PrimeRail also creates an error view called *design\_PGnet\_em* in the Milkyway design library. The error view contains the locations of the electromigration violations found during electromigration analysis. You can use the error browser to examine the errors in the GUI by choosing Rail > Error Browser. For more information about the error browser, see “[Examining Routing and Verification Errors](#)” on page A-75 and the “Examining Routing and Verification Errors” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

---

## Performing Inrush Current Analysis

Inrush current is the sum of switching and short-circuit current through a power-switch cell when it is turned on. Inrush current analysis provides a power-up sequence flow to control the simultaneous switching noise (inrush current) due to turning on the power-switch cells. Power-switch cells should be configured such that the amplitude of the peak inrush current is no greater than the amplitude of the current caused by switching during normal operation.

To perform the most accurate inrush current analysis, you need a simulation-based Verilog Change Dump (VCD) file as input. However, early in the design cycle, when this input is not available, you can also perform vector-free inrush current analysis. However, vector-free analysis might show unrealistic scenarios and result in overdesign of the supply networks, so you should always run a VCD-based analysis on the final design.

While you can perform inrush current analysis after inserting and connecting the power-switch cells during design planning, performing inrush current analysis after you run the `place_opt` command is more accurate because of the standard cell capacitance.

To perform In-Design inrush current analysis,

1. Generate an event file that contains the power-switch cell arrival time information in Scheme syntax.

The event file uses the following syntax:

```
definePortInstancePMCellEvent (geGetEditCell)
    "inst_name" "pg_port_name" num_port
    "(p1 p2...) num_event "(t0 s0 t1 s1...)
definePMCellPortInstTransition (geGetEditCell)
    "inst_name" "signal_port_name" riseSlew fallSlew
```

where

- *inst\_name* is the name of the power-switch cell instance
- *pg\_port\_name* is the name of the input power pin on the power-switch cell
- *num\_port* is the number of control pins
- *(p1 p2...)* is the list of control pins on the power-switch cell
- *num\_event* is the number of events
- *(t0 s0 t1 s1...)* is list of event pairs, where each pair consists of an arrival time and a state for each control pin, which can be one of “r” (rise), “f” (fall), “1”, “0”, or “x”.

The following example defines event information for the Mult/header1\_CO power-switch cell, which has an input power pin TVDD and two control pins, NSLEEPIN1 and NSLEEPIN2. In this example, at arrival time 15.258717, the NSLEEPIN1 input is in the rise state and the NSLEEPIN2 input is in the 0 state. At arrival time 123.856032, the NSLEEPIN1 input is in the 1 state and the NSLEEPIN2 input is in the rise state.

```
definePortInstancePMCellEvent (geGetEditCell)
    "Mult/header1_CO" "TVDD" 2
    "(NSLEEPIN1 NSLEEPIN2) 2 "(15.258717 r0 123.856032 1r)
```

In IC Compiler, you can use the `export_pm_cells_event_file` procedure to generate the event file from static timing information. This procedure is defined in the *Analyzing Inrush Current in Power Gated Designs with the In-Design Rail Flow Using Synopsys® Tools Application Note* (available from [SolvNet article 030497](#)).

## 2. Generate a PrimeRail configuration file.

In the PrimeRail configuration file, you specify

- The wake-up threshold (optional)

The wake-up threshold is the percentage of the supply voltage considered as the stable controlled voltage level after power-up in inrush analysis. The default is 0.01.

You specify this value by using the following syntax:

```
define WAKEUP_THRESHOLD float
```

The `WAKEUP_THRESHOLD` option is used to generate the power management control file.

- The name of the power-switch cell event file

You specify this file name by using the following syntax:

```
define SWITCH_CELL_EVENT_FILE file_name
```

You can specify one event file at a time. Multiple files are not supported.

## 3. Run the `set_rail_options` command (or choose Rail > Set Rail Options in the GUI) to enable dynamic analysis and specify the name of the PrimeRail configuration file.

To enable dynamic analysis, use the `set_rail_options -analysis_mode dynamic` command.

**Note:**

Even if you do not change the analysis mode, inrush current analysis ignores the `set_rail_options -analysis_mode static` setting and performs the analysis in dynamic mode.

To specify the PrimeRail configuration file, use the `set_rail_options -config_file` command.

4. Run the `analyze_rail -inrush` command (or choose Rail > Analyze Rail and select “In-rush current analysis on specified PG nets” in the GUI) to perform inrush current analysis based on the arrival time of the power-switch control pins.

PrimeRail can perform inrush current analysis on both actual power nets and on virtual power nets controlled by the power-switch cells. To specify a virtual power net, you must specify the complete path to the virtual power net and its supply voltage, as shown in the following example:

```
icc_shell> analyze_rail -inrush {VDD {inst/VDDV 1.08}}
```

When you use the `-inrush` option, the `analyze_rail` command calculates the inrush current and the time required for the virtual power net to reach the same voltage value as the actual power net (the wake-up time) based on the event file that you created earlier. PrimeRail also performs dynamic voltage drop analysis.

After the inrush current analysis is complete, PrimeRail generates the following output in the PrimeRail run directory:

- Fast Signal Database (FSDB) file

The FSDB file is stored in a file named `inrush.fsdb`. It contains the following waveform information:

- Total rush current waveform for the switch cell subgroup
- Rush current waveform through each power-switch cell
- The voltage waveform for the virtual power and ground net

You can view the FSDB file in a waveform viewer, such as WaveView or nWave.

- The PrimeRail log file

The PrimeRail log file is stored in a file named `analyze_rail.log`.

The log file includes the following report, which shows the number of power-switch cells (called power management cells in the report), the total off-state leakage current, the total on-state leakage current, the wake-up time, and the peak inrush current for each switching group:

#### Power Management Analysis Report

```
Controlled voltage domain 0: VDDGS
    273 power management cell channels are used to control 4211 std
    cells.
    Total OFF leakage current from PM cells is 19.386e-3 (uA).
    Total ON leakage current from std cells is 6.153 (uA).
    0% (989.831987) 10% 20% 30% 40% 50% (2.991832e3) 60% 70% 80% 90%
    (4.724832e3)
```

```
Stable PG net voltage 1.069 (V) is reached at wakeup time 6.33e3
[start at 525.832 duration 5.804e3] (ps).
Peak current 23.618e-3 (A) is required at 1.645e3 (ps).
```

You can use the leakage power information to refine the number and sizing of the power-switch cells. You can use the wake-up time and peak inrush current information to validate the switch control assumptions.

- A voltage drop map and a parasitics map for the specified power and ground nets

The map data is stored in a file named `rail_map_data/design_PGnet.map`.

The voltage drop map is a visual display of the colored range of voltage drop values overlaid on the physical supply nets. To view the voltage drop map in the GUI, choose Rail > PrimeRail Voltage Drop (or run the `read_rail_maps` command). For static analysis, the map displays average voltage drop values. For dynamic analysis, the map can display peak voltage drop values, average voltage drop values, or peak voltage rise values. For more information about viewing the voltage drop map, see the “Displaying the PrimeRail Voltage Drop Map” topic in IC Compiler Help.

The parasitics map displays the parasitic resistors of a given power and ground net in the design. It shows the resistance for any given polygon of the net. To view the parasitics map in the GUI, choose Rail > PrimeRail Parasitics (or run the `read_rail_maps` command). For more information about viewing the parasitics map, see the “Displaying the PrimeRail Parasitics Map” topic in IC Compiler Help.

- The PrimeRail setup data

The PrimeRail setup data is stored in a directory named `synopsys_rail_setup`.

- The PrimeRail script file

The PrimeRail script file is stored in a file named `analyze_rail.cmd`. It contains the PrimeRail commands that were used to run the analysis. If an error occurs, you can modify the script file and use it in a subsequent run. For debugging purposes, you can also run the script in PrimeRail outside of the IC Compiler environment.

- The PrimeRail log file

The PrimeRail log file is stored in a file named `analyze_rail.log`.

---

## Performing Decoupling Capacitance Analysis and Insertion

Decoupling capacitor cells reduce the peak voltage drop and attenuate noise on the power supply rails. Decoupling capacitance analysis focuses on achieving a user-specified target voltage drop while minimizing the cost of inserting decoupling capacitors. The cost is a function of the total area and leakage current of the inserted decoupling capacitor cells.

You can perform decoupling capacitance analysis and insertion on a routed design after you have inserted filler cells and performed dynamic voltage drop analysis. To perform decoupling capacitance analysis, set the appropriate rail analysis options and then run the `analyze_rail -decap` command (or choose Rail > Analyze Rail and select “Decoupling capacitance analysis” in the GUI).

When you perform decoupling capacitance analysis, PrimeRail provides placement suggestions for decoupling capacitor cells to minimize power supply noise. IC Compiler can use this information to automatically place the decoupling capacitor cells to achieve a target voltage drop reduction.

This section includes the following topics:

- [Preparing for Decoupling Capacitance Analysis](#)
- [Performing Decoupling Capacitance Analysis](#)
- [Performing Decoupling Capacitor Insertion](#)

---

## Preparing for Decoupling Capacitance Analysis

Before you run decoupling capacitance analysis, you must use the `set_rail_options` command (or choose Rail > Set Rail Options in the GUI) to specify the following information:

- The analysis mode

Decoupling capacitance analysis is a dynamic analysis. To set the analysis mode to dynamic, set the `-analysis_mode` option to `dynamic`.

- The names of the reference cells for the filler cells to be replaced

To specify these reference cells, use the `-filler_lib_cells` option. You must specify the exact names; wildcard usage is not supported.

Note that the filler cell instances must already be placed in IC Compiler by using the `insert_stdcell_filler` command.

- The names of the reference cells for the decoupling capacitor cells to be inserted

To specify these reference cells, use the `-decap_lib_cells` option. You must specify the exact names; wildcard usage is not supported.

- The target voltage drop

To specify the target voltage drop threshold in volts, use the `-vd_threshold` option. If you do not specify this option, PrimeRail tries to achieve a voltage drop reduction of 10 percent.

When you save your design in Milkyway format, the options set by the `set_rail_options` command are stored in the Milkyway design library.

---

## Performing Decoupling Capacitance Analysis

When you perform decoupling capacitance analysis, the PrimeRail tool selects available preplaced filler cells in the design and virtually replaces them with decoupling capacitor cells. During the analysis, the PrimeTime tool removes unneeded decoupling capacitor cells to minimize area and leakage current, while meeting the user-specified voltage drop reduction target.

To perform decoupling capacitance analysis for the top-level design,

1. Set the decoupling capacitance analysis options, as described in [“Preparing for Decoupling Capacitance Analysis” on page 13-16](#).
2. Run the `analyze_rail -decap` command (or choose Rail > Analyze and select “Decoupling capacitance analysis” in the GUI).

For decoupling capacitance analysis, you can specify only a single net for analysis. The PrimeRail tool iterates on the design to determine which filler cells can be replaced with decoupling capacitor cells to satisfy the voltage drop target for that net.

The following example shows how to perform decoupling capacitor insertion on the VDD net. The design uses the FillerCell1 and FillerCell2 filler library cells and the DecapCell1 and DecapCell2 decoupling capacitor library cells. The target voltage drop threshold is 1.5 V.

```
icc_shell> set_rail_options -filler_lib_cells "FillerCell1 FillerCell2" \
    -decap_lib_cells "DecapCell1 DecapCell2" -vd_threshold 1.5
icc_shell> analyze_rail VDD -decap
```

After the decoupling capacitance analysis is complete, PrimeRail generates the following output in the PrimeRail run directory:

- ECO file

The ECO file is named `.decap_ude_n`, where *n* is the number of the decoupling capacitance analysis iteration. It contains a list of filler cells that need to be swapped along with the corresponding decoupling capacitor cells.

The following is an example of the ECO file:

```
change_link [get_cells -hierarchy -all xofiller!FILL16!9053] DCAP16
change_link [get_cells -hierarchy -all xofiller!FILL16!9054] DCAP16
```

In this example, `xofiller!FILL16!9053` and `xofiller!FILL16!9054` represent existing filler instance names. DCAP16 represents the replacement decoupling capacitor library cell.

The tool writes the ECO file once per analysis iteration.

- The PrimeRail log file

The PrimeRail log file is stored in a file named `analyze_rail.log`.

- The PrimeRail setup data

The PrimeRail setup data is stored in a directory named synopsys\_rail\_setup.

- The PrimeRail script file

The PrimeRail script file is stored in a file named analyze\_rail.cmd. It contains the PrimeRail commands that were used to run the analysis. If an error occurs, you can modify the script file and use it in a subsequent run. For debugging purposes, you can also run the script in PrimeRail outside of the IC Compiler environment.

- The PrimeRail log file

The PrimeRail log file is stored in a file named analyze\_rail.log.

PrimeRail also creates an error view in the Milkyway design library. The error view contains the locations of the filler cells which are to be replaced and the replacing decoupling capacitor cell. You can use the error browser to examine the error view in the GUI by choosing Rail > Error Browser. For more information about the error browser, see “[Examining Routing and Verification Errors](#)” on page A-75 and the “Examining Routing and Verification Errors” topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

---

## Performing Decoupling Capacitor Insertion

After PrimeRail generates the ECO file, you can insert the decoupling capacitor cells by sourcing the generated ECO file, .decap\_ude\_n. The commands in the ECO file replace filler cells with decoupling capacitor cells.

```
icc_shell> source pr_design_name/.decap_ude_n
```

During decoupling capacitor insertion, IC Compiler saves physical information from the filler cell. This information includes the location, size, orientation, and information about the power and ground nets. After saving the information, the tool deletes the filler cell, replaces it with a new instance of the decoupling capacitor cell, and attaches the physical attributes of the filler cell.

---

## Loading and Deleting PrimeRail Analysis Maps

When you perform power network analysis by using the `analyze_rail` command, PrimeRail generates map files for the analysis modes you specify. You can load the map file into the IC Compiler GUI by using the `read_rail_maps` command or by choosing the appropriate item from the Rail menu in the IC Compiler GUI:

- Rail > PrimeRail Parasitics to view the parasitics map.
- Rail > PrimeRail Resistivity to view the resistivity map.
- Rail > PrimeRail Power to view the power map.
- Rail > PrimeRail Voltage Drop to view the voltage drop map.
- Rail > PrimeRail Electromigration to view the electromigration map.

Use the `remove_rail_maps` command to remove the rail map data from the current IC Compiler session.



# 14

## Multivoltage Design Flow

---

This chapter describes the multivoltage design flow in IC Compiler.

This chapter contains the following sections:

- [Multivoltage Designs](#)
- [High-Level Design Flow for Multivoltage Designs](#)
- [UPF Flow for Multivoltage Designs](#)
- [Defining Power Domains and Supply Networks](#)
- [Defining and Using Voltage Areas](#)
- [Power Management Cells and UPF Strategies](#)
- [Example IC Compiler Script for the UPF Flow](#)
- [Voltage-Area-Aware Capabilities](#)
- [Placing and Optimizing the Design](#)
- [Multivoltage Specific Queries, Checks, and Reports](#)
- [Hierarchical UPF Flow](#)

---

## Multivoltage Designs

IC Compiler supports multivoltage, multisupply, and mixed multivoltage-multisupply designs. In multivoltage designs, the subdesign instances, or blocks, operate at different voltages. In multisupply designs, the block voltages are the same, but the blocks can be powered on and off independently. (In this user guide, unless otherwise noted, the term *multivoltage* includes multisupply and mixed multisupply-multivoltage designs).

You use the IEEE 1801 Unified Power Format (UPF) to specify the power supply intent for your design. UPF supports the ability to specify the power intent for your design early in the design process. IC Compiler supports the use of UPF for the entire design flow. For more details about the low-power flow and various Synopsys tools that support UPF, see the *Synopsys Low-Power Flow User Guide*.

Alternatively, you can also specify the power intent in the RTL file. For more information about specifying power intent in the RTL file, see “[Example IC Compiler Script for the UPF Flow](#)” on page 14-70.

Multivoltage designs typically make use of the following features:

- Power domain – a grouping of logic hierarchies comprising a block
  - Voltage area – physical placement area for the cells of a power domain
  - Special cells – level shifters and isolation cells used to connect the drive and load pins across different power domains
- 

## Power Domains

Power consumption can be reduced in a multivoltage design by making use of power domains that are independently powered up and down, including domains that are defined to have always-on relationships relative to each other.

Specifically, a power domain is defined as a grouping of one or more *logic* hierarchies comprising a design block that share the following properties:

- Primary voltage states or voltage range (specifically, the same operating voltage)
- Power net hookup requirements
- Power-down control and acknowledge signals (if any)
- Power-switching style
- Process, voltage, and temperature (PVT) operating condition values (all cells of the power domain except level shifters)

- Same set or subset of nonlinear delay model (NLDM) target libraries
- A *physical* voltage area into which the cells of these logic hierarchies are to be placed

## Defining Power Domains

You have the following three different ways of defining power domains for your design:

- Define power domains in a UPF file.

You specify all the power information for your design in a separate file, the UPF file. You read this UPF file in IC Compiler, along with your design. For more details, see “[UPF Flow for Multivoltage Designs](#)” on page 14-11.

- Define power domains in the RTL design.

If you use Design Compiler for logic synthesis, you can also define power domains in the RTL code and use the `compile_ultra` or the `compile` commands of Design Compiler to synthesize your design. For further information, see “[Design Compiler to IC Compiler Interface](#)” on page 14-86.

To save your synthesized design and the power constraints in a file for use in the IC Compiler flow, follow one of the following methods:

- Write the design in the .ddc file format.
- Write the design in the Milkyway database.
- Write the design in the Verilog format and the constraints in a separate file. In the Verilog format, the power constraints are not saved. These have to be saved separately in a constraints file.

- Define power domains in IC Compiler.

If you use a third-party logic synthesis tool that does not support power domain definitions either in a UPF file or in the RTL code, use the `create_power_domain` command in IC Compiler to define the power domains. You create these power domains in IC Compiler in the same way as you do in Design Compiler. For more details, see the *Power Compiler User Guide*. Power domains created in IC Compiler are stored in the Milkyway database.

For further information, see “[Defining Power Domains and Supply Networks](#)” on page 14-14.

---

## Voltage Areas

A voltage area is the physical placement area of a logic block comprising one or more logic hierarchies operating under a single voltage level. Except for level-shifter cells, all cells in the hierarchies associated with a voltage area operate at the same process, voltage, and temperature (PVT) operating condition values.

You create voltage areas by using the `create_voltage_area` command. Voltage areas must be defined before running the `psynopt` or `place_opt` command.

Note:

If you use the floorplanning method to define voltage areas, the floorplan must contain a default voltage area for the top-level cells and at least one other voltage area. If you create the voltage areas directly by using the `create_voltage_area` command, the tool automatically derives a default voltage area for the top-level leaf cells and level shifters that do not belong to any block.

Physically nested voltage areas are supported, but intersecting voltage areas are not supported. This property of the tool has certain implications for how you decompose intersecting voltage areas into areas that do not intersect. The recommended way of creating physically nested voltage areas is to have one voltage area completely encompassing the other.

For more information, see “[Defining and Using Voltage Areas](#)” on page 14-37 and “[Handling Nested Voltage Areas](#)” on page 14-43.

---

## Associating Power Domains and Voltage Areas

There must be an exact one-to-one relationship between logical power domains and physical voltage areas. Design Compiler and IC Compiler can automatically align the logic hierarchies of the power domains with their voltage areas if you provide the corresponding power domain name as an argument in each `create_voltage_area` command. In this case, the power domain name and the voltage area name are identical.

If you do not make these specifications, you are responsible for ensuring that the logic hierarchies are correctly aligned, as well as being correctly associated with the appropriate operating conditions.

---

## Level-Shifter and Isolation Cells

Level-shifter cells operate across voltage differences, connecting drive and load pins of cells belonging to different power domains (and placed in different voltage areas). The basic function of a level shifter is to connect the power domains by stepping the voltage up or down as needed. IC Compiler supports both simple buffer-type level shifters and enable-type level

shifters, which are essentially buffer-type level shifters with an additional enable pin. Enable-type level shifters are used when the power domains must be powered on and off independently. A design can contain both types of level shifters.

By using the `insert_mv_cells` command, you can explicitly insert buffer-type level shifters into an unmapped or mapped netlist at any point in the design flow before IC Compiler places the cells of a design. In an *unmapped* design, buffer-type level shifters are automatically inserted as needed when you run the `compile_ultra` or `compile` command. If you intend to explicitly insert level shifters, you should run the command as early in the flow as possible.

In UPF mode, you can insert enable-type level shifters using the `insert_mv_cells` command. Usually these level shifters are instantiated at the RTL level or represented by generic library (GTECH) cells, before the unmapped design is compiled. During logic synthesis, existing isolation cells are sometimes replaced with enable-type level shifters. (Since enable-type level shifters are buffers, they can also be used as isolation cells.)

You use isolation cells to isolate the input and output signals of the shut-down power domains. These cells can be instantiated at the RTL level of the design description, or you can run the `insert_mv_cells` command to insert them directly. (Note that isolation cells are sometimes replaced by enable-type level shifters during logic synthesis.)

IC Compiler places level shifters and isolation cells near the voltage area boundaries, usually at the top level of the design. However, if the port voltages are appropriately specified, these cells can be placed inside the voltage areas. For some designs, there are advantages to placing these cells inside the voltage areas.

For more information, see “[Power Management Cells and UPF Strategies](#)” on page 14-45.

---

## Basic Library Requirements for Multivoltage Designs

The libraries must conform to the Liberty open library rules. IC Compiler supports multiple libraries characterized at different voltages.

Target library cells are selected on the basis of matching operating conditions between library cells and voltage area. The selection of these cells can be further restricted by using the `set_target_library_subset` command.

Note:

K-factor scaling is not supported for multivoltage designs and is ignored if present in the libraries.

## Using a Target Library Subset

When you need to restrict the target library cells eligible for optimizing the hierarchical cells of a block, use the `set_target_library_subset` command.

The command syntax is

```
set_target_library_subset {library_list} -object_list {cell_list}
```

where

- `library_list` is a list of target library file names, all of which must also be listed in the `target_library` variable.
- `cell_list` is a list of hierarchical cells (blocks or top level) for which the target library subset is used.

To use this command at the top level, you must include the `-top` option.

Applying this command to a hierarchical cell or to the top-level design enforces this library restriction on all lower cells in the hierarchy, except for those cells that have a different library subset constraint explicitly set on them.

Note:

When you use the `set_target_library_subset` command, you do not need to uniquify the designs before using the command. (Note, however, that if you intend to use the `insert_mv_cells` command as part of the logic synthesis flow in Design Compiler, you need to run the `uniquify` command first.)

To remove a target library subset constraint, use the `remove_target_library_subset` command with the appropriate library list and cell list.

You can check for errors and conflicts introduced by the target library subset, by using the `check_mv_design -target_library_subset` command. The command checks for the following conditions:

- Conflicts between target library subsets and the global `target_library` variable
- Conflicts between operating condition and target library subset
- Conflicts between the library cell of a mapped cell and target library subset

Use the `report_target_library_subset` command with the appropriate library cell list to find out which target library subsets have been defined both for the hierarchical cells and at the top level.

## Converting Libraries to PG Pin Library Format

IC Compiler uses the power and ground (PG) pin information specified in the Liberty library syntax, during optimization. However, if your target library does not contain PG pin information, you can convert it into PG pin library format. The following sections describe how to convert your libraries into the PG pin library format:

- [Using FRAM View as a Reference to Convert to PG Pin Library Format](#)
- [Using Tcl Commands to Convert to PG Pin Library Format](#)
- [Tcl Commands for Low-Power Library Specification](#)

### Using FRAM View as a Reference to Convert to PG Pin Library Format

You can use the FRAM view as the reference for converting your library to the PG pin library format. You must set the `mw_reference_library` variable to the location of the Milkyway reference libraries. Use the `update_lib_model` command to convert your library to the PG pin library format. The tool uses the PG pin definitions available in the FRAM view of the Milkyway library for the conversion. This is the default behavior. [Figure 14-1](#) shows the steps involved in converting a non-PG pin library to a PG pin library.

*Figure 14-1 Conversion of a Non-PG Pin Library to a PG Pin Library Using the FRAM View*



To ensure that the newly created PG pin library is complete, use the `check_library` command. If the newly created PG pin library is not complete, run the library specification Tcl commands to complete the library specification. For more details, see [“Tcl Commands for Low-Power Library Specification” on page 14-9](#).

## Using Tcl Commands to Convert to PG Pin Library Format

When your library files are not in the PG pin library syntax and you do not have the FRAM view of the Milkyway library, you can use the following Tcl commands to specify the information required for deriving the PG pin details, as shown in [Figure 14-2](#).

- `update_lib_voltage_model`  
Sets the voltage map for the specified library.
- `update_lib_pg_pin_model`  
Sets the PG pin map for the specified library cell.
- `update_lib_pin_model`  
Sets the pin map for the specified library cell.

These Tcl commands specify the library requirements that are used while converting the libraries to the PG pin format.

*Figure 14-2 Conversion of Non-PG Pin Library to PG Pin Library Using Tcl Commands*



Run the `update_lib_model -reference_mode TCL` command to convert your libraries to the PG pin library format. To check if your newly created PG pin library is complete, run the `check_library` command. If your newly created PG pin library contains conflicts or is

incomplete, you can run the library specification Tcl commands to complete the library specification. For more details, see “[Tcl Commands for Low-Power Library Specification](#)” on page 14-9.

### Tcl Commands for Low-Power Library Specification

When you convert your library to the PG pin format, if the newly created library file is complete, you can start using the library for the low-power implementation of your design. However, if your library contains power-switch cells and the modeling is not complete, you can use the following Tcl commands to complete your library specifications. These commands specify the library voltage and the PG pin characteristics.

- `set_voltage_model`  
Sets the voltage model on the specified library by updating the voltage map in the library.
- `set_pg_pin_model`  
Defines the PG pins for the specified cell.
- `set_pin_model`  
Defines the related power, ground, or bias pins of the specified pin of the library.

For more details, see the man page and the *Library Quality Assurance System User Guide*.

---

## Physical Synthesis

You use the `place_opt` command in IC Compiler to accomplish the physical synthesis phase of the multivoltage design flow. During this phase, the gate-level designs are read into memory along with the floorplan. The multivoltage design steps are

- (Optional) Insert buffer-type level shifters if they were not inserted during the logic synthesis phase of the flow.
- Transfer the power domain objects into the Milkyway database (Design Compiler to IC Compiler flow) or create power domains and power domain objects in IC Compiler (third-party synthesized design to IC Compiler flow).
- Create voltage areas and associate or align the logic hierarchies, and write the information into the Milkyway database. (Optional) Create power wells within given voltage areas as always-on placement sites for single-power standard cells.
- Run the `place_opt` command to perform cell placement in the corresponding voltage areas of the power domains and optimize the design. This includes always-on optimization of the paths that must receive power when shut-down power domains are powered down.

## High-Level Design Flow for Multivoltage Designs

IC Compiler support for multivoltage designs is part of a larger design flow involving several Synopsys tools. Support for multivoltage designs is automatically enabled across the entire Galaxy Design platform. [Figure 14-3](#) shows the Galaxy Design platform high-level flow for multivoltage designs. This is a complete RTL-to-signoff design flow. To understand how to use the individual tools of the design flow, consult the appropriate user guides.

*Figure 14-3 Galaxy Design Platform High-Level Multivoltage Design Flow*



The Galaxy Design platform tools recognize a design as a multivoltage design and use multivoltage capabilities if any of the following conditions are true:

- A UPF command is encountered
- Power domains are defined
- Instance-based operating conditions are specified
- Target library subset is used

- Multiple link libraries are used
- Multiple target libraries are used

If none of these conditions hold, the tools assume the design is not a multivoltage design.

## UPF Flow for Multivoltage Designs

[Figure 14-4](#) shows an overview of the UPF flow for multivoltage designs.

*Figure 14-4 IC Compiler Multivoltage UPF Flow*



The steps involved in the UPF flow are,

1. Read the target libraries.

The libraries must comply with the power and ground pin Liberty library syntax.

For additional information about the power and ground pin library syntax, see the advanced low-power modeling information in the *Library Compiler Modeling Timing, Signal Integrity, and Power in Technology Libraries User Guide*.

2. Read the multivoltage design.

The design being read into IC Compiler should already contain special cells such as the retention registers, isolation cells, and level-shifter cells. For more details, see “[Reading the Design](#)” on page [3-11](#).

3. Read the UPF file using the `load_upf` command.

Use the UPF commands to specify the power intent or power constraints for your multivoltage design in the UPF file. Use the `load_upf` command to read this file in IC Compiler. The `load_upf` command executes the UPF commands in the specified UPF file. This UPF file can also be used for RTL simulation and equivalence checking.

4. Create and map the power switch to the technology library cell.

Use the `create_power_switch_ring` command to create a ring of power-switch cells around a voltage area, macro cell, or polygon. Use the `map_power_switch` command to map the power switch to the technology library cell. To instantiate the power-switch cell in the floorplan use the `create_power_switch_array` command.

5. Create the logical power and ground connections by using the `derive_pg_connection` command.

After you read in the design, you must create logical connections between the power and ground nets and the power, ground, and tie-off pins of the cells in your design. To create these connections use the `derive_pg_connection` command. Use the `-create_net` option to create the missing power nets. To override the existing power connections and use the power intent defined in the UPF file, use the `-reconnect` option.

The `derive_pg_connection` command can automatically derive power and ground connections for physical-only cells as well, based on the power domain to which the physical-only cell belongs.

For more information, see “[Creating Logical Power and Ground Connections](#)” on [page 3-20](#) and the *IC Compiler Design Planning User Guide*.

6. Set the operating conditions on the top level of the design hierarchy by using the `set_operating_conditions` command.

Set the operating condition and derive the process and temperature conditions for the design by using the `set_operating_conditions` command.

Use the `set_voltage` command to set the voltage values for the power or ground supply nets. If your setup has both, the `set_operating_conditions` and the `set_voltage` commands, IC Compiler uses an internal precedence rule to derive an appropriate operating condition.

Note:

If you do not set the top-level operating condition, IC Compiler issues the MV-028 error message.

## 7. Check for multivoltage-specific violations.

Use the `check_mv_design` and `analyze_mv_design` commands to check for multivoltage-specific violations in the design. The `-verbose` option gives a detailed report of the violations.

## 8. Perform the optimizations.

Run the optimization commands. When you run the `place_opt`, `clock_opt`, and `route_opt` commands, the tool internally runs the `derive_pg_connection` command and updates the log file with a summary of the power and ground connections. If you use any optimization commands other than these core commands, you should run the `derive_pg_connection` command to complete the power and ground connections. Use the `check_mv_design -power_nets` command to check for mismatches in the power and ground pin connections.

If the floorplan is read from a DEF file, the port names in the DEF file and the UPF file should be consistent. If not, the port names in the DEF file take precedence over the port names in the UPF file. However, for boundary ports, IC Compiler honors both DEF file and UPF file definitions.

## 9. Save the UPF file.

After the optimization steps, use the `save_upf` command to write the UPF file updated by IC Compiler.

The UPF standard requires simple names for the argument of certain UPF commands. By default, IC Compiler does not enforce this requirement. To enforce this requirement in the UPF file written by the `save_upf` command, set the `mv_output_enforce_simple_names` variable to `true`.

Compared to the UPF file that you read into the tool, the UPF file written by IC Compiler contains the following additional information:

- The following comment on the first line of the UPF file:  
`#Generated by IC Compiler(B-2008.09) on Mon Aug 4 14:26:58 2008`
- Explicit power connections to special cells such as level shifters and isolation cells.
- Any additional UPF commands that you specified at the command prompt in the IC Compiler session.

---

## Defining Power Domains and Supply Networks

This section describes how to define power domains, supply networks, power state tables using the UPF commands. This section contains the following subsections:

- [Power Domains](#)
  - [Hierarchy and Scope](#)
  - [Supply Sets](#)
  - [Creating Power Domains](#)
  - [Creating the Supply Network](#)
  - [Creating Power Switches](#)
  - [Defining State Information for the Supply Ports](#)
  - [Creating a Power State Table](#)
  - [Defining the States of the Supply Nets](#)
  - [Connecting Power and Ground Nets](#)
- 

### Power Domains

Multivoltage designs contain design partitions which have specific power behavior compared to the rest of the design. A power domain is a basic concept in the Synopsys low-power infrastructure, and it drives many important low power features across the flow.

By definition, a power domain is a logic grouping of one or more logic hierarchies in a design that shares the same power characteristics, including:

- Power net hookup requirements
- Power down control and acknowledge signals, if any
- Power switching style

Thus, a power domain describes a design partition, bounded within logic hierarchies, which has a specific power behavior with respect to the rest of the design.

A power domain has the following characteristics:

- Name
- Level of hierarchy or scope where the power domain is defined or created

- The set of design elements that comprises the power domain
- An associated set of supply nets that are allowed to be used within the power domain
- Primary power supply and ground nets
- Synthesis strategies for isolation, level shifters, and retention registers

Note:

A power domain is strictly a logic construct; not a netlist object. For more details about the concept of power domains see the *Synopsys Low-Power Flow User Guide*.

---

## Hierarchy and Scope

Logical hierarchy, where the power domain is created, is called the scope of the power domain. Design elements that belong to a power domain are said to be in the extent of the power domain. For more details, see the *Synopsys Low-Power Flow User Guide*.

In Design Compiler and IC Compiler, in UPF mode, you can use the `set_scope` command to specify the scope or level of hierarchy. The `set_scope` command sets the scope or the level of hierarchy to the specified scope. When no instance is specified, the scope is set to the top level of the design hierarchy. Alternatively, you can also use the `current_instance` command to specify the current scope. However, in the power context, the `set_scope` command is preferred.

You should explicitly specify the scope using the `set_scope` or the `current_instance` command. Unless explicitly specified, IC Compiler uses the current scope or current level of hierarchy when you define objects. For more details about scope, see the *Synopsys Low-Power Flow User Guide*.

---

## Supply Sets

A supply set is a collection of supply nets. A supply set can be considered as a unified and progressively defined bundle of supply nets that are not specific to a power domain. Supply sets can be used only within the scope in which it is defined and in scopes under it.

The supply set concept eliminates the need to define the supply nets and ports in the design in the logic synthesis tool. The supply sets must be associated with the supply nets and ports before performing physical synthesis.

A supply set supports the following two functions:

- Power
- Ground

You can access the functions of the supply set by using the name of the supply set and the name of the function. To access the power function of the *ss* supply set, specify *ss.power*. To access the ground function of the *ss* supply set, specify *ss.ground*. These are also known as implicit supply nets. For more details about creating supply sets, see “[Creating Supply Sets](#)” on page 14-22.

Supply sets are always domain independent and can only be associated with domain independent nets. The domain-independent supply nets or ports must be created in the same scope as the supply set with which the nets and ports are associated. However, you can restrict the supply set to a power domain by using the `extra_supplies_#` keyword (an integer suffix) with the `-supply` option of the `create_power_domain` command. For more information, see “[Restricting Supply Sets to a Power Domain](#)” on page 14-24.

Note:

You cannot refer to a supply set defined in a scope that is higher in the hierarchy than the scope from which you are referring.

---

## Creating Power Domains

Use the `create_power_domain` command to create a power domain with the specified name. The syntax of the `create_power_domain` command is as follows:

```
create_power_domain
  [-elements element_list]
  [-include_scope]
  [-supply {supply_set_handle supply_set_ref}]
  [-scope instance_name]
domain_name
```

Use the `-elements` option to specify the list of hierarchical cells that are added as the extent of the power domain. The `-include_scope` option specifies that all the elements in the current scope share the primary supply of the power domain, but are not necessarily added as the extent of the power domain.

Use the `-supply` option to associate a supply set with the power domain. You must specify the type of the supply set, also referred as the supply set handle, with the `-supply` option. For more details about creating power domains using supply sets, see “[Creating Power Domains Using Supply Sets](#)” on page 14-24.

Use the `-scope` option to specify the logical hierarchy or the scope at which the power domain is to be defined. The `domain_name` argument is the name of the power domain to be created.

The UPF standard requires a simple name for the `domain_name` argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

*Figure 14-5 Defining a Power Domain and Scope*

The following example creates the PD1 and PD2 power domains shown in [Figure 14-5](#).

```
create_power_domain -elements {U1 U2 U3} -scope Block1 PD1
create_power_domain -elements {U4 U5 U6} -scope Block1 PD2
```

Alternatively, you can use the `set_scope` command to first set to the desired scope and then create the power domain:

```
set_scope Block1
create_power_domain -elements {U1 U2 U3} PD1
create_power_domain -elements {U4 U5 U6} PD2
```

You can use the `-include_scope` option to include all the elements in the specified scope to share the supply of the power domain.

```
create_power_domain -include_scope Block2 PD3
```

In this case, the U9 element shares the supply of power domain PD3, though U9 is not explicitly mentioned to be part of the PD3 power domain.

---

## Creating the Supply Network

Each power domain has a supply network consisting of supply nets and supply ports. The supply network can contain power switches. The supply network is used to specify the power and ground net connections for a power domain. A supply net is a conductor that carries a supply voltage or ground. A supply port is a power supply connection point between the inside and outside of the power domain. Supply ports serve as the connection points between supply nets. A supply net can carry a voltage supply from one supply port to another.

When used together, the power domain and supply network objects allow you to specify the power management intentions of the design.

Every power domain must have one primary power supply and one primary ground. In addition to the primary power and ground nets, a power domain can have any number of additional power supply and ground nets.

## Creating Supply Ports

To create the supply and ground ports, use the `create_supply_port` command.

The syntax of the `create_supply_port` command is as follows:

```
create_supply_port [-domain power_domain]
                   [-direction in | out]
                   supply_port_name
```

The *supply\_port\_name* specified should be unique at the level of hierarchy where it is defined. The `-domain` option is used to create the supply port in the scope of the submodule. The supply port name should be a simple nonhierarchical name. When the `-domain` option is not used, the supply port is created in the current scope or level of hierarchy and all power domains in the current scope can use the created port.

The UPF standard requires a simple name for the *port\_name* argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

[Figure 14-6](#) shows the power intent for a design that contains four power domains: PD\_TOP, PD1, PD2, and PD3. The PD\_TOP power domain has four supply ports, VDD1, VDD2, VDD3, and GND; the PD1 power domain has three supply ports, VDD1, VDD1g, and GND; the PD2 power domain has two supply ports, VDD2 and GND; and the PD3 power domain has two supply ports, VDD3 and GND. [Example 14-1](#) shows the `create_supply_port` commands used to create the supply ports for this power intent.

*Figure 14-6 Power Intent Specification Example**Example 14-1 Creating Supply Ports*

```

# Create supply ports for PD_TOP power domain
create_supply_port VDD1
create_supply_port VDD2
create_supply_port VDD3
create_supply_port GND

# Create supply ports for PD1 power domain
create_supply_port VDD1 -domain PD1
create_supply_port VDD1g -domain PD1
create_supply_port GND -domain PD1

# Create supply ports for PD2 power domain
create_supply_port VDD2 -domain PD2
create_supply_port GND -domain PD2

# Create supply ports for PD3 power domain
create_supply_port VDD3 -domain PD3
create_supply_port GND -domain PD3

```

**Note:**

The connectivity is not defined when the supply port is created. To define the connectivity, use the `connect_supply_net` command.

## **Creating Supply Nets**

A supply net connects supply ports. Use the `create_supply_net` command to create a supply net. The syntax of the `create_supply_net` command is as follows:

```
create_supply_net [-domain power_domain]
                  [-reuse]
                  [-resolve unresolved | parallel]
                  supply_net_name
```

When you specify the power domain, the supply net is created in the same scope or logical hierarchy as the specified power domain. When you do not use the `-domain` option, the supply net is created in the active scope and the net can be used by power domains at the current scope and scopes within the current scope.

When the `-reuse` option is used, the specified supply net is not created; instead an existing supply net with the specified name is reused.

```
create_supply_net GND_NET
create_supply_net -domain PD1 GND_NET
create_supply_net -domain PD2 GND_NET
create_supply_net -domain PD3 GND_NET
```

When a supply net is created, it is not considered a primary power supply or ground net. To make a specific power supply or ground net of a power domain into a primary supply or ground net, use the `set_domain_supply_net` command.

The UPF standard requires a simple name for the `net_name` argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

**Note:**

It is an error to set the primary supply of the power domain as domain dependent supply net, unless the domain has the `suppress_is` design attribute. For more information about setting design attributes, see “[Setting Isolation Attributes on Cells](#)” on page 14-59.

## **Connecting Supply Nets**

The `connect_supply_net` command connects the supply net to the specified supply ports or pins. The connection can be within the same level of hierarchy or to ports or pins down the hierarchy. You can also use this command to connect to the internal PG pins of the macro cells with fine-grained switches. For more details about fine-grained switch cells, see “[Macro Cells with Fine-Grained Switches](#)” on page 14-32.

The syntax of the `connect_supply_net` command is as follows:

```
connect_supply_net supply_net_name [-ports list]
```

When the scope of the domain-independent net is higher than the scope of the supply port, the net can be connected to the high end of the supply port. When the scope of the net and the port are same, the supply net can be connected to the low end of the supply port. Using this command, you can also connect physical-only cell to the supply net.

The UPF standard requires a simple name for the `supply_net_name` argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

The following example depicts the use of the `connect_supply_net` command to connect supply nets to various supply ports in different levels of hierarchy or power domains.

```
connect_supply_net GND_NET -ports GND
connect_supply_net GND_NET -ports {B1/GND B2/GND B3/GND} GND
```

## Specifying the Primary Supply Nets for a Power Domain

Use the `set_domain_supply_net` command to define the primary power supply net and primary ground net for a power domain. The syntax of the `set_domain_supply_net` command is as follows:

```
set_domain_supply_net
  -primary_power_net supply_net
  -primary_ground_net supply_net
  domain_name
```

Every power domain must have one primary power and one ground connection. When a supply net is created, it is not a primary supply net. You must use the `set_domain_supply_net` command to designate the specific supply net as the primary supply net for the power domain. If a power or ground pin of a cell in a power domain is not explicitly connected to any supply net, that power or ground pin of the cell is assumed to be connected to the primary power or ground net of the power domain to which the cell belongs.

When in the scope of Top, you can use the following command to designate VDD and GND nets as the primary power and ground net, respectively, of the power domain PD\_TOP:

```
icc_shell> set_domain_supply_net -primary_power_net VDD \
-primary_ground_net GND
```

Note:

The domain-independent nets that are defined in the current or higher scope can be specified as the power and ground nets for the `set_domain_supply_net` commands.

---

## Creating Supply Sets

To create a supply set, use the `create_supply_set` command. You can use supply sets to define the power network. A supply set is created in the current logic hierarchy or the current scope.

The syntax of the `create_supply_set` command is as follows:

```
create_supply_set
  [-function {function_name net_name}]
  [-update]
  supply_set_name
```

Use the `-function` option to specify the function to which the specified supply net should be associated. This option takes two arguments, the name of the function, which can be either power or ground, and the name of the supply net.

The `-update` option associates a supply net to the power or ground functions of an existing supply set.

The UPF standard requires a simple name for the `supply_set_name` argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

The following example shows how you use the `-update` option to associate supply nets to the functions of the supply set:

```
icc_shell> create_power_domain PD_TOP
icc_shell> create_supply_net TOP_VDD -domain PD_TOP
icc_shell> create_supply_net TOP_VSS -domain PD_TOP
icc_shell> create_supply_set ss \
  -function {power TOP_VDD} \
  -function {ground TOP_VSS} \
  -update
```

The following example shows how you create a supply set and associate it with the primary power supply of a power domain:

```
icc_shell> create_supply_set primary_supply_set
icc_shell> create_power_domain PD_TOP
icc_shell> set_domain_supply_net PD_TOP \
  -primary_power_net primary_supply_set.power \
  -primary_ground_net primary_supply_set.ground
```

Note:

When you use supply set handles, the power and ground supply nets that you specify with the `set_domain_supply_net` command must belong to the same supply set. Otherwise, IC Compiler issues an error message.

## Defining Power States for the Components of a Supply Set

Power states are attributes of a supply set. Different supply nets of a supply set can be at different power states at different times. Using the `add_power_state` command, you can define a power state for the various supply nets of the supply set. Multiple power states can be defined on a supply set. By default, the undefined power states are considered illegal states. The syntax for this command is

```
add_power_state supply_set_name state state_name
{-supply_expr {supply_net_function ==
{legal_state, [voltage_1, [voltage_2, [voltage_3]]]}}}
```

Use the `-state` option to specify the name of the power state of the supply set.

Use the `-supply_expr` option to specify the power state and the voltage value for the various supply net components of the supply set.

The expression specified with the `-supply_expr` option is used to determine the legal states of the supply nets of the supply set during the synthesis of your design. The following are the only allowed states that you can specify:

- FULL\_ON
- OFF

For each state of the supply net component you can specify up to three voltage values which are floating-point numbers. When the state is `FULL_ON`, you must specify at least one voltage value.

The voltage values that you specify with power state are interpreted by the tool as follows:

- When you specify a single voltage value, this value is considered the nominal voltage of the associated state.
- When you specify two voltage values, the first value is considered the minimum voltage and the second, the maximum voltage. The average of the two values is considered the nominal voltage of the power state.
- When you specify three voltage values, the first value is considered the minimum voltage, the second, the nominal voltage and the third, the maximum voltage of the power state.

**Note:**

The tool issues an error if the second value is less than the first and the third value is less than the second.

The `add_power_state` command supports `-logic_expr` option which is parsed but ignored by IC Compiler.

The UPF standard requires a simple name for the *supply\_set\_name* argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

The following example shows the usage of the `add_power_state` command to define the power states HVp and HVg power states for the components of the PD1\_primary\_supply\_set supply set:

```
icc_shell> add_power_state PD1_primary_supply_set -state HVp \
    -supply_expr {power == {FULL_ON, 1.08, 2.05, 3.0} }

icc_shell> add_power_state PD1_primary_supply_set -state HVg \
    -supply_expr {ground == {FULL_ON, 0.0}}
```

## Creating Power Domains Using Supply Sets

When you create a power domain, you can associate a supply set with the power domain by using the `-supply` option of the `create_power_domain` command. Specify the type of the supply set, also referred as the supply set handle, with the `-supply` option. You can use the `-supply` option multiple times to associate multiple supply set types with a power domain. The valid names of the supply set handles are `primary`, `default_retention`, `default_isolation`, and `extra_supplies_#`. For more details about using the `extra_supplies_#` keyword, see “[Restricting Supply Sets to a Power Domain](#)” on page 14-24.

The following example shows how you create a power domain and associate a supply set with the power domain:

```
# Create the supply sets
create_supply_set primary_supply_set
create_supply_set retention_supply_set
create_supply_set isolation_supply_set

# Create power domain and associate it with the supply set
create_power_domain PD1 -supply {primary primary_supply_set} \
    -supply {default_retention retention_supply_set} \
    -supply {default_isolation isolation_supply_set}
```

## Restricting Supply Sets to a Power Domain

To restrict specific supply sets to a power domain use the `extra_supplies_#` keyword (a number suffix) with the `-supply` option of the `create_power_domain` command. The `extra_supplies_#` keyword is written in the UPF file written out by IC Compiler. You can also specify `extra_supplies ""`, (without the #) with the `-supply` option. This causes the power domain not to use any extra supply nets other than those that are already defined in other strategies. IC Compiler issues error message if you use both `extra_supplies_#` and `extra_supplies ""` simultaneously.

By default, a power domain can use supply nets defined in the power domain or domain independent supply nets. When you define supply sets with `extra_supplies_#` keyword, the power domain is restricted to use only the following supplies:

- Primary supply of the power domain
- Default isolation supply of the power domain
- Default retention supply of the power domain
- Supplies specified in the isolation strategies of the power domain
- Supplies specified in the retention strategies of the power domain
- Domain dependent supplies defined or reused in the power domain

The following example shows how to use the `extra_supplies_#` keyword while creating the power domain.

```
icc_shell> create_power_domain SUB_DOMAIN \
           -supply {extra_supplies_1 supply_set1} \
           -supply {extra_supplies_2 supply_set2} mid1/PD_MID
```

## Updating a Supply Set

You can redefine the functions of a supply set by using the `-update` option. When you use the `-update` option, you must use the `-function` option to associate the function names with the supply nets or ports.

The following example shows how you use the `-update` option to associate supply nets to the functions of the supply set:

```
icc_shell> create_power_domain PD_TOP
icc_shell> create_supply_net TOP_VDD
icc_shell> create_supply_net TOP_VSS
icc_shell> create_supply_set supply_set \
           -function {power TOP_VDD} \
           -function {ground TOP_VSS} \
           -update
```

You must follow these rules when updating a supply set with a supply net:

- **Voltage rule**

The voltage of the supply set handle must match with the voltage of the supply net with which the supply set is updated.

If voltage is not specified for the supply net, then after the update, the voltage on the supply set handle are inferred as the voltage of the supply net.

- **Function rule**

The supply set function must match with the function of the supply net with which the supply set is updated.

IC Compiler issues an error message when

- The ground handle of a supply set is used to update power handle of another supply set and vice versa.

- The supply net updated with the ground handle of a supply set is connected to a power supply port or pin of a power object, such as a power domain, and vice versa.

- **Scope rule**

The scope of supply set must match with the scope of the explicit supply net with which the supply set is updated.

- **Availability rule**

The explicit supply net with which the supply set is updated, must be domain independent.

- **Connection rule**

The explicit supply net with which the supply set is updated, should not be connected to a driver port when the supply set handle is connected to a driver port unless a resolution function is defined for the explicit supply net.

- **Conflicting supply state names rule**

A supply set handle cannot be updated with an explicit supply net or a supply set if their power states causes a conflict.

- **Valid power state table rule**

A supply set can be updated only if the update does not create a user-defined power state table with different supplies in the same function.

---

## Creating Supply Set Handles

Supply set handles enable abstraction of the power supply network, because you do not need to define the actual supply nets until the physical implementation stage. You can create supply set handles when you create a power domain. To enable this capability, you must set the `upf_create_implicit_supply_sets` variable to `true` before you create the power domains. The default is `false`.

Note:

You must enable this capability before creating any power domains. After you create a power domain, you cannot change this variable setting.

When you enable this capability, IC Compiler automatically creates the following supply set handles when you create a power domain:

- `primary`
- `default_isolation`
- `default_retention`

In addition to these predefined supply set handles, you can use the `-supply` option with the `create_power_domain` command to create user-defined supply set handles when you create a power domain.

Supply set handles are created at the scope of the power domain and are available for use in power domains that are at the same or lower scope than the power domains where they are created. You refer to a supply set handle by using the following naming convention: `power_domain_name.supply_set_handle`. If a power domain is deleted, its supply set handles are also deleted.

---

## Assigning Supply Nets to Supply Set Handles

Before physical implementation, you must assign supply nets to the supply set handles. You can assign supply nets to a supply set handle either by explicitly specifying the supply nets used by the supply set handle or by associating the supply set handle with a supply set or another supply set handle. Use one of the following methods to assign supply nets to the supply set handles:

- Use the `create_supply_set -update` command to specify the supply nets used by the supply set handle.

For example, to assign the VDD power net and VSS ground net to the primary supply set handle for the PD1 power domain, use the following command:

```
icc_shell> create_supply_set PD1.primary -update \
           -function {power VDD} -function {ground VSS}
```

When you use this method, you must assign supply nets to the supply functions; you cannot assign supply set handles to the supply functions. The specified supply nets must be available in the power domain associated with the supply set handle. In addition, the supply net and the supply set handle must be defined in the same scope.

For more information about updating a supply set, see “[Updating a Supply Set](#)” on page 14-25.

- Use the `associate_supply_set` command to associate the supply set handle with a supply set or another supply set handle.

The `associate_supply_set` command has the following syntax:

```
associate_supply_set target_supply_set
    -handle supply_set_handle
```

The `target_supply_set` argument can be either a supply set that you previously created with the `create_supply_set` command or another supply set handle. The `supply_set_handle` argument must be a supply set handle that is defined at or below the scope of the target supply set. You can associate a supply set with multiple supply set handles; however, you cannot make circular associations.

For example, to use the same supply nets for the primary and `default_isolation` supply set handles for the PD1 power domain, use the following command:

```
icc_shell> associate_supply_set PD1.primary \
    -handle PD1.default_isolation
```

To define the SS1 supply set and associate it with the `primary` supply set handle for the PD1 power domain, use the following commands:

```
icc_shell> create_supply_set SS1 \
    -function {power VDD} -function {ground VSS}
icc_shell> associate_supply_set SS1\
    -handle PD1.primary
```

- Use the `create_power_domain -update -supply` command to specify the supply set associated with the supply set handle.

For example, to define the SS1 supply set and associate it with the primary supply set handle for the PD1 power domain, use the following commands:

```
icc_shell> create_supply_set SS1 \
    -function {power VDD} -function {ground VSS}
icc_shell> create_power_domain PD1 -update \
    -elements {a} \
    -supply {primary SS1}
```

When you use this method, you must assign a supply set to the supply set handle. Note that you can use the `-update` option only when you also use the `-supply` option.

For more information about the `-update` option, see “[Updating a Supply Set](#)” on [page 14-25](#).

- Use the `set_domain_supply_net` command to specify the supply nets used by the primary supply set handle.

For example, to associate the VDD power net and VSS ground net with the primary supply set handle for the PD1 power domain, use the following command:

```
icc_shell> set_domain_supply_net PD1 \
-primary_power_net VDD -primary_ground_net vss
```

Note:

You can associate a supply set handle with a supply set (or supply nets) only once. If you try to associate a supply set handle after an association has been defined, IC Compiler issues an error.

You must define the supply nets for all supply set handles before performing physical implementation. The `derive_pg_connection` command verifies that supply nets are defined for all supply set handles and issues an error if it finds unresolved supply set handles.

## Creating Power Switches

The `create_power_switch` command creates an instance of a power switch in the scope of the specified power domain. The power switch has at least one input supply port and one output supply port. When the switch is off, the output supply port is shut down and has no power. The syntax of the `create_power_switch` command is as follows:

```
create_power_switch
  -domain power_domain
  -output_supply_port {port_name supply_net_name}
  -input_supply_port {port_name supply_net_name}
  -control_port {port_name net_name}
  [-ack_port {port_name net_name [{boolean_function}]}]
  -on_state {state_name port_name {boolean_function}}
  [-ack_delay {port_name delay}]
  [-off_state {state_name {boolean_function}}]
  switch_name
```

The UPF standard requires a simple name for the `switch_name` argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

The following simple power switch definition can be used to create the power switch shown in [Figure 14-6 on page 14-19](#):

```
create_power_switch SW1 -domain PD_TOP \
    -output_supply_port {SWOUT VDD1g} \
    -input_supply_port {SWIN1 VDD1} \
    -control_port {CTRL swctl} \
    -on_state {ON VDD1 {!swctl}}
```

## Connecting Power Switches

You use the `connect_power_switch` command to connect the power-switch cells in the design. The switch cells within and across voltage areas can be connected by using this command. The command also supports disjoint voltage areas.

The `connect_power_switch` command supports various options to specify the style of interconnection of the switch cells, the control or acknowledge signals to connect, and so on.

The switch cells can be connected in the daisy-chain, high-fanout mode, or fishbone mode, based on your specification. This reduces the wire length of the switch cell connections.

In the ring-style power switch connection, when you specify the voltage area with the `connect_power_switch` command, the tool identifies the ring associated with the voltage area and all the switch cells of the ring. The control pin of the first switch cell is connected to the source pin or port. The acknowledge pin of the first cell is connected to the control pin of the second switch cell in the ring. This method of connection is continued for all the switch cells in the voltage area. The acknowledge pin of the last switch cell is connected to the acknowledge pin that you specified with the `-ack_out` option of the `connect_power_switch` command.

The `connect_power_switch` command has the following syntax:

```
connect_power_switch
    [-source driver_pin_or_port]
    [-ack_out driver_pin_or_port]
    [-port_name name]
    [-ack_port_name name]
    [-mode hfn | daisy | fishbone]
    [-direction horizontal | vertical]
    [-start_point lower_left | upper_left | lower_right | upper_right]
    [-verbose]
    [-auto]
    [-voltage_area list_of_voltage_area_name]
    [-object_list list_of_ordered_cells]
    [-lib_pin library_pin_names]
```

The `-source` option specifies the direction of the pin or port from where the switch cells should be connected. The direction of the pin or port cannot be inout.

The `-ack_out` option specifies the pin or port that should be used as the acknowledge-out signal. This option can be used only when the mode is `daisy` or `fishbone`.

The `-port_name` option specifies the base name to use for the new ports that are created to make the connection. This is a required option.

The `-ack_port_name` option specifies the base name to use when new ports are created for the acknowledge ports. This is a required option when the mode is either `daisy` or `fishbone` and you have used the `-ack_out` option.

The `-mode` option specifies the style of switch connections - either `daisy` chain, high fanout, or `fishbone`. This is a required option.

The `-direction` option specifies the direction of the switch-cell connections. This is a required option when the mode is either `daisy` or `fishbone`.

When the mode is `daisy`, the direction option is used to infer the daisy chain connection based on the instantiated switch cells.

When the mode is `fishbone`, the direction option is used to specify the direction of the connections for the branches connecting the main trunk of the fishbone.

The `-start_point` option specifies the starting point for the `daisy` and the `fishbone` connection. In the `fishbone` mode, this option specifies the starting point of the trunk of the `fishbone`.

This option is required when you use the `-direction` option and is useful in connecting the source pin to the nearest switch cell.

The `-auto` option specifies that the object list that you specify with the `-object_list` option should be sorted. When you do not specify this option, the order in which you specify the objects to the `-object_list` option is honored and used.

When you specify the `-auto` option, the `-direction` option is also required and it determines the sorting order.

The `-voltage_area` option specifies the voltage areas. You can specify either a collection of voltage area handles or voltage area names. The command connects all the switch cells in the specified voltage area. The switch cells are connected in the order in which the voltage areas are specified with this option.

The `-object_list` option specifies the list of cells that have to be connected. In the `daisy` mode, the connections are made in the order they are specified, when the `-auto` option is not specified. You cannot use the `-direction` option with the `-object_list` option.

The `-lib_pin` option specifies the list of library input and output pins to be used in the `daisy` and `hfn` modes.

Using the `create_power_switch_ring` command, you can create multithreshold-CMOS cells in a ring pattern around a voltage area or a macro. The ring can be either a full ring or part of a ring. This command creates a ring consisting of the switch cells and the optional filler cells and corner cells. You must specify the density, the offset, the list of filler cells, and the orientation of the cells to form a ring. This command supports the following types of areas around which the switch cells are created:

- Disjoint voltage area

A disjoint voltage area is a voltage area that consists of multiple nonintersecting rectilinear polygons.

When you specify disjoint voltage areas, the `create_power_switch_ring` command creates a ring that surrounds all the disjoint polygons. You can also create part of a ring by using the `-start_point` and `-end_point` options; the command then selects only one polygon to insert the power switches.

- Rectilinear polygon area

If you do not require the power switches to be inside a voltage area, you can create the power switch ring around any rectilinear polygon by specifying the polygon coordinates to the `-area_obj` option of the `create_power_switch_ring` command.

## Macro Cells with Fine-Grained Switches

A macro cell is considered a fine-grained switch cell when its definition in the library contains the following cell-level attribute setting:

```
switch_cell_type: fine_grain;
```

IC Compiler supports macro cells with fine-grained switches that have the following attribute settings in the PG pin definition in the target library:

- The `direction` attribute is `internal`.
- The `pg_type` attribute is either `internal_power` or `internal_ground`.
- The `switch_function` attribute is defined.
- The `pg_function` attribute is defined.
- The `switch_pin` attribute is `true` for the control port.

## Connecting Supply Net to the Internal PG Pins of the Fine-Grained Switch Cells

You can use the `connect_supply_net` command to connect the supply nets to the internal PG pins of the fine-grained switch cells. However, supply nets connected only to the internal PG pins of these cells cannot be used for level-shifter insertion and always-on synthesis, unless the supply nets belong to one of the following categories:

- Primary supply of the power domain
- Supplies specified in the isolation strategies of the power domain
- Supplies specified in the retention strategies of the power domain
- Domain-dependent supplies defined or reused in the power domain
- Supplies defined with the `extra_supplies_#` keyword

For more information about fine-grained switch cells, see *Library Compiler Modeling Timing, Signal Integrity, and Power in Technology Libraries User Guide*.

---

## Defining State Information for the Supply Ports

The `add_port_state` command adds state information to a supply port. This command specifies the name of the supply port and the possible states of the port. The first state specified is the default state of the supply port. The port name can be a hierarchical name. Each state is specified as a state name and the voltage level for that state. The voltage level can be specified as a single nominal value, a set of three values - minimum, nominal, and maximum, or the keyword `off` to indicate the “off” state. The state names are also used to define all possible operating states in the power state table. The syntax of the `add_port_state` command is as follows:

```
add_port_state
  -state {name nom | min nom max | off}
  supply_port_name
```

The supply port of a power switch is considered a supply port because it is connected by a supply net, so it can be specified as the supply port in the `add_port_state` command. Similarly, a RTL port can be made a supply port by this command or by the `connect_supply_net` command. Note that supply states specified at different supply ports are shared within a group of supply nets and supply ports directly connected together. However, this sharing does not happen across a power switch.

---

## Creating a Power State Table

A power state table (PST) defines the legal combination of states that can exist simultaneously during the operation of the design. A power state table is a set of power states of a design in which each power state is represented as an assignment of power states to individual power nets. A power state table for a design captures all the possible operational modes of the design in terms of power supply levels. Given a power state table, a power state relationship including voltage and relative always-on relations can be inferred between any two power nets. The power state table is used by the synthesis tool for analysis, synthesis, and optimization of the multivoltage design.

The `create_pst` command creates a new power state table and assigns a name to the table. The command lists the supply ports or supply nets in a particular order. The `add_port_state` defines the name of the possible states for each supply port.

You can also use supply sets to define the power stable table. When power states are defined for the supply sets, the states of the component supply nets can be determined without ambiguity. For more details about defining the states of the supply set, see “[Defining Power States for the Components of a Supply Set](#)” on page 14-23.

The `create_pst` command can only be used at the top-level scope. The power switch supply ports are considered supply ports because they are connected by supply nets, so they can be listed as supply nets in `create_pst` command.

A supply port and a supply net can have the same name, even when they are unconnected. If such a name is listed in the `create_pst` command, it is assumed to represent the supply port and not the supply net.

The UPF standard requires a simple name for the `table_name` argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

---

## Defining the States of the Supply Nets

The `add_pst_state` command defines the states of each of the supply nets for one possible state of the design. The syntax of the command is as follows:

```
add_pst_state -pst pst_name -state list state_name
```

The command must specify the name of the state, the name of the power state table previously created by the `create_pst` command, and the states of the supply ports in the same order as listed in the `create_pst` command.

The listed states must match the supply ports or nets listed in the `create_pst` command in the corresponding order. For a group of supply ports and supply nets directly connected together, the allowable supply states are derived from the shared pool of supply states commonly owned by the members of the group.

The UPF standard requires a simple name for the `state_name` argument. By default, IC Compiler does not enforce this requirement. To enforce this requirement, set the `mv_input_enforce_simple_names` variable to `true`.

The following example creates a power state table, defines the states of the supply ports, and lists the allowed power states for the design.

```
create_pst pt -supplies { PN1 PN2 SOC/OTC/PN3 }
add_port_state PN1 -state { s88 0.88 }
add_port_state PN2 -state { s88 0.88 } -state { s99 0.99 }
add_port_state SOC/OTC/PN3 -state { s88 0.88 } -state { pdown off }
add_pst_state s1 -pst pt -state { s88 s88 s88 }
add_pst_state s2 -pst pt -state { s88 s88 pdown }
add_pst_state s3 -pst pt -state { s88 s99 pdown }
```

## Connecting Power and Ground Nets

To connect the power and ground pins defined in your power domain to the appropriate power and ground supply ports of your design, use the `derive_pg_connection` command. By default, this command works only on the unconnected power and ground nets. Use the `-reconnect` option to force the command to work on the entire power network by reconnecting the already-connected power and ground pins as well as connecting the unconnected pins. Use this command before using any of the optimization commands. This command appropriately connects the power and ground pins defined in the design hierarchy based on the power and ground details defined in the power domains in the UPF file. This command can also perform the power and ground connections for the physical-only cells.

The automatic connection behavior for power pins is as follows:

- For a power pin with an exception connection defined, the power net specified in the exception is used.
- For cells with a single power pin that are used as always-on cells, the backup power net is used.
- For cells with a single power pin that are *not* used as always-on cells, the primary power net is used.
- For multithreshold-CMOS switch cells with multiple power pins, the power pins are connected to the power domain power nets of the same type – that is, primary power pin to primary power net, backup power pin to backup power net, and internal power pin to internal power net.

- In the shut-down power domains of a multithreshold-CMOS design, the primary power pins of the standard cells are connected to the internal power net of the shut-down domain. The primary power net of the shut-down power domain is connected only to the primary pin of the switch cell.
- For boundary cells with multiple power pins (level shifters and isolation cells), the power pins are connected to the power nets of the related power domains – that is, the load pin of the boundary cell is connected to the power net of the driver's power domain, and the drive pin of the boundary cell is connected to the power net of the load's power domain.
- For cells with multiple power pins that are neither boundary cells nor multithreshold-CMOS switch cells (for example, multirail always-on cells, retention registers, macro cells), the power pins are connected to the appropriate power nets – that is, the primary and backup power pins are connected to the primary and backup power nets, respectively.

Note:

The rules applicable for the automatic connection of ground pins are similar to those for the automatic connection of power pins.

To verify the power connections, use the `check_mv_design -power_nets` command.

For more information, see the man pages.

---

## Specifying the Operating Voltage

Use the `set_operating_conditions` command to set the operating conditions for the top level of your multivoltage design. To specify the operating voltage for the supply nets or internal supply ports, use the `set_voltage` command.

The `set_voltage` command has the following syntax:

```
set_voltage
  [-min min_voltage]
  -object_list object_list
  max_voltage
```

Use the `-min` option to specify the operating voltage for the minimum or best case.

Use the `-object_list` option to specify the list of supply nets or internal supply ports.

Use the `set_voltage` command to specify the maximum and minimum operating voltage for all the supply nets. All supply nets, including the ground net, must be assigned an operating voltage value. If any of the supply nets is not assigned voltages, IC Compiler issues an error message.

You can use the `set_voltage` command to set the operating voltage on the internal PG pins of the fine-grained switch cells. If you do not set the voltage on the internal PG pin of the fine-grained switch cells, the value of the `voltage_name` attribute of the PG pin is used as the operating voltage. For more details about the various attributes of the fine-grained switch cell, see “[Macro Cells with Fine-Grained Switches](#)” on page 14-32.

The operating voltage that you have already set cannot be removed. However, you can override the existing settings by using the `set_voltage` command again.

Use the `check_mv_design -power_nets` command before optimizing the design, to ensure that operating voltages are defined for all the supply nets. For more details, see “[Multivoltage-Specific Checks](#)” on page 14-82

---

## Defining and Using Voltage Areas

A voltage area is a placement area for one or more logical partitions operating at the same voltage. The cells of the logical partition are associated with the partition’s voltage area and are constrained to placement within that area.

Use the `create_voltage_area` command to create voltage areas and align the hierarchies, as described in the *IC Compiler Design Planning User Guide*.

In IC Compiler, you can define voltage areas at any level of a logic hierarchy. A voltage area can be a single rectangular or rectilinear shape or can consist of multiple disjoint rectilinear and rectangular shapes.

Physically nested voltage areas are supported, provided the inner voltage is completely contained within the outer voltage area. These nested voltage areas correspond to logically nested power domains. Voltage areas that would overlap physically have to be resolved into nonoverlapping, abutted rectangular or rectilinear subareas. How you construct voltage areas in this case is discussed in “[Handling Nested Voltage Areas](#)” on page 14-43.

Voltage areas can be explicitly associated with existing power domains, or they can be created without specifying any explicit association with the power domains. They can also be created when no power domains have been defined for the design.

The logic hierarchies are assigned to specific voltage areas when you create or update these voltage areas by specifying a cell list in the `create_voltage_area` command. You must ensure that the hierarchies are aligned correctly. The tool checks the operating condition voltage of each module against the voltage area specification to ensure that all modules inside the voltage area operate at the correct voltage.

For designs with power domains, cell alignment can be assured by specifying the name of the associated power domain when you run the `create_voltage_area` command. Use the `-power_domain` option to specify the name. In this case, you do not specify a voltage area name or the list of cells in the `create_voltage_area` command. (The cell list is provided in the power domain definition.)

Level shifters and isolation cells can have site heights that differ from the standard cell site height by either integer multiples (homogeneous sites) or noninteger multiples (heterogeneous sites). IC Compiler supports the placement of both types of sites.

Using heterogeneous sites for certain level shifters and isolation cells can help improve utilization. However, if the design has overlapping rows, set the `physopt_check_site_array_overlap` variable to `false` before running placement and legalization.

**Figure 14-7** shows a multivoltage design divided into several voltage areas.

*Figure 14-7 Multivoltage Design With Several Voltage Areas*



In this design, the floorplan has four voltage areas: Ra, Rb, Rc, and Rd. The default voltage area is Rd. Each voltage area has a corresponding logical partition, A, B, C, and D, that aligns with its respective voltage area. A hard bound can be defined inside a voltage area but not across voltage areas. In this example, a hard bound, BB, is defined inside voltage area Ra.

Special always-on site rows can be defined within a given voltage area. The standard cells placed in these site rows serve as the always-on cells of the shut-down power domain associated with the given voltage area.

Optionally, guard bands can be specified for some or all voltage areas to prevent shorts. Guard bands define hard keepout margins surrounding the voltage areas in which no cells, including level shifters and isolation cells, can be placed. Guard bands can be defined when creating voltage areas automatically or when updating the voltage areas.

[Figure 14-8](#) shows a floorplan similar to [Figure 14-7](#) but with guard bands protecting voltage areas Ra and Rc.

*Figure 14-8 Multivoltage Design With Several Voltage Areas and Guard Bands*



---

## Creating Voltage Areas

You create voltage areas by using the `create_voltage_area` command. With this command you specify the exact coordinates of the voltage area.

If the design contains power domains, you can use the `-power_domain` option with the corresponding power domain name in the `create_voltage_area` command. Then the power domain name is also the voltage area name. For this case, do not specify a cell list in the `create_voltage_area` command. The cells that were specified as belonging to the power domain are the cells that IC Compiler places in the given voltage area. Using the `-power_domain` option ensures correct alignment of the logic hierarchies with the voltage areas.

If the design does not contain power domains or you do not use the `-power_domain` option, you must then specify a voltage area name and provide the list of cells that are to be placed in the given voltage area. In this case, you are responsible for making sure that the hierarchies align correctly with their voltage areas.

For an example on how to use the `create_voltage_area` command without using the `-power_domain` option, see the script provided in [Example 14-2 on page 14-40](#). For an example that uses the `-power_domain` option, see the script provided in [Example 14-4 on page 14-71](#).

Note:

You can specify guard bands when creating voltage areas by using the `-guard_band_x` and `-guard_band_y` options with the `create_voltage_area` command. See “[Including Guard Bands With Voltage Areas](#)” on page 14-41.

The script in [Example 14-2](#) shows you how to create voltage areas manually without specifying power domains.

#### *Example 14-2 Manual Voltage Area Specification*

```
# Block1 is VoltageArea1 and Block2 is VoltageArea2 #
##
create_voltage_area -coordinate {...} -name VoltageArea1
update_voltage_area -voltage_area VoltageArea1 Block1
create_voltage_area -coordinate {...} -name VoltageArea2
update_voltage_area -voltage_area VoltageArea2 Block2
report_voltage_area -all
```

Using the `-polygons` option you can specify a list of polygons for the voltage area. The geometry of the voltage area can be either a rectangle or a rectilinear polygon. This option is used for automatic shaping of the voltage area. For more details, see the man page.

## Updating Voltage Areas in a Design

After you have created voltage areas and associated hierarchical cells with them, you can use the `update_voltage_area` command to add or remove cells from specified voltage areas. Using this command, you can also add additional regions to the voltage area. However, the new regions that you specify should not overlap the existing regions of the voltage area. You cannot remove a region from the voltage area, using this command.

The following are the limitations of the `update_voltage_area` command:

- Intersecting voltage areas are not supported.
- All voltage area geometries must be mutually exclusive.
- An error occurs when you use values with the `-coordinate` option that is too small for all the cells to fit.

You can use the `get_voltage_areas` command instead of explicitly specifying voltage area names. By adding or removing cells, you can adjust the utilization of the voltage area. However, you might prefer to change the size of the voltage areas and keep the utilization the same.

**Note:**

You can specify guard bands when updating voltage areas by using the `-guard_band_x` and `-guard_band_y` options with the `update_voltage_area` command. For more details, see “[Including Guard Bands With Voltage Areas](#).”

---

## Default Voltage Area

IC Compiler automatically derives a default voltage area after you create the first voltage area. Similarly, when you delete the last voltage area of the design, IC Compiler automatically removes the default voltage area. The default voltage area is used for the placement of cells that are not specifically assigned to any voltage area. The default voltage area can contain top-level leaf cells and buffer-type level shifters, as well as blocks.

You can prevent the insertion of new cells in the default voltage area by setting the `mv_no_cells_at_default_va` variable to `true`. The default for this variable is `false`. Setting the `mv_no_cells_at_default_va` variable to `true` eliminates the requirement for setting the `dont_touch` attribute on the affected top-level nets in the default voltage area. It also controls the placement of new buffers in the default voltage area. This variable is effective for designs with both abutted and nonabutted voltage areas at the top level.

**Note:**

The `mv_no_cells_at_default_va` variable is not honored during clock tree synthesis.

Using the `get_voltage_areas` command, you can get a collection of voltage areas in the design, including the default voltage area.

Using the `update_voltage_area` command, you can update the guard band information for the voltage areas, including the default voltage area.

Using the `report_voltage_area` command, IC Compiler reports all the voltage areas, including the default voltage area.

---

## Including Guard Bands With Voltage Areas

You can use guard bands to ensure that no shorts occur at the boundaries of the voltage areas. Guard bands define hard keepout margins surrounding the voltage areas. No cells, including level shifters and isolation cells, can be placed within the guard band margins.

For example, using guard bands is recommended when the rows are the same for all the voltage areas. The guard bands guarantee that the cells in different voltage areas are separated so that power planning does not introduce shorts.

You can include guard bands when you create or update voltage areas. You generate guard bands by using the `-guard_band_x` and `-guard_band_y` options with any of the following commands:

- `create_voltage_area`  
`[-guard_band_x x_width]`  
`[-guard_band_y y_width]`  
`[-name] voltage_area_name`
- `update_voltage_area`  
`[-guard_band_x x_width]`  
`[-guard_band_y y_width]`  
`[-voltage_area list_of_voltage_areas]`  
`cells_list`

[Figure 14-9](#) shows two voltage areas with guard bands of different widths. For both voltage areas, the x-width is 20 and the y-width is 10. Notice that the x-width defines the horizontal width of the vertical part of the guard band, and the y-width defines the vertical width of the horizontal part.

*Figure 14-9 Two Voltage Areas With Guard Bands*



In the IC Compiler GUI, voltage areas are outlined. Spaces or margins between voltage areas indicate the presence of guard bands.

When generating guard bands by using the `create_voltage_area` or `update_voltage_area` commands, you should be aware of the following conditions:

- If some coordinates of a voltage area are defined outside the core area, the command does not generate the voltage area and issues a warning and error message.
- If a voltage area intersects an existing voltage area, the command does not create the voltage area and issues an error message.
- If a guard band of a voltage area overlaps another voltage area, the command generates the guard band and issues a warning message.
- The x (y) guard band width applies to both the left and right (top and bottom) side of a voltage area.
- The IC Compiler GUI can highlight the guard bands.
- Overlapping guard bands are not allowed and generate warning messages.
- A guard band that lies outside the core area does not generate a warning message.

---

## Handling Nested Voltage Areas

Voltage areas can be physically nested corresponding to the nested relationship of the logic hierarchy of nested power domains. You still use the `create_voltage_area` command to define the individual voltage areas. A given voltage area can contain one or more nested voltage areas. Note that a voltage area must completely contain its nested voltage areas. Intersecting voltage areas are not supported.

In the case where logically nested hierarchies would lead to overlapping voltage areas, you can use the `create_voltage_area` command to resolve the overlapping areas by defining a number of voltage areas consisting of separate, *abutted* rectangles or rectilinear shapes. Each shape would share at least one boundary with another shape of the given voltage area.

[Figure 14-10](#) shows an example of areas intersecting and how you might resolve them into three physically abutted, separate voltage areas, VA1, VA2\_l, and VA2\_r. Voltage area VA1 is an eight-sided rectilinear area, and voltage areas VA2\_l and VA2\_r are four-sided rectangles.

*Figure 14-10 Example of Physically Resolved Voltage Areas*



## Voltage Area Support for Macros

Macro cells can be listed as belonging to power domains and can be physically located within the corresponding voltage areas. If a macro is not listed in a power domain, it can be explicitly listed in the `create_voltage_area` command.

**Note:**

Care must be taken to define whether a given macro cell is internally isolated or requires external isolation. Internally isolated macros should have the `connected_to_iso_cell` attribute set on the appropriate library pin; otherwise the tool assumes external isolation might be required and adds an isolation cell to the appropriate input net. Usually, if attribute marking is required, it is done as part of logic synthesis.

Because a macro cell is a physical cell, having height, width, and location, a voltage area is not created if the specified voltage area would not completely contain the macro cell. Instead, an error message is issued. Also, if a given macro cell already belongs to a voltage area, a new voltage area is not created if you run the `create_voltage_area` and list the macro cell. An error message is issued.

The `report_voltage_area` command reports all the top-level voltage area blocks, including macros. If a macro cell is within a hierarchical block that belongs to a voltage area, that macro is not part of the top-level blocks and is not reported.

## Defining Always-On Power Wells Within Voltage Areas

To create an always-on well within a voltage area, use the `create_bounds` command with the `-exclusive` option to define a special placement area or well for specific cells within a voltage area. You define the location and dimensions of an exclusive move bound as well as providing the list of cells to be placed within the exclusive move bound. The geometry of the exclusive bound must fit within the voltage area. No cells except the specified cells can be placed within the bound.

After the exclusive move bounds are defined, you use the `set_power_guide` command to identify these bounds as power guides. Use the `unset_power_guide` command to “remove” a move bound as a power guide. You can determine the already defined power guides by using the `report_power_guide` command.

You use the exception connection mechanism to connect these cells to the backup power net. The cells then function as always-on cells, so you can use single-power, standard cells.

---

## Removing Voltage Areas From the Design

Use the `remove_voltage_area` command to remove all voltage areas or specified voltage areas from the design. This includes removing any move bounds and guard bands belonging to the removed voltage area. If you remove a logically nested voltage area, the subhierarchy logic inherits the voltage properties of the parent hierarchy.

---

## Reporting on the Voltage Areas of a Design

You use the `report_voltage_area` command to obtain information about existing voltage areas. The report includes voltage area name, the list of hierarchical cells associated with the voltage area, the voltage area geometry, area, utilization, and guard band information if guard bands are present.

---

## Power Management Cells and UPF Strategies

This section discusses the requirements, properties and commands you can use to manage the power management cells in your design.

- [Library Requirements of Level-Shifter and Isolation Cells](#)
- [Managing the Level-Shifter Cells](#)
- [Managing Isolation and Enable-Type Level-Shifter Cells](#)
- [Connecting the Isolation and Level-Shifter Cells Back-to-Back](#)
- [Retention Registers](#)
- [Handling Always-On Logic](#)
- [Power Management Cells and the ASCII UPF Flow](#)

---

## Library Requirements of Level-Shifter and Isolation Cells

The following are the library requirements of a level-shifter and isolation cell:

- IC Compiler selects the level shifters and isolation cells from the target libraries. Therefore, at least one of the libraries must contain the required cells.
- The input and output pin voltages of the Isolation cell should be same.
- Input and output pin voltages are different for level shifters, although they can connect driver and load pins operating at the same voltage (property of buffers).
- Only buffer-type or enable-type level-shifter library cells are currently supported by IC Compiler. (Enable-type level shifters are like buffer-type level shifters except they have an additional enable pin.)
- Buffer-type and enable-type level-shifter library cells must have the library attribute `is_level_shifter` set to `true`.
- Enable-type level shifters must also have the `level_shifter_enable_pin` attribute on the enable pin.
- Isolation library cells must have the library attribute `is_isolation_cell` set to `true`.
- Isolation cells must have the `isolation_cell_enable_pin` attribute on the enable pin.
- You can define special sites (for multiheight cells) where IC Compiler places the level shifters and isolation cells when you run the `place_opt` command. Otherwise, the tool attempts to place the level shifters and isolation cells near the voltage area boundaries.

---

## Managing the Level-Shifter Cells

Level-shifter cells function as the interface between power domains that operate at different voltage levels. These cells ensure that the output transition of a driver can cause the receiving cell to switch even though the receiver is operating at a different voltage level.

IC Compiler uses the strategies defined in the UPF file, using the `set_level_shifter` command to insert the level-shifter cell. The details of inserting level shifters, specifying the threshold voltage, level-shifter strategies are described in the following sections:

- [Inserting the Buffer-Type Level Shifters](#)
- [Setting the Threshold Voltage for Level Shifters](#)
- [Defining the Level-Shifter Strategy](#)
- [Associating Specific Library Cells With the Level-Shifter Strategy](#)

- [Checking Level-Shifter Violations](#)
- [Placing Level Shifters](#)
- [Removing Level Shifters](#)

## Inserting the Buffer-Type Level Shifters

If buffer-type level shifters were not inserted automatically during logic synthesis or modifications are needed, you can use the `insert_mv_cells` command to insert these level shifters in the current design.

Note:

If the design is synthesized using Design Compiler, *automatic* level-shifter insertion is done as part of the `compile_ultra` command. In this case, you do not need to use the `insert_mv_cells` command unless level-shifter modifications are necessary.

Using the `insert_mv_cells` command, level shifters are inserted on nets where significant voltage differences occur between drive pins and load pins. The voltage differences are determined either automatically by the tool or according to voltage threshold conditions that you define by using the `set_level_shifter_threshold` command. For more details, see “[Setting the Threshold Voltage for Level Shifters](#)” on page 14-49.

Also, you can accept the default level-shifter strategy, which allows buffer-type level shifters that step up the voltage and those that step it down, or you can use the `set_level_shifter_strategy` command to control whether only step-up or step-down buffer-type level shifters are to be used. This command automatically assigns `dont_touch` attributes to the nets connecting ports and buffer-type level shifters.

Note:

Although you can manually insert buffer-type level shifters at a number of points in the multivoltage design flow, you should insert them early in the flow—preferably before logic synthesis—or let logic synthesis automatically insert them. The latest they should be inserted is before you run the `place_opt` command in IC Compiler.

By default, level shifters are not inserted on clock nets. Use the `-all_clock_nets` or `-clock_net list_of_clock_nets` option if you want level shifters inserted on clock nets.

To obtain information about all the level shifters available in the target libraries, use the `-verbose` option. The information reported includes library name and type, level-shifter cell name, operating conditions, input and output voltages, process ID, temperature, and tree type. Also, the number of inserted level shifters is reported.

IC Compiler follows these steps to insert buffer-type level shifters into the voltage-mismatched nets:

- Identifies nets in the design with voltage mismatches that meet the automatically determined or user-defined threshold
- Analyzes the target library for available buffer-type level shifters, given the specified level-shifter rule

Note:

IC Compiler accesses only the target library buffer-type level-shifter cells that are marked with the library attributes specified in the Synopsys Liberty library model.

- Instantiates the proper buffer-type level shifter, and sets a `size_only` attribute on the level shifters and a `dont_touch` attribute on the port-to-level-shifter nets
- Instantiates buffer-type level shifters in clock nets as needed but only if the `-all_clock_nets` or the `-clock_net` option is specified

The buffer-type level shifters are inserted between the blocks if the operating voltage is set on the instance and not on any of its ports. However, if an operating voltage different from the block operating voltage is set on a port of the block, the buffer-type level shifter for that port is inserted inside the block. This behavior is the same for both automatic insertion during compile and manual insertion through the `insert_mv_cells` command.

You annotate operating voltages on the instances or their hierarchical ports by using the `set_operating_conditions` command for blocks. To have a buffer-type level shifter inserted inside a block, use the `set_operating_conditions -object_list` command to provide a port list and operating voltage setting for these ports that is different from the block voltage.

[Figure 14-11](#) shows an example of buffer-type level-shifter insertion at both the top level for a block port that has the default block voltage and within a block for a port that is set at the top-level voltage.

**Figure 14-11 Buffer-Type Level-Shifter Insertion at the Top Level and Block Level**



**Note:**

Buffer-type level shifters are marked with the `size_only` attribute and therefore can be optimized as part of the physical synthesis phase (`place_opt` command).

## Setting the Threshold Voltage for Level Shifters

A level-shifter threshold strategy must be defined before buffer-type level shifters are inserted either manually or automatically). The following are the two methods of defining the threshold voltage on the level-shifter cells:

- The tool automatically determines the default threshold values while inserting the buffer-type level-shifter cells.
- User-specified threshold voltage for nets with voltage mismatches. Threshold conditions are defined by using the `set_level_shifter_threshold` command.

### Automatically Determined Threshold Voltage for Level Shifters

The tool can automatically determine level-shifter thresholds if the target library cells have the following attributes (usually described by equations involving the rail voltages, for example,  $VDD1+0.5$ ):

- $V_{ih}$  – lowest input voltage for logic 1
- $V_{il}$  – highest input voltage for logic 0
- $V_{imax}$  – maximum input voltage for logic 1
- $V_{imin}$  – minimum input voltage for logic 0
- $V_{oh}$  – lowest output voltage for logic 1
- $V_{ol}$  – highest output voltage for logic 0
- $V_{omax}$  – maximum output voltage for logic 1
- $V_{omin}$  – minimum output voltage for logic 0

These voltage parameters are used to determine output and input voltage bands (ranges) for both logic 1 and logic 0. For logic 1, the input voltage band is ( $V_{imax}-V_{ih}$ ) and the output voltage band is ( $V_{omax}-V_{oh}$ ). Similarly, for logic 0, the input voltage band is ( $V_{il}-V_{imin}$ ) and the output voltage band is ( $V_{ol}-V_{omin}$ ).

Therefore, for any pair of driver and load pins, if the output voltage band of the driver pin is completely overlapped by (contained within) the input voltage band of the load pin, no level shifter is required. This behavior holds for both logic 1 and logic 0.

Conversely, a sufficient voltage difference between the driver and load pins exists so that buffer-type level-shifter insertion is required if any of the following conditions hold:

- Driver pin  $V_{omax} >$  Load pin  $V_{imax}$
- Driver pin  $V_{omin} <$  Load pin  $V_{imin}$
- Driver pin  $V_{oh} <$  Load pin  $V_{ih}$
- Driver pin  $V_{ol} >$  Load pin  $V_{il}$

For any of these four conditions, the driver voltage band does not fall completely within the load voltage band, and buffer-type level shifters are needed.

## User Specified Threshold Voltage for Level Shifters

You can override the default threshold conditions by using the `set_level_shifter_threshold` command to specify the minimum voltage difference beyond which the voltage is to be adjusted by use of a buffer-type level shifter. Use the `-voltage` option to specify an absolute voltage difference between source and sink voltages, or use the `-percent` option to specify the percentage by which the source and sink voltages must differ.

You can specify both the options simultaneously. In this case, buffer-type level shifters are inserted when either threshold condition is met. For example, to specify both a 0.5 voltage threshold and a 5 percent threshold, enter

```
icc_shell> set_level_shifter_threshold -voltage 0.5 -percent 5
```

Note:

The percentage is computed as  $100 \times (\text{absolute value of the difference between the driver voltage and the load voltage}) / \text{driver voltage}$ .

## Defining the Level-Shifter Strategy

Use the `set_level_shifter_strategy` command to set the strategy to be used for adjusting voltage levels in the design. IC Compiler inserts level shifters on signals that have sources and sinks that operate at different voltages, following the specified strategy. If a level-shifter strategy is not specified for a particular power domain, the default level-shifter strategy applies to all elements in the power domain. The syntax of the `set_level_shifter` command is as follows:

```
set_level_shifter strategy_name
  [-domain domain_name]
  [-elements port_pin_list]
  [-applies_to inputs | outputs | both]
  [-threshold float]
  [-rule low_to_high | high_to_low | both]
  [-location self | parent | automatic]
  [-no_shift]
```

The `-elements` option specifies a list of ports and pins in the domain to which the strategy applies, overriding any `-threshold` or `-rule` settings.

The `-threshold` option defines how large the voltage difference must be between the driver and sink before level shifters are inserted, overriding any such specification in the cell library. The `-rule` option can be set to `low_to_high`, `high_to_low` or `both`. If `low_to_high` is specified, signals going from a lower voltage to a higher voltage get a level shifter when the voltage difference exceeds the `-threshold` value. Similarly if `high_to_low` is specified, signals going from higher voltage to lower voltage get a level shifter when the voltage difference exceeds the `-threshold` value. The default behavior is `both`, which means that a level-shifter cell is inserted in either situation.

The `-location` option specifies where the level-shifter cells are placed in the logic hierarchy:

- `self` - The level-shifter cell is placed inside the domain whose interface port is being shifted.
- `parent` - The level-shifter cell is placed in the parent of the domain whose interface port is being shifted.
- `automatic` - IC Compiler is free to choose the appropriate location. This is the default behavior.

The following strategies have decreasing order of precedence, irrespective of the order in which they are executed:

```
set_level_shifter -domain -elements  
set_level_shifter -domain -applies_to input_or_output  
set_level_shifter -domain (with optional -applies_to both)
```

It is an error to explicitly specify a strategy of the same precedence level on the same power domain or design elements as the previous strategy specification.

## Associating Specific Library Cells With the Level-Shifter Strategy

When you specify the level-shifter strategy for a power domain, by default the tool maps the level-shifter cells to any suitable level-shifter cells in the technology library. Use the `map_level_shifter_cell` command to associate a specific set of library cells to the specified level-shifter strategy. This command does not force the insertion of the level-shifter cells. Instead, when the tool inserts the level-shifter cell, it chooses the library cells that are specified with the `-lib_cells` option of the `map_level_shifter_cell` command. This command has no effect on instantiated level-shifter cells that have a `dont_touch` attribute set on them. For more details, see the man page.

## Checking Level-Shifter Violations

Use the `check_mv_design -level_shifters` or `analyze_mv_design -level_shifter` command to report net, cell, and environment violations and design details that can help in understanding the level shifters. You can run the command at any point in the flow. (These commands are preferred over the `check_level_shifters` command.)

## Placing Level Shifters

Level shifters (both types) can be placed at regular sites (single-height cells) or at special sites (multiheight cells) with multiple power rails. For regular sites, you are responsible for connecting secondary power to the level shifters.

If special sites are needed for level shifters, these sites must be instantiated in the floorplan at locations where these level shifters could be placed. Such sites should usually be defined along the voltage area boundaries. They can overlap with the base site array.

Level-shifter placement is performed when you run the `place_opt` command or when you issue the `create_placement` and `legalize_placement` commands. If the library attribute `is_level_shifter` is set to `true` for the level shifters, the tool attempts to place the level-shifter cells at legal sites nearest the voltage area boundaries. This same placement process holds for isolation cells that have their `is_isolation_cell` attribute set to `true`.

## Removing Level Shifters

Use the `remove_level_shifters` command to remove all level shifters in a design except those marked with the `dont_touch` attribute. Use this command to correct or redefine the use of level shifters in the design. For more details, see the man page.

---

## Managing Isolation and Enable-Type Level-Shifter Cells

In multivoltage designs, IC Compiler inserts isolation cells when signals leave a powered-down block and enter a block that is currently powered-up or is always-on. An isolation cell provides a known constant logic value to an always-on block when the power-down block has no power, thereby preventing unknown or intermediate values.

IC Compiler uses the strategies defined in the UPF file, with the `set_isolation` command to insert the isolation cells. The following sections provide details about inserting the isolation cells and specifying the isolation strategies:

- [Inserting Isolation Cells and Enable-Type Level Shifters](#)
- [Defining the Isolation Strategy](#)

## Inserting Isolation Cells and Enable-Type Level Shifters

Isolation cells and enable-type level shifters are used to selectively shut off the input side of the voltage interface of a voltage area. Isolation cells do not shift the voltage. In general enable-type level shifters are used to step the voltage up or down, but they can also be used as isolation cells. (During logic synthesis, the `compile_ultra` command can replace isolation cells with enable-type level shifters if the appropriate cells are available in the libraries.)

Isolation cells can be instantiated at the RTL level or you can insert them by using the `insert_mv_cells` command, at various points in the flow. The enable-type level shifters can be instantiated only at the RTL level or inserted by the tool to replace isolation cells that are already present. You should instantiate isolation cells and enable-type level shifter cells at the RTL level; otherwise, formal verification of the logic is likely to fail.

Set the `is_isolation_cell` and `isolation_cell_enable_pin` library attributes on the isolation cells and their enable pins. Similarly, set the `is_level_shifter` and the `level_shifter_enable_pin` library attributes on the enable-type level shifter cells and their enable pins. After these cells are instantiated in the netlist, mark them with the `size_only` attribute before logic optimization.

If you instantiate GTECH isolation cells, they can be mapped, retargeted, and sized during synthesis. GTECH isolation cells can be instantiated in the RTL netlist when you run HDL Compiler Verilog or VHDL.

Use the `check_isolation_cells` command to check for redundant isolation cells. For more details about various multivoltage-specific checks, see “[Multivoltage-Specific Checks](#)” on page 14-82.

## Defining the Isolation Strategy

Use the `set_isolation` command to define the isolation strategy for a power domain and the elements in the power domain on which the strategy is applied. The `set_isolation` command has the following syntax:

```
set_isolation isolation_strategy_name
  -domain power_domain
  [-isolation_power_net isolation_power_net]
  [-isolation_ground_net isolation_ground_net]
  [-isolation_supply_set isolation_supply_set]
  [-source source_supply_set_name]
  [-sink sink_supply_set_name]
  [-diff_supply_only boolean_string]
  [-clamp_value 0 | 1 | latch]
  [-applies_to inputs | outputs | both]
  [-elements objects]
  [-no_isolation]
```

Definition of an isolation strategy contains specification of the enable signal net, the clamp value, and the location (inputs, outputs, or both). At least one of the `-isolation_power_net` or `-isolation_ground_net` or `-isolation_supply_set` arguments must be specified unless `-no_isolation` option is used. If you specify only the `-isolation_power_net` argument, the primary ground net is used as the isolation ground supply. If you specify only the `-isolation_ground_net` argument, the primary supply net is used as the isolation power supply. If you use both arguments, the specified supply nets are used as the isolation power and ground nets. The isolation power and ground nets are automatically connected to the implicit isolation circuit.

The `-isolation_supply_set` option specifies that the power and ground functions of the same supply set should be used as the isolation power and isolation ground nets respectively. If the power and ground functions specified belong to different supply sets, IC Compiler issues an error message. The `-isolation_supply_set` option is mutually exclusive with the `-isolation_power_net` and `-isolation_ground_net` options.

The `-source` option filters the set of elements specified with the `set_isolation` command. This option filters the ports connected to a net that is driven by the supply set. This option is mutually exclusive with `-applies_to` option.

The `-sink` option filters the set of elements specified with the `set_isolation` command. This option filters the ports driving a net that fans out to the logic driven by the supply set. This option is mutually exclusive with the `-applies_to` option.

When both, the `-sink` and the `-source` options are specified, a port is included if it has the specified source and sink.

The `-diff_supply_only` option determines the isolation behavior between the driver and the receiver supply sets. When the same supply set connects the driver and the receiver of a port on the interface of the reference power domain, if the `-diff_supply_only` option is set to `true`, isolation cell is not added in the path from the driver to the receiver. The default for the `-diff_supply_only` option is `false`. So, by default, IC Compiler does not restrict the insertion of isolation cell in the path from the driver to receiver.

**Note:**

The `-sink`, `-source`, and `-diff_supply_only` options cannot be used simultaneously.

The `-no_isolation` option specifies that the elements in the `-elements` list should not be isolated.

The `-elements` option can be used to specify the elements to isolate in cases where there are multiple isolation strategies within a given power domain. The listed elements (input or output ports on the domain boundary) must be within the specified power domain. If the `-elements` option directly specifies a port by name (not implicitly, by specifying the port's instance or an ancestor of that instance), then the isolation strategy applies to that port

regardless of whether that port's mode matches the one specified by the `-applies_to` option. Without the `-elements` option, the isolation strategy applies to the whole power domain.

When you use the `-source`, `-sink`, and `-diff_supply_only` options to define the isolation strategy, you can specify a combination of ports and pins with the `-elements` option.

Ports of a power domain refer to the logical ports of the root cells of the power domain, or in case of a power domain containing the top-level design, logical ports of the design. Input ports of a power domain are the ports defined as inputs in the corresponding HDL module. Similarly, output ports of a power domain are the ports defined as outputs in the corresponding HDL module.

The `-clamp_value` option specifies the constant value in the isolation output: 0, 1, latch. The latch setting causes the value of the non-isolated port to be latched when the isolation signal becomes active.

**Note:**

IC Compiler does not support a value of z for the `-clamp_value` option. The only supported values are 0, 1, and latch.

The `-applies_to` option specifies the parts of the power domain that are isolated: inputs, outputs or both. The default is outputs.

Although the power state table can potentially reduce the number of isolation cells required, isolation synthesis is entirely based on directives set with the `set_isolation` and `set_isolation_control` commands.

IC Compiler requires that the isolation power and ground nets operate at the same voltage as the primary and ground nets of the power domain where the isolation cells are located.

### **Order of Precedence of Isolation Strategies**

The isolation strategies have the following decreasing order of precedence, irrespective of the order of execution:

1. Pin or port-level strategy matching the `-source` and `-sink` options
2. Pin or port-level strategy matching the `-source` and `-diff_supply_only` options or matching the `-sink` and `-diff_supply_only` options
3. Input pin or port-level strategy matching the `-source` option
4. Output pin or port level strategy matching the `-sink` option
5. Input pin or port-level strategy matching the `-sink` option
6. Output pin or port-level strategy matching the `-source` option

7. Pin or port-level strategy matching the `-diff_supply_only` option
8. Pins or ports specified with the `-elements` option, without specifying the `-source`, `-sink`, or `-diff_supply_only` option
9. Domain-level strategy matching the `-source` and `-sink` options
10. Domain-level strategy matching the `-source` and `-diff_supply_only` options on an input pin, or matching the `-sink` and `-diff_supply_only` options on an output pin
11. Domain-level strategy matching the `-source` option on an input pin, or matching the `-sink` option on an output pin
12. Domain-level strategy matching the `-source` and `-diff_supply_only` options on an output pin or matching the `-sink` and `-diff_supply_only` options on an input pin
13. Domain-level strategy matching the `-source` option on an output pin or matching the `-sink` option on an input pin.
14. Domain-level strategy specified with `-diff_supply_only` option and without the `-source` or `-sink` options.
15. Domain-level strategy specified without the `-source`, `-sink`, and `-diff_supply_only` options.

### **Setting Isolation Attributes on Ports**

You can use the `set_port_attributes` command with the `set_isolation` command to identify the isolation source and sink ports for the power domains. The `set_port_attributes` command has the following syntax:

```
set_port_attributes
[-ports port_list]
[-elements instance_names]
[-applies_to inputs | outputs | both]
[-attribute name value]
[-receiver_supply supply_set_reference]
[-driver_supply supply_set_reference]
```

**-ports**

Specifies a collection of ports that are set as the source or sink for the `set_isolation` command.

**-elements**

This option identifies a set of ports on the interface excluding the supply ports. If you specify a `.` (dot), the tool uses the current UPF scope. This is a required option when the `-applies_to` option is specified.

**-attribute**

Specifies the name and value of the attribute that is set on the ports. The *name* argument can be `iso_source`, `iso_sink`, `derived_iso_strategy`, or `related_supply_default_primary`. The *value* argument is a list of supply sets or supply-net pairs.

You can set the `iso_source` attribute only on the input ports. You can set the `iso_sink` attribute only on the output ports.

The value of the `related_supply_default_primary` attribute can only be `true`. If you specify `false`, IC Compiler issues the following error message:

```
Error: Invalid value FALSE for related_supply_default_primary attribute. Expected value is TRUE. (UPF-232)
```

For ports that do not have a `related_supply_default_primary` attribute, IC Compiler assumes the primary supply of the domain as the default supply.

You can see this attribute setting in the UPF file written by IC Compiler. This ensures that other tools in the flow use the same assumptions for the default supply of the ports.

**-receiver\_supply**

This option specifies the power supply for the receiving logic or the logic that fans out from the port. If the receiving logic is not within the logic design starting at the top level of the design, the tool assumes that the receiver supply is the supply for the receiving logic.

You can specify the `-receiver_supply` option only at the top-level ports of the design. The tool issues a warning message if you specify ports that are not at the top level of the design hierarchy, and the attribute is ignored.

**-driver\_supply**

This option specifies the power supply for the logic that drives the port. If the logic that drives the port is not within the logic that starts at the top level of the design, the tool assumes that the driver supply is the supply for the driver logic.

You can specify the `-driver_supply` option only on the top-level ports of the design. The tool issues a warning message if you specify ports that are not at the top level of the design hierarchy, and the attribute is ignored.

With the support of `-receiver_supply` and `-driver_supply` options, you can replace the `set_related_supply_net` command by the `set_port_attributes` command.

## Setting Isolation Attributes on Cells

You can use the `set_design_attributes` command with the `set_isolation` command to identify the isolation source and sink cells for the power domains. The `set_design_attributes` command has the following syntax:

```
set_design_attributes
  [-elements element_list]
  -attribute name value
```

`-elements`

Specifies a collection of cells or supply sets on which to set the attributes.

`-attribute`

Specifies the name and value of the attribute to be set on the cells specified with the `-elements` option. The `name` argument can be `external_supply_map`, `derived_external`, or `merge_domain`. The `value` argument is the reference name of a supply set or a supply-net pair. When the `-elements` option is not used, the attribute is set on the current top-level design.

The source or sink property of a net for isolation corresponds to all the connected net segments, including the nets that connect to the level shifters and isolation cells. The dangling isolation and level-shifter cells are also treated as sources or sinks.

## Setting the Isolation Control

Every isolation strategy defined by the `set_isolation` command must have a corresponding `set_isolation_control` command, unless the strategy is `-no_isolation`.

The `set_isolation_control` command enables the specification of the isolation control signal and sense separate from the `set_isolation` command. The command identifies an existing isolation strategy and specifies the isolation control signal for that strategy. The syntax of the `set_isolation_control` command is as follows:

```
set_isolation_control isolation_strategy_name
  -domain power_domain
  -isolation_signal isolation_signal
  [-isolation_sense 0 | 1]
  [-location self | parent | fanout]
```

The tool can identify isolation cells in the power domain across the design hierarchy and associate them with UPF strategies. To identify the isolation cells, the tool uses the location value you specify using the `-location` option of the `set_isolation_control` command. When the value you specify is `self`, the tool starts the search from the port on the boundary of the power domain and traverses inside the power domain until it encounters either a cell, a multiple fanout net, or the boundary of another power domain. When the location you specify is `parent`, the tool starts the search from the port on the boundary of the power domain and traverses outside the power domain until it encounters a cell, a multiple fanout net, or the boundary of another power domain. When the value you specify is `fanout`, the

isolation cells are inserted at all fanout locations of the port being isolated, and inside the power domain of respective loads. For more information about the rules that apply when you use the `-location fanout` option, see “[Rules to Follow When You Use the -location fanout Option](#)” on page 14-60.

If the cell encountered is an isolation cell that is not already associated with an isolation strategy, the tool associates the cell with an appropriate isolation strategy. This association is based on the values you specified with the `-clamp_value` option of the `set_isolation` command and the `-isolation_sense` option of the `set_isolation_control` command. If the cell encountered is not an isolation cell, the tool does not treat the port as an isolation port, and during the next optimization step, the tool inserts an isolation cell.

The `-isolation_sense` option specifies the logic state of the isolation control signal that places isolation cells in the isolation mode. The possible values for this option are 0 or 1. The default is 1. The isolation signal specified by the `-isolation_signal` option can be for a net or a pin or port, with the net having higher precedence. The isolation signal need not exist in the logical hierarchy where the isolation cells are to be inserted; the synthesis or implementation tool can perform port-punching as needed to make the connection. Port-punching means automatically creating a port to make a connection from one hierarchical level to the next. These punched ports are not considered for isolation or level-shifting, even though after the port creation, these ports reside within the coverage of an isolation or level-shifter strategy.

Existing ports are isolated and level-shifted according to the applicable isolation and level-shifter strategy, even if they reside on an always-on path, a logic path marked as always-on relative to the receiving end.

### Rules to Follow When You Use the -location fanout Option

If you use the `-location fanout` option with the `set_isolation_control` command, you must follow these rules:

- You cannot use the `-isolation_power_net` option with the `set_isolation` command. Note that when you use the `-location` option with the `parent` or `self` value, you must use the `-isolation_power_net` option with the `set_isolation` command.
- You must use the `-elements` option and one of `-source`, `-sink`, or `-diff_supply_only` options with the `set_isolation` command.

When you use these options with the `set_isolation` command,

- You must set the `derived_iso_strategy` attribute before setting these options.

To set the `derived_iso_strategy` attribute, use the `set_design_attributes` command. After setting the `derived_iso_strategy` attribute, if you do not specify these options, the tool issues an error.

Note that if you set the `derived_iso_strategy` attribute, the only value that you can specify with the `-location` option is `fanout`.

- You cannot use the `-no_isolation` option with the `set_isolation` command.
- You must specify `fanout` as the value for the `set_isolation_control -location` option.

### Associating Specific Library Cells With the Isolation Strategy

When you define an isolation strategy, by default the tool associates the isolation strategy with any suitable isolation cell in the technology library. Using the `map_isolation_cell` command you can associate a specified set of library cells with the isolation strategy. The `map_isolation_cell` command can also be used to associate normal cells used as isolation cells and enable-type level-shifter cells with the isolation strategy.

When designs contain instantiated isolation cells that are associated with an isolation strategy, the `map_isolation_cell` command remaps these library cells to the cells specified with the `-lib_cells` option of the command. If the instantiated isolation cells have the `dont_touch` attribute set on them, the command does not remap these cells. The command has no impact on the instantiated isolation cells that are not or cannot be associated with an isolation strategy. For more details, see the man page.

---

### Connecting the Isolation and Level-Shifter Cells Back-to-Back

You can connect various combinations of isolation and level-shifter cells back-to-back, inside the power domain boundary. In each connection, the always-on quality of the power at the source must be either the same as or greater than that of the destination. When an enable level-shifter cell is available in the library, the tool replaces the level-shifter and isolation cell combination with an enable level-shifter cell.

[Table 14-1](#) shows each of the combinations of the isolation and level-shifter locations supported by IC Compiler.

*Table 14-1 Combination of Isolation and Level-Shifter Cells Connected Back-to-Back*

| Target power domain | Isolation location | Level-shifter location | Isolation power | Replaced by an enable level-shifter cell? |
|---------------------|--------------------|------------------------|-----------------|-------------------------------------------|
| source              | self               | self                   | source          | no                                        |
| source              | self               | self                   | destination     | yes                                       |
| source              | parent             | parent                 | source          | no                                        |
| source              | parent             | parent                 | destination     | yes                                       |
| destination         | parent             | parent                 | source          | no                                        |
| destination         | parent             | parent                 | destination     | yes                                       |

## Retention Registers

In multivoltage designs, when a power domain is shut down and later powered up, the power domain must resume operation based on its last good state. Special cells called retention registers can store the state during the shutdown.

The following sections provide further information about retention registers:

- [Library Specification of Retention Register](#)
- [Defining the Retention Strategy](#)
- [Mapping the Retention Registers](#)

## Library Specification of Retention Register

A retention register has two control signals, save and restore, to save and restore the data as shown in [Figure 14-12 on page 14-63](#). Retention cells occupy more area than regular flip-flops. These cells continue to consume power when the power domain is powered down.

Library Compiler supports modeling of retention registers with only one control pin called the `save_restore` pin. The `save_restore` pin saves and restores the state of a cell. In general, when the cell is in save mode, it operates as a flip-flop or a latch. When the cell is in restore mode, the previously saved value is available on the Q pin of the cell. For more details, see the *Library Compiler Modeling Timing, Signal Integrity, and Power in Technology Libraries User Guide*.

*Figure 14-12 Two-Pin Retention Register*



## Defining the Retention Strategy

Use the `set_retention` command to specify the registers in the power-down domain that should be implemented as retention registers. The command also identifies the save and restore signals for the retention functionality.

```

set_retention retention_strategy_name
  -domain power_domain
  [-retention_power_net retention_power_net]
  [-retention_ground_net retention_ground_net]
  [-retention_supply_set retention_supply_set]
  [-no_retention]
  [-elements objects]
  [-save_condition save_condition]
  [-restore_condition restore_condition]
  [-retain_condition retain_condition]
  
```

The `-elements` option specifies the objects in the specified power domain to which the retention strategy applies. The objects can be hierarchical cells, leaf-level cells, RTL blocks, and nets. If a design element is specified, all registers within the design element acquire the specified retention strategy. If a process is specified, all registers inferred by the process acquire the specified retention strategy. If a register, signal, or variable is specified and that object is a sequential element, the implied register acquires the specified retention strategy. Any specified register, signal, or variable that does not infer a sequential element is not affected by this command.

The `-retention_power_net` and `-retention_ground_net` options specify the supply nets to be used as the retention power and ground nets. The retention power and ground nets are automatically connected to the implicit save and restore processes and shadow register. If you specify only the `-retention_power_net` option, the primary ground net is used as the retention ground supply. If you specify only the `-retention_ground_net` option, the primary supply net is used as the retention power supply.

The `-no_retention` option excludes specific registers from the retention behavior. When you use this option, the registers specified with the `-elements` option are excluded from the retention behavior. This option is useful when, among a large number of registers, a few have to be excluded from the retention behavior. If you use the `-no_retention` option but do not specify any registers in the `-elements` option, all registers in the power domain are excluded from the retention behavior.

The `-retention_supply_set` option specifies the supply set whose power and ground functions are associated with the retention power and retention ground nets respectively. This option is mutually exclusive with the `-retention_power_net` and `-retention_ground_net` options.

The following strategies have decreasing order of precedence, irrespective of the order in which they are executed:

```
set_retention -domain -elements
set_retention -domain
```

The power and ground nets of the retention registers can operate at voltage levels different from the primary and ground supply voltage levels of the power domain where the retention register is located.

The `-save_condition`, `-restore_condition`, and `-retain_condition` options are intended to capture the clock-dependent retention behavior during simulation. These options are parsed and ignored by IC Compiler. Also, the `save_upf` command does not write these options in the UPF file.

### **set\_retention\_control**

Every retention strategy defined by a `set_retention` command must have a corresponding `set_retention_control` command. The `set_retention_control` command allows the specification of the retention control signal and sense separately from the `set_retention` command. The command identifies an existing retention strategy and specifies the save and restore signals and senses for that strategy. The syntax of the `set_retention_control` command is as follows:

```
set_retention_control
  -domain domain_name
  -save_signal {save_signal high | low}
  -restore_signal {restore_signal high | low}
  [-assert_r_mutex {net_name high | low}]*
```

```

[-assert_s_mutex {net_name high | low}]*
[-assert_rs_mutex {net_name high | low}]*
retention_strategy_name

```

The `-save_signal` option specifies the existing net, port, or pin in the design used to save data into the bubble register before the power-down and the logic state of the signal, either `low` or `high`, that causes this action to be taken.

Similarly, the `-restore_signal` option specifies the existing net, port, or pin in the design used to restore data from the bubble register before power-up and the logic state of the signal, either `low` or `high`, that causes this action to be taken.

Each control signal can be either a net, pin, or a port, with nets having higher precedence. The retention signal need not exist in the logical hierarchy where the retention cells are to be inserted.

The `-assert_r_mutex`, `-assert_s_mutex`, and `-assert_rs_mutex` options are intended to capture the clock-dependent retention behavior during simulation. These options are parsed and ignored by IC Compiler. Also, the `save_upf` command does not write these options in the UPF file.

## Mapping the Retention Registers

The `map_retention_cell` command provides a mechanism for constraining the implementation choices for retention registers. The command requires the name of an existing retention strategy and power domain. The syntax of the `map_retention_cell` command is as follows:

```

map_retention_cell retention_strategy_name
  -domain power_domain
  [-lib_cells lib_cells]
  [-lib_cell_type lib_cell_type]
  [-elements objects]

```

The `-lib_cells` option specifies a list of target library cells to be used for retention mapping.

The `-lib_cell_type` option directs the tool to select a retention cell that has the specified cell type in the implementation model. Note that this option setting does not change the simulation semantics specified by the `set_retention` command. The `retention_cell` attribute on the library cells in the target library defines the retention styles of the library cells.

The `-elements` option lists the register elements within the power domain to which the mapping command is applied. The elements must be included in the set of elements listed in the related `set_retention` command. If you do not use the `-elements` option, the mapping is applied to all registers inferred from the retention strategy.

---

## Handling Always-On Logic

Multivoltage designs typically have power domains that are shut down and powered up during the operation of the chip while other power domains remain powered up. The control nets that connect cells in an always-on power domain to cells within the shut-down power domain must remain on during shut down. These paths are referred to as always-on paths.

The target library can have special cells that can be used on the always-on paths and such cells are called the always-on cells. These library cells have the cell-level Boolean attribute `always_on` set to `true`, in the target library. These cells have the primary and backup power pins and are also referred to as dual-rail always-on cells. If your target library does not support the `always_on` attribute, you can set the `always_on` attribute on the single-rail standard cells in the library, using the `set_attribute` command. IC Compiler uses these always-on cells during always-on optimization. It performs always-on synthesis only when the target library contains always-on buffers and always-on inverters.

You can specify the type of always-on cell to be used in a specific shutdown power domain, using the `-cell_type` option of the `set_always_on_strategy` command. When you specify the type as `single_power`, the tool uses single-power, standard cells whose placement area is confined to the site rows of the special always-on power wells within the voltage of the shutdown power domain. When you specify the cell type as `dual_power`, the tool uses special dual-rail always-on cells that can be placed anywhere inside the shutdown power domain.

The always-on paths terminate inside the shutdown power domain. For power management cells such as the isolation cells, enable-type level shifters, multithreshold-CMOS switch cells, retention registers, IC Compiler recognizes the control pins of such special cells as always-on pins.

The always-on pins can also be marked manually by using the `set_attribute` command. To identify the user-defined always-on paths, the tool traverses back from the always-on pins or anchors along the fanin logic cone and applies the always-on strategy. It then traverses backward until it finds the logic cells and nets connected to the always-on anchor pin within the power-down power domain. Use the `get_always_on_logic` command to get all the design objects on the always-on path.

You can use the `check_mv_design -connection_rules` command to get a report of violations in the always-on synthesis and pass-gate connections. For more details about checks and reporting commands see, “[Multivoltage Specific Queries, Checks, and Reports](#)” on page 14-81.

Note:

When you set the `always_on` attribute on library cells, those cells are used only on the always-on paths. When you set the `always_on` attribute on the pin of a cell instance, the pin is considered the starting point of the always-on tracing path.

## Marking Always-On Library Cells

IC Compiler can recognize the always-on library cells from the library level `always_on` attribute. You can also set the `always_on` attribute on the library cell. To apply single-power always-on strategy, having the `always_on` attribute on library cells is useful.

The following example shows how to set the `always_on` attribute on the library cells in the technology library:

```
library (library_name) {  
...  
cell (cell_name) {  
    always_on : true  
}
```

You can also set the `always_on` attribute on the library cells by using the `set_attribute` command, as shown in the following example:

```
icc_shell> set_attribute [get_lib_cells CORE/BUFF*] always_on true
```

## Marking Always-On Pins

To mark the pin of a cell that is not an isolation cell or an enable-type level shifter as always-on, you must follow these rules:

- Any input pin of a leaf cell instance can be marked always-on.
- A top-level output port can be marked always-on.
- Either the input or output pin of a hierarchical cell can be marked always-on.

In the following example, the `always_on` attribute is set to `true` on the input pin of the cell instance U1/U2/A.

```
icc_shell> set_attribute [get_pins U1/U2/A] always_on true
```

By default, the tool assumes that the enable pin of special cells such as isolation cells or level-shifter cells, is always-on. You do not have to explicitly mark these pins as always-on.

You use the `get_attribute` command to query the `always_on` attribute on the library cell pin.

You can mark the pins of the special cell by defining a `.lib` file with the appropriate attribute settings, which you should then compile using Library Compiler to obtain an output `.db` file, or by specifying the attributes in a script that you run in every session. For more details about marking cells and pins as always-on, see the advanced low-power modeling information in the *Library Compiler Modeling Timing, Signal Integrity, and Power in Technology Libraries User Guide*.

## Supply-Net-Aware Always-On Synthesis

In the UPF flow, IC Compiler performs automatic constraining, marking, and optimization of always-on nets including the feedthrough nets. The tool performs automatic always-on synthesis by default and does not require any additional settings.

IC Compiler uses the related supply net of the load or the driver as the supply net for the inserted always-on buffers or inverters. It ensures that no additional isolation or level-shifting violations are introduced by the automatic always-on synthesis.

To select the supply nets for the inserted buffers and inverters used in always-on synthesis, the tool applies the following rules, in the specified order:

1. For a load net, when the related supply net of the load is in the same power domain as the net, the related supply net of the load is used.
2. For a driver net, when the related supply net of the driver is in the same power domain as the net, the related supply net of the driver is used.
3. For feedthrough nets with multiple choices of nets, related supply net of the load has precedence over the related supply net of the driver.

The tool marks the selected nets based on the following rules:

- Marks the net as always-on, when the related supply net is in the same power domain as the net, and it is not the primary power net of the power domain.
- Marks the net as `dont_touch`, when the related supply net is not in the same power domain as the net.
- When the related supply net is in the same power domain as the net, and it is the primary power net of the power domain, the tool inserts a regular buffer or inverter. So, no specific marking is done on the net.

Note:

When the always-on cells in the power domain have more than one backup power, IC Compiler does not support single-rail always-on cells for automatic always-on synthesis.

## Marking Pass-Gate Library Pins

In the current implementation, the tool has the ability to prevent always-on cells from connecting to cells with pass-gate inputs. An always-on buffer should not drive a gate that has pass transistors at the inputs (pass-gate). Pass-gate input cells should be driven by a standard cell in a shut-down power domain. Therefore, if your library contains any of these cells, you must mark them as pass-gates in each session.

For example, to mark pin A of the multiplexer cell MUX1, run the following command:

```
icc_shell> set_attribute [get_lib_pins lib_name/MUX1/A] pass_gate true
```

Use the `get_attribute` command to query the `pass_gate` attribute on the library cell pin.

---

## Power Management Cells and the ASCII UPF Flow

In the ASCII UPF flow, when the design is synthesized using a third-party tool, IC Compiler supports commands to associate the existing power management cells with the UPF strategies and if required, to insert new power management cells in the design. The following sections discuss these capabilities in more detail:

- [Inserting Power Management Cells](#)
- [Associating of Power Management Cells With UPF Strategies](#)

### Inserting Power Management Cells

You can insert isolation, level-shifter, and retention cells in your design by using the `insert_mv_cells` command. This command uses the strategies defined in the UPF file to insert these cells. While inserting the new power management cells, the tool preserves the power management cells that already exist in the design. The `insert_mv_cells` command inserts the power management cells in the following order:

- Isolation cells
- Level-shifter cells
- Enable level-shifter cells

You can choose to insert only specific power management cells by using specific options of the `insert_mv_cells` command.

The following command options and command sequence results in the insertion of enable level-shifter cells:

- `insert_mv_cells -all`
- `insert_mv_cells -isolation -level_shifter`
- `insert_mv_cells -isolation`  
`insert_mv_cells -level_shifter`
- `insert_mv_cells -level_shifter`  
`insert_mv_cells -isolation`  
`insert_mv_cells -level_shifter`

## Associating of Power Management Cells With UPF Strategies

IC Compiler supports the `associate_mv_cells` command to associate the existing power management cells in the design with the strategies defined in the UPF file. This command also checks and reports the correlation between the power management cells and the UPF strategies. The command reports the following information about the level-shifter cells and level-shifter strategy:

- The number of level-shifter cells that are associated with each level-shifter strategy, including the default strategy.
- The number and names of the level-shifter cells that do not have any supply net connection.
- The number and names of level-shifter cells that violate the level-shifter strategy.
- All level-shifter cells and their associated strategy information are also reported when the `verbose` option is used.

In addition, the command can also report correlation issues for isolation cells, retention cells, and power switches.

## Example IC Compiler Script for the UPF Flow

The following is an example script for power intent specification using the UPF commands.

### *Example 14-3 Example UPF Script for Power Intent Specification*

```
# Use the load_upf command to load this file
```

```
set_scope
name_format -isolation_prefix "ISO_" -level_shift_prefix "LS_"
create_power_domain TOP
create_supply_port VDD -domain TOP
create_supply_port VDDI -domain TOP
create_supply_port VDDG -domain TOP
create_supply_port VDDM -domain TOP
create_supply_port VSS -domain TOP
add_port_state VDD -state {active_state 1.0}
add_port_state VDDI -state {high_state 1.0} \
    -state {low_state 0.8} -state {off_state off}
add_port_state VDDG -state {high_state 1.0} \
    -state {low_state 0.8} -state {off_state off}
add_port_state VDDM -state {active_state 1.0}
create_supply_net VDD -domain TOP
create_supply_net VDDI -domain TOP
create_supply_net VDDIS -domain TOP
create_supply_net VDDG -domain TOP
create_supply_net VDDM -domain TOP
create_supply_net VSS -domain TOP
```

```

set_domain_supply_net TOP -primary_power_net VDD -primary_ground_net VSS
create_power_switch my_sw -input_supply_port {vin VDDI} \
    -output_supply_port {vout VDDIS} -control_port {ctrl inst_on} \
    -on_state {state1 VDDG {inst_on}}
map_power_switch my_sw -domain TOP -lib_cells HDRDID2HVT
connect_supply_net VDDI -ports {VDDI inst_sw/vin }
connect_supply_net VDDIS -ports {inst_sw/vout InstDecode/VDDIS}
connect_supply_net VDD -ports {VDD GPRs/VDD MULT/VDD}
connect_supply_net VDDG -ports {VDDG GPRs/VDDG}
connect_supply_net VDDM -ports {VDDG Multiplier/VDDM}
connect_supply_net VSS \
    -ports {VSS InstDecode/VSS GPRs/VSS Multiplier/VSS}
create_pst chiptop_pst -supplies {VDD A/VDDMS B/VDDIS C/VDDGS}
add_pst_state s0 -pst myblock_pst -state {1.0 0.8 0.8 1.0}
add_pst_state s1 -pst myblock_pst -state {1.0 1.0 1.0 1.0}
add_pst_state s2 -pst myblock_pst -state {1.0 off 1.0 1.0}
add_pst_state s2 -pst myblock_pst -state {1.0 1.0 off off}

```

The following is an example of a IC Compiler script for the UPF flow.

**Example 14-4 Example IC Compiler Script for the UPF Flow**

```

# Invoke IC Compiler

## Open design .ddc file
read_ddc design.ddc
save_mw_cel -as floorplan
save_upf out.upf
link_physical_library
## derive pg connections
derive_pg_connection -create_nets -reconnect

## Floorplan steps
read_pin_pad_physical_constraints design_ios.tcl

## Initialize floorplan
create_voltage_area -power_domain PD1 -guard_band_x 1 -guard_band_y 1
check_mv_design -verbose

## Power plan and secondary power pin routing steps
create_rectangular_rings -nets {VDDGS VDDMS}
create_rectangular_rings -nets {VSS }
create_power_straps -direction vertical -start_at x \
    -nets {VSS VDD VDDI} -layer M6 -width 2
create_power_straps -direction horizontal -{VSS VDD VDDI ...} \
    -layer M5 -width 2
preroute_standard_cells -mode net -nets VDDG \
    -h_layer M5 -v_layer M6 \
    -h_width 0.38 -v_width 0.38

```

```
## Switch cell mapping and insertion
map_power_switch -domain top -lib_cells HDRSODHVT name_of_switch
create_power_switch_array -lib_cell "GSWITCH" \
    -bounding_box {110 200 250 400}

## Connect switch cells in daisy/hfn mode
connect_power_switch -source inst_on -port_name on -mode hfn -verbose

## Implementation steps
place_opt
clock_opt
route_opt

## Chip finishing
set_cell_vt_type -vt_type "VtType1"
set_vt_filler_rule
insert_stdcell_filler -cell_without_metal
check_mv_design

## Write results out
save_upf out2.upf
## The Power Ground Netlist is written
write_verilog -pg -output_net_name_for_tie out.v

## This is the non power ground netlist
write_verilog file_name.v
```

---

## Voltage-Area-Aware Capabilities

The `place_opt`, `clock_opt`, and `route_opt` commands are voltage-area-aware, which means that these commands can be used on multivoltage designs. Other important capabilities include

- [Automatic High-Fanout Synthesis](#)
- [Virtual Hierarchy Routing](#)
- [Maximum Net Length Optimization](#)
- [Voltage-Area-Based Optimization](#)
- [Voltage-Area-Based Clock Tree Synthesis and Optimization](#)
- [Voltage-Area-Based Global Routing](#)
- [Voltage Area Feedthrough Flow](#)
- [Voltage-Area-Aware Always-On Synthesis](#)
- [Voltage-Area-Based Power and Ground Net Associations](#)

- [Voltage-Area-Based Standard-Cell Filler Cell Insertion](#)
  - [Interface Logic Model Hierarchical Flow](#)
  - [Multivoltage Relative Placement Capability](#)
  - [Hierarchical Signal Integrity Flow](#)
- 

## Automatic High-Fanout Synthesis

This capability is part of the `place_opt` command. Buffer trees are built with dedicated subtrees for the fanouts in each voltage area. In particular, automatic high-fanout synthesis selects buffers according to the associated operating condition. Buffers are inserted and placed correctly.

---

## Virtual Hierarchy Routing

The virtual route estimator takes the presence of voltage areas into account. This estimator observes the following constraints:

- Virtual routes for nets connecting cells within a voltage area do not go outside the voltage area.
- Virtual routes for nets connecting cells outside a voltage area detour around the voltage area.
- Virtual routes for nets crossing a voltage area do not zigzag in and out of the voltage area: the number of boundary crossings is minimized.

Also, routing-driven synthesis, such as maximum net length optimization, uses voltage-area-aware routing.

---

## Maximum Net Length Optimization

The maximum net length optimization carried out by the `psynopt` command takes into account the presence of voltage areas, basically routing around them. Routes for nets connecting two cells within a voltage area stay inside the voltage area, and routes for nets crossing into a voltage area do not excessively zigzag in and out of the voltage area.

---

## Voltage-Area-Based Optimization

Cell placement and buffer optimization is one-pass voltage-area-aware. When the tool buffers a net that crosses voltage areas, the net is divided into multiple segments, each of which is confined within a single voltage area (including the default voltage area), and buffering is confined to the segments. The insertion of new buffers does not introduce additional zigzag paths that cross the voltage area boundaries.

For designs with multiple voltage areas, the tool ensures that a tie cell in one voltage area does not feed a cell in another voltage area. You should ensure that constant nets remain within their respective voltage area boundaries.

If the `direct_power_rail_tie` attribute has been set on a library pin, instances of this pin do not connect to constant signals by connecting to a tie-off cell. Instead, such pins are connected to generic constant signals so that during power routing these pins can be connected directly to power rails.

---

## Voltage-Area-Based Clock Tree Synthesis and Optimization

Clock tree synthesis and optimization are voltage-area-aware; they honor the following constraints:

- Sink pins are separated and clustered by voltage areas so that clock subtrees are built for each voltage area.
- A guide buffer is inserted for the set of sink pins for each voltage area to ensure that any subsequent levels of clustering do not mix pins from different voltage areas.

After the clock subtrees are built for each voltage area, clock tree synthesis can proceed in the usual manner, joining the subtrees at the root of the clock net. In addition to the synthesis of the initial clock tree, the constraints that are listed previously are also honored by several clock tree optimization techniques, such as buffer relocation, buffer sizing, gate relocation, and delay insertion.

---

## Voltage-Area-Based Global Routing

As with virtual hierarchy routing, global routing also takes the presence of voltage areas into account. The global router and the detail router observe the following constraints:

- Routes for nets connecting cells within a voltage area do not go outside the voltage area.
- Routes for nets connecting cells outside a voltage area detour around the voltage areas.
- Routes for nets crossing a voltage area boundary do not zigzag in and out of the voltage area. The number of boundary crossings is minimized.

For more details, see “[Setting Multivoltage Options](#)” on page 8-53.

## Voltage Area Feedthrough Flow

The voltage area feedthrough flow supports both the classic router and Zroute. The flow also supports disjoint voltage areas. To create feedthrough nets for disjoint voltage areas, the following criteria must be met:

- The load and the drivers present in the two disjoint voltage areas must belong to different hierarchical modules.
- For a net within one disjoint voltage area, all the cells of the net must belong to the same hierarchical module.

Note:

Feedthrough ports are not generated for internal nets whose driver or driver-region cells and load or load-region cells belong to the same hierarchical module; however, the load and the driver are placed in two disjoint voltage areas.

## Voltage-Area-Aware Always-On Synthesis

For long nets that span disjoint voltage areas, IC Compiler supports the insertion of always-on buffers across the disjoint voltage areas. The driver and the load of the net can belong to the same logical hierarchy or to different hierarchies but they should belong to the same power domain.

Consider the long net shown in [Figure 14-13](#). In the logical view, the net and the buffer are in the same hierarchy Mid, which is an always-on domain. However, in the physical view, the voltage area associated with this power domain is in two disjoint voltage areas.

*Figure 14-13 Always-On Buffer Insertion in Disjoint Voltage Areas*



If the primary supply defined in the power domain for the subdesign Mid is available in the power domain for Top, IC Compiler inserts an always-on buffer in the subdesign Mid that physically belongs to the Top design. IC Compiler supports insertion of both, single-rail and dual rail always-on buffers.

IC Compiler follows these steps to support always-on synthesis across disjoint voltage areas:

1. Creates a dummy logical hierarchy inside the existing hierarchy Mid as shown in [Figure 14-14](#).
2. Creates two hierarchical ports, P1 and P2, on the dummy hierarchy and connects the buffer inside the dummy hierarchy to these ports.
3. Associates the dummy hierarchy with the existing voltage area, VA1, to which the buffer belongs.

*Figure 14-14 Creating Dummy Hierarchy to Support Always-On Buffer Insertion in Disjoint Voltage Areas*



## Controlling the Dummy Hierarchy

The creation of the dummy logical hierarchy and port punching on the dummy hierarchy allow the tool to perform always-on synthesis and legalization. You can associate the dummy hierarchy with the default voltage area if the buffer belongs to the default voltage area.

## Controlling the Location

You can control the location of the dummy hierarchy by setting the `skip_vao_hierarchy` attribute. Dummy hierarchies are not created in the hierarchical cells that have the `skip_vao_hierarchy` attribute. For example, to skip the creation of dummy hierarchy in the hierarchical cell A, you set the `skip_vao_hierarchy` attribute as shown in the following example:

```
icc_shell> set_attribute [get_cells A] skip_vao_hierarchy true
```

The `skip_vao_hierarchy` attribute is persistent in the IC Compiler session where it is created and the attribute is saved in the Milkyway database.

## Controlling the Name

You can specify a prefix to distinguish the tool-created dummy hierarchies from the other hierarchies in the design. The new dummy hierarchies created by the `psynopt` and `place_opt` commands to fix DRC violations start with the specified prefix.

Use the `vao_feedthrough_module_name_prefix` variable to specify the prefix. The following example sets the `vao_feedthrough_module_name_prefix` variable to `SNPS_`. With this variable setting, the names of all the newly created dummy hierarchies start with `SNPS_`.

```
icc_shell> set_app_var vao_feedthrough_module_name_prefix SNPS_
```

---

## Voltage-Area-Based Power and Ground Net Associations

You can assign specific power and ground tie-off nets to voltage areas by using the `set_power_net_to_voltage_area` command. This command allows you to link and unlink these nets to the specified voltage areas. Using the `-report` option, you can determine the power and ground nets currently associated with a voltage area. In addition, the CEL consistency checker automatically checks the multivoltage (voltage area) tie-off cells against the assigned settings.

---

## Voltage-Area-Based Standard-Cell Filler Cell Insertion

The `insert_stdcell_filler` command is voltage-area-aware. By specifying the `-voltage_area` option, you can specify the particular voltage areas in which to insert filler cells in the empty standard cell row sites.

---

## Interface Logic Model Hierarchical Flow

Interface logic models (ILMs) and transparent interface models are supported in multivoltage design optimization flows. These models are used to model the interface logic of the *mapped* lower-level blocks of a hierarchical design. In general, the noninterface logic is excluded from the model, although you can specify options that allow certain noninterface nets and cells to be included. For more information about hierarchical models, see [Chapter 12, “Using Hierarchical Models.”](#)

The following relationships between voltage areas and ILMs are supported:

- A voltage area of the top-level design can contain ILMs. The combined physical area of the ILMs must be less than or equal to the area of the voltage area.
- An ILM at the top level can contain voltage areas.

In both cases, the operating conditions applied to the block (`set_operating_conditions` command) before you create the ILM for the block (`create_ilm` command) are not visible at the top level. At the top level, use the `propagate_constraints` command with the `-operating_conditions` option to propagate the operating conditions placed on the ILM design, cells, and ports, and on the hierarchical pins inside the ILM.

Note that propagation of voltage areas inside an ILM is not supported. Therefore, you must propagate the operating conditions of the hierarchical cells within the voltage area by using the `propagate_constraints` command, or you must reapply the operating conditions from the top level.

The region utilization calculation skips the placeable area or cell area occupied by any ILM contained in the region. That is, only the cell area occupied by the top-level cells and the actual placeable area (region area minus the area occupied by the ILMs) are used in the calculation. If the entire region is occupied by ILMs, the placeable area for the top-level cells is zero, and region utilization is reported as zero.

Level shifters are kept only if they are an actual part of the interface logic. Those level shifters past the first registers of a block are not retained. For level shifters that become part of the ILM, the leaf cells connected to the input and output nets of the level shifter are also retained, as well as the nets. You can use the `check_level_shifters` command to determine whether any output nets of the level shifters are floating.

---

## Multivoltage Relative Placement Capability

You can use the relative placement capability with multivoltage designs.

First, you group selected cells of a voltage area into a relative placement grouping. You can then place them as a single structure within the voltage area. The flow is identical to a typical relative placement flow, and the entire relative placement feature set is available.

However, you should be aware of these limitations:

- A relative placement group should not span voltage areas. If it is necessary to span voltage areas, break the relative placement group into multiple relative placement groups, each contained within its voltage area.
- In situations where a relative placement group is placed very close to a voltage area boundary, legalization might place part of the relative placement outside the multivoltage area. When this happens, the relative placement group is broken in a way that respects the voltage area constraint.

Relative placement is most often applied to physical datapaths. It provides a way for you to create structures in which you specify the relative column and row positions of instances with respect to each other. During placement and legalization, these structures are preserved, and the cells in each structure are placed as a single entity.

---

## Hierarchical Signal Integrity Flow

The hierarchical signal integrity flow can handle multivoltage designs, that is, designs with voltage areas. You do not have to run any special commands or set any variables to enable this capability. As with all signal integrity flows, you enable signal integrity functionality by running the `set_si_options` command with the appropriate options.

---

## Placing and Optimizing the Design

The `place_opt` command, while placing and optimizing the locations of the cells of the design, honors the power supply intent specified in the UPF file. The tool places level shifters and isolation cells near the boundaries of defined voltage areas. No buffering is done between the placed level shifter and the edge of the voltage area.

To perform always-on synthesis, the tool first identifies the always-on paths connecting the drive pins in the always-on power domains to the always-on load pins in the shut-down power domains. Always-on paths can be determined only if the tool finds always-on pins in the shut-down power domains. The enable pins of the special dual-power cells and the input pins of the single-powered, standard cells placed in always-on power wells are recognized as always-on pins. You can manually mark other pins as always-on if needed.

After the tool has established the always-on paths, it carries out optimizations appropriate to these paths, such as sizing and buffering. The tool uses ordinary cells for the portion of the paths outside the shut-down power domain. Inside the shut-down power domains, the tool optimizes, using the cells that you have specially marked as always-on.

The tool uses the following rules during optimization:

- Always-on logic is mapped only with always-on cells.
- Always-on cells are used in the shut-down power domains and on the always-on nets derived by IC Compiler during supply-net-aware always-on synthesis.
- Any gate with input pass gate pins that is driven by an always-on cell is swapped with a functionally equivalent cell that does not have pass gate pins at the inputs.

Note:

After completing always-on synthesis, you can determine the always-on logic by using the `get_always_on_logic` command. This command shows you the nets and cells on the always-on paths of the design.

---

## Handling Isolation Cells and Always-On Clock Paths During Clock Tree Synthesis

When performing clock tree synthesis, both the `compile_clock_tree` and `optimize_clock_tree` commands honor the isolation cells in the clock path and perform synthesis on the always-on clock paths.

To ensure correct isolation between shutdown and power-up power domains, clock tree synthesis does not insert buffers between the isolation cells and the power domain boundary.

The tool uses the following approach on the always-on clock paths during clock tree synthesis:

- Dual-power always-on cells are inserted in the shutdown power domain.
- All the buffers inserted on the always-on paths are dual-power always-on cells, and these cells are in the powered-down power domain.
- The always-on cells are always inserted in the correct power domain, that is, the always-on region.
- Redundant dual-power always-on cells are not inserted in the powered-down region or power domain.

Alternatively, you create always-on islands in the shutdown power domain and the tool during clock tree synthesis, inserts buffers in these always-on islands. This ensures that the always-on paths are not disturbed during clock tree synthesis.

**Note:**

To avoid long runtimes, before performing clock tree synthesis, you should manually insert buffers at the top level if your clock path at the top level traverses from the output of one module to the input of another module.

You should use the `check_mv_design` command before and after the clock tree synthesis process.

The following example shows the usage of the `check_mv_design` command before and after the clock tree synthesis process:

```
open_mw_lib library
open_mw_cel cel
remove_clock -all
create_clock -name clk -period 10 -waveform {0.0 2.0 4.0 6.0}
set_clock_tree_options -clock_trees [get_ports clk] \
    -max_transition 0.5 -target_skew 0.1
check_mv_design
compile_clock_tree -clock_trees clock_name
check_mv_design
save_mw_cel -as post_cts
```

## Multivoltage Specific Queries, Checks, and Reports

IC Compiler supports commands to query, check, and report multivoltage specific details such as,

- Query and report multivoltage specific `dont_touch` attributes.
- Find or query objects such as nets and ports using the UPF query commands such as `find_objects`, `query_cell_instances`, `query_cell_mapped`, `query_net_ports`, `query_port_net`.
- Check and report target library subsetting inconsistencies.
- Check and report the power management cells, strategies, and their consistency.
- Report the operating conditions and process (P), voltage (V), and temperature (T) values on different blocks.
- Report the power supply nets and ports and their connections across various blocks.
- Report the power switches and the power states in the design.

---

## Multivoltage Specific dont\_touch Attributes - Query and Report

IC Compiler supports the following commands to query and report multivoltage specific dont\_touch attributes:

- `get_dont_touch_nets`

The `get_dont_touch_nets` command creates a collection of nets, with `dont_touch` attributes, that meet the specified multivoltage specific reason or criteria. The `-type` option is required and you must specify the `mv` argument with the `-type` option. When you use the `-hierarchical` option, the command searches for nets hierarchically.

- `report_dont_touch_net`

The `report_dont_touch_net` command reports the reason for the `dont_touch` attribute on the nets of the current instance of the design or current design. The `-type` is a required argument and you can only specify `mv` with the `-type` argument. The command reports nets that have `dont_touch` attributes because of multivoltage reasons.

- `report_net`

The `report_net` command prints `mvd` in the attributes column, for nets that have `dont_touch` attribute because of multivoltage reasons.

For more details, see the man pages.

---

## Multivoltage-Specific Checks

The following commands perform multivoltage-specific checks. You can use them at various stages of your multivoltage design implementation.

- `check_mv_design`

Use this command to check for various types of violations such as inconsistent and conflicting library settings, missing isolation cells, incorrect voltage shifting across power domains. Use the `-verbose` option to get details of the violations and inconsistencies.

- `analyze_mv_design`

Use this command to analyze and report multivoltage design issues. This command reports the design details that can help you understand the level-shifter and always-on violations. The command also reports design setup details, library information, and details of UPF constraints.

- `check_level_shifters`

Use this command to check if the level shifters in the design violate the specified level-shifter strategy. Use the `-verbose` option to get a detailed report of the violations.

- `check_isolation_cells`

Use this command to get a list of isolation cells in the design. However this command also reports the possible requirement of an isolation cell as well as redundant isolation cells, if any, in the design.

---

## Multivoltage-Specific Reports

This section describes a list of multivoltage-specific reporting commands that provide details of the operating conditions, inconsistencies if any, statistics of the various blocks in your design, and so on.

- `report_power_domain`

You use this command to get specific details such as the scope and the operating condition of a power domain.

- `report_voltage_area`

You use this command to get a list of voltage areas in your design. You can also get the operating condition and the pin connection details of the voltage areas. If your design contains disjoint voltage areas, this command also reports the components of a disjoint voltage area.

- `report_level_shifter`

You use this command to report all the level-shifter cells in the design. Use the `-verbose` option to get details of the level-shifter strategy of the level-shifter cells.

- `report_isolation_cell`

You use this command to get details of the isolation cells in your design. Use the `-verbose` option to get details of the isolation strategy.

- `report_retention_cell`

You use this command to get the details of the retention cells in the design. Use the `-verbose` option to get details of the retention strategy.

- `report_supply_port`

This command reports the details of all or the specified power supply ports in the design.

- `report_supply_net`

This command reports the details of power supply nets in the design. If you use the `-include_exception` option, you get the details of the exception pins on the power supply net.

- `report_power_pin_info`

This command reports the power pin information for the instantiated cells and not the library cells, in the design. This command can also be used to get details of exception supply connections.

- `report_power_switch`

This command reports all the power switches in the design. Use the `-verbose` option to get details of the power switches.

- `report_pst`

This command reports the power states in the current design.

The following commands can also be useful in reporting multivoltage specific details.

- `report_timing`

You can use the `-voltage` option to report the operating voltage specified in the operating condition, for each path element.

- `report_operating_conditions`

This command reports all or the specified operating conditions in the specified target library.

- `report_target_library_subset`

This command reports the target library subsets set on the design.

- `report_pg_net`

This command reports the power and ground net information for the opened Milkyway design.

## Hierarchical UPF Flow

IC Compiler supports the complete hierarchical methodology for the UPF flow. You can use the synthesized netlist obtained from the Design Compiler hierarchical UPF methodology and continue the hierarchical flow using IC Compiler. [Figure 14-15](#) shows the IC Compiler hierarchical UPF flow.

*Figure 14-15 IC Compiler Hierarchical UPF Flow*



The following sections describe the hierarchical UPF flow in IC Compiler:

- [Design Compiler to IC Compiler Interface](#)
- [Guidelines for the Hierarchical UPF Flow](#)
- [Full-Chip Design Planning](#)
- [Block-Level Place and Route](#)
- [Top-Level Place and Route](#)

Each of these steps is described in detail in the sections that follow.

---

## Design Compiler to IC Compiler Interface

Both Design Compiler and IC Compiler support the hierarchical UPF flow. After synthesizing your design using the hierarchical UPF flow supported in Design Compiler, you can choose from the following two interface formats to continue the flow in IC Compiler:

- A binary design database in .ddc format
- An ASCII design database in the Verilog format along with constraint files such as SDC and UPF.

The binary design database is recommended because it contains all information including the constraints that are to be transferred from Design Compiler to IC Compiler.

---

## Guidelines for the Hierarchical UPF Flow

To use the hierarchical flow in IC Compiler, follow the guidelines for methodology, interface, and implementation. These are described in the following sections:

- [Methodology Guidelines](#)
- [Interface Guidelines](#)
- [Implementation Guidelines](#)
- [Known Limitations](#)

## Methodology Guidelines

Follow these set of guidelines, which are common to both Design Compiler and IC Compiler, to implement your design in IC Compiler.

- Align the physical partitions with the power domain boundaries as defined in the logical netlist.
- Create all the necessary power supply nets for the power domain inside the power domain. These supply nets should also be connected from the top level.
- Specify the voltage information for each supply net.
- Specify the timing constraints.

## Interface Guidelines

The first step to hierarchical design is determining the physical partitioning. Follow these interface guidelines while partitioning your design:

- The scopes of all the power domains inside a partition must be contained inside the partition.
- For all supply connections inside a partition, the supply nets must be specified within the partition.

## Implementation Guidelines

You should follow these guidelines to implement your design using the hierarchical UPF flow:

- UPF characterization

To categorize the UPF information in the subblocks, you must run the `allocate_fp_budgets` command before running the `commit_fp_plan_groups` command.

When you run the `allocate_fp_budgets` command, IC Compiler sets the related supply net on the ports of the partition, based on the following criteria:

- The direction of the port.
- The location constraint of the isolation and level-shifter strategies.
- The type of the pin: load or driver.

While setting the related supply net, IC Compiler performs checks for voltage violations, availability of supply nets, unspecified level-shifter strategies, and conflicts between isolation and level-shifter strategies.

When the subblock contains supply ports without PG pins, the `allocate_fp_budgets` and the `commit_fp_plan_groups` commands add dummy supply ports.

- Automatic propagation of the UPF from hierarchical model (ILM or block abstraction) to the top level.

All the UPF constraints from the top level are applied only to the block. These constraints cannot be applied to the hierarchical model. However, the constraints are automatically propagated from the hierarchical model. So, do not reapply the UPF constraints or re-create the voltage area for the hierarchical model.

The `allocate_fp_budgets` command supports the following flexible block partitioning useful for the hierarchical flow.

- Partitioning of blocks that have power domains defined with `parent` as the scope. If you have two or more power domains defined on the same block,
  - The primary supply nets of the power domains must be electrically identical.
  - You can define a switch at the interface of the power domains only if a similar switch is present in the power domain of the top-level design.

### **Power Domain Merging**

While merging the power domains to the top level, the supply sets, nets, and ports of the power domain must be equivalent with the top level power domain. In addition, the connectivity of the power domain should be equivalent at the top level. If the power domains are not equivalent, IC Compiler issues an error and does not merge the power domains.

During integration, the block-level ports that have the `smps_derived` UPF attribute are substituted by their equivalent top-level ports and supply nets or supply sets. The block-level supply net or supply sets are deleted.

When the port is not marked with the `smps_derived` UPF attribute, the ports are not deleted.

### **Switch Cell Matching**

When a power switch exists in the blocks, a matching switch must exist at the top level for the domains to be merged. It is an error to match a switch from the block to a switch in the top level, that is already matched.

The following rules apply while merging domains that contain switch cells.

- A switch in the top level should have a unique switch in the domain being merged. The switches being merged should also have equivalent
  - Input supply nets

- Control and acknowledgement signals separated by buffer or inverter pairs
  - Voltage setting on the output supply nets
  - Port states, including the state names, state value, primary domain and so on
- Also, the output supply nets must have similar connectivity with the other supply nets in the design.
- When the domain has multiple equivalent switches, the first matching switch is used.

## Known Limitations

The following are the known limitations in hierarchical UPF flow in IC Compiler:

- The target libraries that you use must contain enable level-shifter cells. IC Compiler infers enable level-shifter cells when your design contains level-shifter cells that drive the isolation cells.
- You must define level-shifter strategies for all the power domains. The level-shifter strategy definition must specify the location as either `self` or `parent` on the inputs and outputs.

---

## Full-Chip Design Planning

[Figure 14-16](#) shows the steps involved in the full-chip design planning phase. Use the `check_mv_design` command after every step to check for UPF consistency. You must follow the guidelines to successfully implement your hierarchical design. For more details about the guidelines, see “[Guidelines for the Hierarchical UPF Flow](#)” on page 14-86 and the *IC Compiler Design Planning User Guide*.

*Figure 14-16 Steps Involved in Full-Chip Design Planning*



The following are the tasks involved in the full-chip design planning phase:

1. Read the .ddc file.

Read the .ddc files by using the `import_designs` command, as shown in the following example:

```
icc_shell> import_designs full_chip.ddc -format ddc \
           -top myDesign -cell myDesign
```

2. Create the power and ground net connections.

Using the `derive_pg_connection` command, create the power and ground net connections based on the power domain definitions and the power supply nets. This command performs automatic connection of power and ground pins.

```
icc_shell> derive_pg_connection -create_nets
icc_shell> derive_pg_connection -verbose
```

Use the `check_mv_design` command to check the power and ground connections.

3. Create the floorplan.

Using the `create_voltage_area` command, create the voltage areas for the power domains defined in the UPF file. Voltage areas are physical partitions corresponding to the power domains that are logical partitions that are defined in the UPF file.

```
icc_shell> create_voltage_area -power_domain myVA -guard_band_x 1 \
           -guard_band_y 1 -coordinate {60.140 60.140 275 244}
```

4. Perform power routing.

Create the power rings or straps manually before inserting the power-switch cells.

5. Insert the power-switch cells.

Before creating the switch cell, map the library power-switch cells to the corresponding switch cells in the UPF file by using the `map_power_switch` command. Then create the switch cells by using the `create_power_switch_array` command.

Connect the control signals of the switch cells by using the `connect_power_switch` command.

6. Create the plan groups.

Create the plan groups by using the `create_plan_groups` command. The partition boundary must correspond to the power domain boundary, as shown in the following example:

```
icc_shell> create_plan_groups -cycle_color \
-coordinate "60.14 60.8 275 244.4" MyPlanGroup
```

7. Perform placement and power network analysis.

Run the initial placement and power network analysis for the power and ground nets. Set the resistance and pin layers before you run the `analyze_fp_rail` command.

8. Perform plan-group-aware routing and pin assignment.

Perform plan-group-aware global routing as shown in the following example. Do not allow feedthrough generation during pin assignment.

```
icc_shell> mark_clock_tree -clock_net
icc_shell> set_fp_pin_constraints -allow_feedthroughs off
icc_shell> set_fp_flow_strategy -plan_group_aware_routing true
icc_shell> set_route_zrt_common_options -plan_group_aware all_routing
icc_shell> route_zrt_global -exploration true
icc_shell> place_fp_pins -use_existing_routing[get_plan_groups *]
```

9. Perform proportional timing budgeting.

Use the `allocate_fp_budgets` command to generate the SDC file for the soft macro as shown in the following example. This command also characterizes the full-chip UPF constraints for the plan groups.

```
icc_shell> allocate_fp_budgets -file_format_spec {./sdc/m.sdc}
```

10. Transform the plan groups into soft macros.

Use the `commit_fp_plan_groups` command to transform the plan groups into soft macros.

```
icc_shell> commit_fp_plan_groups -push_down_power_and_ground_straps
icc_shell> save_mw_cel -hierarchy
```

This completes the full-chip design planning phase. You then perform block-level place and route. See the following section, “[Block-Level Place and Route](#).”

---

## Block-Level Place and Route

After you complete the full-chip design planning phase, the next phase in the hierarchical flow is the block-level place and route phase. For more details about the full-chip design planning phase, see “[Full-Chip Design Planning](#)” on page 14-89.

The block-level place and route phase involves the following tasks, as shown in [Figure 14-17](#):

*Figure 14-17 Steps in the Block Level Place and Route Phase*



Before you perform the place and route step, check the UPF constraints inside the hierarchical model (ILM or block abstraction model), as shown in the following example:

```
icc_shell> save_upf block.upf
icc_shell> report_power_domain
icc_shell> report_pst
icc_shell> report_supply_net
icc_shell> report_supply_port
```

Use the `check_mv_design` command to check the UPF consistency.

You then create the hierarchical model by using the `create_ilm` or `create_block_abstraction` command and create the FRAM view by using the `create_macro_fram` command. The following example creates the ILM and FRAM view for a block:

```
icc_shell> create_ilm
icc_shell> create_macro_fram
```

---

## Top-Level Place and Route

Figure 14-18 shows the steps involved in the top-level place and route phase. In this phase, the UPF constraints in the ILM or block abstraction model are propagated to the top level. When the blocks are integrated, IC Compiler automatically propagates the UPF constraints from the ILM or block abstraction model to the top-level when linking the design. So, do not use the `propagate_constraints -power_supply_data` command in IC Compiler.

Use the `check_mv_design` command to check for UPF consistency.

Figure 14-18 Steps in the Top-Level Place and Route Phase





# 15

## ECO Flow

---

An engineering change order (ECO) is a small, incremental change made to a complete or nearly complete chip layout. You can use ECOs to make small logic changes and to fix timing, noise, and crosstalk violations without rerunning logic synthesis for the whole design.

This chapter describes the IC Compiler ECO flow in the following sections:

- [ECO Flow Overview](#)
- [ECO Flow Features](#)
- [ECO Limitations](#)
- [ECO Recommended Flows](#)
- [Unconstrained ECO Flow](#)
- [Freeze Silicon ECO Flow](#)
- [Hierarchical Placement Area Reservation Flow](#)
- [Removing Tie Cells](#)
- [Comparing Designs](#)

## ECO Flow Overview

ECO is short for Engineering Change Order. An ECO is not a new design, but a small change to the functionality of a design after the design has been fully compiled (that is, synthesis and place-and-route have been completed).

Create ECOs to achieve the following purposes:

- Correct problems in the original tape-out
- Fix functional or timing problems discovered late in the design cycle
- Implement late-arriving design changes while maintaining design performance
- Facilitate importing changes from one application into another, so you avoid repeating the top-down design flow for small changes
- Fix correlation issues between tools

An ECO can be implemented at any stage in the design flow. [Figure 15-1](#) outlines the dependency between the type of ECO recommended (automated or manual netlist edit) as it relates to the maturity of your design.

*Figure 15-1 ECO Analysis in the Design Flow*



---

## ECO Flow Features

The ECO flow in IC Compiler supports the following features.

- [Hierarchical Design Support](#)
  - [Multivoltage and UPF Design Support](#)
  - [Programmable Spare Cell Support](#)
- 

### Hierarchical Design Support

IC Compiler ECO flows support hierarchical design methodologies. However, you should note that although internal logic and ports on hierarchical blocks might be changed, deleting and creating hierarchical blocks, ILMs, or block abstraction models themselves are not supported; the logical and physical hierarchy relationship must be maintained.

---

### Multivoltage and UPF Design Support

In IC Compiler, the multivoltage and UPF ECO flows support multivoltage-specific cells, such as level shifters, isolation cells, retention cells, or always-on cells. A multivoltage ECO can involve a netlist change that is or is not compliant with UPF constraints. For example, when the change is compliant with UPF constraints, perform the following steps:

1. Run the `eco_netlist` command to edit the netlist with the ECO intent.
2. Run the `derive_pg_connection` command to update the power and ground information.
3. Run the `check_mv_design` command and fix any errors.
4. If any UPF error is flagged, your change is no longer UPF compliant and you need to reedit your UPF constraints.

When the change is intentionally not compliant with UPF constraints, you must update the constraints manually by taking the following steps:

1. Run the `eco_netlist` command to edit the netlist with the ECO intent.
2. Edit the UPF to match the ECO intent.
3. Run the `derive_pg_connection` command to update the power and ground information.
4. Run the `check_mv_design` command and fix any multivoltage errors.

Note that if the ECO is not power-related, the UPF constraints are not affected.

If a leaf cell is removed during ECO, its relationship to the multivoltage constraints is removed accordingly. However, the ECO process does not update the multivoltage constraints.

Note:

Changing UPF constraints might cause the post-ECO netlist to be functionally different than the netlist with the original UPF constraints. You need to ensure the verification flow for the netlist with original and new UPF constraints.

---

## Programmable Spare Cell Support

During ECO, IC Compiler swaps an ECO cell with a spare cell that can be programmable, based on the existing cell type, cell width, and voltage area. The tool can recycle the space left by the programmable spare cells that are removed during ECO, and it reuses them for programmable spare cells to be added during ECO, either in one ECO session or in multiple freeze silicon ECO flows.

The programmable spare cell support in IC Compiler provides the following capabilities:

- Minimize wire length of placement
- Map bigger or smaller programmable fillers with more flexibility
- Recycle programmable instances for programmable fillers

To insert programmable filler cells, run the `map_unit_tiles` command using the following syntax:

```
map_unit_tiles -lib_cells {list_of_programmable_filler_library_cells}  
-unit_tile_name unit_tile_name
```

The unit tile name is the name of the programmable filler to be inserted. The FRAM view contains the necessary tile information.

To remove programmable filler cells, use the `-remove` option with the `map_unit_tiles` command.

```
icc_shell> map_unit_tiles -remove {programmable_filler_library_cells}
```

To clean up the mapping table, use the `-reset` option with the `map_unit_tiles` command.

```
icc_shell> map_unit_tiles -reset
```

To report the mapping table, run the `report_unit_tiles` command.

```
icc_shell> report_unit_tiles
```

## Programmable Spare Cell Feasibility Checking

During ECO, the `eco_netlist` command supports feasibility checking for programmable spare cells before implementing any changes. This is to ensure that all programmable spare cells that are being added directly or generated by a replacing or resizing operation have enough space to be placed. The available space includes not only the space occupied by the currently existing programmable spare cells but also the space left by the programmable spare cells that are removed either directly or by the replacing or resizing operation.

The programmable spare cell feasibility check is performed on groups divided by the same master type and the same voltage area, based on the following rules:

- If the total width of the programmable spare cells to be added during ECO is less than or equal to the total width of programmable spare cells to be deleted and programmable spare cells, the adding operations of the programmable spare cells to be added in this group are verified to be feasible. No warning message is issued.
- If the total width of the programmable spare cells to be added is more than the total width of programmable spare cells to be deleted and programmable spare cells, the `eco_netlist` command issues the following warning messages:

```
Programmable filler space is needed to increase <rate>% in gate array  
master type<id> under voltage area<voltage area name>
```

---

## ECO Limitations

When placing spare cells, you must set the `is_spare_cell` attribute on the spare cells to enable the tool to place spare cells automatically. For details, see “[Automatically Distributing the Spare Cells During Placement](#)” on page 15-17.

The `eco_netlist` command does not support the following operations:

- Clock tree synthesis
- Scan chains

For `eco_netlist` usage details, see “[Creating ECO Changes and Updating the Design](#)” on page 15-7.

---

## ECO Recommended Flows

IC Compiler provides the following ECO flows:

- Unconstrained ECO flow

Use this flow if your design has not been taped out yet. In this flow, you can add new cells and move or delete existing cells. You do not need to have spare cells in the design.

- Freeze silicon ECO flow

Use this flow if your cell placement is fixed. In this flow, you only change the metal and via mask patterns because all cell placement is fixed. You use spare cells to make any functional design change. Spare cells are logic gates that you add to the design before running the ECO process. These spare gates should be appropriately preplaced to minimize metal changes. This type of change is usually performed only after tape-out.

The fundamental difference between the freeze silicon ECO flow and the unconstrained ECO flow is that, in the freeze silicon ECO flow, you can only use preplaced spare cells to implement changes; whereas, in the unconstrained ECO flow, you can add new cells and can move or delete existing cells. The freeze silicon ECO flow only supports modifications of the metal-layer masks. To make design changes, you use spare cells which should be appropriately preplaced to minimize metal changes.

No matter which flow you choose to perform ECO, choosing an approach for the design update methodology is important, and you should take into account factors, such as complexity of design change; maturity of design; phase of design flow (placement, CTS, routing, and so on); and legacy interfaces with external tools, such as PrimeTime.

In general terms, the following methods are recommended for netlist edits:

- Use the Verilog netlist approach for major design functionality changes or where you want to tightly enforce design revision control.
- Use the Tcl command approach for minor netlist edits.

[Figure 15-2](#) illustrates the steps taken in completing an unconstrained or a freeze silicon ECO flow.

*Figure 15-2 Unconstrained and Freeze Silicon ECO Flow*



## Unconstrained ECO Flow

The unconstrained ECO flow includes the following steps:

- [Creating ECO Changes and Updating the Design](#)
- [Updating Placement](#)
- [Updating Routing](#)

---

## Creating ECO Changes and Updating the Design

For the unconstrained ECO flow, IC Compiler provides two ways to create ECO changes and add them to your design:

- [Updating With a Verilog Netlist](#)
- [Updating With Tcl Commands](#)

In general, use a complete Verilog netlist for major changes and use the Tcl commands for small changes. Both methods are described in the following sections.

## Updating With a Verilog Netlist

Use the `eco_netlist` command to import your ECO netlist into IC Compiler. You can also import your ECO netlist with the GUI. In the GUI, choose ECO > ECO Netlist. The ECO by Verilog dialog box appears. The default cell is the current cell.

When creating the ECO netlist, it is helpful to note instance and master names of the newly added cells so that you can check the resulting update.

When you run the `eco_netlist` command, the tool first reads the ECO Verilog netlist file and generates a hierarchical cell of the design in its memory data structures. The tool then compares the existing Milkyway design cell with the new Verilog design and makes changes in the existing Milkyway design cell, based on the new inputs. Lastly, the tool saves the ECO changes in text format in the IC Compiler log file.

Note:

The `eco_netlist` command does not follow the Verilog input to adjust the existing connections for tied-off signal pins but retains the power or ground connection in the following cases:

- The connection for a tied-high signal pin from a power net to a tie-high net
- The connection for a tied-low signal pin from a ground net to a tie-low net

For command details, see the `eco_netlist` man page.

## Power and Ground (PG) Support

If your netlist has PG ports and nets and you run the `eco_netlist -compare_pg` command, the ECO engine performs changes on all PG ports and nets and considers the new Verilog netlist as golden. When you use this switch, the PG ports in the golden Verilog netlist override any PG information contained earlier in the Milkyway database.

If your netlist has power and ground ports and nets and you run the `eco_netlist` command without the `-compare_pg` option, the tool performs only the logical ECO. The golden Verilog file's power and ground data has no effect on the existing power and ground data in the Milkyway database.

## ECO on Physical-Only Cells

IC Compiler identifies physical-only cells automatically by their cell type. You do not need to mark these cells in any special way before applying the ECO.

If your golden Verilog netlist contains physical-only cells and you run the `eco_netlist -physical` command, the ECO engine recognizes physical-only cells from the Verilog netlist and saves them in the Milkyway database.

## Recording Changes

Run the `eco_netlist -write_changes` command if you want to generate an output file that contains the changes that the `eco_netlist` command does during ECO. This Tcl file allows you to see exactly what changes are made by the `eco_netlist` command. You can also make changes to this Tcl file and reuse it for subsequent ECO operations.

## Reporting ECO History

Run the `report_eco_history` command if you want to report the ECO changes. By default, the `report_eco_history` command outputs a change list for the latest ECO change to the IC Compiler log file. You can save the output to a Tcl script file instead by using the `-output` option when you run the command. You can also report a summary of all ECO changes made to the design by using the `-summary` option or output a change list for a specific ECO change by using the `-id` option.

For more information about the `report_eco_history` command, see the man page.

## Updating With Tcl Commands

IC Compiler provides two ways of using Tcl commands for changing your netlist:

- You can run the netlist editing commands from the command line or GUI.
- You can use a Tcl file that contains the netlist editing commands. To use a Tcl file for making netlist changes, run the `eco_netlist` command using the following syntax:

```
eco_netlist -by_tcl_file file_name.tcl
```

Note that if the `sh_continue_on_error` variable is set to `false`, the `eco_netlist -by_tcl_file` command stops executing the Tcl commands in the ECO change file when it encounters an error. Otherwise, it continues the execution of the Tcl commands even if it encounters an error.

Use the `-echo_commands` option to control whether the contents of the ECO change file are printed when you run the `eco_netlist -by_tcl_file` command. The `-echo_commands` option must be used along with the `-by_tcl_file` option.

When you use the `-freeze_silicon` option together with the `-by_tcl_file` option, the `create_cell`, `remove_cell`, and `change_link` commands are treated as if they have the `-freeze_silicon` option specified in the Tcl file, even though in fact they do not. You cannot use the `-by_tcl_file` option with any other option of the `eco_netlist` command, except the `-freeze_silicon` and `-echo_commands` options.

For more information about the `eco_netlist` command, see the man page.

IC Compiler provides the following types of netlist editing commands:

- [Tcl Commands for Port Operations](#)
- [Tcl Commands for Net Operations](#)
- [Tcl Commands for Bus Operations](#)
- [Tcl Commands for Connection Operations](#)
- [Tcl Commands for Instance Operations](#)

### **Tcl Commands for Port Operations**

You can use Tcl commands to perform the following port operations:

- `create_port`: Creates a new port or hierarchical port in the current design or its subdesign
- `remove_port`: Removes a port or hierarchical port from the current design or its subdesign
- `set_name`: Changes the port name that is local to the parent hierarchical module; it does not change the hierarchical path information

### **Tcl Commands for Net Operations**

You can use Tcl commands to perform the following net operations:

- `create_net`: Creates a new flat or hierarchical net in the current design or its subdesign
- `remove_net`: Removes a flat or hierarchical net from the current design or its subdesign
- `change_names`: Renames a flat or hierarchical net in the current design or its subdesign
- `set_name`: Changes the net name that is local to the parent hierarchical module; it does not change the hierarchical path information

## Tcl Commands for Bus Operations

You can use Tcl commands to perform the following bus operations:

- `define_bus`: You can define a bus that is composed of port or net objects by using the `define_bus` command. The syntax for this command is

```
define_bus
  -type port | net
  -name bus_base_name
  -range {start end}
```

The objects that are being grouped into a bus must already exist in the design and must have names that match the base name specified in the `-name` option and have indexes in the range specified in the `-range` option. The object indexes must be continuous. If the object names do not match the bus naming style, use the `set_name` command to change the object names before running the `define_bus` command.

- `undefine_bus`: You can remove a bus definition by using the `undefine_bus` command. This command does not remove the objects comprising the bus; it only removes the bus property from these objects. The syntax for this command is

```
undefine_bus -type port | net
  -name bus_base_name
```

- `report_bus`: You can report on buses by using the `report_bus` command. You can report on all the buses in the current instance, on all the buses in a specific cell, or on one or more specific buses. The syntax for this command is

```
report_bus
  -cell cell
  object_list
```

If you do not specify either the `-cell` option or the `object_list` argument, the command reports on all buses in the current instance. If you specify both the `-cell` option and the `object_list` argument, the command reports on the buses in the specified cell and ignores the `object_list` argument. Note that you can specify only a single cell when you use the `-cell` option.

## Tcl Commands for Connection Operations

You can use Tcl commands to perform the following connection operations:

- `connect_net`: Connects a specified flat or hierarchical net to the specified port or hierarchical port instance
- `disconnect_net`: Disconnects a specified port or hierarchical port instance from the specified flat or hierarchical net

## Tcl Commands for Instance Operations

You can use Tcl commands to perform the following instance operations:

- `create_cell`: Adds a new flat cell instance. By default, the `create_cell` command uses the FRAM view for the new or changed cells. If you want to change to the CEL view, use the `-view CEL` option with the `create_cell` command.

If you want to create a hierarchical cell in the design, run the `create_cell -hierarchical` command.

**Note:**

IC Compiler applications, such as extraction, timing, and optimization require a FRAM view for all cells. If you specify the `-view CEL` option, you must provide both a CEL view and a FRAM view for all cells that use the CEL view. If a FRAM view does not exist for a cell, use the `create_macro_fram` command to create it.

- `insert_buffer`: Adds a new buffer
- `remove_cell`: Removes a flat cell instance
- `replace_cell_reference`: Changes the reference cell of a leaf cell
- `remove_buffer`: Removes a buffer
- `size_cell`: Resizes a flat cell instance
- `set_name`: Changes the cell name local to the parent hierarchical module; it does not change the hierarchical path information

The following example uses Tcl commands to size the block1/U2 cell from reference BUFX2 to BUFX8 and to insert a buffer with reference BUFFX16:

```
icc_shell> size_cell block1/U2 class/BUFX8
icc_shell> insert_buffer {block1/U2/z} class/BUFFX16
```

## Updating Placement

When functional ECO is completed, you need to update your ECO changes by using the `place_eco_cells` command. This command performs placements and legalizations on the ECO cells which are a small number of cells that pass to the command as collection, or a small number of unplaced cells as the result of the `eco_netlist` or Tcl editing command runs.

The following is the syntax of the `place_eco_cells` command:

```
place_eco_cells
  -cells cell_list | -unplaced_cells | -eco_changed_cells
  -no_legalize | -legalize_only
```

The command has the following options:

`-cells cell_list`

Specify the cells to be placed.

`-unplaced_cells`

Place all unplaced cells.

`-eco_changed_cells`

Place or legalize the cells that are changed by ECO operations without manual tracking of each operation.

The `-eco_changed_cells` option is supported only in the unconstrained mode, and is mutually exclusive with the `-cells` and `-unplaced_cells` options.

`-no_legalize`

Place cells without legalization. Use this option when you need to place the cells multiple times for different purposes but legalization needs to be done only once.

This option is used only with the `-cells` option. The `-legalize_only` and `-no_legalize` options are mutually exclusive.

`-legalize_only`

Legalize cells without placement. Use this option for cells for which the `is_placed` attribute is set to `true`. When the option is enabled, you need to specify locations for all input cells. If there is an unplaced cell, the command errors out with the UID-700 message.

This option is used only with the `-cells` option. The `-legalize_only` and `-no_legalize` options are mutually exclusive.

The `place_eco_cells` command legalizes cells only on unoccupied sites in the neighborhood of the ECO cell location. The output of this command is a legally placed netlist. This command is designed for connectivity-based incremental ECO placement and provides the following features:

- The `place_eco_cells` command places only the ECO cells and leaves other existing cells untouched to minimize the impact to the existing cell placements. It uses only free sites and does not push other cells away. You do not need to set other cells fixed.
- The placement and legalization results from the `place_eco_cells` command are user-controllable. You can select the cells for placement with the `-cells` option and legalize the cells with user-specified locations using the `-legalize_only` option.
- The placement results are blockage and macro aware. The `place_eco_cells` command uses the timing information from the design to obtain net delay information and internally computes net weight based on net delay to control the ECO placement for timing improvement. After obtaining the initial location from the connectivity and timing

information, the command adjusts the location if needed. The command legalizes the cells using the nearest free site, similar to the legalization performed by the `place_opt` or `legalize_placement` command.

The following examples show different uses of the `place_eco_cells` command:

```
icc_shell> place_eco_cells -cells {STACK_BLK/NEW1 SEW2}
icc_shell> place_eco_cells -unplaced_cells
icc_shell> place_eco_cells -unplaced_cells -no_legalize
icc_shell> place_eco_cells -no_legalize -cells {STACK_BLK/NEW1 NEW2}
icc_shell> place_eco_cells -legalize_only -cells {STACK_BLK/NEW1 NEW2}
```

### **Working with the `eco_change_status` Attribute**

When the `-eco_changed_cells` option is specified, running the `place_eco_cells` command processes the cells with the `eco_change_status` attribute. The `eco_change_status` attribute is designed for leaf cell instances and has the following valid values:

- `create_cell`
- `change_link`
- `insert_buffer`
- `size_cell`
- `eco_legalized`

During manual ECO edit, running the `eco_netlist` command with the `-by_verilog_file` or `-by_tcl_file` option sets the `eco_change_status` attribute to the first 4 values according to the editing command that has been used. The `eco_legalized` value is set after the cells are legalized with the `place_eco_cells` command.

To manually set and get the `eco_change_status` attribute, use the `set_attribute` and `get_attribute` command. To remove the attribute, use the `remove_attribute` command.

## **Updating Routing**

There are several options for routing the ECO placement. You can manually connect the ECO routing when the change is very minor or if the routing is limited to a few layers. When the change is major, use the `route_zrt_eco` command to route the changed nets. This command routes the broken and newly added nets and cleans up the deleted nets, obsolete nets, and unused sections of changed wires. The `route_zrt_eco` command performs global routing, track assignment, and detail routing. It attempts to preserve the critical routes and fix DRC violations.

The `route_zrt_eco` command has many powerful options that make routing intelligent. For example, it can freeze certain layers or vias and skip global routing or track assignments. This command only routes modified nets, regional-based ECO routing (that is, specified areas), and distributed regions, based on ECO routing. The following example performs ECO routing by using the `-max_detail_route_iterations`, `-utilize_dangling_wires`, `-open_net_driven`, and `-reroute` options.

```
icc_shell> route_zrt_eco -max_detail_route_iterations 5 \
    -utilize_dangling_wires true -open_net_driven true \
    -reroute modified_nets_first_then_others
```

After routing update is complete, use the `extract_rc -incremental` command to perform incremental extraction on the changed nets. The tool runs the incremental extraction based on the previous extraction results in the same session.

---

## Freeze Silicon ECO Flow

The freeze silicon ECO flow requires you to add and place spare cells in anticipation of possible ECO needs. Then you create your ECO changes and add them to your design with the `eco_netlist` command. You can do this by using a Verilog netlist or Tcl commands.

After each call of the `eco_netlist` command, run the `place_freeze_silicon` or `map_freeze_silicon` command (freeze ECO flow only) to

- Swap the deleted cell out of the design
- Map the newly added cells to spare cells
- Delete unused spare cells from the Milkyway database
- Restore the cell count to a consistent state

### Programmable Spare Cell Support

For programmable spare cells to be added during ECO, the `place_freeze_silicon` command swaps them with spare cells with the same cell type and within the same voltage area. This command does not do master-cell-ID-based swapping on the programmable spare cells to be added.

The programmable filler library should contain programmable fillers whose width is less than or equal to the minimum width of the cells with the same cell type, or the `place_freeze_silicon` command might not be able to recover some unused design areas.

All the programmable filler widths in the programmable filler library should be a multiple of the minimum programmable filler width, or the `place_freeze_silicon` command might not be able to recover some unused design areas.

You specify which library cells to use for filling the space during ECO with the following syntax:

```
place_freeze_silicon -use_lib_cells lib_cell_name
```

If the `-use_lib_cells` option is disabled, the `place_freeze_silicon` command uses all available library cells in the reference library.

For the nonprogrammable spare cells to be added during ECO, the `place_freeze_silicon` command swaps them based on the reference cell ID. The vertical row design style is also supported.

The freeze silicon ECO flow section consists of the following topics:

- [Inserting Spare Cells](#)
- [Creating ECO Changes and Updating the Design](#)
- [Finalizing the Freeze Silicon Flow](#)
- [Updating Routing](#)
- [Freeze Layer ECO Flow](#)

---

## Inserting Spare Cells

Spare cells are used in the freeze silicon ECO flow.

Spare cells accommodate late-arriving design changes. You insert them before or after placement and use them when placement is fixed. With spare cells, you can perform simple logic changes by updating only one or a few metal and via masks, thereby saving the considerable expense of generating a whole new set of silicon-layer masks.

Spare cells are most useful when they are physically near the location of the logic that needs to be changed. Therefore, spare cells need to be dispersed across the chip rather than gathered in one or several tight locations.

To add and place spare cells in a design, do one of the following steps:

- Manually instantiate the spare cells into the Verilog netlist

Do this before reading the netlist into IC Compiler. There is no RTL description for spare cells; you must instantiate all spare cells. See [“Inserting Spare Cells Using a Verilog Netlist” on page 15-17](#).

- Use the `insert_spare_cells` command

Run this command to insert a specified number of specified library cells into a legally placed design. The new cells can be evenly distributed and legalized. These additional cells do not affect existing placement. The command does not remove any existing spare cells. For details, see “[Inserting Spare Cells by Using the `insert\_spare\_cells` Command](#)” on page 15-21.

These methods are described in the following sections:

- [Inserting Spare Cells Using a Verilog Netlist](#)
- [Inserting Spare Cells by Using the `insert\_spare\_cells` Command](#)

## Inserting Spare Cells Using a Verilog Netlist

There is no limit to the number of spare cells you can add to the design. This allows you the flexibility to break up the spare cells so that they can be easily scattered or be located near one specific logic that might be more likely to require an ECO.

Usually the spare cells are instantiated and grouped in separate hierarchical blocks. However, if you want to place a group of spare cells near one specific logic, you can break the hierarchical blocks into multiple blocks. This enables you to place a group of spare cells physically near its related logic.

The spare cell inputs can be connected to high or low logic levels. To prevent the gate from oscillating (creating noise and consuming power), tie the inputs to ground or power, as appropriate. The spare gates are usually independent, but you can connect them together to form other functions. In any case, you must instantiate each spare cell in the netlist.

Note that each spare cell block can be used only once within the design.

After you read in the netlist, you can place the cells in the following ways:

- Automatically place the spare cells during placement
- Manually place the spare cells before placement
- Manually place the spare cells after placement

These methods are described in the following sections.

### Automatically Distributing the Spare Cells During Placement

Note:

Automatic spare cell placement works only for spare cells that have all inputs tied low or high and have output ports that float. Additionally, due to the current tool limitations, you must set the attribute `is_spare_cell` on the spare cells to enable the tool to place spare cells automatically. Any spare cells that are connected to signal nets, such as sequential

cells connected to a clock, cannot be distributed automatically. You need to insert these spare cells manually, as described in “[Manually Distributing the Spare Cells After Placement](#)” on page 15-19.

After you add your spare cells into the Verilog netlist and import the netlist into IC Compiler, the tool distributes the spare cells automatically during placement. This placement is hierarchically aware, so you can insert spare cells in a logic submodule instead of across the entire design. In this case, when IC Compiler places these spare cells, instead of placing the cells across the entire floorplan, the placement is limited to the area that the submodule covers. Consider the spare cell placement in [Figure 15-3](#).

*Figure 15-3 Spare Cells Inserted in a Submodule*



In [Figure 15-3](#),

- The spare cells in module Top/spare1 are distributed across the placed area of Top (A, B, and C).
- The module Top/A contains a submodule, spare2, which contains only spare cells. The spare cells in spare2 are placed only in the area in which Top/A is placed.

When you know you are likely to do an ECO on module A, you want some of the known spare cells to be placed only in that module. Placing 100 percent of these spare cells in that module is not necessary; some spare cells can spill over to other regions.

When you want IC Compiler to place the spare cells automatically, keep the following in mind:

- If you apply the `dont_touch` attribute to the spare cells, the spare cells are not removed during optimization.
- You must connect the spare cell inputs to low or high. The tool identifies spare cells automatically by checking the inputs. If the inputs of spare cells are not tied low or high, they are not treated as spare cells and placement might place them in one tight location.
- Set the spare cells to the soft-fixed attribute after the spare cells are distributed. With the soft-fixed attribute, they can still be moved slightly.

### **Manually Distributing the Spare Cells After Placement**

If you want to manually control spare cell placement, use the `spread_spare_cells` command.

The `spread_spare_cells` command evenly distributes specified spare cells over a specified region. Manual cell spreading means that the spare cells are not placed automatically during placement; instead, they are placed either before or after placement. This is useful when you want to control the spare cell location.

To manually place spare cells after placement, use the following steps:

1. Apply the `is_spare_cell` attribute to the spare cells.

To do this, you can run the `set_attribute` command. For example,

```
set_attribute [get_cells block1/spare*] is_spare_cell true
```

You must apply this attribute; otherwise, the `spread_spare_cells` command does not work.

2. Apply the `dont_touch` attribute and the `fixed` attribute to all the spare cells.

If you do not set the cell to fixed status, the placement places all the spare cells into a small tight location and waste the placement area.

3. Run the placement optimization.

4. Remove the `fixed` attribute from spare cells.

If you do not remove the `fixed` attribute, the spare cells cannot be distributed.

5. Run the `spread_spare_cells` command.

The `spread_spare_cells` command accepts collections, which means you can pass any collection variable from other Tcl commands. The `spread_spare_cells` command distributes the specified spare cells into the specified region. It derives the location for

each of the spare cells but does not perform legalization on the distributed spare cells. You need to run incremental legalization for these spare cells. The command works for both rectangular and rectilinear areas.

#### 6. Run incremental legalization.

Incremental legalization attempts to maintain the existing placement. You should run incremental legalization by using the following syntax:

```
legalize_placement -incremental
```

#### 7. Set the spare cells to soft-fixed.

This maintains the spare cell placement location and also allows the cell to be moved slightly, if necessary, later in further optimization. Do this with the `set_attribute` command.

[Example 15-1](#) shows a script that manually places spare cells after regular placement.

#### *Example 15-1 Manually Placing Spare Cells After Placement*

```
source icc.setup
open_mw_lib MDBLIB
open_mw_cel top
set_attribute [get_cells *spares*] is_spare_cell true
set_dont_touch_placement [get_cells *spares*]
place_opt
remove_dont_touch_placement [get_cells spare*]
spread_spare_cells [get_cells spare*] -bbox {{20 20} {999 999}}
legalize_placement -incremental
set_dont_touch [get_cells *spares*] true
set_attribute [get_cells *spares*] is_soft_fixed true
clock_opt
route_opt
...
```

[Example 15-2](#) shows a script that manually places spare cells before regular placement.

#### *Example 15-2 Manually Placing Spare Cells Before Placement*

```
open_mw_cel top
set_attribute [get_cells spares*] is_spare_cell true
spread_spare_cells [get_cells spare*] -bbox {{5 5} {2000 2000}}
set_attribute [get_cells spares*] is_soft_fixed true
set_dont_touch [get_cells spares*]
place_opt
clock_opt
route_opt
```

## Inserting Spare Cells by Using the `insert_spare_cells` Command

Use the `insert_spare_cells` command to insert a specified number of instances of a specified library cell as spare cells in a legalized design. If your design does not have legal placement, run the `insert_spare_cells -skip_legal` command to skip legalized placement checking on the design. However, the command still tries to find a legal location for each spare cell even if the design has illegal placement.

When you insert spare cells in a specific hierarchy by using the `-hier_cell` option, the spare cells are placed in the rectangular area that encloses all of the cells belonging to the specified subdesign so that the spare cells are closer to those cells.

If you want to insert a different number of spare cells for different library cells, run the `insert_spare_cells` command with the `-num_cells` option. For example, if you want to insert two AND2 and three BUF3, run the following command: `insert_spare_cells -num_cells {AND2 2 BUF3 3}`. Each cell is inserted with legal placement if there is enough space. New spare cells of the same library cell are spread as evenly as possible. This is the same as if you specify different library cells with the `-num_instances` and `-lib_cell` options; they are placed together if possible. The only difference is now you can have a different number for each library cell. If you use the `-num_cells` option, you do not need to specify the `-num_instances` and `-lib_cell` options.

For more details, see the man page.

[Example 15-3](#) shows how to use the `insert_spare_cells` command.

### *Example 15-3 Example of Running `insert_spare_cells`*

```
...
open_mw_cel top
place_opt
insert_spare_cells -lib_cell {INV8 DFF1} -cell_name spares \
    -num_instances 300
set_attribute [get_cells spares*] is_soft_fixed true
set_dont_touch [get_cells spares*] true
```

---

## Creating ECO Changes and Updating the Design

For the freeze silicon ECO flow, you can create ECO changes and add them to your design with a Verilog netlist or Tcl commands.

## Updating with a Verilog File

In the freeze silicon ECO flow, use the `eco_netlist -freeze_silicon` command to import your ECO netlist into IC Compiler and finalize the ECO changes with the `place_freeze_silicon` command. You can also import your ECO netlist with the GUI. In the GUI, choose ECO > ECO Netlist. The ECO by Verilog dialog box appears. The default cell is the current cell.

When you run the `eco_netlist` command to make ECO changes with a Verilog netlist, the tool sets certain ECO attributes on the modified objects in the design database, such as added or resized cells. This information is then read by the `place_freeze_silicon` command that replaces the newly added cells with the closest spare cells available in the design database.

Note:

You must run the `place_freeze_silicon` command each time you run the `eco_netlist` command. For more information, see “[Finalizing the Freeze Silicon Flow](#)” on page 15-24.

Example:

```
icc_shell> open_mw_cel myOriginalCelBeforeEcoChanges
icc_shell> eco_netlist -freeze_silicon -by_verilog_file eco.v \
    -write_changes eco.tcl
icc_shell> place_freeze_silicon
icc_shell> route_zrt_eco
icc_shell> save_mw_cel -as myEcoedCel
```

It is recommended that you save the created ECO changes to an output Tcl ECO file using the `eco_netlist -freeze_silicon -write_changes` command. With this output Tcl file, you can make further ECO changes in the form of Tcl commands. After all the ECO changes are made, source back the Tcl file to implement the ECO changes in IC Compiler. Then, do incremental placement with the `place_freeze_silicon` command, followed by the incremental routing.

Example:

```
icc_shell> open_mw_cel myOriginalCelBeforeEcoChanges
icc_shell> source -echo -verbose eco.tcl
icc_shell> place_freeze_silicon
icc_shell> route_zrt_eco
icc_shell> save_mw_cel -as myEcoedCel
```

## Updating with a Tcl File

You can use a Tcl file that contains the netlist editing commands if you want to change your netlist for a manual freeze silicon edit. To use a Tcl file for making netlist changes, run the `eco_netlist` command using the following syntax:

```
eco_netlist -by_tcl_file file_name.tcl
```

The following are the Tcl commands you can use to change your netlist for a manual freeze silicon edit:

- `create_cell -freeze_silicon`: When you use the `-freeze_silicon` option with the `create_cell` command, the command uses an existing spare cell for the created cell.
- `remove_cell -freeze_silicon`: When you use the `-freeze_silicon` option with the `remove_cell` command, the cells are not removed from the design; instead they are converted to spare cells.
- `change_link -freeze_silicon`: When you use the `-freeze_silicon` option with the `change_link` command, the command swaps the specified cell instance to a spare cell with the specified library cell.

By default, the `change_link` command uses the FRAM view for the new or changed cells. If you want to change to the CEL view, use the `-view CEL` option with the `change_link` command.

### Note:

IC Compiler applications, such as extraction, timing, and optimization require a FRAM view for all cells. If you specify the `-view CEL` option, you must provide both a CEL view and a FRAM view for all cells that use the CEL view. If a FRAM view does not exist for a cell, use the `create_macro_fram` command to create it.

- `insert_buffer -freeze_silicon`: When you use the `-freeze_silicon` option with the `insert_buffer` command, the command inserts buffer cells that are in a transitional state to support the ECO freeze silicon flow. The `place_freeze_silicon` or `map_freeze_silicon` command then deletes the instances and replaces them with existing spare cells of the same reference library cell.
- `remove_buffer -freeze_silicon`: When you use the `-freeze_silicon` option with the `remove_buffer` command, the command removes buffer cells in a transitional state to support the ECO freeze silicon flow. The buffers are not actually removed from the design. They are marked as spare cells.
- `size_cell -freeze_silicon`: When you use the `-freeze_silicon` option with the `size_cell` command, the command performs sizing on the cell instances in the transitional state to support the ECO freeze silicon flow. The `place_freeze_silicon` or `map_freeze_silicon` command then swaps the cell instances with the available spare cells of the specified reference library cell.

When you use the `-freeze_silicon` option together with the `-by_tcl_file` option, these Tcl editing commands are treated as if they have the `-freeze_silicon` option specified in the Tcl file, even though in fact they do not. All the related commands in the Tcl change list are run under freeze silicon mode and there is no need to update the Tcl change list. You cannot use the `-by_tcl_file` option with any other option of the `eco_netlist` command, except the `-freeze_silicon` and `-echo_commands` options.

---

## Finalizing the Freeze Silicon Flow

For the freeze silicon flow, you can run the `eco_netlist` command multiple times to meet the design need. However, you must run the `place_freeze_silicon` command each time you run the `eco_netlist` command. Otherwise, multiple overlapping ECOs might be created.

If you want to map the cell to the specified spare cells only, run the `map_freeze_silicon cell_name spare_cell_name` command. If you want to map multiple cells to multiple spare cells, run the `map_freeze_silicon -map_file map_file_name` command.

The following is the format of the mapping file:

```
cell_1    spare_cell_1  
cell_2    spare_cell_2  
...        ...
```

For more information, see the man page.

---

## Updating Routing

There are several options for routing the ECO placement. You can manually connect the ECO routing when the change is very minor or if the routing is limited to a few layers. When the change is major, use the `route_zrt_eco` command to route the changed nets. This command routes the broken and newly added nets and cleans up the deleted nets, obsolete nets, and unused sections of changed wires. The `route_zrt_eco` command performs global routing, track assignment, and detail routing. It attempts to preserve the critical routes and fix DRC violations.

For more information, see “[Updating Routing](#)” on page [15-14](#).

## Freeze Layer ECO Flow

As technology sizes shrink, the cost of layout masks is increasing dramatically. One popular approach to saving mask costs is to limit the ECO routing layers used during the post tape-out ECO phase.

[Figure 15-4](#) illustrates the steps to complete a freeze layer ECO flow. As with the freeze silicon ECO flow, you first need to run the `eco_netlist` command for netlist changes and the `place_freeze_silicon` command for placement update. Next, you need to manually choose or remove net shapes or vias, and then do Zroute routing on the selected layers and vias.

The following sections describe the steps for net shape and via preparation and selected routing with Zroute. If you need more information about how to run netlist and placement updates, see “[Updating With a Verilog Netlist](#)” on page 15-8 and “[Finalizing the Freeze Silicon Flow](#)” on page 15-24.

*Figure 15-4 Freeze Layer ECO Flow*



## Preparing Net Shapes and Vias

For the freeze layer ECO flow, you need to do the following steps for net shape and via preparation:

1. Query floating net shapes and vias that are left from the routes of removed nets.
2. Remove user-selected floating net shapes and vias on particular layers.

3. Construct and query the net shapes that are connected through vias.
4. Manually reassign floating net shapes to nets to be routed or rerouted.

**Table 15-1** describes the commands used for preparing net shapes and vias in a freeze layer ECO flow.

*Table 15-1 Commands for Preparing Net Shapes and Vias*

| Command                         | Function                                                                                                    |
|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| remove_user_shape<br>remove_via | Remove the selected floating net shapes or vias on the particular layers.                                   |
| get_net_shapes<br>get_vias      | Construct net shapes. Query the net shapes that are connected through vias.                                 |
| set_attribute                   | Manually reassign the connected (and single) floating net shapes to nets that are to be routed or rerouted. |

## Selected Net Routing

IC Compiler allows you to freeze routes for freeze silicon designs using Zroute. For example, you can choose to route only on the selected layers, including via layers, or the selected nets, such as selected, open, or overlapped nets. Or you can choose to route only within the region you specify.

Zroute provides freeze layer and freeze via support through the `set_route_zrt_common_options` command, as shown in the following syntax:

```
set_route_zrt_common_options
  -freeze_layer_by_layer_name {{layer true | false}...}
  -forbid_new_metal_by_layer_name {{layer true | false}...}
  -freeze_via_to_frozen_layer_by_layer_name true | false

  -freeze_layer_by_layer_name {{layer true | false}...}

Controls whether routing layers are frozen to prevent them from changing during routing.
When the option is set to false (the default), the layer is not frozen. When it is true, the
layer is frozen.

  -forbid_new_metal_by_layer_name {{layer true | false}...}

Controls whether ECO routing can remove, but not add, metal on the specified layers.
When the option is set to false (the default), metal can be added or removed. When it is
true, the metal can be removed, but not added.
```

```
-freeze_via_to_frozen_layer_by_layer_name true | false
```

Controls the treatment of vias that touch a frozen layer on one side. When the option is set to `false` (the default), vias adjacent to a frozen layer can be changed. When it is `true`, vias adjacent to a frozen layer are frozen and cannot be changed.

Zroute recognizes the frozen layers and the frozen vias, including enclosure and cut layers, as hard constraints. Note that running the `verify_zrt_route` command does not report DRC violations on the frozen layers or the frozen vias, including enclosure and cut layers.

You can also perform routing on the selected nets by using the interactive Route Editing tool or by using the commands shown in [Table 15-2](#).

*Table 15-2 Commands for Selected Routing During the Freeze Layer ECO Flow*

| Command                                                                                                                           | Function                                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| <code>route_zrt_eco</code><br><code>-reroute modified_nets_first_then_others</code>                                               | Route only on nonfrozen layers. Route ECO nets and all other nets that are needed for fixing routing DRC violations.                       |
| <code>route_zrt_eco</code><br><code>-nets   -open_net_driven true</code><br><code>-reroute modified_nets_first_then_others</code> | Route only on nonfrozen layers. Route ECO nets and all other nets directly impacted by routing ECO nets for fixing routing DRC violations. |
| <code>route_zrt_eco -reroute modified_nets_only</code>                                                                            | Route only on nonfrozen layers. Route only the ECO nets.                                                                                   |
| <code>route_zrt_eco -nets</code><br><code>-reroute modified_nets_only</code>                                                      | Route only on nonfrozen layers. Route only the selected nets.                                                                              |

## Hierarchical Placement Area Reservation Flow

Use the hierarchical placement area reservation flow to insert buffers or repeaters on top-level nets over the existing soft macros without requiring design changes within the macro cells. This capability enables placement sharing over hierarchical cells similar to route or metal resource sharing.

The hierarchical placement area reservation flow in IC Compiler provides the following features and capabilities:

- Supports both top-down and bottom-up methodologies
  - Passes the reserved area from the top level to the child level as a placement blockage within the child level
  - Passes the reserved placement area from the child cell to the top level as a placeable area via the FRAM or ILM view
- Places buffers in the reserved area over the hierarchy of instantiated macros
- Places fill cells and other completed cells over the macro when repeater insertion is finished. These cells are inside the reserved area. The placement is done with the standard IC Compiler chip finishing methodology.

[Figure 15-5](#) describes the steps in the high-level hierarchical placement area reservation flow.

*Figure 15-5 The High-Level Hierarchical Placement Area Reservation Flow*



[Figure 15-5](#) includes the following steps:

1. Run the `create_placement_blockage` command to create placement sites at the top level with the bounding box of the placement blockages. The placement blockages are within the soft macro boundary.
2. Set the `is_reserved_placement_area` attribute to `true` on the placement blockages.
3. Derive the reserved placement sites with the `derive_reserved_placement_area` command.
4. Run the `create_macro_fram` command to propagate the placement resources to the FRAM views. This converts the reserved placement areas to placement sites.
5. Insert buffers over the soft macros and perform incremental legalization for the repeaters at the top level by using the `add_buffer_on_route` and `legalize_placement -eco` commands.
6. Run the `derive_pg_connection` command for PG connection and the `route_zrt_eco` command for ECO routing for the newly inserted top-level repeaters.

For details about running these commands, see the man pages.

### Top-Down and Bottom-Up Hierarchical Placement Area Reservation Flows

The hierarchical placement area reservation flow supports both top-down and bottom-up methodologies. For example, you can first reserve a space in the child macro. When the macro is completed and placed at the top level, the placement area is available for inserting top-level repeaters. Or you can define the area where the repeaters are to be placed and then push that information down to the child, which must honor it.

[Figure 15-6](#), [Figure 15-7](#), and [Figure 15-8](#) illustrate the top-down and bottom-up hierarchical placement area reservation flows using CEL or FRAM views.

*Figure 15-6 The Top-Down Hierarchical Placement Area Reservation Flow*



As shown in [Figure 15-6](#), you first create a rectangular or polygon shape that defines the area to be reserved for placement of the top-level repeaters. From this point on, this area is treated the same as a hard placement blockage within the cell. The area can be edited by using any of the standard editing commands, such as move, stretch, snap, align, distribute, and so on. When the cell is completed, convert the reserved placement area to placement

sites by pushing the information down to the child cell. Use blockage, pin, and via (BPV) extraction to handle the keep-in area for cell placement. After the buffers are inserted, use the `route_zrt_eco` command to run ECO routing on the changed nets.

*Figure 15-7 Bottom-Up Hierarchical Placement Area Reservation Flow Using CEL View*



As shown in [Figure 15-7](#), the child block SM.CEL has a basic floorplan. You create a rectangular or polygon shape that defines the area to be reserved for placement of the top-level repeaters. From this point on, this area is treated the same as a hard placement blockage within the cell. The area can be edited by using any of the standard editing

commands, such as move, stretch, snap, align, distribute, and so on. When the cell is completed, the tool marks the defined area as allowable for placement for the top-level cell. Use BPV extraction to handle the keep-in area for top-level cell placement. After the buffers are inserted, use the `route_zrt_eco` command to run ECO routing on the changed nets.

*Figure 15-8 Bottom-Up Hierarchical Placement Area Reservation Flow Using FRAM View*



Similar to the bottom-up flow using the CEL view, you first create a rectangular or polygon shape that defines the area to be reserved for placement of the top-level repeaters in the child block SM.CEL. When the cell is completed and the FRAM view is created, the defined area is marked as allowable for placement for the top-level cell. Use BPV extraction to handle the keep-in area for the SM.FRAME view for top-level cell placement. After the buffers are inserted, use the `route_zrt_eco` command to run ECO routing on the changed nets.

## Script Examples

The following is a script example for the top-down hierarchical placement area reservation flow.

```
open_mw_cel postroute
set_app_var legalize_enable_rpa_site_row true
create_placement_blockage -bbox {1000 1000 1860 1860} -name pb1
derive_reserved_placement_area -derive_type top_down
create_macro_fram -library_name macro.mw -cell_name mac1
add_buffer_on_route -no_legalize n999 BUFX1
legalize_placement -incremental -eco
route_zrt_eco
```

The following is a script example for the bottom-up hierarchical placement area reservation flow.

```
set_app_var legalize_enable_rpa_site_row true
# open soft macro CEL view
open_mw_cel mac1
create_placement_blockage -bbox {60 900 150 1000} -name pb1
set_attribute [get_placement_blockage pb1] \
    is_reserved_placement_area true
create_routing_blockage -layers {[get_layers -include_system \
    -filter {name=~metal*Blockage}]} -bbox {60 900 150 1000}

# open top-level CEL view
open_mw_cel postroute
derive_reserved_placement_area -derive_type bottom_up
create_macro_fram -library_name macro.mw -cell_name mac1
add_buffer_on_route -no_legalize n823 BUFX1
legalize_placement -eco
route_zrt_eco
```

---

## Removing Tie Cells

Use the `remove_tie_cells` command to remove tie cells. You can remove both tie cells that are preexisting in the design and those that are inserted by the tool. The tool replaces the original tie cell connections with the proper direct tie-off connections and removes the tie cells.

The syntax is

```
remove_tie_cells [-use_default_tie_net] list_of_tie_cells
```

---

| Argument                          | Description                                                                                                                      |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| <code>-use_default_tie_net</code> | Use the default SNPS_LOGIC0 or SNPS_LOGIC1 nets for tie-off.                                                                     |
| <code>list_of_tie_cells</code>    | Specify the tie cells to be removed. If no tie cells are specified, the command does nothing. Tie cells are leaf cell instances. |

---

To reconnect a leaf pin and a hierarchical pin to the tie-off net, the `remove_tie_cells` command creates or reuses a direct tie net. A tie-off net named SNPS\_LOGIC1 or SNPS\_LOGIC0 is a direct tie net and is written out by the Verilog writer as 1'b1 or 1'b0, respectively.

To connect a hierarchical port, the `remove_tie_cells` command creates an indirect tie net. A tie net with a name other than SNPS\_LOGIC1 or SNPS\_LOGIC0 is an indirect tie net. If the hierarchical port name is Q, the indirect tie-high net name created by this command is Q\_SNPS\_LOGIC1.

[Figure 15-9](#) shows an example of the changes that are made by the `remove_tie_cells` command.

*Figure 15-9 Tie-Off Connection During remove\_tie\_cells*



## Comparing Designs

To analyze logical changes in situations, such as before and after optimization, before and after clock tree synthesis, or before and after ECO, run the `eco_netlist` command with the `-by_design` and `-working_design` options using the following syntax:

```
eco_netlist -by_design golden_design [version]
            -golden_library golden_library
            -working_design working_design [version]
            -working_library working_library
```

With these options, the `eco_netlist` command can compare the working design netlist to the golden design that is in the same or a different design library. The working design can be your current design or the one you specify.

Note that when comparing designs after ECO, one of the `-by_verilog_file`, `-by_design`, or `-by_tcl_file` options is required and these options are mutually exclusive with each other.



# 16

## Signoff-Driven Design Closure

---

This chapter describes how to reduce timing violations during final signoff by using IC Compiler signoff-driven design closure.

IC Compiler is an implementation engine, and StarRC and PrimeTime are signoff engines. In general, the implementation engine and the signoff engine are well correlated with each other. However, small variations can occur because

- PrimeTime and StarRC, as signoff tools, are more accurate.
- PrimeTime has reduced signal integrity pessimism.
- IC Compiler might have implementation margins.
- IC Compiler might have fewer corners.

These differences can cause timing violations during final signoff. To reduce violations, you should use IC Compiler signoff-driven design closure. In this flow, IC Compiler automatically runs PrimeTime and StarRC to find violations. You can enable IC Compiler to perform optimizations automatically to fix these violations, or you can manually fix the violations.

This chapter describes IC Compiler signoff-driven design closure in the following sections:

- [Signoff-Driven Design Closure Overview](#)
- [Key Features](#)
- [Signoff-Driven Design Closure Methodology](#)

- [Usage Guidelines](#)
- [Troubleshooting and Problem Solving](#)

---

## Signoff-Driven Design Closure Overview

The starting point for IC Compiler signoff-driven design closure is a completely routed database from IC Compiler. This flow uses two key commands:

- `signoff_opt`, which runs analysis and optimization and is the basis of the automatic flow. For details, see “[Automatic IC Compiler Signoff-Driven Design Closure](#)” on [page 16-6](#).
- `run_signoff`, which runs analysis and is the basis of the manual flow. For details, see “[Manual IC Compiler Signoff-Driven Design Closure](#)” on [page 16-9](#).

During the analysis process, IC Compiler automatically runs StarRC to perform a complete parasitic extraction on the database and stores the results as an Synopsys Binary Parasitic Format (SBPF) file. To build the netlist and load the constraints and parasitic information, IC Compiler automatically runs PrimeTime. PrimeTime performs a full timing update and passes the timing information back to IC Compiler.

By default, the signoff-driven design closure flow requires the use of both the StarRC and PrimeTime signoff tools.

- To use StarRC for extraction and IC Compiler for timing analysis, use the `-star_only` option when you run the `run_signoff` or `signoff_opt` command.
- To use IC Compiler for extraction and PrimeTime for timing analysis, use the `-pt_only` option when you run the `run_signoff` or `signoff_opt` command.

When you use the `-pt_only` option, the flow supports distributed multi-scenario analysis, advanced on-chip variation (AOCV) modeling, and path-based analysis, as in the default `run_signoff` and `signoff_opt` flow.

**Note:**

If you are using an incremental flow with the `run_signoff -incremental` or `signoff_opt -skip_initial_analysis` command, you must ensure that you use the same tools for extraction and timing analysis in the incremental runs that you used in the initial `run_signoff` run. For example, if you perform the `run_signoff -pt_only` command, you should follow that by performing the `run_signoff -incremental -pt_only` or `signoff_opt -skip_initial_analysis -pt_only` command.

Running IC Compiler signoff-driven design closure increases your memory requirements. The `signoff_opt` command automatically saves one snapshot of the design even if you do not specify the `-snapshot` option. The tool automatically saves the best iteration, which is used as the final solution. For disk space requirement guidelines, see “[Usage Guidelines](#)” on [page 16-12](#).

---

## Key Features

IC Compiler signoff-driven design closure supports the following key features:

- Multicorner-multimode support

Signoff-driven design closure supports multicorner-multimode technology. When you use signoff with this technology, IC Compiler runs PrimeTime distributed multi-scenario analysis and multiple StarRC sessions, one for each parasitic corner. Under PrimeTime, a unique extraction corner requires a mixture technology file plus an operating temperature. This is similar to how IC Compiler defines a corner by using a TLUPlus file plus an operating temperature. To use signoff multicorner-multimode technology, follow the guidelines in [“Multicorner-Multimode Guidelines” on page 16-26](#).

- IEEE 1801 Unified Power Format (UPF) support

IC Compiler signoff-driven design closure supports designs with UPF constraints. IC Compiler automatically passes UPF constraints to PrimeTime for analysis when you run either the `run_signoff` or `signoff_opt` command. The `signoff_opt` flow with UPF constraints is supported for both multicorner-multimode and best-case and worst-case analysis. For IR drop analysis, you need to convert the `set_rail_voltage` commands to `set_voltage` commands manually so that you can use them in the UPF mode.

- Zroute support

By default, IC Compiler signoff-driven design closure uses Zroute for ECO routing. If you want to use the classic router during the `signoff_opt` command, run the `set_route_mode_options -zroute false` command before running the `signoff_opt` command.

- Bottleneck analysis support

IC Compiler signoff-driven design closure supports PrimeTime's bottleneck analysis. PrimeTime bottleneck analysis commands, including `report_bottleneck` and `report_si_bottleneck`, are available after `run_signoff` and `signoff_opt`.

- Path-based analysis support

To improve timing analysis accuracy, IC Compiler signoff-driven design closure supports the PrimeTime path-based analysis feature. To enable this feature, run the `run_signoff -path_based_analysis` or `signoff_opt -path_based_analysis` command.

- Script-based setup and hold fixing support

The `signoff_opt` command can invoke PrimeTime distributed multi-scenario analysis hold fixing script before it runs on-route optimization. To do that, set the `signoff_enable_dmsa_fix_hold` variable to 1 and specify the location of the script file that defines the `dmsa_fix_hold` procedure in the `signoff_pt_dmsa_script_file` variable.

You can also use a custom PrimeTime script to fix setup and hold violations. To enable this capability, set the `signoff_enable_dmsa_fix_signoff` variable to 1 and specify the location of the custom script file in the `signoff_pt_dmsa_script_file` variable. This custom script must be defined in a procedure called `dmsa_fix_signoff`, which has no input parameters.

Note:

These capabilities require PrimeTime version B-2008.12 or later. If you use an earlier version of PrimeTime, the `signoff_opt` command issues a warning and does not perform script-based fixing before on-route optimization.

- Focal optimization support

The `signoff_opt` command performs both on-route optimization and focal optimization to fix timing violations based on signoff timing analysis. To force the `signoff_opt` command to run only focal optimization without on-route optimization, specify the `-only_focal` option, using the following syntax:

```
signoff_opt -only_focal all | file_name
```

When you specify the `-only_focal all` option, the `signoff_opt` command uses signoff timing analysis to generate the focal optimization constraints and then uses focal optimization to fix the violating endpoints.

When you specify the `-only_focal file_name` option, the `signoff_opt` command performs focal optimization to fix the violations specified in the file. This capability enables you to focus on the fixing of a subset of timing violations.

Each focal optimization run fixes only one of the following violation types: setup, hold, or logical DRC. By default, focal optimization within the `signoff_opt` command fixes setup violations.

To use focal optimization to fix hold violations, you must specify the `-only_hold_time` option. To use focal optimization to fix logical DRC violations, you must specify the `-only_design_rule` option.

- Advanced on-chip variation (OCV) modeling and on-chip variation (OCV) support

On-chip variation (OCV) is supported in the `signoff_opt` command. If you enable crosstalk analysis, OCV is automatically supported. If you do not enable crosstalk analysis, you need to enable OCV analysis by using the following command:

```
set_operating_conditions -analysis_type on_chip_variation
```

When using the `set_operating_conditions -analysis_type on_chip_variation` command, you must specify the same value for both the `-max_cap_scale` and `-min_cap_scale` options of the `set_extraction_options` command, as they both apply to the same corner.

For advanced on-chip variation modeling support details, see “[General Guidelines](#)” on page 16-13.

- Automatic Generation of PrimeTime and StarRC Settings

In the signoff-driven design closure flow, IC Compiler runs PrimeTime and StarRC signoff tools to find timing violations. To automatically generate the necessary PrimeTime and StarRC settings for signoff, use the `create_signoff_setup` command before you run the `run_signoff` or `signoff_opt` command.

For more information, see “[Automatic Generation of PrimeTime and StarRC Settings](#)” on [page 16-18](#).

---

## Signoff-Driven Design Closure Methodology

This section describes the IC Compiler signoff-driven design closure methodology which consists of the following topics:

- [Automatic IC Compiler Signoff-Driven Design Closure](#)
- [Manual IC Compiler Signoff-Driven Design Closure](#)

---

### Automatic IC Compiler Signoff-Driven Design Closure

The automatic flow uses the `signoff_opt` command to run analysis and optimizations, such as buffer insertion, buffer removal, and cell sizing, which fix the violations reported during analysis. You can choose three effort levels of optimization: low, medium, or high. For details, see the `signoff_opt` man page.

To run the automatic flow, follow these steps:

1. Generate the necessary PrimeTime and StarRC settings.

Use the `create_signoff_setup` command to generate the required settings for signoff based on your current IC Compiler environment. If you are using PrimeTime, you can download an encrypted Tcl script through SolvNet to generate settings. The generated settings are based on your PrimeTime environment.

For details, see “[Automatic Generation of PrimeTime and StarRC Settings](#)” on [page 16-18](#).

2. If you are using multicorner-multimode technology, see [Example 16-2](#) and complete these steps:

- Set up your host farm by using the `add_distributed_hosts` command. You can verify your host options by using the `report_distributed_hosts` command.

Note that if you are using PrimeTime version F-2011.06 or later, the `signoff_opt` or `run_signoff` command automatically replaces the `add_distributed_hosts` command with the `set_host_options` command. This is because the `add_distributed_hosts` command has been replaced by the `set_host_options` command since PrimeTime version F-2011.06.

- Create your scenarios by using the `create_scenario` command.

For each scenario, specify the scenario-specific operating conditions, the TLUPPlus files, the SDC file, and the `max_nxtgrd_file` value. Note that the `min_nxtgrd_file` value is not supported.

For details, see [“Multicorner-Multimode Guidelines” on page 16-26](#).

3. Run the `signoff_opt` command.

You can also use the GUI by choosing Signoff > Optimize. The Signoff Optimize dialog box appears. Choose the appropriate effort level.

4. Review any violations.

Use the `report_timing`, `report_constraint`, or `report_qor` commands as needed. The reports are based on PrimeTime timing analysis.

5. To fix any remaining violations, follow the guidelines in the manual flow. See [“Manual IC Compiler Signoff-Driven Design Closure” on page 16-9](#).

[Example 16-1](#) shows an example script.

*Example 16-1 Using the signoff\_opt Command*

```
open_mw_cel post_route_opt

set_primetetime_options
set_starrcxt_options

report_primetetime_options
report_starrcxt_options
signoff_opt

report_timing
report_constraint -all_violators
run_signoff -signoff_analysis false

save_mw_cel -as signoff
```

[Example 16-2](#) shows an example script that uses multiple scenarios.

*Example 16-2 Using the signoff\_opt Command With Multiple Scenarios*

```
set pt_dir /tools/primetime/F-2011.06/amd64/syn/bin
set star_dir /tools/star_rcxt/F-2011.06/amd64_star-rcxt/bin

# global settings
set_primetime_options -exec_dir $pt_dir
set_starrcxt_options -exec_dir $star_dir

report_primetime_options
report_starrcxt_options

add_distributed_hosts -target all -farm lsf -setup_path /lsf/bin

report_distributed_hosts

# Create 3 scenarios with scenario specific settings
create_scenario maxmax
  set_operating_conditions -analysis_type on_chip_variation Worst
  set_tlu_plus_files -max_tluplus $max_tlu_file -tech2itf_map $map_file
  set_primetime_options -sdc_file $max_sdc_file
  set_starrcxt_options -max_nxtgrd_file $max_grd_file
create_scenario minmin
  set_operating_conditions -analysis_type on_chip_variation Best
  set_tlu_plus_files -max_tluplus $min_tlu_file -tech2itf_map $map_file
  set_primetime_options -sdc_file $min_sdc_file
  set_starrcxt_options -max_nxtgrd_file $min_grd_file

create_scenario nomnom
  set_operating_conditions -analysis_type on_chip_variation Nom
  set_tlu_plus_files -max_tluplus $nom_tlu_file -tech2itf_map $map_file
  set_primetime_options -sdc_file $nom_sdc_file
  set_starrcxt_options -max_nxtgrd_file $nom_grd_file

# run signoff optimization
signoff_opt
```

---

## Manual IC Compiler Signoff-Driven Design Closure

Manual IC Compiler signoff-driven design closure uses the `run_signoff` command to run analysis. After the analysis, you manually make optimizations to fix the violations reported during analysis. For example, you manually edit the netlist to do different optimizations, such as buffer insertion, buffer removal, or cell sizing. Both IC Compiler and PrimeTime simultaneously update the netlist with your changes, and PrimeTime runs an incremental timing update to verify the effects of the changes.

To run the manual flow,

1. Generate the necessary PrimeTime and StarRC settings.

Use the `create_signoff_setup` command to generate the required settings for signoff based on your current IC Compiler environment. If you are using PrimeTime, you can download an encrypted Tcl script through SolvNet to generate settings. The generated settings are based on your PrimeTime environment.

For details, see “[Automatic Generation of PrimeTime and StarRC Settings](#)” on [page 16-18](#).

2. If you are using multiple scenarios, that is, multicorner-multimode technology, see [Example 16-4](#) and follow these steps:

- Set up your host farm by using the `add_distributed_hosts` command. You can verify your host options by using the `report_distributed_hosts` command.

Note that if you are using PrimeTime version F-2011.06 or later, the `signoff_opt` or `run_signoff` command automatically replaces the `add_distributed_hosts` command with the `set_host_options` command. This is because the `add_distributed_hosts` command has been replaced by the `set_host_options` command since PrimeTime version F-2011.06.

- Create your scenarios by using the `create_scenario` command.

For each scenario, specify the scenario-specific operating conditions, the TLUPlus files, the SDC file, and the `max_nxtgrd_file` value. Note that the `min_nxtgrd_file` value is not supported. For details, see “[Multicorner-Multimode Guidelines](#)” on [page 16-26](#).

3. Run the `run_signoff` command.

You can also use the GUI by choosing Signoff > Analysis. The Run Signoff dialog box appears. Select the full analysis option.

4. Review any violations.

Use the `report_timing` and `report_constraint` commands as needed.

## 5. Manually fix the violations.

Use the `get_alternative_lib_cells`, `size_cell`, `insert_buffer` and `remove_buffer` commands as needed. You can run these commands from the GUI ECO menu. Other netlist editing commands, such as `create_cell`, are not supported in the IC Compiler signoff-driven design closure flow. From the Size Cell dialog box, you can preview slack improvement. For details, see “[Troubleshooting and Problem Solving](#)” on [page 16-32](#).

## 6. Run incremental legalization and incremental routing. This legalizes any newly added cells to legal locations and does ECO routing.

## 7. Run incremental analysis.

Use the `run_signoff -incremental` command. In the GUI, choose Signoff > Analysis. The Run Signoff dialog box appears. Select the incremental analysis option.

## 8. Review any violations. Repeat steps 3 through 6 until all violations are fixed.

[Example 16-3](#) shows an example script for running the `run_signoff` command.

### *Example 16-3 Using the run\_signoff Command*

```
set pt_dir /tools/primetime/F-2011.06/amd64/syn/bin
set star_dir /tools/star_rcxt/F-2011.06/amd64_star-rcxt/bin
set_starrcxt_options -exec_dir $star_dir -map_file $MAP \
    -max_nxtgrd_file $MAX_GRD \
    -min_nxtgrd_file $MIN_GRD
set_primetime_options -exec_dir $pt_dir -sdc_file $SDC
report_starrcxt_options
report_primetime_options
run_signoff
report_qor
report_timing
size_cell ...
insert_buffer ...
legalize_placement -eco
route_zrt_eco
run_signoff -incremental
report_qor
report_timing
```

[Example 16-4](#) shows an example script for a design that uses multiple scenarios.

### *Example 16-4 Using the run\_signoff Command With Multiple Scenarios*

```
set pt_dir /tools/primetime/F-2011.06/amd64/syn/bin
set star_dir /tools/star_rcxt/F-2011.06/amd64_star-rcxt/bin

open_mw_cel post_route_opt

# global settings
set_primetime_options -exec_dir $pt_dir
set_starrcxt_options -exec_dir $star_dir -map_file $map_file
```

```
report_primestime_options
report_starrcxt_options

add_distributed_hosts -target primetime -farm lsf -setup_path /lsf/bin
report_distributed_hosts

# Create three scenarios with scenario-specific settings
create_scenario maxmax
    set_operating_conditions -analysis_type on_chip_variation Worst
    set_tlu_plus_files -max_tluplus $max_tlu_file -tech2itf_map $map_file
    set_primestime_options -sdc_file $max_sdc_file
    set_starrcxt_options -max_nxtgrd_file $max_grd_file

create_scenario minmin
    set_operating_conditions -analysis_type on_chip_variation Best
    set_tlu_plus_files -max_tluplus $min_tlu_file -tech2itf_map $map_file
    set_primestime_options -sdc_file $min_sdc_file
    set_starrcxt_options -max_nxtgrd_file $min_grd_file

create_scenario nomnom
    set_operating_conditions -analysis_type on_chip_variation Nom
    set_tlu_plus_files -max_tluplus $nom_tlu_file -tech2itf_map $map_file
    set_primestime_options -sdc_file $nom_sdc_file
    set_starrcxt_options -max_nxtgrd_file $nom_grd_file

# run signoff optimization
run_signoff

report_timing
report_constraint -all_violators

get_alternative_lib_cells
size_cell
insert_buffer

legalize_placement -eco
route_zrt_eco

run_signoff -incremental
report_timing
report_qor

run_signoff -signoff_analysis false

save_mw_cel -as final
```

---

## Usage Guidelines

Before running IC Compiler signoff-driven design closure, you need to be familiar with the following usage guidelines:

- [Entry Requirements](#)
- [General Guidelines](#)
- [PrimeTime and StarRC Guidelines](#)
- [Multicorner-Multimode Guidelines](#)
- [Scenario Differences Between IC Compiler and PrimeTime](#)
- [Rail Voltage Information Update](#)

These guidelines are described in the next sections.

---

### Entry Requirements

When you use IC Compiler signoff-driven design closure, you should be finished with any functional ECO changes, and your design should meet the following conditions:

- There are no routing shorts. Routing shorts cause the tool to issue an error message and exit the `signoff_opt` command, unless you specify the `-ignore_design_readiness` option.
- The number of routing DRC violations must be less than 0.1 percent of the total nets or less than 1000 nets. Otherwise, the tool issues an error message and exits the `signoff_opt` command, unless you specify the `-ignore_design_readiness` option.
- The number of unrouted nets must be less than 0.1 percent of the total nets or less than 1000 nets. Otherwise, the tool issues an error message and exits the `signoff_opt` command, unless you specify the `-ignore_design_readiness` option.
- The number of logical DRC violations should be less than 0.1 percent of the total nets or less than 1000 nets. Otherwise, the tool issues a warning message.
- The number of violating paths should be less than 1000. Otherwise, the tool issues a warning message.
- Violating endpoints should be less than 1000. Otherwise, the tool issues a warning message.

You might not get the best QoR if your design does not meet the previous requirements when you run the `signoff_opt` command. To prevent the tool from exiting with an error message, run the `signoff_opt -ignore_design_readiness` command.

---

## General Guidelines

The following list describes the general IC Compiler signoff-driven design closure guidelines.

1. Signoff-driven design closure requires additional memory because the `signoff_opt` command automatically saves one snapshot of the design. Use the following guidelines for memory requirements:

- In the run directory, you need free space of at least twice the CEL size.
- In the directory that contains the Milkyway CEL view, you need free space of at least twice the CEL size.
- If you use the `-snapshot` option of either the `run_signoff` command or the `signoff_opt` command, you need about the same CEL size for both the run and the CEL view directory per iteration.

If you are using multicorner-multimode technology, you need additional memory. For details, see “[Multicorner-Multimode Guidelines](#)” on page 16-26.

2. To improve QoR, you can enable the tool to fix static noise by running the `set_si_options -static_noise true` command. When you use this command, the following commands are based on PrimeTime after the `run_signoff` and `signoff_opt` commands are run:

- `report_noise`
- `report_noise_parameters`
- `report_noiseViolation_sources`
- `report_si_aggressor_exclusion`
- `report_si_bottleneck`
- `report_si_double_switching`
- `report_si_delay_analysis`
- `report_si_noise_analysis`

3. To improve timing analysis, use the PrimeTime path-based analysis feature. To enable this feature, run the `run_signoff -path_based_analysis` command or the `signoff_opt -path_based_analysis` command.

4. To achieve better correlation with the standalone signoff tools, set the `StarRC REDUCTION` option to `YES`. For the best QoR, IC Compiler sets the `StarRC REDUCTION` option to `TOPOLOGICAL`, by default, when you run the `signoff_opt` command.

5. By default, IC Compiler signoff-driven design closure always performs full extraction either with StarRC or IC Compiler before starting the signoff flow. To quickly enter signoff mode without doing full extraction, run the `run_signoff -skip_initial_extraction` or `signoff_opt -skip_initial_extraction` command.

Note:

The `-skip_initial_extraction` option is available only for the first initial signoff run.

### PrimeTime Requirements

- A PrimeTime saved session is required with parasitics data loaded.
- All conditions or scenarios should have a PrimeTime image. For example, you should provide both maximum and minimum PrimeTime images for best-case and worse-case scenarios, and one PrimeTime image for each scenario in a multicorner-multimode design. As with the signoff multicorner-multimode behavior, specify the PrimeTime image by using the `set_primateime_options` command with the `-max_image` option in all scenarios, as shown in the following syntax:

```
set_primateime_options -max_image PT_session
```

- You must add the following command at the beginning of the PrimeTime script to generate a PrimeTime saved session for the `signoff_opt` command:

```
set_program_options -enable_eco
```

- You must set the `read_parasitics_load_locations` variable to `true` in the PrimeTime environment by using the following syntax:

```
set read_parasitics_load_locations true
```

### StarRC Requirements:

If you are using StarRC to generate the parasitics for PrimeTime images, use the following StarRC settings.

For the SPEF format, use the following settings:

```
REDUCTION: TOPOLOGICAL  
NETLIST_NODE_SECTION: YES  
EXTRA_GEOMETRY_INFO: NODE  
NETLIST_TAIL_COMMENTS: YES
```

For the SBPF format, use the following settings:

```
REDUCTION: TOPOLOGICAL  
EXTRA_GEOMETRY_INFO: NODE  
NETLIST_TAIL_COMMENTS: YES
```

6. After you run the `signoff_opt` command, you need to reinsert the filler cells. Any filler cells that overlap with new or changed cells are automatically removed during the `signoff_opt` run. Generally, it is best to run the `signoff_opt` command before chip finishing. But, if there is a significant timing impact during the chip finishing process, you need to run the `signoff_opt` command after chip finishing.
7. Perform metal fill before or after the signoff-driven design closure flow with the `run_signoff` or `signoff_opt` command. If metal fill has no or minor impact on timing, it should be done after `signoff_opt`; otherwise, run the `signoff_opt` command before metal fill.

You can perform metal fill in IC Compiler or StarRC.

### Metal Fill in IC Compiler

IC Compiler supports metal fill in one of the following ways:

- a. Using the IC Validator metal fill capability

Run the `signoff_metal_fill` command to use the IC Validator metal fill capability for designs that are at the 45-nm process node and below or designs that are routed with Zroute. IC Validator metal fill supports a timing-driven capability to address the timing impact that is introduced by running the `signoff_metal_fill -timing_preserve_*` command.

If metal fill has a significant timing impact that needs to be fixed with the `signoff_opt` command, use the following guidelines when running the `signoff_opt` flow:

- i. The metal fill must be in the FILL view, not the CEL view. To define metal fill in the FILL view, run the `signoff_metal_fill -timing_preserve_*` command.

- ii. The metal fill has to be floating. To define metal fill as floating, run the `set_extraction_options` command using the following syntax:

```
set_extraction_options -real_metalfill_extraction FLOATING
```

Note that the FILL view supports only floating metal fill.

- iii. Run the `signoff_opt` command with the `-only_psyn` option so that `signoff_opt` stops after ECO routing.

- iv. Perform automatic overlap removal for the FILL view to remove the fills that overlap with routes in the CEL view by using the following command:

```
signoff_metal_fill -remove_overlap_with_nets *
```

- v. Repeat steps iii and iv, if necessary.

b. Using the IC Compiler metal fill capability

Use IC Compiler metal fill for designs that are at the 65-nm process node and above or designs that are routed with the classic router. Note that the support of IC Compiler metal fill is limited to critical bug fixing only.

When using IC Compiler metal fill with the `insert_metal_filler` command, you must follow these recommendations:

- i. The metal fill must be in the FILL view, not the CEL view. To define metal fill in the FILL view, run the `insert_metal_filler` command using the following syntax:

```
insert_metal_filler ... -out design_name.FILL
```

- ii. The metal fill has to be floating. To define metal fill as floating, use the `insert_metal_filler -tie_to_net` command. Note that the FILL view supports only floating metal fill.

- iii. Run the `signoff_opt` command with the `-only_psyn` option so that `signoff_opt` stops after ECO routing.

```
signoff_opt -only_psyn
```

- iv. Manually update the metal fill by using the `trim_fill_eco` command to remove overlaps between signal routes and fill metals using the following syntax:

```
trim_fill_eco -input design_name.FILL -output design_name.FILL
```

- v. Repeat steps iii and iv, if necessary.

Both flows are semi-automatic with some manual effort. Note that no matter which flow you use, you lose the capability to run the incremental StarRC and incremental PrimeTime features for the `signoff_opt` command. This is because in each iteration, running the `signoff_opt -only_psyn` command performs full extraction and full timing analysis.

### Metal Fill in StarRC

To perform metal fill in StarRC, specify the following options in the `starrcxt_cmd` StarRC option file:

```
METAL_FILL_POLYGON_HANDLING : AUTOMATIC
MILKYWAY_ADDITIONAL_VIEWS: FILL
```

Then provide the `starrcxt_cmd` file to the `signoff_opt` command by running the following command:

```
set_starrcxt_options ... -option_file starrcxt_cmd
```

8. To exit the PrimeTime timing engine and return to the IC Compiler timing engine, run the `run_signoff -signoff_analysis false` command.

9. By default, the tool always runs incremental extraction and incremental PrimeTime analysis if possible. To force full extraction, use the `-full_extract` option. To force full timing analysis, use the `-full_analysis` option.

If you specify the `-full_extract` option, you must use the `-full_analysis` option. However, if you use the `-full_analysis` option, you do not need to use the `-full_extract` option. When you use the `-full_analysis` option without the `-full_extract` option, the tool runs StarRC with incremental extraction and creates a full netlist output. A warning is issued for runtime increases.

10. The `signoff_opt` command supports the IC Compiler hierarchical flow. However, the StarRC and PrimeTime SI runs are flat. If you run the command on a hierarchical design that contains ILMs or block abstraction models, IC Compiler requires less memory and should run faster. StarRC and PrimeTime SI are unaffected.

Note that for a design with ILMs or block abstraction models, the `signoff_opt` command requires that the link libraries and target libraries used for block-level implementation are in the search path.

11. If you run the `run_signoff` command before the `signoff_opt` command, you can use the `signoff_opt -skip_initial_analysis` command to use the previous analysis results. In this case, the previous `run_signoff` run must be done on a full design and you need to make sure that nothing is changed between the `run_signoff` and `signoff_opt` commands. Note that you still need to run StarRC to create the netlist output, but no actual extraction is needed.

12. IC Compiler signoff-driven design closure supports the advanced on-chip variation (OCV) modeling feature in PrimeTime. You enable advanced OCV modeling by using the `-aocvm` option with the `run_signoff` or `signoff_opt` command. You must use a saved session or the `-specific_file` option when running IC Compiler signoff-driven design closure with advanced OCV modeling. See “[PrimeTime and StarRC Customization Options](#)” on page 16-21.

13. You cannot change the timing constraints after you run the `run_signoff` command. To change timing constraints, exit `run_signoff` by using the `run_signoff -signoff_analysis false` command, as shown in the following example:

```
run_signoff
report_timing
run_signoff -signoff_analysis false
set_false_path
...
```

---

## PrimeTime and StarRC Guidelines

This section contains some PrimeTime and StarRC guidelines for running signoff-driven closure in IC Compiler.

The guidelines are described in the following sections:

- [PrimeTime and StarRC Version Requirements](#)
- [Automatic Generation of PrimeTime and StarRC Settings](#)
- [PrimeTime and StarRC Customization Options](#)
- [PrimeTime and StarRC Correlation](#)

### PrimeTime and StarRC Version Requirements

For best results, use the following signoff tools when running IC Compiler signoff-driven design closure:

- PrimeTime version F-2011.06 or later

IC Compiler uses the default options of PrimeTime and the PrimeTime SI default filters in the signoff-driven design closure flow. If you want to use nondefault settings, see [“PrimeTime and StarRC Customization Options” on page 16-21](#).

- StarRC version F-2011.06 or later

IC Compiler accepts a StarRC run directory, and supports writing subnode information. IC Compiler uses the following default StarRC options in the signoff-driven design closure flow:

- MODE: 200
- OPERATING\_TEMPERATURE: 25
- REDUCTION: TOPOLOGICAL

If you want to use nondefault options, see [“PrimeTime and StarRC Customization Options” on page 16-21](#).

### Automatic Generation of PrimeTime and StarRC Settings

Run the `create_signoff_setup` command to automatically generate the required settings for signoff based on your current environment. By default, the tool saves all the output files to the directory named `signoff_setup`. Use the `-output directory` option if you want to save the files to a directory that you specify. Note that you need to manually specify some of the settings in the output Tcl file for a successful StarRC or PrimeTime run, such as the location of a map file for StarRC or a common file for PrimeTime.

The `create_signoff_setup` command uses the following syntax:

```
create_signoff_setup
  [-output directory] [-verbose] [-overwrite]
```

The `signoff_setup.tcl` file, generated by the `create_signoff_setup` command, contains the required signoff settings with detailed descriptions and examples. The following is an example of the output Tcl file:

```
add_distributed_hosts
set_primestime_options -exec_dir ... -common_file ...
set_starrcxt_options -exec_dir ... -map_file ...
report_primestime_options
report_starrcxt_options

# scenario-specific setup
remove_scenario xxx
create_scenario xxx
current_scenario xxx
set_primestime_options -sdc_file ... -specific_file ...
set_primestime_options -max_image ...
set_starrcxt_options -max_nxtgrd_file ...
report_primestime_options
...
run_signoff -check_only
check_signoff_correlation
```

The following list describes the commands used in the Tcl file.

- `add_distributed_hosts`  
`# LSF: add_distributed_hosts -target all -farm lsf \`  
`-setup_path /lsf/bin -options {-q amd64} -num_of_hosts 8`  
`# GRD: add_distributed_hosts -target all -farm grd \`  
`-setup_path /grd/bin -num_of_hosts 8`

Use the `add_distributed_hosts` setting to submit multiple PrimeTime and StarRC jobs to an LSF or Oracle Grid Engine pool, or to different local machines. Doing this reduces CPU and memory usage on the machine that runs IC Compiler, thus saving runtime in the IC Compiler signoff flow. For a design with multiple scenarios, this also allows you to submit all jobs to other machines and run them at the same time, which improves runtime significantly.

Note that if you are using PrimeTime version F-2011.06 or later, the `signoff_opt` or `run_signoff` command automatically replaces the `add_distributed_hosts` command with the `set_host_options` command. This is because the `add_distributed_hosts` command has been replaced by the `set_host_options` command since PrimeTime version F-2011.06.

- `set_primestime_options -exec_dir ${ptdir} -common_file ${common_file}`  
`set_starrcxt_options -exec_dir ${starrcxtdir} -map_file ${map_file}`

The tool can detect a PrimeTime or StarRC binary from your search path. For a map or common file, you need to specify the location manually.

- `set_primestime_options -sdc_file ${scenario_name}.sdc \`  
`-specific_file ${scenario_name}.tcl`  
`set_starrcxt_options -max_nxtgrd_file ${nxtgrd_max}`

Specify the necessary StarRC and PrimeTime settings. Some options require your manual input, such as the names of the nxtgrd and SDC files. Because the `create_signoff_setup` command writes out the SDC files during signoff using the settings in IC Compiler or PrimeTime, you can decide whether to use any SDC file from PrimeTime with the `-sdc_file` option, or let the tool automatically use the SDC file from IC Compiler.

- `report_primestime_options`  
`report_starrcxt_options`

Report the settings of the `set_starrcxt_options` and `set_primestime_options` commands. You should always perform a report command per scenario.

- `run_signoff -check_only`

Run a quick signoff without invoking PrimeTime and StarRC.

## For PrimeTime Users

If you are using PrimeTime, download the Tcl script named `signoff_setup.tcl.e.PT` from [SolvNet article 031628](#) and run the script in PrimeTime to generate a similar setup script.

To create the required settings for signoff within PrimeTime, run the `create_signoff_setup` command using the following syntax:

```
source signoff_setup.tcl.e.PT
create_signoff_setup
  [-output directory] [-verbose]
  [-overwrite]
```

Note the following differences in this script as compared with the one generated in IC Compiler:

- For multicorner-multimode designs, if the IC Compiler scenarios differ from those in PrimeTime, the script generated from PrimeTime always removes all IC Compiler scenarios and regenerates each scenario based on the PrimeTime environment.
- PrimeTime images, that is, saved sessions, are generated from PrimeTime distributed multi-scenario analysis (DMSA) and used during the `set_primestime_options -max_image run`.

## PrimeTime and StarRC Customization Options

When you use IC Compiler signoff-driven design closure, IC Compiler automatically runs PrimeTime and StarRC using each tool's default settings. If you want to customize these settings, use the following options:

- Saved sessions
- The `-common_file` option to the `set_primestime_options` command
- The `-specific_file` option to the `set_primestime_options` command
- The `-option_file` option to the `set_starrcxt_options` command
- The `-mode` option to the `set_starrcxt_options` command

These methods are described in the following paragraphs.

### Saved Sessions

To create a saved session in PrimeTime, use the `save_session` command in PrimeTime. Note that you must add the following command at the beginning of the PrimeTime script to generate a PrimeTime saved session for the `signoff_opt` command:

```
set_program_options -enable_eco
```

Without this command, IC Compiler cannot use the saved session for incremental analysis. If you try to run the `signoff_opt` command with a PrimeTime saved session that does not have ECO enabled, IC Compiler issues a PSYN-441 warning and behaves as if the `-only_psyn` option is specified.

To use a saved session of PrimeTime, specify the PrimeTime saved session file name by using the `-max_image` option or the `-min_image` option of the `set_primestime_options` command, as shown in [Example 16-5](#). To verify your PrimeTime option settings, use the `report_primestime_options` command, as shown in [Example 16-6](#).

To use a saved session of StarRC, specify the run directory name by using the `set_starrcxt_options` command, as shown in [Example 16-5](#). To verify your StarRC option settings, use the `report_starrcxt_options` command, as shown in [Example 16-7](#) on page [16-22](#).

***Example 16-5 Specified Saved PrimeTime and StarRC Runs***

```

set SDC pt.sdc
set pt_dir /tools/primetime/F-2011.06/amd64/syn/bin
set star_dir /tools/star_rcxt/F-2011.06/amd64_star-rcxt/bin
set_starrcxt_options -exec_dir $star_dir \
    -max_nxtgrd_file $MAX_GRD \
    -min_nxtgrd_file $MIN_GRD \
    -max_image star_max \
    -min_image star_min \
    -map_file $MAP
set_primestime_options -exec_dir $pt_dir -sdc_file $SDC \
    -max_image pt_max \
    -min_image pt_min
report_starrcxt_options
report_primestime_options

```

***Example 16-6 Report PrimeTime Options***

```

icc_shell> report_primestime_options
*****
Report : PrimeTime_options
Design : tutorial
Version:
Date   :
*****
PrimeTime exec dir: / tools/primetime/F-2011.06/amd64/syn/bin
PrimeTime SDC file: /home/signoff/tutorial/pt.sdc
PrimeTime max image: pt_max
PrimeTime min image: pt_min

```

***Example 16-7 Report StarRC Options***

```

icc_shell> report_starrcxt_options
*****
Report : StarRCXT_options
Design : tutorial
Version:
Date   :
*****
StarRCXT exec dir: /tools/star_rcxt/F-2011.06/amd64_star-rcxt/bin
StarRCXT max nxtgrd file: /libraries/71m.nxtgrd
StarRCXT min nxtgrd file: /libraries/71m.nxtgrd
StarRCXT map file: /libraries/90_71m.map
StarRCXT max image: star_max
StarRCXT min image: star_min

```

## Running the `set_primestime_options -common_file` Command

The `set_primestime_options -common_file` command uses one file for all PrimeTime runs (best-case/worst-case, and all scenarios). This file is sourced into PrimeTime before the netlist loads and is used for setting up Tcl variables.

Only the following variables are allowed; otherwise, the tool reports a PSYN-387 error:

- All RC variables
- All case analysis variables
- All CCS variables
- All path-based analysis variables
- All report variables
- All timing variables except `timing_save_pin_arrival_and_slack`
- All signal integrity variables except `si_enable_analysis`
- All parasitic variables except `read_parasitics_load_locations`
- All variation variables except `variation_enable_analysis` and `variation_derived_scalar_attribute_mode`

## Running the `set_primestime_options -specific_file` Command

When you use the `set_primestime_options -specific_file` command, you can specify up to two files `{max_file min_file}` in best-case/worst-case mode. The second file is used for the PrimeTime minimum corner in best-case/worst-case analysis. If only one file is specified, the same file is used for both corners. This file is sourced into PrimeTime after the netlist loads. You can specify one specific file per corner when using multicorner-multimode technology in the IC Compiler signoff-driven design closure flow.

Only the following commands are allowed; otherwise, the tool reports a PSYN-388 error:

- All report commands
- All check commands
- All update commands
- All set commands except `set_units` and `set_unix_variable`
- All reset commands except `reset_design`
- `create_correlation` and `create_variation`
- `define_scaling_lib_group`
- `group_path`

- `read_aocvm` and `remove_aocvm`
- `scale_parasitics` and `complete_net_parasitics`

### Running the `set_starrcxt_options -option_file` Command

To customize StarRC options, use the `set_starrcxt_options -option_file` command. This is a file you create that contains a subset of the StarRC command file.

Note that the following commands are reserved and are automatically set by IC Compiler. Do not put any of these commands in the option file; otherwise, the tool returns a PSYN-171 error:

- `BLOCK`
- `COUPLE_TO_GROUND`
- `EXTRA_GEOMETRY_INFO`
- `FSCOMPARE_FILE_PREFIX`
- `FS_PREPROCESSOR_STAGE`
- `HIERARCHICAL_SEPARATOR`
- `INCREMENTAL`
- `MAPPING_FILE`
- `MILKYWAY_DATABASE`
- `MILKYWAY_EXPAND_HIERARCHICAL_CELLS`
- `MULTI_CPU_ON_LICENSE_ONLY`
- `NETLIST_FILE`
- `NETLIST_FORMAT`
- `NETLIST_INCREMENTAL`
- `NETLIST_NODE_SECTION`
- `NETLIST_TAIL_COMMENTS`
- `STAR_DIRECTORY`
- `SENSITIVITY`
- `TARGET_ANALYSIS`
- `TCAD_GRD_FILE`

### Running the `set_starrcxt_options -mode` Command

You can specify a StarRC mode by running the `set_starrcxt_options -mode` command. The valid values are 100, 150, 200, and 400. The default is 200. The mode establishes the tradeoff between runtime and accuracy. See the man page for details. You can also provide the mode by using the `set_starrcxt_options -option_file` command.

## PrimeTime and StarRC Correlation

IC Compiler runs PrimeTime and StarRC during the signoff-driven design closure flow. Run the `check_signoff_correlation` command to check the correlation between IC Compiler and PrimeTime, and between IC Compiler and StarRC, including

- The timing and signal integrity related variables, commands, and SDC setup in both IC Compiler and PrimeTime
- The extraction settings in both IC Compiler and StarRC

When correlation checking is completed, the command generates a correlation report and other files for correlation analysis and correlation improvement.

Note:

Correlation setup checking is faster with the `check_signoff_correlation` command than with the `run_signoff -correlation` command, because the `check_signoff_correlation` command does not invoke StarRC or PrimeTime.

Run the `check_signoff_correlation` command using the following syntax:

```
check_signoff_correlation
  -setup
  -spf_out
  -pt_only
  -star_only
  -preroute
  -keep_signoff_mode
  -html
  -output output_directory
```

## Multicorner-Multimode Support

If the design being analyzed is a multicorner-multimode design, running the `run_signoff -correlation` or `check_signoff_correlation` command generates all the related reports and script files for each scenario. The generated files are stored in the output directory using the following structure:



## Multicorner-Multimode Guidelines

Use the following guidelines when running IC Compiler signoff-driven design closure with multicorner-multimode technology:

1. Using IC Compiler signoff-driven design closure in multicorner-multimode requires additional memory space. Use the Unix `top` command to determine the amount of available memory. As a general rule, you need 10 GB memory to run IC Compiler for a one million instance design for a single scenario. For a multicorner-multimode design with X instances and Y scenarios, the memory requirement is:

$$10 \text{ GB}/(1 \text{ MB}/X) * Y * 25\%, \text{ assuming } Y \geq 4$$

This requirement only considers the IC Compiler process. PrimeTime and StarRC processes are assumed to be run with distributed hosts. If you use GRD/LSF for your main IC Compiler process, memory size needs to be bigger because you are sharing with other users. Insufficient memory causes excessive memory swap and increases runtime.

2. When using GRD for your distributed processes, you must submit the job as a binary job by using the `-b y` option. Otherwise, PrimeTime fails. The following example uses the `-b y` option.

```
add_distributed_hosts -farm grd \
    -setup_path ... -num_of_hosts 8 \
    -options {-cwd -P bnormal -b y -l arch=glinux,cputype=amd64}
```

These options direct the `qsub` command to run the specified script directly without making an intermediate copy, which speeds up the submission of the jobs. For details, see the `qsub` man page.

3. IC Compiler signoff-driven design closure uses a distributed processing environment. Note that by default IC Compiler signoff-driven design closure uses the remote shell (rsh) program to invoke the StarRC and PrimeTime processes. To use the C-shell (csh), create a runcmd file as follows:

```
#!/bin/csh -f  
$argv &
```

Specify the `add_distributed_hosts` command with the `runcmd` script file as follows:

```
add_distributed_hosts -submission_script runcmd ...
```

To use the ssh secure shell protocol, use the `-enable_ssh` option as follows:

```
add_distributed_hosts -enable_ssh
```

**Note:**

The secure shell protocol must be configured without using an explicit user name and password. This is a PrimeTime distributed multi-scenario analysis limitation.

If you are using PrimeTime version F-2011.06 or later, the `signoff_opt` or `run_signoff` command automatically replaces the `add_distributed_hosts` command with the `set_host_options` command. This is because the `add_distributed_hosts` command has been replaced by the `set_host_options` command since PrimeTime version F-2011.06.

4. Scenarios are not run on the local host unless explicitly defined in the `add_distributed_hosts` command. If the number of scenarios is more than the number of hosts specified by the `add_distributed_hosts` command, the tool waits until a host becomes free to run the additional scenarios.

For example, if you have 15 scenarios and specify only 5 hosts by using the following command:

```
icc_shell> add_distributed_hosts -farm lsf -num_of_hosts 5
```

the tool analyzes the 15 scenarios using the 5 LSF hosts, based on a daisy-chain schedule.

This behavior is the same as the PrimeTime distributed multi-scenario analysis behavior.

5. IC Compiler signoff-driven design closure starts running PrimeTime distributed processes as soon as a single host becomes available. Other hosts start PrimeTime processes as soon as they become available.

For example, if you define 15 hosts by using the following command:

```
icc_shell> add_distributed_hosts -farm lsf -num_of_hosts 15
```

IC Compiler starts your PrimeTime analysis as soon as the first host becomes available from LSF. Additional PrimeTime processes start as soon as additional hosts become available.

Note that PrimeTime distributed multi-scenario analysis allows you to specify how many hosts must be available before you can run another task. This feature cannot be configured in IC Compiler signoff-driven design closure (`signoff_opt` and `run_signoff`). IC Compiler always sets this value to 1.

6. If you use `add_distributed_hosts` multiple times, the number of hosts is cumulative. For example, if you run the following commands:

```
add_distributed_hosts -farm lsf -num_of_hosts 4
add_distributed_hosts -farm now -num_of_hosts 2 unix1
add_distributed_hosts -farm now -num_of_hosts 2 unix2
```

IC Compiler runs the first four processes on LSF hosts, the next two processes on the machine “unix1,” and the last two processes on the machine “unix2.”

7. The `signoff_opt` command supports only the `-leakage_power` option of the `set_scenario_options` command; it ignores any other options of the `set_scenario_options` command.
8. The `signoff_opt` command automatically calls the `get_dominant_scenarios` command before optimization for scenario reduction. Scenario reduction saves runtime with a minor QoR impact.

Check the messages written to the log file when scenarios are reduced by the adaptive multicorner-multimode technology. In the following example, scenario1 and scenario2 remain active. Scenario3 and scenario4 are no longer active.

```
Reduced scenarios: scenario1 scenario2 ...
Information: Scenario scenario3 is no longer active. (UID-1022)
Information: Scenario scenario4 is no longer active. (UID-1022)
```

9. After you run the initial analysis (`run_signoff`),
  - Determine the dominant scenario by using the `get_dominant_scenarios` command.
  - To manually reduce the number of scenarios, specify the active scenarios by using `set_active_scenarios`.
10. IC Compiler does not support the PrimeTime `current_session` command. Use `set_active_scenarios` instead.

11. All active scenarios in IC Compiler, that is, those specified by the `set_active_scenarios` command, are analyzed in PrimeTime distributed multi-scenario analysis. Inactive scenarios in IC Compiler are not analyzed in PrimeTime.

Use a one-to-one mapping between active scenarios in IC Compiler to scenarios in PrimeTime. Note the following:

- IC Compiler does not split a scenario based on minimum and maximum conditions.
- For each scenario, you must use on-chip variation (OCV) and you cannot use `set_min_library`, `minimum TLUPlus`, `minimum nxtgrd`, `minimum images` for PrimeTime, or `minimum images` for StarRC.

12. You must redefine scenarios for `signoff_opt` if a scenario contains two corners in IC Compiler.

Because IC Compiler does not split a scenario based on minimum and maximum conditions automatically, you must redefine all your best case and worst case scenarios.

For example, assume the following best case and worst case scenario in IC Compiler multicorner-multimode:

```
set_tlu_plus_files -max_tluplus max.tlup -min_tluplus min.tlup
set_min_library -min_version fast.db slow.db
set_operating_conditions -analysis_type bc_wc
```

When using the `set_operating_conditions -analysis_type bc_wc` command, you can specify different values for the `-max_cap_scale` and `-min_cap_scale` options of the `set_extraction_options` command, for the two different corners.

You need to replace the single scenario with two scenarios, when running IC Compiler signoff-driven design closure with multicorner-multimode technology:

- Scenario worst case (WC)

```
set_tlu_plus_files -max_tluplus max.tlup
# Use slow.db as the link_library
set_operating_conditions -analysis_type on_chip_variation
```

- Scenario best case (BC)

```
set_tlu_plus_files -max_tluplus min.tlup
# Use fast.db as the link_library
set_operating_conditions -analysis_type on_chip_variation
```

13. After you run the `run_signoff` command, you cannot activate a scenario that was inactive before you ran the `run_signoff` command. If you try to do so, IC Compiler issues a PSYN-432 warning message.
14. IC Compiler disables the `create_scenario` and `remove_scenario` commands after you run the `run_signoff` or `signoff_opt` command. To enable these commands, quit signoff mode by running the following command:

```
run_signoff -signoff_analysis false
```

---

## Scenario Differences Between IC Compiler and PrimeTime

When creating scripts for IC Compiler signoff-driven design closure, you need to understand how IC Compiler and PrimeTime handle scenarios differently. Both tools define scenarios the same way by using the `create_scenario` command, but each tool uses a different command to specify the scenarios to be used in the current run. IC Compiler uses the `set_active_scenarios` command; PrimeTime uses the `current_session` command. Keep the following in mind:

- The scenario concept is the same for both IC Compiler and PrimeTime.
- The actual user interface commands have differences.
- IC Compiler's *active scenario* is similar to PrimeTime's *session*.
- IC Compiler does not support the PrimeTime `current_session` command. You need to use the `set_active_scenarios` command instead.
- Each PrimeTime process reads only one corner for the `read_parasitics` command.
- IC Compiler reads multiple corners for the `read_parasitics` command.

After you run the IC Compiler `current_scenario` command, most reporting commands and the `read_parasitics` command are applied only to the specified current scenario. All other commands, such as optimization and netlist editing commands, are applied to all scenarios. The IC Compiler `current_scenario` command does not support the following PrimeTime commands:

- `current_scenario -all`
- `current_scenario {Func Test}`

After you run the PrimeTime `current_scenario` command, all commands are applied to the specified current scenario. Even optimization commands, such as `size_cell`, change only the given scenarios. The PrimeTime `current_scenario` command supports the following options:

- `current_scenario -all`

- `current_scenario {Func Test}`

After you run the IC Compiler `run_signoff` command, the `current_scenario` behavior is changed to update both IC Compiler and PrimeTime.

- `current_scenario -all`

No change occurs to the current scenario in IC Compiler.

Command focus is changed to include all scenarios in PrimeTime distributed multi-scenario analysis.

- `current_scenario Func`

Running the `current_scenario Func` command changes the current scenario to Func in IC Compiler.

Running the `current_scenario Func` command changes the command focus to Func in PrimeTime distributed multi-scenario analysis.

---

## Rail Voltage Information Update

During the signoff-driven design closure flow in IC Compiler, you can use PrimeTime with IR drop analysis by specifying rail voltages on cell instances or hierarchical cells. The specified rail voltage, which is usually slightly different in comparison to the default operating condition voltage value, is then used as a scaling factor in PrimeTime delay calculation. The actual rail voltage is obtained from PrimeTime PX or PrimeRail.

To update rail voltage information for cells that are newly inserted to the netlist without actually invoking PrimePower or PrimeRail, run the `signoff_opt -update_rail_voltage` command.

Because `signoff_opt` does not support PrimePower and PrimeRail directly, you need to use either the previously saved PrimeTime sessions or the `-specific_file` option to specify rail voltage information for existing cells. By updating rail voltage information for newly inserted cells after optimization, timing analysis is more accurate with consideration of IR drop effects.

---

## Troubleshooting and Problem Solving

Troubleshooting guidelines are as follows:

1. To help you find problems early and quickly, you can check your design by running the `run_signoff -check_only` command. In this case you do not actually invoke StarRC and PrimeTime.
2. If IC Compiler signoff-driven design closure is producing poor QoR, your design might not be meeting the entry requirements. For detailed requirements, see “[Entry Requirements](#)” on page 16-12.
3. If your IC Compiler signoff-driven design closure runs are excessively slow, you might not have enough memory. For memory requirements, see “[Usage Guidelines](#)” on page 16-12 and “[Multicorner-Multimode Guidelines](#)” on page 16-26.
4. If you are getting warnings about not being able to load the PrimeTime or StarRC tools, you might not be using the correct StarRC or PrimeTime versions or platforms.
5. The signoff-driven design closure flow requires that IC Compiler and PrimeTime use the same library models. If different library models, such as NLDM and CCS, are detected in the two tools, the `run_signoff` and `signoff_opt` commands issue an error and quit. To ignore this inconsistency and allow these commands to continue, use the `-ignore_library_mismatch` option.

You can use the `get_libs *` or `write_link_library` command before `signoff_opt` and `run_signoff` to ensure library consistency between IC Compiler and PrimeTime.

6. After you save the Milkyway CEL view and reload it, you might have inconsistencies in your timing reports among IC Compiler, PrimeTime, and StarRC. If this happens, run the `run_signoff` command again. The timing in IC Compiler is different from the timing in PrimeTime and StarRC, shown by the previous `run_signoff` session, until you run the `run_signoff` command again.
7. If you are performing manual fixing, you can preview slack improvements in the GUI by using the Size Cell dialog box. Choose ECO > Size Cell. The Size Cell dialog box appears. Choose an alternative reference cell to size the cells in the design that have the same reference name. From this dialog box you can calculate slack values for alternative reference cells. This enables you to see how much slack can be improved with the new reference cell before you make actual changes to the netlist. [Figure 16-1](#) shows the current slack values and the new values for an alternative reference cell.

Figure 16-1 Slack Preview Using the GUI



From the Size Cell dialog box, you can highlight the checked cells in layout view to see the locations of these checked cells. You can select different colors for highlighting.

[Figure 16-2](#) highlights the checked cells in yellow.

Figure 16-2 Highlighting Cell Locations



# A

## Using GUI Tools

---

The IC Compiler GUI provides a variety of tools for viewing, analyzing, and editing your design. This appendix provides an overview of these tools. For detailed information about these tools, see IC Compiler Help.

This appendix contains the following sections:

- [Viewing a Design](#)
- [Examining Design and Object Information](#)
- [Visualizing the Physical Design](#)
- [Analyzing the Physical Design](#)
- [Analyzing Timing Paths](#)
- [Examining Routing and Verification Errors](#)
- [Editing the Physical Layout](#)

---

## Viewing a Design

The IC Compiler GUI displays graphic representations of design data in several types of graphic views. To help you visualize a design, the GUI provides tools and commands that you can use to examine the design data and to select or highlight objects of interest for analysis and editing.

- Layout views are the focal point of the IC Compiler GUI. A layout view displays graphic representations of design objects in a single, flat view of the physical design. You can display or hide objects or layers and customize the viewing environment. You can also open multiple layout views to work simultaneously with different areas of the design.

For information about working in a layout view, see [“Visualizing the Physical Design” on page A-34](#).

- Histograms are focal points of visual timing analysis that allow you to view the overall timing performance of your design. You can generate histograms to view distributions of timing values such as slack or clock arrival times.

For information about working with histograms, see [“Viewing Histograms” on page A-69](#).

- Schematic views display schematic representations of specific types of design data. You can use different types of schematic views to examine logic designs (hierarchical cells), selected objects or timing paths (including fanin and fanout logic), and the fanin or fanout networks for selected clock trees.

For information about working in schematic views see [“Viewing Path and Design Schematics” on page A-71](#) and [“Viewing the Fanout or Fanin Schematic” on page 7-136](#).

- Clock graph views display time-based representations of clock tree fanout networks. You can use clock graph views to examine clock tree fanout and fanin in a time-based display that facilitates clock tree latency and skew analysis. A clock graph view displays a symbolic representation of design data that is similar to a schematic display.

For information about working in clock graph views, see [“Viewing Clock Latency and Skew in the Clock Graph View” on page 7-133](#).

The GUI provides interactive left-button mouse tools that you can use to view and probe a design. In a layout or schematic view, you can

- Select or deselect individual objects or timing paths or objects in an area of the design

Selection is global in IC Compiler. Any objects or timing paths that you select appear selected in all open views.

- Color highlight individual objects or timing paths or objects in an area of the design

Highlighting is global in graphic views. When you highlight objects or timing paths in a view, the GUI highlights them with the same color in every view where they appear.

- Display (query) object properties for individual objects (such as design and timing attribute values)
- Traverse (pan) the design and magnify or shrink (zoom) areas of interest
- Draw rulers to measure distances in a layout view or clock graph view

For information about performing these tasks, see the following sections:

- [Selecting a Mouse Tool](#)
- [Previewing Objects in a Layout View](#)
- [Selecting Objects](#)
- [Highlighting Objects](#)
- [Selecting Only the Highlighted Objects](#)
- [Selecting or Highlighting Objects by Name](#)
- [Viewing Object Information](#)
- [Magnifying and Traversing the Design](#)

For details about drawing rulers, see “[Drawing Rulers](#)” on page A-36.

---

## Selecting a Mouse Tool

Mouse tools control the actions performed in graphic views when you click or drag the pointer with the left mouse button. IC Compiler provides mouse tools for design visualization that you can use to

- Magnify or traverse the view in a layout, schematic, histogram, or clock graph view
- Select, highlight, or query objects in a layout, schematic, or clock graph view
- Draw rulers in a layout or clock graph view

The visualization mouse tools are available in all top-level GUI window. You can activate these mouse tools by clicking buttons on the Mouse Tools toolbar or by choosing commands on the Mouse Tools menu. (Choose *View > Mouse Tools* to display the menu.) [Figure A-1](#) shows the full version of this toolbar that is available in the layout window.

**Figure A-1 Full Mouse Tools Toolbar**

[Figure A-2](#) shows the abbreviated version of the toolbar that is available in the main window, the timing analysis window, and the interactive CTS window.

**Figure A-2 Abbreviated Mouse Tools Toolbar**

[Table A-1](#) describes the tasks you can perform with the tools on the Mouse Tools toolbar.

**Table A-1 Mouse Tools**

| To perform this task                                                                                | Use this tool                                                    |
|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| To set the left mouse button to select objects by clicking or dragging with the Selection tool,     | Click the  button or choose View > Mouse Tools > Selection tool. |
| To set the left mouse button to highlight objects by clicking or dragging with the Highlight tool,  | Click the  button or choose View > Mouse Tools > Highlight Tool. |
| To set the left mouse button to display object information by clicking objects with the Query tool, | Click the  button or choose View > Mouse Tools > Query Tool.     |
| To set the left mouse button to magnify the design by clicking or dragging with the Zoom In tool,   | Click the  button or choose View > Mouse Tools > Zoom In Tool.   |

**Table A-1** *Mouse Tools (Continued)*

| To perform this task                                                                              | Use this tool                                                                                                                                    |
|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| To set the left mouse button to shrink the design by clicking or dragging with the Zoom Out tool, | Click the  button or choose View > Mouse Tools > Zoom Out Tool. |
| To set the left mouse button to scroll or navigate through the design by dragging the Pan tool,   | Click the  button or choose View > Mouse Tools > Pan Tool.      |
| To set the left mouse button to draw rulers by clicking with the Ruler tool,                      | Click the  button or choose View > Mouse Tools > Rule Tool.     |

**Note:**

IC Compiler also provides mouse tools that you can use to perform various layout editing tasks. For details about these mouse tools, see “[Editing Objects Interactively](#)” on [page A-87](#).

The Selection tool is the default mouse tool. When you open a layout window or a new layout view, schematic view, or histogram view, the Selection tool is the active mouse tool. When you enable a mouse tool in the active view, the tool remains active until you enable a different mouse tool. When you change the mouse tool, you change it only in the active view.

When you enable a mouse tool in a layout view, the options for using the tool appear on the Mouse Tool Options toolbar. See [Figure A-3 on page A-7](#) for an example of this toolbar. If you need assistance using the active mouse tool, you can click the  button to display a Help page in the man page viewer.

You can use the Zoom In tool, the Zoom Out tool, or the Pan tool as nested tools when you are performing an operation with another mouse tool. When you finish the nested tool operation, the left mouse button returns to the previous tool and you can resume the operation that you were performing with that tool.

For more information about using mouse tools, see the “Selecting a Mouse Tool” topic in IC Compiler Help.

---

## Previewing Objects in a Layout View

If you need to click an object in an area of the design where objects are densely packed or overlapped, you can preview information about the objects at a location before clicking the object you need. The tool displays the information in an InfoTip. InfoTips are enabled by default.

When you move the pointer over the active layout view, the status bar displays the relative coordinates of the pointer position. When you move the pointer over an object, the tool highlights the object in the preview color, which is white by default and has thinner lines than selection coloring. You can hold the pointer over an object to view its name, attribute values, and other information. If more than one object occupies the same location, you can display information sequentially for each object.

- To display the information for the next object in the sequence, press F1.
- To display the information for the previous object in the sequence, press Shift-F1.

When the tool displays the information for the object you need, click the object. This preview mechanism is available for the Selection tool, the Highlight tool, the Query tool, and the layout editing mouse tools. For tools that operate on selected objects, you can preview any selectable object that is enabled for selection on the View Settings panel. For other tools, such as the Query tool, you can preview any object that the tool can operate on regardless of whether the object can be selected.

**Note:**

If you have trouble previewing small objects, try magnifying the view. In a large design, some objects or object outlines are too small to preview at low magnification. For details, see “[Magnifying and Traversing the Design](#)” on page A-15.

The information that the InfoTip displays varies depending on the type of object. You can add or remove attributes in the InfoTip for an object type by modifying the LayoutInfoTipText attribute group in the Attribute Group Manager dialog box. To open this dialog box, click the  button in the Properties dialog box, the Selection List dialog box, or an object list view window. For more details, see “[Managing Attribute Groups](#)” on page A-27.

By default, an InfoTip floats near the object origin. You can also disable InfoTips if, for example, you do not want to view them while traversing the design.

To set InfoTip options for the active layout view,

1. On the View Settings panel, click the Settings tab and then click the View tab.
2. Set options as needed.
  - To enable or disable InfoTips, select or deselect the Show InfoTip option.  
A check mark on the option indicates that InfoTips are enabled.
  - To set the location for the InfoTips, select an option in the InfoTip Location list.  
You can set the InfoTips to float near the object origin (the default) or to appear at the bottom of the layout view.
3. Click Apply.

Alternatively, you can enable or disable InfoTips by choosing View > InfoTip. A check mark beside the command on the View menu indicates that InfoTips are enabled;

---

## Selecting Objects

You can use the Selection tool and the Select menu commands to select objects or timing paths in the design.

- Use the Selection tool () to select objects interactively in the active layout or schematic view.
- Use commands on the Select menu to select objects by name or type, select timing paths, or select fanin or fanout objects.

The GUI displays selected objects in the selection color, white by default, and cross-selects the objects in all other open views in which they appear. The object names appear in the selection list. To view the selection list, choose Select > Selection List. If you need to deselect all selected design objects and timing paths in the current design, choose Select > Clear.

When you use the Selection tool, you can fine-tune selections by adding or removing objects in existing selections. Before you can select an object in a layout view, it must be enabled for display and selection.

To activate the Selection tool,

- Click the  button on the Mouse Tools toolbar or choose View > Mouse Tools > Selection Tool.

When you enable the Selection tool in a layout view, options for using the tool appear on the Mouse Tool Options toolbar. [Figure A-3](#) shows the default options when the Selection tool is the active mouse tool. For Help using the Selection tool and its options in a layout view, click the  button on the Mouse Tool Options toolbar.

*Figure A-3 Selection Tool Options on Mouse Tool Options Toolbar*



You can select or deselect objects in a schematic view, and by default in a layout view, by clicking or dragging the pointer.

- To select an object and deselect any other selected objects, click the object.
- To select multiple objects at the same time and deselect any other selected objects, drag the pointer to draw a rectangular box around the objects.

To add objects to the current selection, press the Ctrl key while you click or drag the pointer. To remove an object from the current selection, press the Shift key while you click or drag the pointer. In a layout view, you can set an option to control whether the tool replaces the current selection, adds objects to the current selection, or removes objects from the current selection.

Note:

If you have trouble selecting small objects, try magnifying the view. In a large design, some objects or object outlines are too small to click at low magnification. For details, see [“Magnifying and Traversing the Design” on page A-15](#).

In a layout view, you can fine tune the Selection tool by setting options on the Mouse Tool Options toolbar.

- To select or deselect a single object, by clicking the object, or the objects in a rectangular area, by dragging the pointer over the objects, select the Smart option or press P.

The Smart option is selected by default.

- To select or deselect objects in a rectangular area by either dragging the pointer or clicking two diagonally opposite corners of the rectangle, select the Rectangle option or press W.

This allows you to click one corner of the rectangle and then use the nested zoom and pan tools before clicking the other corner.

- To select or deselect objects along a straight line by dragging across an edge of each object, select the Line option or press L.
- To select or deselect objects that are partially outside a rectangular area when the Smart or Rectangle input mode option is selected, select the Enable option.
- To control whether the tool replaces objects in, adds objects to, or removes objects from the current selection, select an option in the Selection list.

The choices are Replace, Add, and Remove. The default is Replace.

In a layout view, if you need to select an object at a location where objects overlap, you can preview the objects at the location. Move the pointer over an object to display object information in an InfoTip. The object is highlighted in the preview color, which is white by default but is thinner than selection coloring. To preview multiple objects at the same location sequentially, forward or backward, press F1 or Shift-F1. For more details, see [“Previewing Objects in a Layout View” on page A-5](#).

To deselect all selected objects,

- Choose Select > Clear.

Alternatively, in a layout view, you can click the Clear button on the Mouse Tool Options toolbar.

---

## Highlighting Objects

You can interactively highlight objects in the active layout or schematic view by using the Highlight tool. You can highlight individual objects or objects within a region. In a layout view, you can set options to highlight an object's net connections and to display information about an object on the Query panel. You can also remove highlighting from objects by using the Highlight tool.

When you highlight an object, the GUI displays the object in the current highlight color, which is yellow by default. In a layout view, if you enable highlighting for net connections, flylines appear in the highlight color. The GUI also highlights the object in all other open layout and schematic views.

To activate the Highlight tool,

- Click the  button on the Mouse Tools toolbar (or choose View > Mouse Tools > Highlight Tool).

When you activate the Highlight tool in a layout view, the Highlight tool options appear on the Mouse Tool Options toolbar.

- To display object information on the Query Object panel when you highlight an object, select the Query On Highlight option.
- To highlight the nets connected to objects that you highlight, select the Highlight Nets option, and select the options for the types of nets you want to highlight. The choices are Signal, Clock, Power, Ground, Tie High, and Tie Low. By default, Signal and clock are enabled, and the other options are disabled.

In a layout view, if you need to highlight an object at a location where objects overlap, you can preview the objects at the location. Move the pointer over an object to display object information in an InfoTip. The object is highlighted in the preview color, which is white by default but is thinner than selection coloring. To preview multiple objects at the same location sequentially, forward or backward, press F1 or Shift-F1. For more details, see “[Previewing Objects in a Layout View](#)” on page A-5.

You can use the Highlight toolbar and the Highlight menu to change the highlight color. By default, the GUI applies the same color to each object you highlight until you change the color. You can enable an automatic color cycling mechanism.

To enable or disable autocycling,

- Choose Highlight > Auto Cycle Colors.

A check mark next to the Auto Cycle Colors command on the Highlight menu indicates that autocycling is enabled.

When you enable the automatic color cycling mechanism, the GUI automatically cycles through the highlight colors. Each time you apply highlighting to selected objects or paths, the GUI uses the next highlight color in the cycle.

To highlight objects by using the Highlight tool,

1. Make sure the  button is selected on the Mouse Tools toolbar.
  2. (Optional) Select a highlight color in the  list on the Highlight toolbar, or click the  button to highlight objects by brightness (non-highlighted objects are dimmed) instead of color.
  3. Highlight objects or remove highlighting in any of the following ways:
    - To highlight individual objects, click the objects.
- Note:
- If you have trouble highlighting small objects, try magnifying the view. In a large design, some objects or object outlines are too small to click at low magnification. For details, see “[Magnifying and Traversing the Design](#)” on page A-15.
- To highlight objects in a rectangular area, drag the pointer diagonally to draw a box around the area. The GUI highlights objects that are completely inside the box.
  - To remove highlighting from individual objects, Ctrl-click the objects.
  - To remove highlighting from objects in a rectangular area, press Shift and drag the pointer diagonally to draw a box around the area. The GUI removes highlighting from objects that are completely inside the box.
4. Repeat step 2 or steps 2 and 3 as needed.

The Highlight toolbar lets you select the highlight color, add or remove highlighting on selected objects, remove highlighting on all objects, or highlight objects by brightness instead of color. This toolbar can be found in the main, layout, timing analysis, and interactive clock tree synthesis windows; however, the highlight by brightness capability is only available in layout windows. [Figure A-5](#) shows the full toolbar as it appears in the layout window.

**Figure A-4 Full Highlight Toolbar**

**Figure A-5** shows the abbreviated version of the toolbar that is available in the main window and the timing analysis window.

**Figure A-5 Abbreviated Highlight Toolbar**

You can also highlight selected timing paths in the active layout or schematic view. When you highlight a timing path, the pins and ports on the path appear in a different color from the unhighlighted objects. Flylines appear in the highlight color to show the connections between the objects on the path.

To highlight timing paths,

1. Select the paths you want to highlight.
2. Click the button on the Highlight toolbar or choose Highlight > Selected.

You can remove the highlighting from selected objects or timing paths, remove the current highlight color from objects and paths highlighted with that color, or remove all highlighting in the active layout or schematic view.

To remove highlighting from selected objects and paths,

1. Select the objects and paths from which you want to remove the highlight color.
2. Click the button on the Highlight toolbar or choose Highlight > Clear Selected.

To remove the current highlight color from objects and paths,

- Choose Highlight > Clear Current Color.

To remove all highlighting from objects and paths,

- Click the  button on the Highlight toolbar or choose Highlight > Clear All.

You can also enable a mechanism to select only those objects that are currently highlighted when you select objects interactively with the Selection tool or an editing mouse tool. For details, see “[Selecting Only the Highlighted Objects](#)” on page A-12.

---

## Selecting Only the Highlighted Objects

If you need to select a large number of objects incrementally, for example, or some but not all of the objects in an area of the design, you can enable a layout view option that permits the Selection tool and the editing mouse tools to select only highlighted objects. If you enable this option and then drag the Selection tool or an editing tool to select objects in a rectangular area, the tool selects only those objects that are currently shown in highlight coloring.

To enable the constraint to select only highlighted objects,

- Click the  button on the Highlight toolbar or choose Highlight > Select Only Highlighted.

A check mark appears next to the command on the Highlight menu when the capability is enabled.

When the View Settings panel is visible, you can select the “Only select highlighted objects” option and click Apply. A check mark appears on the option when the constraint is enabled

---

## Selecting or Highlighting Objects by Name

You can select or highlight objects in the active layout view by typing their names on the Select By Name tool. You can operate this tool by pressing keys on the keyboard or by setting options and typing the object names on the Select By Name toolbar.

Note:

The Select By Name toolbar is designed for fast object searches based on names or name patterns that you type. For more sophisticated object searches using reusable filters or regular expressions, use the Select By Name dialog box. For details, see “[Searching for Objects by Name](#)” on page A-29.

To display the Select By Name toolbar,

- Choose Select > By Name Toolbar or press Ctrl+/.

The Select By Name toolbar appears below the layout view by default.

*Figure A-6 Select By Name Toolbar*



When you display the Select By Name toolbar, the keyboard focus automatically changes to the object name box on the toolbar. To select a cell by default, type its name and press Return. You can

- Cycle through the object type list by pressing the Page Up key or Page Down key.
- Type one or more object names, or select the names in the name completion list.
- Set the operating mode by pressing F1 to select objects or F2 to highlight objects.
- Press the Insert key to change between the add and replace selection operations.
- Press Enter to apply the selection or highlighting to the objects.

When you begin typing a name, the letters appear in the object name box on the toolbar. You can type multiple object names by separating them with blank spaces. You can allow the tool to complete a name you are typing by pressing Tab. The tool completes the name to its longest match. If the tool finds multiple objects with names that match, an object list appears showing the first 15 names.

For more information about the Select By Name toolbar, see the “Selecting Objects by Name” topic in IC Compiler Help.

## Viewing Object Information

You can use the Query Tool to view design and timing information for objects in a layout or schematic view. When you click an object in the active view, the information appears on the Query panel (the panel opens automatically if it is not already open). You can also set options on the Query panel to automatically or manually copy the information to the session transcript in the console log view. You can also control which attributes the Query panel displays.

To enable object queries in the active layout or schematic view,

- Click the  button on the Mouse Tools toolbar (or choose View > Mouse Tools > Query Tool).

The Query panel appears, docked by default to the right side of the window. You should dock the panel or move it to a place on the screen where you can work with both it and the active view at the same time.

In a layout view, if you need to query an object at a location where objects overlap, you can preview the objects at the location. Move the pointer over an object to display object information in an InfoTip. The object is highlighted in the preview color, which is white by default but is thinner than selection coloring. To preview multiple objects at the same location sequentially, forward or backward, press F1 or Shift-F1. For more details, see “[Previewing Objects in a Layout View](#)” on page A-5.

To display information for an object,

1. Make sure the  button is selected on the Mouse Tools toolbar.
2. Click the object.

The object is highlighted in the query color, which is white by default, and the information for the object appears on the Query panel. Query highlighting has thinner lines than selection highlighting.

Note that you can select and copy text on the Query panel, but you cannot edit the text.

Note:

If you have trouble querying small objects, try magnifying the view. In a large design, some objects or object outlines are too small to click at low magnification. For details, see “[Magnifying and Traversing the Design](#)” on page A-15.

To copy the object information into the session transcript in the console log view,

- Select the “Print to Log” option on the Query panel.

When this option is selected, information for objects you click in Query Tool is automatically copied to the transcript.

You can configure the information that appears on the Query panel by specifying which attributes the tool displays for different types of queries—single object query or multiple object query—and different types of objects. The default attribute groups for most object types are QueryText for single object queries and Basic for multiple object queries. You can add or remove attributes in the QueryText attribute group. For details, see “[Managing Attribute Groups](#)” on page A-27.

For object types that do not have a QueryText or Basic attribute group, the default attribute group is All. If you need to restore the dialog box options to their defaults, click Default. The All attribute group is available for every object and query type. The other groups that are available vary depending on the object and query type. You can select any attribute group that appears in the list for a particular object and query type.

For more details about using the Query tool and the Query panel, see the “Viewing Object Information” topic in IC Compiler Help.

## Magnifying and Traversing the Design

You can use the zoom and pan tools and the zoom commands to find and display information in different parts of the design.

The View Zoom/Pan toolbar, shown in [Figure A-7](#), lets you instantly zoom or pan in increments defined by the tool. For example, you can zoom to a full view of the design, zoom in or out by a factor of 2, pan or zoom to a selection, or have zoom follow your selections. This toolbar can be found in the main, layout, timing analysis, and interactive clock tree synthesis windows.

*Figure A-7 View Zoom/Pan Toolbar*



You can magnify a view in any of the following ways:

- To double the magnification in the active view, click the button on the View Zoom/Pan toolbar or choose View > Zoom > Zoom In.
- To recenter the active view and double the magnification, click the button on the Mouse Tools toolbar or choose View > Mouse Tools > Zoom In Tool, and click where you want to center the view.
- To magnify a rectangular area to fill the active view, click the button on the Mouse Tools toolbar or choose View > Mouse Tools > Zoom In Tool, and drag the pointer diagonally across the area you need to magnify.

You can shrink a view in any of the following ways:

- To fit the entire design in the active view, click the  button on the View Zoom/Pan toolbar or choose View > Zoom > Zoom Fit All.
- To shrink the active view to half the magnification, click the  button on the View Zoom/Pan toolbar or choose View > Zoom > Zoom Out.
- To recenter the active view and shrink it to half the magnification, click the  button on the Mouse Tools toolbar or choose View > Mouse Tools > Zoom Out Tool, and click where you want to center the view.
- To shrink the active view by filling a rectangular area, click the  button on the Mouse Tools toolbar or choose View > Mouse Tools > Zoom Out Tool, and drag the pointer diagonally across the area you need to fill.
- To adjust the magnification in the active view to fit all selected objects that are visible in the view, click the  button on the View Zoom/Pan toolbar or choose View > Zoom > Zoom to Selection.
- To adjust the magnification in the active view to fit all highlighted objects that are visible in the view, choose View > Zoom > Zoom Fit Highlight.

To magnify a location in the active layout view by specifying its coordinates,

1. Choose View > Zoom > Zoom To.

The Zoom To dialog box appears.

2. Type the coordinates for two corners of a rectangular area, top-left and bottom-right or bottom-left and top-right, in the Coordinates box.

3. Click OK or Apply.

When only part of the design is visible in the active layout or schematic view or part of the histogram is visible in the active histogram view, you can use the Pan tool or the scroll bars to traverse the view to see different areas of the design or histogram. You can also use the pan commands to recenter the design by displaying selected objects or highlighted objects in the active layout or schematic view.

You can traverse a view in any of the following ways:

- To traverse the active view in any direction, click the  button on the Mouse Tools toolbar or choose View > Mouse Tools > Pan Tool, and drag the pointer in the direction that you want to move the design within the view.
- To recenter the active view and display selected objects, click the  button on the View Zoom/Pan toolbar or choose View > Zoom > Pan to Selection.
- To recenter the active view and display highlighted objects, choose View > Zoom > Pan to Highlight.
- To apply the magnification level in the active layout view to other open layout views in the same layout window, choose View > Mouse Tools > Zoom Layout View to Current View.
- To shrink the active view by filling a rectangular area, click the  button on the Mouse Tools toolbar or choose View > Mouse Tools > Zoom Out Tool, and drag the pointer diagonally across the area you need to fill.
- To traverse a view up or down by using vertical scroll bar, click the top or bottom scroll arrows or drag the scroll box.
- To traverse a view left or right by using the horizontal scroll bar, click the left or right scroll arrows or drag the scroll box.

The scroll boxes represent the visible part of the design. When you move a scroll box, the view moves in that direction.

You can also enable a mechanism that automatically zooms to an object when it is selected, and you can reuse zoom and pan settings. For more information, see the following sections:

- [Following Selected Objects](#)
- [Reusing Zoom and Pan Settings](#)
- [Redrawing the Active View](#)

## Following Selected Objects

You can control whether a layout or schematic view automatically zooms to an object when you select it, thus increasing or decreasing the magnification of the design to fit the object within the view.

You can enable or disable this “follow-selection” mechanism separately for each open view. When you enable follow selection in a view, it remains enabled even when the view is not the active view. Follow selection is disabled by default.

To enable or disable the follow-selection mechanism for the active layout or schematic view,

- Click the  button on the View Zoom/Pan toolbar or choose View > Zoom > Follow Selection.

A check mark next to the Follow Selection command on the Zoom menu indicates that the follow-selection mechanism is enabled.

## Reusing Zoom and Pan Settings

The IC Compiler GUI maintains a list of zoom and pan settings for each layout or schematic view. Each zoom and pan setting consists of both a zoom (magnification) level and a pan position (visible area). When you change the magnification or traverse the view (by panning or scrolling), the previous zoom and pan setting is added to the list.

The Zoom and Pan History toolbar, shown in [Figure A-8](#), lets you use previously used or specially defined zooms. It also lets you define special zoom settings for future use. This toolbar can be found in the main and layout windows.

*Figure A-8 Zoom and Pan History Toolbar*



You can

- Reverse the zoom level and pan position to the last zoom and pan setting by stepping backward in the list toward the initial display you encountered when you opened the view
- Reapply the next (previously reversed) zoom level and pan position by stepping forward in the list after stepping backward in the list
- Save the current zoom level and pan position in a list of named zoom and pan settings
- Return the view to a certain zoom level and pan position by selecting a named zoom and pan setting that you saved earlier in the session

For more information, see the “Reusing Zoom and Pan Settings” topic in IC Compiler Help.

## Redrawing the Active View

Certain operations (such as zooming or panning) in a layout view cause the GUI to automatically redraw the view. In addition, you can manually redraw the active layout or schematic view at any time.

To redraw the active view,

- Choose View > Refresh.

If necessary, you can recompute the boundary of the entire design, including the die area, to fit within the active layout view.

To recompute the boundary of the entire design,

1. Choose View > Zoom > Recompute Cell Boundary.

The GUI recalculates the cell boundary coordinates.

2. Update the layout view by choosing View > Zoom > Zoom Fit All.

---

## Examining Design and Object Information

In addition to graphic views, the IC Compiler GUI provides tools and commands that you can use to select and examine design objects and other design data. You can view and edit object properties, explore the design hierarchy, view reports, and select or search for objects that you want to select or highlight.

You can save an image of a graphic view that you can view or print later outside of IC Compiler. The GUI provides a Tcl command that you can use to save an image of any open top-level GUI window or view window.

For information about performing these tasks, see the following sections:

- [Viewing and Editing Object Properties](#)
- [Exploring the Design Hierarchy](#)
- [Exploring the Virtual Hierarchy of a Flat Design](#)
- [Managing Attribute Groups](#)
- [Searching for Objects by Name](#)
- [Selecting and Viewing Timing Paths](#)
- [Viewing Reports](#)
- [Saving an Image of a Window or View](#)

---

## Viewing and Editing Object Properties

You can use the Properties dialog box to view and edit attributes and other properties for selected designs, design objects, or timing paths. For example, to view properties for a cell that you see in a layout or schematic view, you can select the cell and then choose Edit > Properties. You can also set, change, or remove the values for some of the properties.

The Properties dialog box lists the properties in a table with two columns: property names and property values. The properties you can view include object names, attribute values, and certain timing and placement values. The list of properties differs depending on the types of objects that you select in the design and the attribute group that you select in the Properties dialog box.

**Note:**

Timing attribute values do not appear until you perform an operation that updates timing information, such as generating a timing report or opening a histogram.

To open the Properties dialog box,

1. Select one or more objects.
2. Choose Edit > Properties.

The Properties dialog box appears, with the number of selected objects displayed above the property list table. The property values for the first selected object appear in the table.

**Note:**

The Properties dialog box displays properties for the objects that are currently selected. If you change the current selection when the Properties dialog box is open, the dialog box changes to display the properties for the newly selected objects.

You can control which attributes appear in the Properties dialog box. The attributes are organized into attribute groups. For most object types, you can display all attributes, all application (predefined) attributes, all user-defined attributes, or just the basic (most frequently used) attributes. For cells, you can also display placement or timing attributes. In addition, for types of objects that can be previewed or queried in the layout view, you can display the attributes that appear in the preview InfoTip or on the Query panel.

To control which attributes appear in the Properties dialog box,

- Select an option in the “Attribute group” list.

The default attribute group depends on which type of object you select. If you select multiple objects of different types, only the attributes in the basic attribute group appear.

You can modify the contents of some attribute groups and create custom, user-defined attribute groups by using the Attribute Group Manager dialog box.

To open Attribute Group Manager dialog box,

- Click the  button in the Properties dialog box.

For more details about attribute groups, see “[Managing Attribute Groups](#)” on page A-27.

When you select multiple objects, the property lists are displayed separately for each object.

You can use the previous and next arrow buttons ( and ) to navigate from one list of object properties to another.

You can select an option to list the property values for all the selected objects together in a single table.

- If you try to display properties for all objects of the same type, the dialog box shows the values that are identical for all the objects and displays “<Multiple values>” for other values.
- If you try to display properties for all objects of more than one type, the dialog box does not display any properties.

For more information about using the Properties dialog box, see the “Viewing and Editing Object Properties” topic in IC Compiler Help.

---

## Exploring the Design Hierarchy

You can use the hierarchy browser to explore the design hierarchy and examine the blocks and hierarchical cells in the design. If you are not familiar with a design, you can explore the hierarchy to understand its structure and gather information about the design objects in a block or hierarchical cell. Use the hierarchy browser to

- Explore the complete hierarchical structure of the design and observe how many hierarchical blocks are present and the size of each block
- View design information for the objects (cells, ports and pins, or nets) within a block or hierarchical cell

You can select the hierarchical cells, leaf cells, or other objects that you want to examine in a layout or schematic view or with other analysis tools.

- Examine hierarchical cell placement in the layout view

You can map the leaf cells descended from each hierarchical cell by applying colors to the hierarchical cells in the hierarchy browser.

To open the hierarchy browser in the main window,

- Choose Hierarchy > New Hierarchy Browser View.

To open the hierarchy browser in the layout window,

- Choose Partition > New Hierarchy Browser View.

The Partition menu is available only when the current task in the layout window is set for design planning (choose File > Task > Design Planning) or all tasks (choose File > Task > All Tasks).

The hierarchy browser view window consists of two panes, with an instance tree view that is always visible and an object list view that is hidden by default. The instance name of the top-level design appears at the top of the instance tree. The icons beside the cell names represent their cell types (standard cells, hard or soft macros, and so forth).

To display or hide the object list view,

- Right-click in the instance tree view and choose Show Child List.

A check mark next to the Show Child List command indicates that cell list is visible.

The object list view contains an object table that displays details about the cells, pins and ports, or nets in the selected block or hierarchical cell.

## Examining Hierarchical Cells

To explore the design hierarchy and examine the design objects within each hierarchical cell, you can

- Expand hierarchical cells, showing the names of the instances at the next level in the hierarchy  
To expand a hierarchical cell, click the expansion button (plus sign) next to the instance name.
- Select hierarchical cells in the instance tree view to display information about leaf cells or other objects in the object list view

You can filter the cells by type and display or hide columns in the instance tree or the object table.

- Select an object type in the list above the object table to display object information for cells, ports and pins, or nets

The object table displays cell information by default.

You can select an object in the hierarchy browser by clicking its row in the instance tree or the object table. You can select multiple objects by dragging the pointer over their rows, and you can Shift-click or Ctrl-click rows to select combinations of objects.

For more information about using the hierarchy browser, see the “Exploring the Design Hierarchy” topic in IC Compiler Help.

## Examining Hierarchical Cell Placement

You can examine hierarchical cell placement in the layout view by applying colors to cells in the hierarchy browser. You can color complete cell hierarchies, selected hierarchical cells, or selected leaf cells. The layout view highlights leaf cells with the applied colors. The hierarchy browser displays the cell colors on the icons beside the cell names.

To automatically assign colors to top-level hierarchical cells,

- Right-click and choose Set Top Hierarchy Colors.

To set the color for selected instances or leaf cells,

1. Select the cells.
2. Right-click and choose Set Selected Hierarchy Color to open the Auto Color menu.
3. Choose a color.

For more information about coloring hierarchical cells, see the “Examining Hierarchical Cell Placement” topic in IC Compiler Help.

---

## Exploring the Virtual Hierarchy of a Flat Design

You can explore the virtual hierarchy of a flat design and examine the virtual hierarchical cells in the design. If you are not familiar with a design, you can explore the virtual design hierarchy to understand its structure and gather information about the leaf cells in each virtual hierarchical cell.

The Flat Design Hierarchy Browser dialog box creates and displays a virtual design hierarchy based on a delimiter that you specify. You can

- Explore the complete virtual hierarchical structure of the flat design and observe how many virtual hierarchical cells are present and the size of each cell
- Examine design information for the leaf cells within a virtual hierarchical cell  
You can select the leaf cells that you want to examine in a layout or schematic view or with other analysis tools.
- Examine the virtual hierarchical cell placement in the layout view

You can map the leaf cells descended from each virtual hierarchical cell by applying colors to the virtual hierarchical cells in the Flat Design Hierarchy Browser dialog box.

Use the Flat Design Hierarchy Browser dialog box if you need to debug the quality of placement for macro and standard cells, find critical placement-related problems, or examine the timing optimization of module boundary logic.

**Note:**

The Flat Design Hierarchy Browser dialog box is available only when the current design is a flat design. It is not available when the current design is a partially or fully hierarchical design.

To open the Flat Design Hierarchy Browser dialog box,

1. Choose one of the following commands:

- In the main window, choose **Hierarchy > Flat Design Hierarchy Browser**.
- In the layout window, choose **Floorplan > Flat Design Hierarchy Browser**.

The Flat Design Hierarchy Browser command appears on the Floorplan menu only when the current task in the layout window is set for block implementation (choose **File > Task > Block Implementation**) or all tasks (choose **File > Task > All Tasks**).

The Flat Design Hierarchy Browser - Separator dialog box appears.

2. (Optional) Type the character that you want the tool to use as the delimiter to build the virtual hierarchy tree from the flat design.

The default delimiter is a slash (/).

3. Click **OK**.

The Flat Design Hierarchy Browser dialog box contains two views: a virtual hierarchy tree view that is always visible and a cell list view that is hidden by default. The instance name of the top-level design appears at the top of the virtual hierarchy tree. The icons beside the cell names represent their cell types (standard cells, hard or soft macros, and so forth).

The cell list view contains an object table that displays details about the leaf cells in the selected virtual hierarchical cell.

To display or hide the cell list view,

- Right-click in the virtual hierarchy tree view and choose **Show Child List**.

A check mark next to the Show Child List command indicates that cell list is visible.

If you edit the design and change the netlist, you can regenerate the virtual design hierarchy by clicking the Reload button below the virtual hierarchy tree.

To close the Flat Design Hierarchy Browser dialog box,

- Click **Close**.

## Examining Virtual Hierarchical Cells

To explore the virtual hierarchical structure of a flat design and examine the leaf cells within each virtual hierarchical cell, you can

- Expand virtual hierarchical cells, showing the names of the virtual hierarchical blocks or cells at the next level in the hierarchy

To expand a virtual hierarchical cell and view the next level in the virtual hierarchy, click the expansion button (plus sign) next to the cell name.

- Copy the hierarchy paths for virtual hierarchical cells

To copy a hierarchy path, select the hierarchical cell, and then right-click and choose Copy Hierarchy Path. You can paste the path on the command line, in a dialog box, or in an external tool such as a text editor.

- Select hierarchical cells in the virtual hierarchy tree to display leaf cell information in the cell list view

You can filter the leaf cells, display or hide cell attributes, generate histograms, and export the leaf cell information to a text file.

You can select a virtual hierarchical cell or a leaf cell by clicking its row in the virtual hierarchy tree or the object table. You can select multiple cells by dragging the pointer over their rows, and you can Shift-click or Ctrl-click rows to select combinations of cells.

Note:

Selecting a virtual hierarchical cell in the Flat Design Hierarchy Browser dialog box clears the global selection list.

To facilitate your examination of the leaf cells within a virtual hierarchical cell, you can control the information in the object table by displaying or hiding columns, generate histograms that show the distribution of values in specific columns, and save the leaf cell information by exporting it to a text file.

To control the object information in the cell list view,

1. Select an attribute group in the list below the object table.

The object table displays a column for each attribute in the attribute group. The default attribute group is Basic, which contains only the most frequently used cell attributes.

2. (Optional) Click the  button below the object table to open the Attribute Group Manager dialog box.

You can modify an attribute group or create a user-defined attribute group.

For more information about attribute groups, see “[Managing Attribute Groups](#)” on [page A-27](#). You can also filter the object table to view information for just the leaf cells in which you are interested. For details, see the “Filtering Object Lists” topic in IC Compiler Help.

To generate a histogram that shows the distribution of values in a column,

1. Click the Histogram button below the object table, or click the  button and choose Histogram.
2. Set options as needed in the Table Histogram dialog box and click OK.

For more details, see “[Viewing Histograms](#)” on [page A-69](#).

To save the leaf cell information in a text file,

1. Click the Export button below the object table, or click the  button and choose Export.
2. Select or type the file name in the Export to File dialog box and click Save.

For more information about using the Flat Design Hierarchy Browser dialog box, see the “Exploring the Virtual Hierarchy of a Flat Design” topic in IC Compiler Help.

## Examining Virtual Hierarchical Cell Placement

You can examine the quality of cell placement in the layout view by applying colors to virtual hierarchical cells. The layout view displays the leaf cells with the applied colors and the Flat Design Hierarchy Browser dialog box displays the cell colors on the icons beside the cell names.

To apply colors automatically to the top-level cells in the virtual hierarchy tree,

- Right-click and choose Set Colors On Top Hierarchies.

The tool applies a different color to the leaf cells descending from each top-level hierarchical cell.

Alternatively, you can use the `gui_set_flat_hierarchy_color` command with the `-cycle_color` option.

To apply a certain color to the leaf cells descending from one or more virtual hierarchical cells,

1. Select the virtual hierarchical cell names in the hierarchy tree.
2. Right-click and choose Set Selected Hierarchy Color to open the color menu.
3. Choose a color.

If you choose Automatic, the tool applies the next color in the color cycle. If you choose More, the Library Colors dialog box appears. Select a color and click OK.

Alternatively, you can apply a color to a virtual hierarchical cell by using the `gui_set_flat_hierarchy_color` command with the `-color` option.

To remove colors from one or more virtual hierarchical cells,

1. Select the virtual hierarchical cell names in the hierarchy tree.
2. Right-click and choose Clear Selected Hierarchy Color.

To remove the colors from all the cells in the virtual hierarchy tree,

- Right-click and choose Clear All Hierarchy Colors.

Alternatively, you can remove the color from a virtual hierarchical cell by using the `gui_unset_flat_hierarchy_color` command.

Each time you apply or remove colors in the Flat Design Hierarchy Browser dialog box, the tool logs the equivalent `icc_shell` command and displays it in the console log view. When you save the design, the tool saves any colors that are currently applied to virtual hierarchical cells in the flat design hierarchy browser.

---

## Managing Attribute Groups

Attribute groups are collections of attributes that the GUI uses to determine which attribute values to display in lists of design objects. The content of these groups varies depending on the object type.

You can control which attribute group the GUI uses to display attribute values when you

- View or edit object properties in the Properties dialog box
- View object information on the Query panel
- View selected objects in the Selection List dialog box
- View object information in object list views

You can view both application attributes that are defined in IC Compiler and user-defined attributes that you define by using the `define_user_attribute` command.

The GUI provides the following predefined attribute groups:

- The Application attribute group contains all the attributes for an object that are defined in IC Compiler.
- The User attribute group contains any user-defined attributes that you have defined for an object by using the `define_user_attribute` command.
- The All attribute group contains all the application and user-defined attributes for an object.
- The Basic attribute group contains only the most frequently used attributes for an object.
- The LayoutInfoTipText attribute group contains the attributes that appear in the InfoTip when you preview an object in the layout view.
- The QueryText attribute group contains the attributes that appear on the Query panel when you query an object with the Query tool.

In addition, the GUI provides placement, timing, path, floorplan, relative placement, and wire attribute groups for the appropriate types of objects.

The tool updates the All and User groups automatically when you create or remove a user-defined attribute.

You can use the Attribute Group Manager dialog box to view, modify, create, and remove attribute groups. You can create, rename, and remove user-defined attribute groups but not attribute groups that are defined in the GUI. You can modify any attribute group except All, Application, and User. For example, you can customize preview InfoTips in the layout view by modifying the LayoutInfoTipText attribute group. You can also copy an attribute group to create a new user-defined attribute group with the same content, and then modify the group to meet your needs.

You can save attribute groups in your preferences file, load them from the preferences file, or reset the attribute groups to their system defaults.

To open the Attribute Group Manager dialog box,

- Click the  button in the Properties dialog box, the Selection List dialog box, or an object list view.
- On the Query panel, you can choose Options > Customize to open the Customize Query Toolbar dialog box, and then click the Attribute Groups button.

For more information about working with attribute groups, see the “Managing Attribute Groups” topic in IC Compiler Help.

---

## Searching for Objects by Name

You can use the Select By Name dialog box to search for objects of any type by specifying a name or name pattern or by defining a regular expression. Then you can select or highlight some or all of the objects found in the search.

To search for objects, you select an object type and a design scope. You can search

- All objects in the design
- Selected objects
- All or selected objects found in the previous search

You can define and save filters for different object types based on object name patterns and attribute or function values. You can also copy or modify existing filters.

Note:

The Select By Name dialog box is designed for sophisticated object searches using filters or regular expressions. For faster object selection using object searches based on names or name patterns that you type, use the Select By Name toolbar. For details, see [“Selecting or Highlighting Objects by Name” on page A-12](#).

The search results include the total number of objects found and a list of object names with the values of any attributes or functions used to generate the search. When you are satisfied with the search results, you can select the names of objects that you want to select, deselect, or highlight in the active layout view.

To search for and select objects by name or regular expression,

1. Choose Select > By Name to open the Select By Name dialog box.
2. Select an object type and a design scope in the left and right “Search for” lists.

The default object type is Leafiest and the default design scope is “In entire design.”

3. Specify the name or regular expression by doing one of the following:

- To search for objects by name, select the “Wildcard matching” option (the default), and type an object name or name pattern (with wildcards) in the Name box.
- To search for objects by using a regular expression, select the “Full regular expressions” option, and either define a search filter or select the name of a previously defined filter in the Filter list.

You can define a search filter with one or more terms. To start a new filter, click the Add Term button and select an object name, an operator, and a value in the table below the Name box. To add a term, select AND or OR in the Next Term list.

If you want to save the filter for future use, click the Save button to open the Save Filter As dialog box, type a filter name, and click OK. The GUI adds the filter name to the Filter list and saves the filter definition in your preferences file. You can delete a saved filter by selecting the filter name in the Filter list and clicking the Delete button.

4. Set other options as needed.

5. Click Search.

The names of the objects found in the search appear in the “Search results” list. Initially, all the names in the list are selected. You can modify the list by removing object names or by performing another search and adding the object names to the list.

6. Select the names of objects in the “Search results” list that you want to use to select, deselect, or highlight in the most recently active layout view.

7. Select, deselect, or highlight the objects by doing one or more of the following:

- To select objects and replace the current selection, select the object names, select the Replace option and click the Change Selection button.
- To select objects and add them to the current selection, select the “Add to” option and click the Change Selection button.
- To deselect objects (remove them from the current selection, select the “Remove from” option and click the Change Selection button.
- To highlight objects in the most recently active layout view, click the Add to Highlight button.

You can also display the object names in a new list view by clicking the Show in Table View button.

8. To close the Select By Name dialog box, click Close.

Selected objects are displayed in the selection color (white) in graphic views and indicated by reverse video in hierarchy views, their names appear in the selection list, and the number of selected objects appears in the status bar. Highlighted objects appear in the current highlight color.

---

## Selecting and Viewing Timing Paths

You can select timing paths that you want to view or highlight in a layout or schematic view. Use the Select Paths dialog box to select the paths with the worst slack in the design or in a path group. You can also select individual timing paths to or from specific inputs, outputs, or registers.

When you select paths with the worst slack in the design, you can

- Include specific paths
- Set the maximum number of paths in the design, in a specific path group, or to a single endpoint
- Set other timing path options

You can also specify the selection bus and the selection operation.

To select specific paths or the paths with the worst slack in the design,

1. Choose Select > Paths From/Through/To.

The Select Paths dialog box appears.

2. (Optional) Specify individual timing paths by entering the startpoint, throughpoint, or endpoint names necessary to identify the paths in the From, Through, or To boxes.

Only paths that begin at valid startpoints or end at valid endpoints are included in the selection. If you specify more than one startpoint or endpoint, all paths that start at any of the startpoints or end at any of the endpoints (and meet the other criteria) are included.

3. Set options to control the maximum number and type of paths in the selection.
  - To change the maximum number of paths to an endpoint, enter a value in the “Nworst paths” box.
  - To change the maximum number of paths, enter a value in the “Max paths” box.
  - To specify a path group, select its name in the “Group name” list.
4. Set other options as needed.
5. Click OK or Apply.

When you select a timing path, the pins and ports on the path appear in the selection color (white). Flylines appear in the selection color to show the connections between the objects on the path.

---

## Viewing Reports

The GUI displays reports in report views. By default, when you generate a report by choosing a report command on a menu, the GUI displays the report in a new report view.

Note:

When you enter a report command on the command line, the tool displays the report in the console log view and in `icc_shell` but does not open a report view.

You can use report views to

- Save a report in a text file
- Open a report previously saved in a text file

You can also search for words or phrases in a report. You can remove report text from a report view and use the blank view to open a report from a text file.

To save a report displayed in a report view,

1. Click the  button.

The “Save Report to File” dialog box appears.

2. Navigate to the directory where you want to save the report.
3. Select a file name, or type a file name in the “File name” box.

If you select or enter the name of an existing file, the GUI overwrites the file.

4. Click Save.

To find a word or phrase in the report text,

1. Type the word or phrase in the find box near the top-right corner of the view.
2. Click the  button.

The report view highlights the first occurrence of the word or phrase.

3. (Optional) Repeat step 2 to find the next occurrence of the word or phrase in the report text.

To remove the report text from a report view,

- Click the  button.

To display a report saved in a file,

1. Click the  button.

The Open Report File dialog box appears.

2. Navigate to the directory where the report file is located.
3. Select the file name.
4. Click Open.

---

## Saving an Image of a Window or View

You can capture a picture of the design in a layout view and save it in an image file. You can save the image in any of the following formats: BMP, JPEG, PNG, or XPM. You can save an image of entire layout window (the default) or just the layout view.

To save an image of the design in the active layout view,

1. Choose View > Save Screenshot As.

The Save Screenshot As dialog box appears.

2. Navigate to the directory where you want to save the image file and select or type a file name in the “File name” box.

You can save the image in BMP, JPEG, PNG, or XPM format by using the appropriate file name extension. The default format is PNG.

3. To save an image of just the layout view, select the “Grab screenshot of layout view window only” option.

By default, the image includes the entire layout window.

4. Click Save.

Alternatively, you can use the `gui_write_layout_image` command.

You can capture a picture of any open GUI window or view window and save it in an image file. The image format can be PNG (the default), BMP, JPEG, or XPM. The image shows the window exactly as it appears on the screen but without the window border or title bar. For example, if you save an image of the active schematic view, the image shows the visible portion of the schematic at the current zoom level and pan position.

To save an image of a GUI window or view window, use the `gui_write_window_image` command to specify the file name, image format, and window name. Window instance names appear in the window title bars and on the Window menu.

Use the `-file` option to specify the file name. This option is required. For example, to save a PNG image of the active schematic view in a file named `my_schematic.png`, you can enter

```
icc_shell> gui_write_window_image -file my_schematic
```

You can use a file name extension or the `-format` option to specify the image format. The default image format is PNG. For example, to save an XPM image of the active layout view in a file named `my_layout.xpm`, enter either of the following commands:

```
icc_shell> gui_write_window_image -file my_layout.xpm
icc_shell> gui_write_window_image -file my_layout -format xpm
```

Use the `-window` option to specify the window. For example, to save a PNG image of the layout window named `Layout.1` in a file named `mux_1.png`, enter either of the following commands:

```
icc_shell> gui_write_window_image -file mux_1 -window Layout.1
```

For more details about saving window and view images, see the “Saving an Image of a Window” topic in IC Compiler Help and the `gui_write_window_image` man page.

---

## Visualizing the Physical Design

The layout view displays a very accurate graphic representation of the physical design. You use the layout view to visually examine the floorplan, placement, clock tree, and routing objects and gather information that can help you work on the design. You can open multiple layout views to simultaneously work with different areas of the design.

To open a layout view,

- In the layout window, choose View > New Layout View.

You can use the Overview panel to magnify or traverse the design in the active layout view. If multiple layout views are open, you can change the active view to a different layout view.

Layout data can be densely packed with overlapping objects on different layers. You can control the visibility (display or hide) and selection (enable or disable) of individual object types or layers by setting options on the View Settings panel. You can also customize object or layer properties (color, fill pattern, and so forth) and set other layout and object display options. If you open multiple layout views, you can set different options for each view.

Typically you set layout view properties for each design. For example, the colors you use for individual layers might change depending on the number of layers in the design. If you change settings in the active view and want to use the same settings in another view or during a future session, you can save them in your preferences file. You can also restore previously saved view settings by loading them from your preferences file.

You can visualize the physical layout as explained in the following sections:

- [Navigating Through Layout Views](#)
  - [Displaying Grid Lines](#)
  - [Drawing Rulers](#)
  - [Adjusting the Color Brightness](#)
  - [Displaying Cell Orientations](#)
  - [Examining ILMs and Blocks with Abstraction](#)
  - [Viewing Design Overlays](#)
  - [Setting and Saving View Properties](#)
  - [Using Stroke Activated Commands](#)
- 

## Navigating Through Layout Views

In the layout window, the Overview panel shows you what portion of the design is visible in each open layout view.

- The portion of the design displayed in the active layout view is shown as a solid yellow rectangle.
- The portions of the design displayed in other layout views are shown as solid gray rectangles.

You can use the Overview panel to quickly magnify or traverse the design in the active layout view. When multiple layout views are open, you can quickly change the active view to a different layout view.

By default, the Overview panel appears docked below the toolbars at the top left corner of the layout window. If you hide the Overview panel, you can redisplay it by choosing *View > Toolbars > Overview*.

For more information, see the “navigating Through Layout Views” topic in IC Compiler Help.

---

## Displaying Grid Lines

You can display or hide the lithography grid and the user grid. By default, both grids are hidden.

To display or hide the lithography grid,

- Choose View > Show Litho Grid.

To display or hide the user grid,

- Choose View > Show User Grid.

To switch between the default grid spacing and ten times the default grid spacing,

- Choose View > Cycle Grid Spacing.

---

## Drawing Rulers

You measure distances in a layout view by drawing rulers. A ruler can be composed of one or more horizontal, vertical, or diagonal segments. By default, the distances from the beginning of the ruler are labeled at the ends of each segment and at every tenth tick mark within a segment.

While you draw a ruler, the GUI displays a ghost image of the ruler in the drag object color (red by default), and displays the coordinates for the current point position on the status bar. The rulers also appear in any other layout views that you have open in the layout window.

Note:

You cannot reverse (by choosing Edit > Undo) ruler drawing operations.

To draw rulers in a layout view,

1. Click the  button on the Mouse Tools toolbar or choose View > Mouse Tools > Ruler Tool.

When you enable the Ruler tool in a layout view, the Ruler Tool options appear on the Mouse Tool Options toolbar and the pointer changes shape. By default, cross hair rulers appear attached to the pointer in the layout view.

2. (Optional) Set options as needed on the Mouse Tool Options toolbar.

You can

- Select a direction option
- Display or hide the cross hair rulers attached to the pointer when you start a new ruler. The labels that show the distance from the ruler origin to the endpoint of each ruler segment, or the labels that show the segment length at the midpoint of each ruler segment
- Control whether the distances displayed by the ruler labels are absolute measurements from the design origin, relative measurements from the ruler origin, or relative measurements from each segment origin
- Change the grid snapping option for the ruler segments
- Record the ruler segment lengths or distances in the session transcript (console log view)

3. Click in the layout view where you want to begin the ruler.

A ghost line appears indicating the horizontal or vertical distance between the initial point and the current pointer location.

4. Click where you want to end the ruler segment.

The ruler segment appears.

5. (Optional) To draw another ruler segment, repeat steps 2 through 4.

6. To end the ruler, press the Esc key or right-click and choose End Ruler.

You can also end a ruler by selecting a different mouse tool (click a button on the Mouse Tools toolbar).

7. (Optional) To draw another ruler, repeat steps 2 through 6.

You can remove individual rulers or all rulers in the layout view, but you cannot remove or modify individual ruler segments.

To remove a ruler from the layout view,

1. Move the pointer over the ruler you need to remove.
2. Right-click and choose Remove Nearest Ruler.

To remove all rulers from the layout view,

- Click the  button on the Mouse Tools toolbar (or choose View > Mouse Tools > Clear Rulers).

For more information about using interactive mouse tools, see “[Selecting a Mouse Tool](#)” on page [A-3](#).

---

## Adjusting the Color Brightness

When you activate a visual mode or a map mode, the GUI dims the visible objects in the layout view. You can use the Brightness option on the View Settings panel to control the visual contrast between the visual mode or map mode colors and the other visible objects in the layout view. The GUI automatically dims the visible objects by resetting the color brightness to 33 percent.

To adjust the contrast between the color overlay and visible objects in the layout view,

- On the View Settings panel, select a value in the Brightness list.  
The choices are 100, 75, 66, 50, 33, 29, and Off.

---

## Displaying Cell Orientations

IC Compiler represents cell orientation in the layout view as an F. The position of the “hat” of the F indicates the first direction; the “arm” indicates the second direction.



Cells can be oriented in any of the following ways:



To display cell orientations in the active layout view,

1. On the View Settings panel, click the Settings tab.
2. Click the Cells tab.
3. Select or deselect the Show Cell Orientation option.
4. Click Apply.

You can change the orientations of individual cells. For details, see the “Changing Cell Orientations” topic in IC Compiler Help.

## Examining ILMs and Blocks with Abstraction

You can use interface logic models (ILMs) and block abstraction models to reduce the number of design objects and memory requirements when the tool performs top-level optimization on large designs. Using block abstraction also allows the tool to optimize the interface logic within the blocks during top-level postroute optimization.

ILMs and blocks with abstraction are structural models of circuits. In an ILM or a block with abstraction, the gate-level netlist is modeled by another gate-level netlist that contains only the interface logic of the block and any logic that you associate manually with the interface logic.

You can expand ILMs and block abstraction models to display the objects (cells, ports, pins, nets, and so forth) inside the blocks. When the blocks are expanded, you can use layout window analysis and editing tools to analyze and modify the placement of cells within the blocks. If you display cell labels in the layout view, expanded ILMs and blocks abstraction models display the full cell names from the top of the design for cells inside the blocks.

ILMs and blocks with abstraction contain cells whose timing affects or is affected by the external environment of a block. If you select a timing path that passes through a boundary pin into an expanded ILM or block abstraction model, the layout view displays the selected path inside the block. You can control whether the layout view displays selected timing paths as routes or flylines.

To expand ILMs and block abstraction models,

1. Type a value greater than 0 in the “View level” box on the View Settings panel.
2. Click the Settings tab.
3. Select ILM in the “Child view name” list.
4. Make sure the Block/ILM expanding cell type option is selected.
5. Click Apply.

To collapse (close) ILMs and block abstraction models,

1. Set at least one of the following options on the View Settings panel:
  - Type 0 in the “View level” box on the View Settings panel.
  - Click the Settings tab, and then deselect the Block/ILM expanding cell type option.
2. Click Apply.

You can control the visibility and selection of objects within ILMs and block abstraction models by using the same View Settings panel options you use for other objects in the layout window.

For more information, see the “Examining ILMs and Block Abstraction Models” topic in IC Compiler Help.

---

## Viewing Design Overlays

You can use the View Settings panel to overlay other designs on the primary design in the active layout view. For example, to view the fill data for a design, you can display the FILL view as an overlay over the CEL view. Similarly, you can view changes in a design by displaying an earlier version as an overlay over the current version.

To add an overlay on the active layout view,

1. On the View Settings panel, click the Settings tab and then the Overlays tab.

The panel lists the names of the current overlay designs and their brightness levels.

2. Click the Add button.

The Add Overlay Design dialog box appears, with a list of the designs that are open and available to be used as layout view overlays.

3. (Optional) If you need to open a design and display it as an overlay, click the Open Design button, select the design name in the Open Design dialog box, and click OK.

Note:

The GUI does not open a new layout window for a design you open to add as an overlay. However, when you open a new layout window (by choosing Window > New Layout Window), you can select any design as the primary design for the window.

4. Select the design name in the Add Overlay Design dialog box, and click OK.

The tool displays the design name on the Overlays tab, sets the brightness level to 50 percent, and displays the overlay on the active layout view.

When you add an overlay to the active layout view, the tool displays the design name on the View Settings panel and sets the brightness level to 50 percent. You can display or hide an overlay by controlling its brightness, but you cannot select, query, or edit objects in an overlay design.

To remove an overlay from the active layout view,

1. On the View Settings panel, click the Settings tab.

2. Click the Overlays tab.

3. Click the Remove button for the design you want to remove.

A message box appears asking if you want to close the design. Do one of the following:

- To keep the design open, deselect the “Close design after removing” option and click OK.
- To close the design, click OK.

If you have unsaved design changes, the Close Design dialog box appears. Set options to save or discard design changes as needed and click OK to close the design, or click Cancel to keep the design open without saving the changes.

For more information, see the “Viewing Design Overlays” topic in IC Compiler Help.

---

## Setting and Saving View Properties

The View Settings panel provides options you can use to set display properties in the active layout view. You can also save the current settings in your preferences file, or load settings from the preferences file. If you open multiple layout views, you can set different options for each view.

To display or hide the View Settings panel,

- Choose View > Toolbars > View Settings.

A check mark beside the command on the Toolbars menu indicates that the View Settings panel is visible.

You can set options on the View Settings panel to

- Control object or layer visibility and selection
- Change object or layer style properties such as colors or fill patterns
- Set display options for the view or for cells, ports, pins, or nets in the view

[Figure A-9](#) shows the View Settings panel as it appears when you open a new layout window, and explains what you can do with it.

*Figure A-9 View Settings Panel for Objects in Layout Views*



[Figure A-10](#) shows the View Settings panel as it appears when you click the Layers tab to set options for layers or objects on layers.

*Figure A-10 View Settings Panel for Layers in Layout Views*



To change layout view display properties in the active layout view,

1. Set options as needed on the View Settings panel.
2. Click Apply.

By default, when you change settings on the View Settings panel, you must click Apply before the changes take effect in the active view. If you prefer, you can set the panel to automatically apply your changes as soon as you make them.

To enable or disable the automatic apply mechanism,

- Choose Options > Auto Apply.

A check mark beside the command on the Options menu indicates that the auto apply mechanism is enabled.

Alternatively, when the automatic apply mechanism is not enabled, you can reverse changes that you have not already been applied.

To reverse unapplied changes,

- Choose Options > Cancel.

You can set visibility or selection options or change style properties for

- Object types or subtypes
- All objects on a layer
- Object types on a layer

Object subtypes are categories of objects by property or attribute. For example, when cells are visible, you can display core cells and hide macro cells.

By displaying or hiding particular object types or layers, you can visually inspect just the physical layout data that you are interested in viewing while ignoring unrelated data. By enabling or disabling selection for particular object types or layers, you can control which types of objects are selected when you click or drag the pointer in a layout view.

You can customize how objects appear in the layout view by changing their style properties. Object styles set the appearance of objects in the active layout view. You can set the color, fill pattern, outline style, outline width, or exaggeration value for individual object types or layers.

Note:

The exact properties that you can change depend on an object's graphic representation in the layout view.

Typically you customize object style properties for a design. For example, the colors you use for individual layers might change, depending on the number of layers in the design.

The default display characteristics for design objects in a layout view are set for optimal viewing. These default characteristics work well for most designs. However, you can change the display characteristics for individual object types if you need to customize your layout views for a particular design or working environment.

IC Compiler does not save view settings when you exit the session. If you change layout view settings during a session and want to use the same settings in a future session, you can save them in your preferences file. You can also restore previously saved view settings by loading them from your preferences file.

To save the current settings for the active layout view,

- Choose Options > Preferences > Save to Preferences on the View Settings panel.

To restore the most recently saved layout view settings,

- Choose Options > Preferences > Set from Preferences on the View Settings panel.

For more information about using the View Settings panel with the active layout view, see the “Configuring the Layout View” topic in IC Compiler Help.

---

## Using Stroke Activated Commands

You can stroke the pointer to activate preset commands, which can include icc\_shell commands, in the active layout view. By default, the strokes are set up to activate commands that do the following:

- Increase or decrease the magnification of the design
- Pan the design
- Display the entire design

You can also define your own strokes. You can define up to 72 basic strokes and many more multisegmented strokes.

A basic stroke is a single click of the middle mouse button with the pointer in the layout view. A point-to-point stroke (dragging the pointer from point to point in one of the following directions while holding down the middle mouse button).



You can activate other commands for each of these strokes by also pressing a modifier key (Shift, Ctrl, or Alt), or a combination of these keys as shown below.

#### **Basic strokes made without pressing Shift, Ctrl, or Alt**



#### **Basic strokes made while pressing Ctrl**



In addition to the basic and modified stroke commands, you can perform multisegmented strokes. Each segment can go in any one of the eight directions used for the basic stroke commands. The following drawing shows some of the simple multisegmented strokes you can define:



To bind a command to a basic or multisegmented stroke, use the `set_gui_stroke_binding` command. By default, the GUI is set up to use basic strokes instead of multisegmented strokes. You can change this preference by using the `set_gui_stroke_preferences` command. For details about using these commands, see their man pages.

---

## Analyzing the Physical Design

The layout window provides tools and commands that you can use to visualize and analyze your design at each stage in the design process. These tools and commands are described in the following sections:

- [Using Visual Analysis Modes](#)
  - [Examining and Editing Relative Placement Groups](#)
  - [Analyzing Signal Integrity](#)
  - [Analyzing Clock Trees](#)
- 

### Using Visual Analysis Modes

The layout view provides visual analysis modes that help you analyze the physical design by coloring specific types of design or timing data. You can use the Analysis toolbar, shown in [Figure A-11](#), to enable or disable the following visual analysis modes in the active layout view:

- Flylines
- Net connectivity

- Map modes
- Visual modes

The Analysis toolbar is available only in the layout window.

*Figure A-11 Analysis Toolbar*



In addition, the layout window provides tools that you can use to examine relative placement groups, analyze signal integrity, and examine routing and verification errors.

You can use the GUI to analyze the physical layout as explained in the following sections:

- [Displaying Flylines](#)
- [Displaying Net Connectivity](#)
- [Using Visual Modes](#)
- [Using Map Modes](#)

## Displaying Flylines

Flylines let you view the connectivity of selected objects (cells, pins, or ports) in the layout window. You can select an object and display flylines to see the locations of the objects that have net connections to the selected object.

Flylines represent unrouted straight-line pin-to-pin connections. By default, the layout window shows flyline connections from the selected objects to macro cells, I/O ports, and other selected objects.

Note:

Make sure the desired object types (core cells, macro cells, I/O cells, pins, or ports) are visible and can be selected in the layout view (select their visibility and selection options on the View Settings panel).

To view the flylines from selected cells,

1. In the layout window, click the  button on the Analysis toolbar or choose View > Flylines.

The Flyline Settings panel appears.

2. (Optional) Set options as needed on the Flyline Settings panel.

You can control how the flylines are displayed and change their appearance.

3. Select one or more cells, pins, or ports.

Flylines appear from the selected objects to the cells, pins, ports, or other selected objects with which they are connected. You can

- Zoom in if necessary to see individual flylines
- Pan or scroll to follow a flyline through the design

4. Select or deselect objects as needed to view their flylines.

If you highlight an object while its flylines are displayed, the flylines are also highlighted, and they remain highlighted when the object is no longer selected.

Note:

A flyline is a line that represents a single connection between two objects such as pins or cell instances. If you need to visualize the connectivity for an object such as a plan group that requires multiple connection lines, use the net connectivity display.

For more information, see the “Displaying Flylines” topic in IC Compiler Help.

## Displaying Net Connectivity

Net connectivity lets you view the connections of selected nets in the layout window. You can select a net and display net connectivity to see the locations of the objects that have connections to the selected net.

Net connectivity displays the net connections to an object as a line with a number representing one or more nets between objects. These objects can be macro cells (including soft macros, hard macros, and black boxes), I/O cells, bounds, or plan groups. Net connections represent unrouted straight-line pin-to-pin connections. By default, the layout window shows net connections from a selected net to macro cells, I/O ports, and other selected objects.

Note:

Make sure the desired net types are visible and can be selected in the layout view (select their visibility and selection options on the View Settings panel).

To view the connections from selected nets,

1. In the layout window, click the  button on the Analysis toolbar or choose View > Net Connectivity.

The Connectivity Settings panel appears.

2. (Optional) Set options as needed on the Connectivity Settings panel.

You can control how the net connections are displayed and change their appearance.

3. Select one or more cells, pins, or ports.

Net connections appear from the selected objects to the cells, pins, ports, or other selected objects with which they are connected. You can

- Zoom in if necessary to see individual net connections
- Pan or scroll to follow a net connection through the design

4. Select or deselect objects as needed to view their net connections.

If you highlight an object while its net connections are displayed, the connections are also highlighted, and they remain highlighted when the object is no longer selected.

For more information, see the “Displaying Net Connections” topic in IC Compiler Help.

## Using Visual Modes

Visual modes are analysis tools you can use to illuminate specific design or timing information with colors in the active layout view. When you activate a visual mode, the GUI dims the visible objects in the layout view and opens the Visual Mode panel. The name of the active visual mode appears in the list at the top of the Visual Mode panel.

For power network analysis in a multivoltage design, you can highlight voltage areas and level shifters.

For floorplan and placement analysis, you can use visual modes to highlight

- Block placement
- Cells by hierarchy
- Illegal cell locations
- Worst slack through cells
- Net connections in an area
- Relative placement groups

- Relative placement net connections
- Scan chains
- Categorized timing reports

For routing analysis, you can use visual modes to highlight

- Worst slack timing paths
- Timing path pins
- Net capacitance

For signal integrity analysis, you can use visual modes to highlight

- Crosstalk victim and aggressor nets
- Static noise
- Switching noise

For clock tree analysis, you can use visual modes to highlight

- Clock trees
- Clock tree timing (latency or transition)

A visual mode groups design objects, timing data, or other information into categories or ranges called bins. The layout view displays each bin in a different color.

- To enable or disable visual mode, click the visible visual mode button on the Analysis toolbar or choose View > Visual Mode.  
Clicking the visual mode button activates the default visual mode (snapshot) or the most recently active visual mode. The button icon changes to indicate the active visual mode.
- To activate a particular visual mode, choose a command from the Visual Mode menu on the Analysis toolbar.
- To change to a different visual mode, select its name in the list on the Visual Mode panel.

Note:

The first time you activate some visual modes during a session, you must load the data before you can view the color overlay in the layout view.

Figure A-12 shows the default visual mode button and the Visual Mode menu button.

*Figure A-12 Visual Mode Tools on the Analysis Toolbar*



Each visual mode displays a legend of colored bars on the Visual Mode panel. The legend colors correspond to colors in the overlay. You can click the visibility options at the left end of each bar to display or hide individual bins in the layout view.

From left to right, the legend consists of

- A column of visibility options
- A column of labels (names or range values) that identify the bins
- Columns of information about the bins, including (by default)
  - Color and fill pattern (colored boxes)
  - Count (total items in a bin)
  - Exaggeration value in pixels (hidden by default)
- A histogram showing the distribution of objects or values by the relative lengths of the colored bars

You can change the color styles for individual bins, hide or display information columns on the legend, and adjust the color exaggeration.

In visual modes that color design objects, you can select or deselect the objects in each bin. In visual modes that color discrete, unrelated sets of objects or other information, you can reorder the bars in the legend.

## Using Map Modes

Map modes are analysis tools you can use to illuminate specific floorplan, placement, or routing results with colors in the active layout view. When you activate a map mode, the GUI dims the visible objects in the layout view and opens the Map Mode panel. The name of the active map mode appears in the list at the top of the Map Mode panel.

You can generate color maps to display

- Congestion (global route, track assignment, or detail route)
- Preroute power network analysis (electromigration, voltage drop, or resistance)
- Cell placement (cell density or pin density)
- Signal electromigration
- Critical areas (shorts and opens)
- Static postroute In-Design rail analysis (electromigration, voltage drop, resistivity, parasitics, or power)
- Dynamic postroute In-Design rail analysis (electromigration or voltage drop)

A map mode divides the core area into an array of boxes with colored edges. The box edges are colored and labeled to represent the map data (such as congestion or power density) through the horizontal and vertical planes. Each map color represents a range of values.

- To enable or disable map mode, click the map mode button on the Analysis toolbar or choose View > Map Mode.  
Clicking the map mode button activates the default map mode (global route congestion) or the most recently active map mode. The button icon changes to indicate the active map mode.
- To display a particular map mode, choose a command from the Map Mode menu on the Analysis toolbar.
- To change to a different map mode, select its name from the list on the Map Mode panel.

[Figure A-13](#) shows the default map mode button and the Map Mode menu button.

*Figure A-13 Map Mode Tools on the Analysis Toolbar*



Each map mode displays a legend of colored bars on the Map Mode panel. The legend colors correspond to colors in the map. You can click the visibility options at the left end of each bar to display or hide individual bins in the layout view.

From left to right, the legend consists of

- A column of visibility options
- A column of labels (names or range values) that identify the bins
- Columns of information about the bins, including (by default)
  - Color and fill pattern (colored boxes)
  - Count (total items in a bin)
  - Exaggeration value in pixels (hidden by default)
- A histogram showing the distribution of map data by the relative lengths of the colored bars

You can change the color styles for individual bins, hide or display information columns on the legend, and adjust the color exaggeration.

---

## Examining and Editing Relative Placement Groups

A relative placement group can contain leaf cells, hierarchy (other groups), and placement keepouts. A hierarchy level is a relative placement group embedded in another relative placement group, either in the same design (included groups) or in a different design or designs (instantiated groups).

The IC Compiler GUI provides tools you can use to interactively examine and edit relative placement groups.

In the layout window, you can

- Explore relative placement group structures by using the relative placement hierarchy browser
- Examine relative placement groups by using the relative placement visual mode.
- Examine relative placement group net connections by using the relative placement net connections visual mode.
- Move relative placement groups in the layout view by using the Move/Resize tool

In the relative placement window, you can

- Explore relative placement group structures by using the relative placement hierarchy browser
- Visually examine the objects in a relative placement group by using interactive mouse tools in a relative placement view

You can select, highlight, and query objects in the group, and you can select rows or columns in the group.

- Edit a relative placement group by using the interactive editing tools in a relative placement view

You can move switch, add, and remove objects in the group, and you can add, remove, and flip rows or columns in the group.

For more information, see “[Working With Relative Placement Groups in the GUI](#)” on [page 11-64](#) and the “Examining and Editing Relative Placement Groups” topic in IC Compiler Help.

---

## Analyzing Signal Integrity

The GUI provides tools you can use to analyze the affects of crosstalk by examining the victim and aggressor nets. The two major effects of crosstalk are crosstalk-induced delay and static noise.

- Crosstalk-induced delay occurs when the victim and aggressor nets switch at the same time or nearly the same times, either speeding up or slowing down the victim net transition times.
- Static noise is a glitch on the victim net that occurs when the victim net is in a steady state of either a high or low, and the aggressor net is switching.

You can analyze crosstalk problems on a design after performing global routing, track assignment, or detail routing. The minimum requirement is a global-routed design. You can

- Examine a high-level view of the delta delays for victim nets in the routed design by using the delta delay visual mode
- Examine a high-level view of the accumulated static noise levels for victim nets in the routed design by using the static noise visual mode
- View information about individual victim nets and their aggressor nets in the static noise analysis window or the path inspector window
- Highlight a victim net and its aggressor nets in the layout view by using the crosstalk visual mode
- Check the current flowing through metal wires and vias by using the signal electromigration map mode

Before analyzing crosstalk to find static noise and crosstalk-induced delay problems, you can set crosstalk-related timing setup options and specify supply voltages. You can set these options by using the Set SI Options dialog box (choose Timing > Set SI Options) or the `set_si_options` command.

For more information about performing crosstalk analysis, see “[Analyzing Crosstalk” on page 10-9](#)” and the “Analyzing Signal Integrity” and “Inspecting Victim and Aggressor nets” topics in IC Compiler Help.

---

## Analyzing Clock Trees

You can use tools in the layout window and the interactive clock tree synthesis window to perform both high-level and detailed analyses of the clock tree structures and timing in your design.

- In the layout window, you can use visual modes to view the overall structures or timing distribution of the synthesized clock trees.
- In the interactive clock tree synthesis window, you can view information about all the clocks in the design and detailed information about individual clock trees.

You can select clock tree objects in the interactive clock tree synthesis window to highlight them in the layout view or color them in the clock trees visual mode. For information about layout view visual modes, see “[Using Visual Modes” on page A-51](#).

In both windows, you can use clock tree synthesis menu commands to perform tasks such as viewing clock tree options and setting, changing, or removing clock tree options, exceptions, and references. in addition, the interactive clock tree synthesis window provides tools you can use to

- View clock details and select clocks in the clock browser
- View the distribution of clock tree pin arrival times in a clock tree arrival histogram
- Explore the pin-to-pin fanout structure of a clock tree in the clock tree fanout browser
- Examine the fanin or fanout network for an entire clock tree or selected clock tree structures in clock tree network schematics
- Find, select, and view information about specific clock tree objects (cells, pins, or load nets) in clock tree synthesis object list views

The following sections describe the analysis tools provided in the interactive clock tree synthesis window:

- [Opening an Interactive Clock Tree Synthesis Window](#)
- [Exploring Clock Tree Structures](#)
- [Highlighting the Critical Paths](#)
- [Examining Clock Tree Timing](#)

## Opening an Interactive Clock Tree Synthesis Window

You can use tools in the interactive clock tree synthesis window to perform both high-level and detailed analyses of the clock trees in your design.

To open an interactive clock tree synthesis window,

- Choose Window > New Interactive CTS Window.

When you open an interactive clock tree synthesis window, the clock browser view window appears. The clock browser displays a list of the clocks in your design with information about each clock.

The Browsers toolbar, shown in [Figure A-14](#), lets you

- Display the clock browser when it is hidden
- Display a clock arrival histogram.
- Select a clock in the clock browser view and display the clock tree in a clock tree fanout browser.

*Figure A-14 Browsers Toolbar*



The clock browser and the clock tree fanout browser are the starting points for detailed clock tree analysis. You can open one clock browser in an interactive clock tree synthesis window, and you can open one clock tree fanout browser for each clock tree in the design. In addition, you can

- Examine the fanin or fanout network for selected clock tree structures by viewing clock tree network schematics
- Examine clock latency and skew in the clock tree fanout over time by viewing clock graph views
- Find and view information about specific clock tree objects by viewing clock tree synthesis object list views

You can also select clock tree objects in a clock tree fanout browser for analysis with tools in the layout window.

For more information, see [“Analyzing Clock Trees in the GUI” on page 7-127](#).

## Exploring Clock Tree Structures

You can use the clock tree fanout browser to display pin-to-pin fanout information about clock tree structures in the physical design. If you are not familiar with the clock trees in your design, you can explore the clock tree structures and gather information about objects (buffers, inverters, and preexisting cells) at each level. You can also select the names of objects you want to examine in graphic views or with other analysis tools.

- Before you perform clock tree synthesis, use the clock tree fanout browser to understand the existing clock tree structure.
- After you perform clock tree synthesis, use the clock tree fanout browser to analyze the resulting clock tree structures and for troubleshooting if you failed to achieve the expected QoR.

You can use the clock tree fanout browser together with clock network fanin and fanout schematics or the clock trees visual mode to determine what constraints or options you need to modify to improve the clock tree synthesis results.

To open a clock tree fanout browser,

1. In the interactive clock tree synthesis window, select a clock tree name in the clock browser.
2. Choose View > Show Clock Tree Hierarchy Browser.

The view window consists of two panes, with an expandable level in the left pane and an object information table in the right pane. You can explore the complete structure of a clock tree, observe how many levels are present, and examine the clock tree fanout information at each level.

The object table shows clock tree fanout information for the clock tree objects you select in a level tree. You can display information about child (next level) objects or associated objects by selecting an option in the list above the object table.

For more information about using the clock tree fanout browser, see the following sections:

- [Expanding or Collapsing Fanout Levels](#)
- [Highlighting a Selected Object](#)
- [Changing the Timing Mode](#)

See also the “Exploring the clock tree Structures” topic in IC Compiler Help.

### Expanding or Collapsing Fanout Levels

The Expand Browser toolbar, shown in [Figure A-15](#), lets you expand or collapse fanout levels for the clock tree displayed in the active clock tree fanout browser. You can expand or collapse all levels, or expand a specified number of levels.

**Figure A-15 Expand Browser Toolbar**

### **Highlighting a Selected Object**

You can locate a specific clock tree object in the fanout browser by selecting the object in another view, such as a layout or schematic view. You can also enable a mechanism in a clock tree fanout browser that automatically displays and highlights an object when you select it in another view.

The Follow Selection toolbar, shown in [Figure A-16](#), lets you find a clock tree object in the clock tree fanout browser by selecting the object in another view.

**Figure A-16 Follow Selection Toolbar**

### **Changing the Timing Mode**

When you view object information in a clock tree fanout browser, you use the Clock Tree Timing Modes toolbar, shown in [Figure A-17](#), to control whether the tool uses maximum or minimum timing values to calculate the timing data.

**Figure A-17 Clock Tree Timing Modes Toolbar**

## Highlighting the Critical Paths

You can use the Critical Path toolbar, shown in [Figure A-18](#), to highlight the longest and shortest clock tree fanout paths in the active clock tree fanout browser or clock tree schematic.

**Figure A-18 Critical Path Toolbar**

## Examining Clock Tree Timing

You can use clock arrival histograms, clock tree schematics, and clock graph views to examine timing problems by focusing on critical fanin or fanout paths through the clock tree network.

- A clock arrival histogram provides a high-level overview of the timing quality in the fanout network of a clock tree.  
You can adjust the arrival time ranges and set histogram options. For more information, see the “Opening a Clock Tree Arrival Histogram” topic in IC Compiler Help.
- A clock tree schematic displays the structure of selected clocks in a flat, single-sheet schematic of cells and nets that have been placed and routed with a general purpose.  
You can generate a clock tree schematic to display an entire clock path or the fanin or fanout logic for selected clock tree objects. For more information, see the “Viewing Clock Tree Schematics” topic in IC Compiler Help.

- A clock tree latency graph represents clock tree fanout and fanin in a time-based display that facilitates clock tree latency and skew analysis.

For more information, see the “Examining Clock Tree Fanout Levels” and “Examining Clock Tree latency Over Time” topics in IC Compiler Help.

For more information about how to examine clock tree timing, see [“Analyzing Clock Trees in the GUI” on page 7-127](#).

You can use clock graph views to examine

- Clock skew, bottlenecks, insertion delays, and the intrinsic path delays in a clock tree latency graph
- Clock tree fanout structure in a clock tree leveled-fanout graph

In a clock graph view.

- Cells appear as single-input single-output boxes
- For clarity and a more concise visualization, pins are not shown with cells.
- Reconverging clock paths appear as diagonal lines.

The clock graph view uses symbols based on gate types. Cells are colored, based on their type. [Figure A-19](#) identifies the symbols that can appear in a clock graph view with the object types they represent.

*Figure A-19 Clock Graph Symbols*

In a clock tree latency graph, the x-axis displays clock tree logic relative to time. The graph positions logic gates based on the latency of their input clock pins.

- Cells are aligned on their left borders with the internal arrival times on their clock pins. If more than one input has a clock pin attribute, the cells are aligned with the worst case arrival time. If you display multiple clocks in the same graph, the clocks are placed based on the maximum latency among the delays on the clock pins of the selected clocks.
- All nets shown entering or leaving a gate converge at a single point, regardless of whether they connect to the same pin. Nets and pins that are not associated with clock signals are not shown in the view. Reconvergent clock paths appear as diagonal lines.

In a clock tree levelized graph, the x-axis displays the clock tree fanout levels for selected clock trees. The graph positions logic gates based on the fanout levels of their clock input pins. The fanout level of a reconvergent point is the maximum level of the fanout branches through that point.

- Cells appear as single-input single-output boxes, aligned on their left borders with the maximum fanout levels of their input pins.

For a cell with feedback clock pins, the tool adjusts the level number to accommodate all the input levels of the cell.

Because the clock structure varies across the clock domains, when you display multiple clocks in the same graph, the level numbers associated with cells on the clock fanout might vary depending on which clocks you selected. A typical case is the level number at a point where clock trees overlap.

- All nets shown entering or leaving a gate converge at a single point, regardless of whether they connect to the same pin.

Similarly, if multiple outputs are in the clock path, their nets are shown emerging from a single point.

You can expand or collapse the logic in a clock tree graph. When you collapse the logic, the view combines all the buffer and inverter chains into metacells. In [Figure A-20](#), a single clock root fans out to three register sinks and a single macro sink.

*Figure A-20 Clock Tree Latency Graph With Collapsed Logic*



The symbols for collapsed buffers and inverters appear with thicker lines than the symbols for other cells. A metacell is positioned relative to the earliest arrival time of its constituent gates. Metacells without inverted outputs have a slightly different appearance from metacells with both inverted and noninverted outputs. The lines emanating from a metacell do not necessarily represent the same net.

[Figure A-21](#) shows the same clock tree with the logic fully expanded.

*Figure A-21 Clock Tree Latency Graph With Expanded Logic*



For more information about how to examine clock tree latency and clock tree fanout levels, see “[Viewing Clock Latency and Skew in the Clock Graph View](#)” on page 7-133 and “[Using the Clock Tree Levelized Graph View](#)” on page 7-134.

## Examining Clock Tree Overlaps

The clock tree overlap analyzer view displays a hierarchical or flat list of clocks and a matrix of overlapping clock pairs. The overlap matrix consists of a grid with a row and column for each clock in the clock list.

To open the clock tree overlap analyzer,

- Choose View > Clock Tree Overlap Analyzer.

In the clock list, expandable hierarchy trees represent the clock hierarchy among primary and generated clocks. You can click the expansion button (plus sign) next to a clock name to expand the tree, showing the names of the clocks at the next level in the hierarchy.

The overlap matrix consists of a grid with a row and column for each clock in the clock list. The Index column on the left side of the matrix correlates the clock names in the list with the rows and columns in the matrix. A light gray color in the grid indicates that clocks belong to the same clock domain. When you select a clock name in the clock list, a light blue color highlights the row for the corresponding clock in the matrix.

The matrix displays X symbols in the grid to indicate overlapping clock pairs. If you click a box in the grid that represents an overlap, the tool displays the overlap point in the selection color, which is white by default, in other views such as a clock tree schematic or clock graph view.

For more information about the clock tree overlap analyzer, see the “Examining Clock Tree Overlaps” topic in IC Compiler Help.

---

## Analyzing Timing Paths

The timing analysis window provides a centralized area for performing timing path analysis. The window includes a timing analysis driver, a path inspector, and other analysis tools such as histograms, schematics, path profiles, and timing reports.

You can use tools in the timing analysis window to perform both high-level and detailed analyses of the timing paths in your design. You can

- Examine timing path details in the timing analysis driver
- View histograms that show the distribution of worst path slack, endpoint slack, net capacitance, or other path details in histogram views
- Inspect the clock network and path data elements for a selected path in the path inspector
- View path delay profiles for selected paths in path profile views
- View selected paths, fanin and fanout cones, and other objects in path schematics
- View and save timing reports for selected paths or the paths with the worst slack in the design

The following sections describe the timing analysis tools:

- [Opening a Timing Analysis Window](#)
- [Viewing Timing Path Details](#)
- [Using Timing Analysis Views](#)
- [Viewing Path and Design Schematics](#)
- [Inspecting a Timing Path](#)

---

## Opening a Timing Analysis Window

When you open a timing analysis window, you can set the criteria for displaying timing path details in the timing analysis driver. By default, details for the 20 worst paths in each path group are displayed.

To open a timing analysis window,

1. Choose Window > New Timing Analysis Window.

The Select Paths dialog box appears.

2. (Optional) To display path details in the window, select a method for choosing the paths, and select other options as needed.

3. Click OK or Apply.

Note:

You can open the timing analysis window without displaying path details by clicking Cancel in the Select Paths dialog box when it appears.

---

## Viewing Timing Path Details

When you open a timing analysis window, the timing analysis driver panel appears, attached to the left side of the window. The timing analysis driver displays detailed information about the timing paths that have the worst slack in the design. You can view the timing path details and select paths for further examination with other analysis tools.

The timing analysis driver consists of a timing path table, a button bar, and a command display box.

- The table displays a list of paths found by the tool, based on criteria that you specify. By default, the tool uses the `get_timing_paths` command.
- The button bar provides commands you can use to reload the paths, customize the table columns, save the path details in a text file, and access other timing analysis tools.
- The command display box shows the command and options used to find the paths.

The timing analysis driver is the focal point for timing path analysis in IC Compiler. You can select paths that you want to examine in another view, such as a schematic view, timing report, or path inspector window. You can also generate timing histograms based on the values in a column of the timing path table.

The first time you open the timing analysis driver during a session, the Select Paths dialog box appears. Use this dialog box to load timing path information in the timing path table. You can

- Set dialog box options for the `get_timing_paths` command.

The dialog box options are set by default to run the `get_timing_paths` command with its default options. You can reset the dialog box options to their defaults by clicking the Default button.

- Select a predefined collection command.

You can load all selected paths or all highlighted paths.

- Enter a command to define a custom collection.

The tool automatically adds the command to the list of predefined commands.

The tool displays the path names and other path information in the timing paths table and displays the command you used to load the paths in the command display box below the button bar. You can copy text in the command display box and paste it somewhere else, such as on the console command line.

You can sort, filter, and customize the table, and you can save the path details in a text file.

For more information, see the “Examining Timing Path Details” topic in IC Compiler Help.

---

## Using Timing Analysis Views

The Timing Views toolbar, which is shown in [Figure A-22](#), lets you generate histograms (path slack, endpoint slack, and net capacitance) and path profiles for timing analysis. The histogram buttons open dialog boxes in which you can set options to customize the histogram. The path profile button is enabled only when a timing path is selected. This toolbar can be found in the timing analysis window.

*Figure A-22 Timing Analysis Toolbar*



For more information about using timing analysis views, see the following sections:

- [Viewing Histograms](#)
- [Examining Path Profiles](#)

## Viewing Histograms

You use histograms to view distributions of timing values such as slack or net capacitance. Histograms are focal points of visual timing analysis that allow you to view the overall timing performance of your design.

The IC Compiler GUI provides the following types of histograms for timing analysis:

- Endpoint slack histograms provide a high-level overview of the timing quality of your design. Create an endpoint slack histogram to identify endpoints that failed to meet their constraints.
- Path slack histograms provide a high-level overview of the timing quality for selected paths in your design. Create a path slack histogram to identify paths that failed to meet their constraints.
- Net capacitance histograms provide a high-level overview of the capacitance values for selected nets or for all the nets in your design. Create a net capacitance histogram to identify nets that have unacceptably high capacitance values.

In addition, when you use the timing analysis driver, you can create histograms that show the distribution of values for various types of path details, such as slack, endpoint clock skew, arrival time, or required time, that are listed in the timing path table.

In the interactive clock tree synthesis window, you can create a clock arrival histogram to identify clock network pins that failed their constraints. For details, see “[Viewing the Clock Tree Arrival Time Histogram](#)” on page 7-132.

Histogram view windows are split into two panes. By default, the histogram bar graph appears in the left pane and an object table appears in the right pane. [Figure A-23](#) shows an example of the bar graph in a path slack histogram. The bins represent the number of paths (y-axis) versus their slack values (x-axis).

*Figure A-23 Example of Path Slack Histogram*



The number at the top of the tallest bin indicates the number of paths in the bin. Green bins (on the positive side of 0) contain paths that met their constraints. Red bins (on the negative side of 0) contain paths that failed to meet their constraints. You can

- Hold the pointer over a bin in the bar graph to display its value range and number of objects or paths in an InfoTip below the pointer
- Click a bin to display its contents (object names and slack or capacitance values) in the object table
- Select objects in the object table for further examination with other analysis tools such as path schematics or reports
- Filter the object table, limiting it to certain objects based on a character string or regular expression that you define

## Examining Path Profiles

You can use the path profile view to visualize the relative importance of different cells and nets in contributing to the total delay of a timing path.

The path delay profile shows the pin-by-pin distribution of delays on a path—the same information that the timing report provides, except in graphic form. You can view two different types of profiles: hierarchical and flat.

The path profile view is identical to the path profile tool that you can view by clicking the Path Delay tab in a path inspector window.

To view the delay distribution along a timing path,

1. Select one or more timing paths.
2. Click the  button on the Timing Views toolbar or choose Timing > Path Profile View.

The path profile view window appears. The hierarchical profile appears by default the first time you open this view.
3. Click the tab for the type of path profile you want to view.
  - To view a hierarchical profile, click the Hierarchy tab.
  - To view a flat, leaf-level profile, click the Flat tab.

The combined delays for each path and the relative delay contribution for each pin appear graphically in bar graphs that represent the percentages of the total path delay. For each timing path, the bar graph shows the percentages of the individual pin delays from startpoint to endpoint. For each pin on a path, the bar graph shows the percentage contribution of the pin delay to the total path delay.

---

## Viewing Path and Design Schematics

You can use the following schematic and symbol views to show graphical representations of the logic design:

- Path schematic view

Path schematic views show graphical representations of the logic design. You use these views to visually analyze timing and logic in the optimized design and to gather information that can help you guide later optimizations. Objects you select in a schematic or symbol view are cross-selected in other views. This capability allows you to efficiently analyze the logic and timing aspects of your design.

- Design schematic view

Design schematics display a design as a schematic composed of cell instances, pins, nets, and ports. The schematic shows both leaf-level logic (gates) and subdesigns (blocks). You can move up or down in the design hierarchy to view the schematic for each block in the hierarchy.

- Symbol view

Symbol views display a hierarchical cell or a leaf cell as a black box with input and output ports. To change the view to a design schematic of the cell, double-click inside the box.

You use schematic and symbol views to visually analyze timing and logic in the optimized design and to gather information that can help you guide later optimizations.

Objects you select in a schematic or symbol view are cross-selected in other views. This capability allows you to efficiently analyze the logic and timing aspects of your design.

The Schematics toolbar, shown in [Figure A-24](#), lets you open design schematics (for selected designs), symbol views (for selected cells), and path schematics (for selected timing paths or design logic). When a design schematic is the active view, you can use this toolbar to move down or up a level in the design hierarchy. When a path schematic is the active view, you can use this toolbar to add timing paths, fanin logic, and fanout logic.

*Figure A-24 Schematics Toolbar*



You can use the View Settings panel to change the following display characteristics for the active schematic view:

- Object name visibility, text colors, and text sizes
- Object annotation visibility, text colors, and text sizes
- Object colors
- Display style for highlighted timing paths

To display the View Settings panel,

- Choose View > Toolbars > View Settings.

[Figure A-25](#) shows the View Settings panel as it appears when a schematic view is the active view.

**Figure A-25 View Settings Panel for Schematic Views**

For more information about using schematic and symbol views, see the “Viewing Path and Design Schematics” topic in IC Compiler Help.

## Inspecting a Timing Path

You can select an individual timing path and use the path inspector window to examine detailed information about the clock network and datapath elements in the path. The path inspector provides tools for viewing different aspects of the path, including

- The path status
- Path and clock summaries
- Clock network and path data elements
- Path delay profiles
- Crosstalk victim and aggressor nets
- A path schematic with clock path highlighting

To open a path inspector window,

1. Select the path you want to inspect.
2. Click the Inspector button on the timing analysis driver button bar.

Alternatively, you can select a path and choose View > Show Path Inspector.

The path inspector window displays path information on three panels:

- The Status panel displays the path startpoint, endpoint, delay type, and slack. It also provides controls for automatically or manually loading another path.



- The Tab panel displays path summaries, clock network and path data element tables, path delay profiles, and crosstalk victim and aggressor net lists in a set of tabbed pages. You can copy the summaries and paste them into text files, export the tables to text files, customize the element tables, and generate delay calculation reports for selected cells or nets.



- The Schematic View panel displays a path schematic of the complete path (datapath, clock launch path, and clock capture path) with data and clock path overlays.



You can add fanin and fanout logic to the path schematic.

The legend below the Schematic View panel provides options you can use to display or hide the paths and buttons you can use to display or hide the overlays.



---

## Examining Routing and Verification Errors

The error browser lets you examine routing design rule errors and verification errors. You select the errors you need to examine by error type or layer, view error information in the error browser, and view error locations in the layout view. You can

- Filter the error list
- Mark errors as fixed or remove the fixed marker, optionally hide fixed errors, and save the updated error status
- Highlight errors in the layout view
- Display error information on the Query panel and optionally record the information in the session log
- Select errors interactively by using the Error Selection tool
- Save the error information in a report file
- Save error updates in an error view

You can also highlight the nets associated with detail routing errors and display the net nodes associated with open locator errors.

IC Compiler provides several routing and verification processes that check your design for rule violations and save the error data in files called error views. You can examine detail routing errors, layout versus schematic (LVS) verification errors, DRC errors, signoff DRC errors, In-Design rail analysis postroute power and ground verification errors, signal electromigration constraint violations, and third-party DRC errors. For more information about using these rule checking processes, see “[Analyzing the Routing Results](#)” on page 8-89.

You can also examine editor DRC errors that result from interactive editing operations in the layout view. The error browser loads editor DRC error view automatically when the tool detects rule violations, and editor DRC incrementally updates the error view when you fix a violation, reverse the edit that caused the violation, disable the rule used to detect the violation, or remove errors in the error browser. For more details about the editor DRC error view, see “[Examining Editor DRC Errors](#)” on page A-108.

Error views are associated with the current design. The error browser loads detail routing errors from memory and other types of errors from the appropriate error views. The error data is grouped by the error types or layers associated with the errors. The available error types depend on the verification process used to generate the error records. Each error record contains information that includes a description string and bounding box coordinates correlated with the physical design. An error record can also provide references to design objects. This is the data that the error browser displays

To open the error browser window,

- Choose Verification > Error Browser or Rail > Error Browser.

If you have already loaded detail routing errors or opened an error view during the session, the error browser window appears. For assistance using the error browser, choose Help > Error Browser Help in the error browser window.

If you have not already loaded detail routing errors or opened an error view, the Open Error View dialog box appears.

- a. Select the options for the types of errors you want to examine, and deselect the options for the types of errors you do not want to examine.
- b. Click OK.
- c. For each option you select except Detail Route, type the error view name in the text box, or click the browse button and select the file in the Choose Cell dialog box.

**Note:**

The Verification menu is available only in the block implementation task mode. To display the block implementation menus in the layout window, choose File > Task > Block Implementation or File > Task > All Tasks.

When the error browser is open, if you need to reload an error view or load a different error view, choose File > Open in the error browser window to open the Open Error View dialog box.

For more information about examining errors with the error browser, see the following sections:

- [Viewing and Fixing Errors](#)
- [Filtering Errors in the Error List](#)
- [Selecting Errors in the Layout View](#)
- [Examining Nets Associated With Detail Routing Errors](#)
- [Examining Net Nodes Associated With Open Locator Errors](#)
- [Examining Errors in an Area](#)
- [Saving the Error List in an Error Report File](#)
- [Saving Error Updates in an Error View](#)
- [Saving a Copy of the Editor DRC Error View](#)

---

## Viewing and Fixing Errors

The error browser displays errors in two views.

- To view detail routing errors or view verification errors from an error view, click the DRC tab.
- To view editor DRC errors in the current design, click the Editor DRC tab.

The error browser window contains, from top to bottom, an error hierarchy tree, an error list view, and an error detail view. You can use the split bars between to adjust the relative heights of these views.

- The error hierarchy tree groups errors by type, the default, or by layer to help you find the problems you need to examine.
- The error list displays the ID number, error type, layer name, and a short summary for each error in the list.
- The error detail pane displays information about the errors that you select in the error list.

You can display information for up to 100 errors. If you hold the pointer over the error detail pane, the details for the first selected error appear in an InfoTip.

You can control the visual display of errors in the active layout view by choosing commands on the Options menu and setting options below the error detail pane.

To examine errors in the error browser,

1. (Optional) To group the errors by layer instead of type, choose Options > Show by Layer.
2. Select an error group in the error hierarchy tree.

To expand an error view, error type, or layer in the hierarchy, click its expansion button (+). When you select an error group, only the errors in that group appear in the error list.

3. (Optional) Filter the error list until it displays just the errors you want to examine.

To set a filter, click the Filter button and select the filter options in the Filter Error List dialog box. You can display or hide selected errors, errors on specific layers when the errors are grouped by error type, or errors of a specific type when the errors are grouped by layer. For more details, see “[Filtering Errors in the Error List](#)” on page A-79.

4. Select one or more errors in the error list.

The error browser displays information about the selected errors in the error detail pane. You can Ctrl-click or drag the pointer to select multiple errors.

5. Examine the errors in the layout view.

By default, when you select an error in the error list, the layout view zooms in to magnify the error shape and colors it in the select color, which is white by default. The error shapes for the other errors in the error list appear in the DRC violation color, which is yellow by default.

You can highlight error shapes in the layout view by clicking buttons or choosing commands on the Highlight menu in the error browser window. You can highlight selected errors, the errors that are visible in the error list, specific types of errors or errors on specific layers, and errors associated with specific nets. For details about highlighting error shapes, see the “[Highlighting Routing or Verification Errors](#)” topic in IC Compiler Help.

You can adjust the layout view error display by setting options in the area below the error detail pane

- To control whether the tool displays all, selected, or no errors in the layout view, select an option in the Show list. The default option is All.
- To control whether the tool zooms in, pans, or neither to display the selected errors, select an option in the Follow list. The default option is Zoom.

To set the scaling factor for the Zoom option, select or type a value in the box beside the Follow list. The default scaling factor is 1.0.

- To control whether the tool dims other objects in the layout view when errors are displayed, select or deselect the Dim option. This option is deselected by default.

To further examine the errors, you can

- Select error shapes in the active layout view by using the Error Selection tool. For details, see “[Selecting Errors in the Layout View](#)” on page A-81.
- Display error information on the Query panel by clicking an error shape with the Query tool. For details about using the Query tool, see “[Viewing Object Information](#)” on page A-13.
- Highlight the nets for selected detail routing errors by choosing Options > Highlight Nets For Selected Errors. For details, see “[Examining Nets Associated With Detail Routing Errors](#)” on page A-81.
- Display the net nodes for selected Open Locator type errors by choosing Options > Display Net Nodes For Selected Open Locators. For details, see “[Examining Net Nodes Associated With Open Locator Errors](#)” on page A-82.

6. (Optional) Mark errors as fixed in the error list by selecting the errors and clicking the Fixed button.

You can display or hide fixed errors in the error list by choosing Options > Hide Fixed Errors.

You can save the updated error status indicators. Detail route error status changes are saved or discarded with other design changes when you save or close the design. The tool also automatically saves error views with unsaved status changes when you save the top-level design. You can manually save individual error views with unsaved status changes by using the Save Error Views dialog box. For details, see “[Saving Error Updates in an Error View](#)” on page A-83.

7. Examine other errors in the error list by repeating steps 4 through 6, or examine errors in a different error group by repeating steps 2 through 6.

The error browser is a global tool: errors that you select in the active layout view are cross-selected in any other open layout views. However, only the active layout view changes when the error browser automatically zooms or pans to display the selected errors.

---

## Filtering Errors in the Error List

When you examine errors in the error browser, you can filter the errors in the error list. You can display or hide selected errors, hide specific types of errors or errors on specific layers, and hide errors associated with specific nets. When the errors are grouped by error type, you can filter the error list by layer. When the errors are grouped by layer, you can filter the error list by error type.

To filter the error list,

1. Click the Filter button or choose Errors > Filter.

The Filter Error List dialog box appears.

2. Select a filter operation option and set the filter conditions as needed.

- To filter selected errors, select the By Selection option, and then select a filter option.

The Hide Selected option is selected by default. To display only the selected errors and hide all the other visible errors, select the Show Selected option.

- To filter errors by layer or error type, select the “Hide by Types and Layer String” option, and then select the options for the layers or error types that you want to hide.

- To filter errors by net connection, select the By Net option, and then select the nets or type the net names in the “Specify nets” box.

You can type multiple net names by separating them with blank spaces. If you type an invalid net name, the name appears on a light red background.

You can type part of a net name and press Tab to complete the name to its longest match. If multiple names match the text, a name completion list appears. Double-click a name, or select one or more names and press Enter, to paste the names into the “Specify nets” box. You can use the Up Arrow and Down Arrow keys to move up and down the list. To close the list, press Escape.

Note:

For optimal performance, the tool checks the names only after the first time you press Tab, press Enter, or display the name completion list for a specific object type.

This means the invalid name indicator might not appear if you have not yet performed any of these operations.

If you want to highlight errors that are not associated with a net and shorts or spacing errors that are associated with only one net, enable the error browser option to hide null net errors. Such a short or spacing error can occur when a net shape has a short or a spacing violation with a shape that has no net association, such as a blockage. A short or spacing error between net shapes of the same net contains two valid net associations with the same net.

To enable or disable the error browser option to hide null net errors, choose Options > Hide NULL Net Errors in the error browser window.

3. Click Apply or OK.

You can repeat this procedure as needed to filter the errors that remain visible in the error list.

To remove the filters, you can

- Click the Clear Filters button or choose Errors > Clear Filter in the error browser window.
- Click the Clear Filters button in the Filter Error List dialog box.

---

## Selecting Errors in the Layout View

When you examine errors in the error browser, you can select detail route or verification errors in the active layout view by using the Error Selection tool. This tool is available only when the All option, the default, is selected in the Show list. Error selection is local to the error browser and the active layout view and does not affect the global selection in other views.

To enable the Error Selection tool in the error browser,

- Click the  button in the error browser window.

The pointer becomes the Error Selection Tool pointer.

You can select or deselect error shapes in the active layout view.

- To select an error and deselect any other selected errors, click the error shape.
- To add an error to the current selection, Ctrl-click the error shape:
- To remove an error from the current selection, Shift-click the error shape:

You can select or deselect multiple errors at the same time by dragging the pointer to draw a rectangular box around the error shapes.

- To select the errors in a rectangular area and deselect any other selected errors, drag the pointer to draw a rectangular box around the error shapes.
- To add the errors in the area to the current selection, press the Ctrl key while you drag the pointer.
- To remove the errors in the area from the current selection, press the Shift key while you drag the pointer.

---

## Examining Nets Associated With Detail Routing Errors

When you examine detail routing errors in the error browser, you can set an option to highlight the nets in the layout view that are associated with the errors selected in the error list.

To highlight the nets for selected detail routing errors,

1. Select the Detail Route error type in the error hierarchy tree.
2. Select one or more errors in the error list.
3. Choose Options > Highlight Nets for Selected Errors.

A check mark appears beside the command on the Options menu when this option is enabled.

---

## **Examining Net Nodes Associated With Open Locator Errors**

When you examine open locator errors in the error browser, you can set an option to display the net nodes in the layout view that are associated with the errors selected in the error list.

To display the net nodes for selected open locator errors,

1. Select the Open Locator error type in the error hierarchy tree.
2. Select one or more errors in the error list.
3. Choose Options > Display Net Nodes for Selected Open Locators.

A check mark appears beside the command on the Options menu when this option is enabled.

---

## **Examining Errors in an Area**

To analyze the relationships among errors due to their physical proximity, you can display just the errors that occur in a specific area of the design.

To display errors in an area of the design,

1. Select the error view in the error hierarchy tree that contains the errors you want to examine.
2. Make sure the All option is selected in the Show list.
3. Display the area of the design you want to examine by using the Zoom In, Zoom Out, and Pan tools.
4. Enable the Error Selection tool, and then select errors in the area by clicking or dragging the pointer.
5. Filter the error list by clicking the Filter button, selecting the Show and Selected options in the Filter Error List dialog box, and clicking OK.

When you are ready to analyze errors in a different area, clear the error list filter by clicking the Clear Filter button, and repeat steps 3 through 5.

---

## Saving the Error List in an Error Report File

When you examine errors in the error browser, you can save the error list information as a report in a text file, and you can choose whether to exclude or include hidden errors.

To save the error list information in a report file,

1. Select the error group you want to save in the error hierarchy tree.
2. Choose one of the following commands on the Options menu:
  - To exclude hidden errors, choose Options > Save to File > Omit Hidden Records.
  - To include hidden errors, choose Options > Save to File > Include Hidden Records.The Save Errors to File dialog box appears.
3. Navigate to the directory where you want to save the file, and type the file name in the “File name” box.
4. Click Save.

---

## Saving Error Updates in an Error View

The tool also automatically saves error views with unsaved status changes when you save the top-level design. You can manually save individual error views with unsaved status changes by using the Save Error Views dialog box. For example, if you opened the top-level design for read-only, you cannot save changes in the design, and you can save changes in the error views only by using the Save Error Views dialog box or the `save_mw_cel` command.

To save error views with error status updates,

1. Choose File > Save in the error browser window.

The Save Error Views dialog box appears. The dialog box lists the error views that have unsaved changes.

2. Select the error views you want to save.
3. Click the Save Selected button.

The tool saves the selected error views. Unsaved changes in error views that you do not select remain in memory.

The Save Error Views dialog box appears automatically if you close or reopen an error view that has unsaved changes. In this case, the dialog box provides a Discard button.

- Click the Save Selected button to save the changes in the selected error views.
- Click the Discard button to discard the unsaved changes in the selected error views.

Click Cancel if you want to return to the error browser without closing or reopening the error view. In this case, the tool does not save or discard the error view changes.

You can also save error view changes by entering the `save_mw_cel` command on the `icc_shell` command line. Note that if you close error views by entering the `close_mw_cel` command without first saving the error views, the tool discards any unsaved changes without notice.

The tool saves detail route error data changes automatically when you save the top-level design or discards the changes when you close the design without saving the design data. Because the detail route error data is in the top-level design instead of in an error view, you cannot save detail route error data changes by using the Save Error Views dialog box.

---

## Saving a Copy of the Editor DRC Error View

The default editor DRC error view name is `design_cell_name_edrc.err`, where `design_cell_name` is the name of the current design. You cannot save the default editor DRC error view, and the tool does not save the error records when it closes the error view. However, you can save a copy of the editor DRC error view with a different name.

To save the editor DRC error view with a different name,

1. Choose File > Save As in the error browser window.  
The Save Error View As dialog box appears.
2. Type an error view name, or click the browse button and select an error view in the file browser that appears.

The default name is `design_cell_name_edrc.err`, where `design_cell_name` is the name of the current design.

3. (Optional) To update a previous version of the error view in the same file, select the “Overwrite existing version” option.
4. Click OK.

You can load a saved copy of the editor DRC error view by choosing File > Open in the error browser window and selecting the Editor DRC option in the Open error view dialog box. However, editor DRC does not update loaded copies of the editor DRC error view incrementally when new violations are detected or old violations are fixed.

---

## Editing the Physical Layout

The layout window provides interactive tools and commands for editing your physical design. You can edit the floorplan and object placement, create and remove physical objects, and route nets and physical buses in the active layout view.

You can use general-purpose editing tools and commands to

- Move, resize, copy, and remove objects
- Rotate and flip objects, and change cell orientations
- Reshape objects
- Align, distribute, and spread objects
- Move pins along an edge of a plan group or soft macro, pads along an edge of the die area, or terminals along an edge of the die area
- Expand objects

You can also use commands on the Floorplan menu to define or draw physical objects such as placement blockages, bounds, plan groups, pin guides, route guides, routing blockages, tracks, and voltage areas.

You can use route editing tools to

- Route physical buses and multiple nets
- Route individual nets
- Route individual nets on the redistribution layer in a flip-chip design
- Create routing corridors
- Create net and user shapes, vias and via arrays, port terminals, and text objects
- Create custom wires
- Split shapes
- Stretch wires while optionally maintaining their physical connections
- Move and stretch objects while optionally maintaining their physical connections
- Push objects away from an area while maintaining their physical connections
- Spread wires evenly on a layer while maintaining their physical connections

Typically, you select the objects that you want to edit. You can select the objects interactively with the Selection tool or by typing their names on the Select By Name toolbar. The interactive editing tools also allow you to select objects when the tool is active.

You can access editing tools and commands by clicking buttons on the Edit toolbar or by choosing commands on the Edit menu. [Figure A-26](#) shows the Edit toolbar as it appears when you select one or more objects in the layout view. The Edit toolbar groups related editing functions together in lists that open when you click the  button.

*Figure A-26 Edit Toolbar When Objects Are Selected*



For information about editing physical design objects and constraints, see the following sections:

- [Editing Objects Interactively](#)
- [Working in the Editing Environment](#)
- [Finding and Fixing Editor DRC Violations](#)
- [Editing Hierarchical Cells in Place](#)

---

## Editing Objects Interactively

The layout editing mouse tools allow you to interactively create, edit, or remove physical objects in a layout view. The layout window provides a consistent editing environment for all of the tools. You can

- Set tool options on the Mouse Tool Options toolbar
- Use keyboard shortcuts for frequent or repetitive operations
- Preview objects for selection and cycle through overlapping objects

If you need to magnify or traverse the design or measure distances when an editing tool is active, you can temporarily activate the Zoom In tool, Zoom Out tool, Pan tool, or Ruler tool without deactivating the editing tool. For more details, see “[Selecting a Mouse Tool](#)” on [page A-3](#).

When you activate a mouse tool in a layout view, the options for using the tool appear on the Mouse Tool Options toolbar. See [Figure A-3 on page A-7](#) for an example of this toolbar.

[Table A-3](#) shows the buttons that you can use to perform actions with the active editing tool.

*Table A-2 Layout Editing Tool Conventions*

| Action                                                    | Button |
|-----------------------------------------------------------|--------|
| Finish operation and apply changes                        |        |
| Cancel pending input, if any, or exit tool                |        |
| Reset toolbar options values to defaults                  |        |
| Switch between toolbar and dialog box                     |        |
| Show Help page for the active tool in the man page viewer |        |

You can perform frequent or repetitive actions by using keyboard shortcuts. [Table A-3](#) shows the standard key bindings for the interactive editing tools.

*Table A-3 Interactive Editing Tool Conventions*

| Action                                         | Shortcut      |
|------------------------------------------------|---------------|
| Add points to perform the operation            | Click or Drag |
| Add point and apply changes                    | Return        |
| Remove last point                              | Backspace     |
| Cancel pending input, if any, or exit tool     | Escape        |
| Cycle forward through overlapping objects      | F1            |
| Cycle backward through overlapping objects     | Shift+F1      |
| Reverse (undo) most recent operation           | Ctrl+X        |
| Reapply (redo) most recently applied operation | Ctrl+Y        |

In addition, if a tool needs to change layers, for example, to add a wire jog, you can press F1 or Tab to cycle through the layers.

Many of the editing tools operate on selected objects. You can select the objects before or after you activate a tool. Selected objects appear in the selection color, which is white by default.

You can preview an object before selecting it by holding the pointer over its position in the active layout view. Information about the object appears in an InfoTip. For details, see [“Previewing Objects in a Layout View” on page A-5](#). If any objects are selected when you activate an editing tool, you can Ctrl-click objects to add them to the current selection and Shift-click objects to remove them from the current selection.

**Note:**

If you have trouble selecting or previewing small objects, try magnifying the view. In a large design, some objects or object outlines are too small to click at low magnification. For details, see [“Magnifying and Traversing the Design” on page A-15](#).

All of the operations that you can perform with the interactive editing tools are logged and can be replayed with the `gui_mouse_tool` command. Similarly, options that you set on the Mouse Tool Options toolbar are logged and can be replayed with the `gui_set_mouse_tool_option` command. For information about these commands and the options for a particular tool, click the  button to see the Help page for that tool.

Most of the editing tools can provide interactive DRC with immediate visual feedback when the tool detects a DRC violation. When you use these tools with the editor DRC facility enabled, the layout view displays a different visual cue for each type of violation. These visual indicators allow you to avoid making changes that cause new DRC violations, but the tools do not prevent you from making these changes. For more details, see “[Finding and Fixing Editor DRC Violations](#)” on page A-103.

The Advanced Route tool, Create Route tool, Create RDL Route tool, Stretch Wire tool, and Window Stretch tool support nondefault routing rules by default. If you disable nondefault routing rule compliance, the tools use the rules defined in the technology file.

When you activate the Advanced Route tool, Create Route tool, or the Create RDL Route tool, the most frequently used tool options appear on the Mouse Tool Options panel. You can open a dialog box that provides all of the options for the tool. You can switch between the toolbar options and the dialog box options by clicking the  button.

For information about the interactive editing operations that you can perform, see the following sections:

- [Moving, Resizing, Modifying, and Removing Objects](#)
- [Routing Nets and Physical Buses](#)
- [Expanding and Rotating Objects](#)
- [Creating Floorplan Objects](#)

## Moving, Resizing, Modifying, and Removing Objects

You can move, resize, copy, split, reshape, and remove objects. To perform basic move and resize operations without regard to connected wires, use the Move/Resize tool. If you need to maintain connectivity when you move or resize objects, use the Stretch Wire tool or the Window Stretch tool.

[Table A-4](#) shows the editing tools you can use to modify the physical design.

**Table A-4 Editing Functions for Design Objects**

| To perform this operation                                                                                                               | Use this tool                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Move objects                                                                                                                            | Click  or choose either Edit > Move/Resize or View > Mouse Tools > Edit Tool, and then select the objects and click or drag to the new location. Alternatively, you can use the <code>move_objects</code> command.                                     |
| Resize objects                                                                                                                          | Click  or choose either Edit > Move/Resize or View > Mouse Tools > Edit Tool, and then select an object and drag an edge or corner to resize. Alternatively, you can use the <code>resize_objects</code> command.                                      |
| Copy objects                                                                                                                            | Click  or choose either Edit > Copy or View > Mouse Tools > Copy Tool, and then select and drag the objects. Alternatively, you can use the <code>copy_objects</code> command.                                                                         |
| Remove objects                                                                                                                          | Click  or choose Edit > Delete, and then click or drag a rectangle to delete objects. Alternatively, you can use the <code>remove_objects</code> command.                                                                                              |
| Split routing or user shapes                                                                                                            | Click  or choose Edit > Split, and then drag a line or rectangle across the objects where the split is to occur. You can set options as needed on the Mouse Tool Options toolbar. Alternatively, you can use the <code>split_objects</code> command. |
| Stretch wires while optionally maintaining connectivity and adhering to nondefault routing rules                                        | Click  or choose Edit > Stretch Wire, and then drag the wires. You can set options as needed on the Mouse Tool Options toolbar.                                                                                                                      |
| Move and stretch objects while optionally maintaining connectivity and adhering to nondefault routing rules                             | Click  or choose Edit > Window Stretch or View > Mouse Tools > Window Stretch Tool, and then drag the objects. You can set options as needed on the Mouse Tool Options toolbar.                                                                      |
| Push objects away from a rectangular area on a layer while maintaining connectivity and optionally adhering to nondefault routing rules | Click  or choose Edit > Area Push, select a shape type, select a layer, and click or drag the pointer to draw the rectangular area. You can set options as needed on the Mouse Tool Options toolbar.                                                 |

*Table A-4 Editing Functions for Design Objects (Continued)*

| To perform this operation                                                                                                          | Use this tool                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Spread wires evenly by layer between two points while maintaining connectivity and optionally adhering to nondefault routing rules | Click  or choose Edit > Spread Wire, select a shape type, select two or more wires, and click or drag the pointer to specify the points. You can set options as needed on the Mouse Tool Options toolbar.                                                                                                                                   |
| Reshape objects by cutting or adding an area with an optional gap                                                                  | Click  or choose Edit > Reshape, optionally set the gap size, and then drag a rectangle across the object where you want to cut or add a piece. You can set options as needed on the Mouse Tool Options toolbar.                                                                                                                            |
| Align objects relative to a side or center of an anchor object or location                                                         | Click  or choose Edit > Align/Distribute, click the Align tab on the Mouse Tool Options toolbar, select the objects you want to align, specify the anchor object or location, and click the toolbar button for the alignment operation you want to perform. You can set options as needed on the Mouse Tool Options toolbar.                |
| Distribute objects relative to a side of an anchor object or location                                                              | Click  or choose Edit > Align/Distribute, click the Distribute tab on the Mouse Tool Options toolbar, select the objects you want to distribute, specify the anchor object or location, and click the toolbar button for the distribution operation you want to perform. You can set options as needed on the Mouse Tool Options toolbar. |
| Spread objects relative to a side of an anchor object or location                                                                  | Click  or choose Edit > Align/Distribute, click the Spread tab on the Mouse Tool Options toolbar, select the objects you want to spread, specify the anchor object or location, and click the toolbar button for the spread operation you want to perform. You can set options as needed on the Mouse Tool Options toolbar.               |
| Move pins on an edge of a plan group or soft macro, pads on an edge of the die area, or terminals on an edge of the die area       | Click  or choose Edit > Move Pins on Edge, and then select the objects and click or drag to the new location. Alternatively, you can use the <code>move_pins_on_edge</code> command.                                                                                                                                                      |

For more information about using these editing tools, see the “Selecting an Editing Tool” topic in IC Compiler Help.

## Routing Nets and Physical Buses

**Table A-5** shows how you can use interactive editing tools to create route objects and route nets and buses in the physical design.

*Table A-5 Interactive Route Editing Tools*

| To perform this operation                                                                                                | Use this tool                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Route physical buses or multiple nets by optionally adhering to nondefault routing rules and interactive DRC rules       | Click  or choose Edit > Create > Advanced Route Tool, select the buses or nets, and click or drag to create route segments. You can set options as needed on the Mouse Tool Options toolbar or in the Advanced Route Tool dialog box.                                                                           |
| Route single nets by optionally adhering to nondefault routing rules and interactive DRC rules                           | Click  or choose Edit > Create > Route Tool, select the net, and click or drag to create route segments. You can set options as needed on the Mouse Tool Options toolbar or in the Create Route Tool dialog box.                                                                                                |
| Route single nets on a redistribution layer by optionally adhering to nondefault routing rules and interactive DRC rules | Click  or choose Edit > Create > RDL Route Tool, select the net, and click or drag to create route segments. You can set options as needed on the Mouse Tool Options toolbar or in the Create RDL Route Tool dialog box.                                                                                        |
| Create new routing corridors and add rectangles to existing routing corridors                                            | Click  or choose Edit > Create > Routing Corridor, set the minimum and maximum layers and the rectangle width, optionally specify one or more nets, and click or drag to draw the rectangles. You can set options as needed on the Mouse Tool Options toolbar or the Create Routing Corridor Tool dialog box. |
| Create net shapes and user shapes                                                                                        | Click  or choose Edit > Create > Shape, select a shape type, select a net (net shape only), and click or drag to draw the shape. You can set options as needed on the Mouse Tool Options toolbar.                                                                                                             |
| Create vias and via arrays                                                                                               | Click  or choose Edit > Create > Via, select a via master or enable automatic mode, drag to the wire intersection, and click to insert the via or via array. You can set options as needed on the Mouse Tool Options toolbar.                                                                                 |
| Create terminals                                                                                                         | Click  or choose Edit > Create > Terminal, select a port, and click or drag to draw the terminal. You can set options as needed on the Mouse Tool Options toolbar.                                                                                                                                            |

**Table A-5 Interactive Route Editing Tools (Continued)**

| To perform this operation                                | Use this tool                                                                                                                                                                                                                                                     |
|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Create text objects                                      | Click  or choose Edit > Create > Text, type the text string and set options as needed on the Mouse Tool Options toolbar, and click or drag to place the text in the layout view. |
| Route one or more nets by adhering to preroute DRC rules | Click  or choose Edit > Create > Custom Wires, select the nets, and click or drag to create wire segments. You can set options as needed in the Create Custom Wires dialog box.  |

For more information about these tools, see “[Routing Nets and Buses in the GUI](#)” on [page 8-109](#) and the “Selecting an Editing Tool” topic in IC Compiler Help.

## Expanding and Rotating Objects

[Table A-6](#) explains how you can expand, rotate, and flip design objects and orient cells.

**Table A-6 Editing Commands for Design Objects**

| To perform this operation                              | Do this                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Expand selected objects to objects on one or all sides | Click an expansion tool (  ,  ,  ,  , or  ) or choose Edit > Expand > <i>expansion_direction</i> . Alternatively, you can use the <code>expand_objects</code> command.                                                                                                                                                                                                                                                            |
| Rotate selected objects 90 or 180 degrees              | Click a rotation tool (  ,  , or  ) or choose Edit > Rotate > <i>rotation</i> . Alternatively, you can use the <code>rotate_objects</code> command.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Flip selected objects on an x- or y-axis               | Click a flip tool (  , or  ) or choose Edit > Rotate > <i>axis</i> . Alternatively, you can use the <code>flip_objects</code> command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Orient selected objects to north                       | Click an orientation tool (  ,  ,  ,  ,  ,  ,  , or  ) or choose Edit > Orientation > <i>orientation</i> . Alternatively, you can use the <code>rotate_objects</code> command. |

For more information about these editing commands, see the “[Expanding Objects](#),” “[Rotating Objects](#),” and “[Changing Cell Orientations](#)” topics in IC Compiler Help.

## Creating Floorplan Objects

You can use the GUI or `icc_shell` commands to create floorplan objects in the physical design.

[Table A-7](#) shows the floorplan objects you can create and the menu commands and the `icc_shell` commands you can use to create them.

*Table A-7 Creating Floorplan Objects*

| Object              | Menu command                          | <code>icc_shell</code> command         |
|---------------------|---------------------------------------|----------------------------------------|
| Placement blockages | Floorplan > Create Placement Blockage | <code>create_placement_blockage</code> |
| Bounds              | Floorplan > Create Bound              | <code>create_bounds</code>             |
| Plan groups         | Floorplan > Create Plan Group         | <code>create_plan_groups</code>        |
| Route guides        | Floorplan > Route Guide               | <code>create_route_guide</code>        |
| Routing blockages   | Floorplan > Routing Blockage          | <code>create_routing_blockage</code>   |
| Routing tracks      | Floorplan > Create Track              | <code>create_track</code>              |
| Voltage areas       | Floorplan > Create Voltage Area       | <code>create_voltage_area</code>       |
| Pin guides          | Pin Assignment > Create Pin Guide     | <code>create_pin_guide</code>          |

For more information about creating these objects, see the “Creating Floorplan Objects” topic in IC Compiler Help.

---

## Working in the Editing Environment

The editing environment provides an incremental undo and redo facility that allows you to reverse or reapply the most recent editing operation or a series of operations. You can also constrain (fix) objects during editing operations, control grid snapping, set editing options, define and edit object groups, view and edit object properties, and enable or disable editor DRC for interactive design rule checking during editing operations. [Table A-8](#) explains the global operations that you can use with any editing tool or command.

*Table A-8 Global Editing Operations*

| To perform this operation                                                                         | Use this tool                                                                                                                                                                                                                                  |
|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reverse the previous edit change                                                                  | Click the  button or choose Edit > Undo. Alternatively, you can use the <code>undo</code> command.                                                            |
| Reapply the subsequent edit change                                                                | Click the  button or choose Edit > Redo. Alternatively, you can use the <code>redo</code> command.                                                            |
| Constrain (fix) selected objects to prevent changes from interactive edits                        | Click the  button or choose Edit > Constraints > Fix Edit. Alternatively, you can use the <code>set_object_fixed_edit</code> command.                         |
| Remove (unfix) the editing constraint on selected objects to allow changes from interactive edits | Click the  button or choose Edit > Constraints > Unfix Edit. Alternatively, you can use the <code>set_object_fixed_edit</code> command.                       |
| Enable or disable grid snapping                                                                   | Click the  button or choose Edit > Snapping. Alternatively, you can use the <code>set_object_snap_type</code> command with the <code>-enabled</code> option. |
| Create edit group that contains the objects in the current selection                              | Click the  button or choose Edit > Create Edit Group. Alternatively, you can use the <code>create_edit_group</code> command.                                |
| View or edit object attribute values for selected objects.                                        | Click the  button or choose Edit > Properties.                                                                                                              |
| Enable or disable design rule checking and violation preview                                      | Choose Edit > Editor DRC > Enable DRC.                                                                                                                                                                                                         |

**Note:**

For details about using the Properties dialog box, see “[Viewing and Editing Object Properties](#)” on page A-20.

For information about the physical design editing environment, see the following sections:

- [Reversing and Reapplying Edit Changes](#)
- [Fixing and Unfixing Objects for Edits](#)

- [Changing the Way Objects Snap to a Grid](#)
- [Setting Editing Options](#)
- [Editing Groups of Objects](#)
- [Finding and Fixing Editor DRC Violations](#)

## Reversing and Reapplying Edit Changes

You can reverse (undo) or reapply (redo) many of the interactive editing operations that you perform in the IC Compiler GUI. You can reverse the most recent editing operation or a series of operations. If you reverse one or more editing operations, you can reapply the most recently reversed operation or a series of operations. You can also add markers to the undo list that let you quickly reverse all subsequent editing operations.

Note:

When you use a command that is not reversible, the tool automatically clears the undo list. You can no longer reverse previous editing operations, and the Undo command is dimmed on the Edit menu.

The Undo toolbar shown in [Figure A-27](#) lets you reverse or reapply the most recent operation or a series of operations, add markers to the Undo list, and clear the Undo list.

*Figure A-27 Undo Toolbar*



- To reverse the most recent editing operation, click the  button on the Undo toolbar, press **Ctrl+Z**, choose **Edit > Undo**, or enter `undo` on the command line.
- To reapply the most recently reversed editing operation, click the  button on the Undo toolbar, press **Ctrl+Y**, choose **Edit > Redo**, or enter `redo` on the command line.

You can reverse any editing operation and all subsequent operations by selecting the operation you want to reverse. Similarly, you can reapply any editing operation that you reversed and all subsequently reversed operations by specifying the operation you want to reapply.

- To reverse a specific editing operation and all subsequent operations, choose the operation on the Undo menu ( ) on the Undo toolbar. To reverse all the operations in the undo list, choose <Undo All>.
- To reapply a specific editing operation and all subsequently reversed operations, choose the operation on the Redo menu ( ) on the Undo toolbar. To reapply all of the operations in the redo list, choose <Redo All>.

You can add markers to the undo list to indicate the beginning or end of a series of operations that you might want to reverse or reapply together. When you add a marker, the tool displays “<mark>” in the undo list. If you choose a marker to reverse the subsequent operations, the tool displays the marker in the redo list.

- To add a marker to the undo list, click the  button on the Undo toolbar.
- To clear the undo and redo lists, click the  button on the Undo toolbar.

## Fixing and Unfixing Objects for Edits

You can fix objects in the active layout view to

- Prevent editing change
- Use as anchors for the distribution or splitting of multiple objects.

To fix objects,

1. Select the objects to fix.

The objects become highlighted.

2. Click the  button on the Edit toolbar or choose Edit > Constraints > Fix Edit.

Each fixed object displays an X across it.



Fixed



Not fixed

**Note:**

When you use the Move/Resize tool to move or resize objects, you can allow the tool to edit fixed objects by selecting the “Ignore fixed” option on the Mouse Tool Options toolbar.

To unfix objects and allow editing changes,

1. Select the objects to unfix.
2. Click the  button on the Edit toolbar or choose Edit > Constraints > Unfix Edit.

Alternatively, you can allow or prevent editing for an object by changing the `is_fixed` attribute value in the Properties dialog box.

## Changing the Way Objects Snap to a Grid

When you create or edit objects interactively in the layout view by using an editing tool or command, IC Compiler first modifies the objects and then snaps them to the nearest associated snap grid. When object snapping is enabled, IC Compiler automatically moves objects to the grid that is associated with the object type. You can enable or disable snapping for all editing operations or for individual object types, and you can select a different snap grid for each type of object. When snapping is disabled, the tool snaps the objects to the lithography (Min) grid.

To enable or disable snapping for all object operations,

- Click the  button on the Edit toolbar or choose Edit > Snapping.

The toolbar button and the icon beside the Snapping command on the Edit menu indicate whether snapping is enabled or disabled.

Alternatively, you can click the  button on the Mouse Tool Options toolbar when an interactive editing tool is active. You can also enable or disable snapping by using the `set_object_snap_type` command with the `-enabled` option. For example, to enable object snapping when it is disabled, enter

```
icc_shell> set_object_snap_type -enabled true  
0
```

When you use the `-enabled` option, the command returns the previous snapping state: 0 for disabled or 1 for enabled.

To change the ways objects are snapped,

1. Choose Edit > Snap Settings.

The Snap Settings dialog box appears. If you need assistance using this dialog box, click Help to display a Help page in the man page viewer.

2. Enable snapping for all object types if necessary by clicking the “Enable snapping” option.
3. Enable or disable snapping for individual object types as needed by clicking the options to the left of the object type names.
4. Change the snap grid for individual object types by selecting an option in the list to the right of the object type name.

The tool provides the following snap grid options. Note that the list for a particular object type displays only the applicable options for that object type.

- Row and Min Grid
- Row and Unit Tile
- Row and Placement Site
- Middle Row and Min Grid
- Middle Row and Unit Tile
- Middle Row and Placement Site
- Routing Track
- Middle Routing Track
- User Grid

Alternatively, you can change the snap grid by using the `set_object_snap_type` command with the `-class` and `-snap` options. For example, to snap hard macro objects to the user grid, enter

```
icc_shell> set_object_snap_type -class hard_macro -snap user  
litho
```

When you use the `-snap` option, the command returns the previous snap type. For more information about the `set_object_snap_type` command, including lists of the valid object classes and snap types, see the man page.

5. Set other options as needed.

- To snap pin shapes to the nearest edges of their parent objects, select the “Snap pin to parent edge” option.
- To snap objects to the nearest horizontal or vertical edge of the nearest visible, selectable object, select the Snap Object Edge option.

When edge snapping is enabled, you can set the search radius, in pixels, by typing a value in the “Edge search radius” box. The search radius controls how far the tool searches for the nearest edge. A small search radius allows finer control. A larger search radius allows snapping over longer distances.

- To snap objects to routing tracks only in the preferred direction, select the “Snap to preferred tracks only” option.

This option is deselected by default, which means that objects can snap to tracks in both the preferred and nonpreferred directions.

When you are ready to close the Snap Settings dialog box, click Close.

## Setting Editing Options

When you use an interactive editing tool in the active layout view, you can control how the tool operates by setting options on the Mouse Tool Options toolbar. You can also set some of the more frequently used editing options by using the Edit Options dialog box. In addition, you can use the Edit Options dialog box to set expand object hit type options, connectivity options, and specific editing tool options.

When you change an editing tool option, either on the Mouse Tool Options toolbar or in the Edit Options dialog box, the change occurs immediately for all applicable tools in all open layout views.

To open the Edit Options dialog box,

- Choose Edit > Options > Edit Options.

The Edit Options dialog box appears. If you need assistance using this dialog box, click Help to display a Help page in the man page viewer.

To set frequently used editing tool options,

1. Click the General tab in the Edit Options dialog box.

This tab is selected by default.

2. Set options as needed.

- To retain the placement of child objects such as the cells associated with a plan group or soft macro, select the Keep Placement option.
- To retain a constant distance between I/O pads and the core area when you resize the core area or the die area, select the “Keep Core to Pad” option.

This option is selected by default. Deselect this option if you want to let the tool change the distance between the core area and the I/O pads.

- To edit fixed objects, select the “Ignore fixed attribute” option.

An object is fixed when the `is_fixed` attribute value is `true`.

- To let the editing tools ignore wire end caps and use the bounding box to define the wire geometry, select the “Ignore end caps” option.

If you split or cut a wire when this option is selected, the tool adjusts the center line and makes an exact cut of the bounding box. In addition, if you change the end cap from an extended type to a nonextended type, the tool adjusts the center line to maintain the same bounding box.

This option is deselected by default, which means the editing tools do not ignore end caps and use the center line to define the wire geometry. If you split or cut a wire, the tool cuts the center line, which can change the bounding box of the line. In addition, the bounding box might change if you change the end cap from an extended type to a nonextended type.

- To let the Delete tool remove disconnected vias when it removes the associated wire or path shape, select the “Remove disconnected vias” option.
- To prevent the layout view from automatically displaying the object types and layers for objects that you modify by using an editing tool, deselect the “Auto display edited objects and layers” option.

This option is selected by default, which means that if you modify an object that is not visible because its object type or layer is hidden, the layout view automatically displays the hidden objects or layer.

- To prevent the layout view from automatically displaying object types and layers for routing objects that you create by using an editing tool, deselect the “Auto display previewed objects and layers” option.

This option is selected by default, which means that if you create an object that is not visible because its object type or layer is hidden, the layout view automatically displays the hidden objects or layer.

To set expand object hit type options,

1. Click the Expand tab in the Edit Options dialog box.
2. Select or deselect expand object hit type options as needed,

These options control which object types are used as targets when you expand objects. You can use soft macros, hard macros, plan groups and bounds, placement blockages, polygons, and voltage areas. If all of these options are deselected, objects expand to the edge of the core area. For more details, see the “Expanding Objects” topic in IC Compiler Help.

To set connectivity options,

1. Click the Connectivity tab in the Edit Options dialog box.
2. Set options as needed.
  - To prohibit the Stretch Wire tool or Window Stretch tool from editing wires that have staggered via connections, deselect the “Allow staggered via connections” option.

This option is selected by default, which means the tools can edit these wires. Deselect this option if you want to avoid poor editing results that can be caused by staggered via connections.

A staggered via is a stack of two or more connected vias with center points that are not coincident. The tools can cause opens or nonoptimal connections by trying to repair the vias at these multiple connection points.

- To allow the Stretch Wire tool and Window Stretch tool to edit connections across multiple layers, select the “Constrain edit propagation to single layer” option.

This option is selected by default, which means connectivity edits are constrained to connections across a single layer or on the same layer. If wire jogging is enabled, the tool creates jogs instead of editing wires and vias on other layers.

- To display the connectivity of selected objects automatically when you edit them with the Stretch Wire tool or Window Stretch tool, select the “Automatically show connectivity” option.

To set options for specific editing tools,

1. Click the Mouse Tools tab in the Edit Options dialog box.
2. Set options as needed.
  - To allow the Stretch Wire tool to change wire widths, select the “Resize wires” option.
  - To constrain wires to a specific widths on a layer when you modify wire widths with the Stretch Wire tool, select the “Snap width resize to discrete values” option.

This option is deselected by default and is available only when the “Resize wires” option is selected.

To define the list of permitted wire widths on a layer, use the `gui_set_layer_widths` command. To view the list of permitted wire widths for a layer, use the `gui_get_layer_widths` command.

To close the Edit Options dialog box,

- Click Close.

## Editing Groups of Objects

You can interactively edit multiple objects at the same time by defining the objects as an edit group. To define an edit group, you assign a name and specify the objects. An edit group consists of one or more geometric objects and maintains the relative positions and orientations of the objects during editing operations.

In the layout view, a geometric object has a bounding box and can be moved to a new position. The bounding box of an edit group is the union of all the object bounding boxes and is dynamically calculated and updated during editing operations. An object can belong to only one edit group, and an edit group cannot contain another edit group.

To define a group of objects for editing,

1. Select the objects.
2. Click the  button on the Edit toolbar or choose Edit > Create Edit Group.

The tool assigns a unique name to the edit group, selects the group, and displays the bounding box in the layout view.

In general, an edit group forms a loose coupling of the objects. You can still manipulate them as separate objects. The edit group just helps you to perform the editing task.

For more information about using edit groups, see the “Editing Groups of Objects” topic in IC Compiler Help.

---

## Finding and Fixing Editor DRC Violations

When you edit or create objects interactively in the layout view, you can check the nets in the design for routing design rule violations. The layout view provides an editor DRC facility that allows you to find and fix DRC violations caused by interactive editing operations. Editor DRC detects design rule violations, displays error shapes in the active layout view, and records the violations in an editor DRC error view.

You can enable editor DRC for interactive editing operations or run editor DRC on nets that you edited while editor DRC was disabled. Editor DRC provides rule checking for a limited set of advanced DRC rules defined in the technology file.

**Important:**

For optimal performance, editor DRC runs only a quick check and displays errors using a limited set of the DRC rules defined in the technology file. It does not fix the errors or guarantee that the editing tools create legal placement or routes without DRC violations. After editing your design interactively, run the `check_legality` command and a DRC or LVS verification tool to identify errors that you need to fix. For more details, see [“Performing Design Rule Checking Using IC Compiler” on page 8-95](#).

The Advanced Route tool, Copy tool, Create Route tool, Create Shape tool, Create Via tool, Move/Resize tool, Reshape tool, Split tool, Stretch Wire tool, and Window Stretch tool can use editor DRC to detect violations and provide immediate visual feedback while you perform editing operations. The Area Push tool and Spread Wire tool do not allow you to make changes that cause DRC violations. However, these tools check for violations after you apply the changes because the changes might fix existing violations.

You control which design rules editor DRC checks by setting options in the Editor DRC Options dialog box. [Figure A-28](#) shows the flow of a route editing session using editor DRC.

*Figure A-28 Route Editing Flow Using Editor DRC*



For more information about using editor DRC, see the following sections:

- [Verifying Route Edits Interactively](#)
- [Verifying Edited Nets](#)
- [Setting Editor DRC Options](#)
- [Examining Editor DRC Errors](#)

## Verifying Route Edits Interactively

To enable or disable the editor DRC for interactive editing operations,

- Choose Edit > Editor DRC > Enable DRC.

Alternatively, you can select or deselect the DRC option on the Mouse Tool Options toolbar.

When you enable editor DRC for an interactive editing operation, it provides immediate visual feedback if it detects a violation. The layout view displays a different visual cue for each type of violation. These visual indicators allow you to avoid making changes that cause new DRC violations, but the tools do not prevent you from making these changes.

Editor DRC supports rule checking on the following types of objects:

- Horizontal and vertical net shapes and user shapes, including wires, vias, via arrays, paths, polygons, and rectangles
- Port shapes and terminals
- Standard cells, hard and soft macros, and black boxes
- Routing blockages

In a flip-chip design, you can control whether right angle connections and acute angle connections are permitted for 45-degree routes on the redistribution layer. By default, editor DRC permits right angle connections but marks acute angle connections as violations.

When nondefault routing rule compliance is enabled, editor DRC records nondefault routing rule violations as nondefault routing rule related errors. If you disable nondefault routing rule compliance, editor DRC removes the errors related to nondefault routing rules from the error view.

## Verifying Edited Nets

If you perform interactive editing operations while editor DRC is disabled in the active layout view, you should check the edited net shapes for editor DRC violations.

To check selected nets for editor DRC violations,

- Select one or more nets you need to check.
- Choose Edit > Editor DRC > Run DRC on Selected Nets.

Alternatively, you can use the `gui_check_drc_errors` command.

To check one or more individual nets for editor DRC violations,

1. Choose Edit > Editor DRC > Run DRC.

The Run DRC on Nets dialog box appears. If you need to reset the dialog box options to their defaults, click Default. For assistance running editor DRC, click Help to display a Help page in the man page viewer.

2. Type the net names in the nets box. Separate the net names with blank spaces. Alternatively, you can select the nets.

3. Select an option to check entire nets or net shapes in a region.

To check all the shapes on the specified nets, select the “Check entire nets” option.

To check just the shapes within a rectangular area, select the “DRC area” option and define the area. You can either type the x- and y- coordinates for the upper left and lower right corners or draw area in the layout view.

4. To restrict the rule checking to nets on specific layers, select the “Restrict layers” option and select or deselect layer names as needed.

5. Set other options as needed.

- To check for opens on the specified nets, select the “Check for opens” option. This option is available only when the “Check entire nets” option is selected.
- To check for nondefault routing rule violations, select the “Honor NDR” option.
- To restrict the rule checking to shorts between the specified nets, select the “Report only violations between specified nets” option.
- To change the maximum number of errors that the tool can report, type a value in the “Maximum number of errors to report” box.

The default number of errors is 250.

- To change the maximum number of net shapes that the tool can check, type a value in the “Maximum number of net shapes to check” box.

The default number of net shapes is 10,000.

6. Click OK or Apply.

Alternatively, you can use the `gui_check_drc_errors` command.

## Setting Editor DRC Options

Editor DRC provides rule checking for a limited set of advanced technology DRC rules defined in the technology file. The interactive editing tools use editor DRC to detect rule violations that occur during interactive editing operations.

To set editor DRC options,

1. Choose Edit > Options > DRC Options.

The Editor DRC Options dialog box appears. If you need to reset the dialog box options to their defaults, click Default. For assistance using this dialog box, click Help.

When an editing tool that supports editor DRC is active, you can open the Editor DRC Options dialog box by clicking the DRC menu button on the Mouse Tool Options toolbar and choosing Set DRC Options. You can also open this dialog box by clicking the DRC Options button in the Run Editor DRC on Nets, Advanced Route Tool Options, Create Rout Tool, or Create RDL Route Tool dialog box.

2. Set options for advanced rules as needed.

- To enable via density rule checking, select the “Via density” option.
- To enable minimum edge rule checking, select the “Minimum edge” option.
- To enable minimum length and minimum area rule checking, select the “Minimum length and area” option.

3. Set options for RDL routing rules as needed.

- To permit acute angle connections for 45-degree routes on the redistribution layer in a flip-chip design, deselect the “Acute angle is violation in 45 degree routing” option.
- To prohibit right angle connections for 45-degree routes on the redistribution layer in a flip-chip design, select the “Right angle is violation in 45 degree routing” option.

4. Set other options as needed.

- To filter out spacing violations between shapes on the same net, select the “Filter same net spacing violations” option.
- To check routing blockages for overlaps with objects on their associated blocking layer, select the “Check routing blockages” option.
- To set the maximum number of errors that the tool reports, type a value in the “maximum errors reported” box.

The default value is 250.

- To disable the mechanism that opens the error browser window, if it is not already open, and loads the errors automatically when editor DRC detects a new violation, deselect the "Show the error browser when new violations are found" option.

This option is selected by default.

When you change an option setting in the Editor DRC Options dialog box, the change occurs immediately for all applicable tools in all open layout views; If GUI command output logging is enabled in the Application Preferences dialog box, the tool also records the change by displaying a `gui_set_pref_value` command in the console log view and history view.

## Examining Editor DRC Errors

When editor DRC detects design rule violations, it displays error shapes in the active layout view, records the errors in an editor DRC error view, and automatically loads the error view into the error browser editor DRC view. For information about using the error browser, see “[Examining Routing and Verification Errors](#)” on page A-75.

The error view contains error records for violations detected during interactive editing operations and violations detected when you run checks on specific nets or on nets within a rectangular area. Editor DRC incrementally updates the error view when you fix a violation, reverse an editing operation that caused a violation, disable the design rule check used to detect a violation, or remove errors in the error browser.

The editor DRC error view is associated with the current design. It remains open and loaded in the error browser until you close the design or change the current design. However, the tool does not save the error view when you save or close the design. If you close the current design, editor DRC closes the error view and removes the errors from the error browser.

For more information about using editor DRC and examining editor DRC errors, see IC Compiler Help.

---

## Editing Hierarchical Cells in Place

You can traverse the design hierarchy to view or edit the contents of blocks and hierarchical cells within the context of the primary design in a layout window. The edit-in-place facility allows you to view and edit subdesign CEL views and FRAM views without closing the primary design.

Note:

For information about the primary design in a layout window, see “[Setting the Primary Design](#)” on page 2-35.

The edit-in-place push and pop operations in a layout window effect as using the `open_mw_cell` and `current_mw_cell` commands in `icc_shell`. However, the edit-in-place operations also maintain and keep track of the parent-child cell relationships and help synchronize parent cells to edited child cells.

- *Push* opens a child cell on the next hierarchy level below the current design, if it is not already open, and changes the current design to that cell.
- *Pop* changes the current design to the parent cell on the next hierarchy level above the current design.

[Figure A-29](#) shows the edit-in-place workflow.

*Figure A-29 Edit-In-Place Workflow*



The cell in which the layout window editing environment is currently active is known as the *current edit cell*. You can perform any available GUI or `icc_shell` operation in the current edit cell. During an edit-in-place session, all of the layout view tools and commands, such as highlighting, flylines, editing tools, and visual modes operate within the context of the current edit cell.

You can edit only those objects that are in the current edit cell, and when the current edit cell changes, the tool clears the undo stack. Flylines and net connectivity lines for selected objects appear only in the current edit cell. For example, if you select a port on the current edit cell, the layout view displays flylines to show the connections from the port to pins in the cell, but it does not display flylines to show connections from the port to ports or pins in the parent cell.

You can perform edit-in-place operations by using tools on the Edit In Place toolbar shown in [Figure A-30](#).

*Figure A-30 Edit In Place Toolbar*



To enable the edit-in-place facility and change the current design to a cell one level down in the design hierarchy,

1. Select the cell you need to edit.

2. Click the  button on the Edit In Place toolbar or choose `Edit > In Place > Push`.

Alternatively, you can use the `change_working_design` command with the `-push` option.

**Note:**

To edit a soft macro cell, the soft macro must reside in the design library and the design library must be open for reading and writing. If you open a cell in a library that is open for reading only, the tool automatically opens the cell for reading only.

To change the current design to the parent cell of the current edit cell,

- Click the  button on the Edit In Place toolbar or choose Edit > In Place > Pop.

The tool automatically synchronizes the cell boundaries and port instances with the corresponding boundaries and pins in the edited cell.

Alternatively, you can use the `change_working_design` command with the `-pop` option.

**Important:**

The tool does not save or close the child cell. To save your edits at the end of an edit-in-place session, choose File > Save Design or use the `save_mw_cell` command to save the top-level design with all the subdesigns in the hierarchy.

To change the current design to the top-level cell and disable the edit-in-place facility,

- Click the  button on the Edit In Place toolbar or choose Edit > In Place > Pop to Top.

Alternatively, you can use the `change_working_design -pop` command.

For more information about using the `change_working_design` command to traverse the hierarchy and open cells for editing, see “[Opening Designs in a Hierarchical Stack](#)” on page 3-14.

By default, the primary design remains visible in the layout view during an edit-in-place session, but the tool dims the objects on hierarchy levels above the current edit cell and displays the objects inside the cell at full brightness.

- The zoom and pan setting does not change.

To magnify the design and fit the current edit cell in the layout view, choose View > Zoom > Zoom Fit All or press F. To shrink the design and fit the primary design in the layout view, choose View > Zoom > Zoom Fit Top or press Ctrl-F.

- The global selection list does not change when you change the current edit cell.

However, the layout view displays the selection color only on objects in the current edit cell.

The layout view displays highlight, visual mode, and map mode colors only in the current edit cell.

- The legend on the Visual Mode panel displays the data for the design in which you loaded it. You must reload the data to display data for the current edit cell.
- The legend on the Map Mode panel displays the data for the current edit cell automatically. However, if no map data exists for a cell, the layout view clears the legend on the Map Mode panel.

The layout view displays rulers only in the current edit cell. Rulers in other open cells are hidden.

GUI tools display coordinates relative to the origin of the current edit cell, such as ruler coordinates or the pointer position displayed on the status bar. When you change the current edit cell, the GUI records a `change_working_design` command with the cell instance name in the session log. This allows you to determine the local origin for any coordinates specified by commands in the current edit cell.

You can set options on the View Settings panel to control the type of view the tool opens, the context in which the current edit cell appears, and the brightness of objects outside the current edit cell.

To set edit-in-place options for the active layout view.

1. On the View Settings panel, click the Settings tab, and then click the View tab.
2. Set options as needed.
  - To change the type of view that the tool opens, select an option in the Child View Name list. The valid choices are DEFAULT, FRAM, and CEL. The default is DEFAULT. Note that you cannot edit ILM views because the tool opens them as read-only.
  - To display the current edit cell by itself in the layout view, deselect the “Edit in Place” option. By default, this option is selected and the layout view displays the current edit cell in its place within the primary design. If you deselect this option, the layout view displays the current edit cell in its normal orientation regardless of its orientation within the primary design. For information about the primary design in a layout window, see [“Setting the Primary Design” on page 2-35](#).
  - To set the brightness level for objects outside the current edit cell when the “Edit in Place” option is selected, select an option in the brightness () list.
3. Click Apply.

If you open multiple layout views in the same layout window, all the layout views have the same current edit cell. If you want to edit different cells at the same time, you must open them in different layout windows.

If the error browser is open when you change the current edit cell, the tool automatically loads the editor DRC error view for the new current design, if it exists, into the error browser editor DRC view. Only error views associated with the current design can be loaded in the error browser. However, regardless of which design is the current design, the layout view continues to display of error shapes for any design that is open in the layout window.

If Hercules VUE is open when you change the current edit cell, the layout view continues to display DRC errors in the primary design. However, you should load the errors for the current edit cell if you want the layout view to interpret coordinates from Hercules VUE in the correct coordinate space.

For more information about using the edit-in-place facility in a layout window, see the “Editing Hierarchical Cells in Place” topic in IC Compiler Help.



# Index

---

## A

abbreviations in scripts 2-18  
add piece to object A-91  
add\_clock\_drivers command 7-105  
add\_end\_cap command 9-54  
add\_tap\_cell\_array command 9-3  
adjust\_premesh\_connection command 7-103  
advanced editing tools  
  Advanced Route tool A-92  
  Area Push tool A-90  
  Spread Wire tool A-91  
Advanced Library Format (ALF) 10-18  
Advanced Route tool 8-115, A-92  
ALF format 10-18  
alias command 2-20  
Align/Distribute tool A-91  
aligning objects A-91  
alignment tool A-91  
all\_rp\_groups command 11-85  
all\_rp\_hierarchicals command 11-85  
all\_rp\_inclusions command 11-85  
all\_rp\_instantiations command 11-85  
all\_rp\_references command 11-85  
all\_scenarios command 3-34  
always-on  
  power wells, multivoltage designs 14-44

synthesis  
  exclusive move bounds 14-44  
  multivoltage designs 14-79  
ambiguous commands 2-18  
AMD64 platform 1-2  
Analysis toolbar A-48  
analysis tools, layout  
  flylines A-48, A-49  
  map modes A-48, A-53  
  net connectivity A-48, A-50  
  visual modes A-48, A-51  
analyze\_rail command 13-4  
analyze\_subcircuit command 7-113  
anchor corner 11-16  
antenna rules  
  checking 9-21  
  disabling 9-21  
  enabling 9-20  
antenna violations  
  fixing  
  disabling 9-21  
  enabling 9-20  
Application Preferences dialog box 2-35, 2-36  
application task, layout window 2-34  
Area Push tool A-90  
area utilization 6-44  
area, voltage 3-19

**attributes**

- connected\_to\_iso\_cell 14-44
- direct\_power\_rail\_tie 14-74
- dont\_touch 14-47, 14-48, 14-53
- ignore, removing 11-87
- is\_isolation\_cell 14-46, 14-53, 14-54
- is\_level\_shifter 14-46, 14-53, 14-54
- isolation\_cell\_enable\_pin 14-46, 14-54
- level\_shifter\_enable\_pin 14-46, 14-54
- relative placement, writing to disk 11-86
- size\_only 14-48, 14-49, 14-54

**B**

- balance\_inter\_clock\_delay command 7-97
- blockages
  - creating placement blockages 6-5
  - creating routing blockages A-94
- blockages, creating placement blockages A-94
- boundary cell, clock tree synthesis 7-45
- bounds, creating objects A-94
- Browsers toolbar 7-130, A-58
- buffer trees
  - creating 6-20
  - removing 6-20
  - reporting 6-20
- buffering high-fanout nets 6-20
- buffer-type level shifters
  - inserting 14-47
  - placing 14-53
- bus routing tool A-92

**C**

- Calibre interface 8-107
- capacitance, net capacitance histogram A-69
- capture window or view image A-33
- categorized timing report interactive viewer 6-56
- CCS timing libraries
  - scaling 3-42

**cell orientations** A-93

- displaying or hiding A-38

**cell placement statistics** 8-89**Cells List toolbar** 3-14**change\_names** command 3-54

- change\_working\_design** command A-110, A-111, A-112

**check\_clock\_tree** command 7-79**check\_isolation\_cells** command 14-54, 14-83**check\_legality** command A-103**check\_level\_shifters** command 14-78

- check\_mv\_design** command 14-6, 14-52, 14-82

**check\_noise** command 10-10**check\_physical\_design** command 3-19**check\_routeability** command 8-6**check\_rp\_groups** command 11-61**check\_timing** command 3-43**check\_tlu\_plus\_files** command 3-38**chip finishing**

- adding end caps 9-54

- adding tap cell arrays 9-3

- displaying critical area heat maps 9-38

- filling empty tracks with metal fill 9-58

- inserting pad fillers 9-57

- inserting standard cell fillers 9-49

- inserting tap cells 9-5

- inserting well fillers 9-55

- performing wire spreading 9-39

- performing wire widening 9-40

**Clear Rulers** A-3**clear rulers** A-36**clock**

- convergent 7-4

- overlapping 7-4

**clock arrival histograms** 7-132**clock graph view** A-2**clock mesh**

- adding mesh drivers 7-105

- analysis 7-112

building premesh trees 7-106  
compiling premesh trees 7-108  
definition 7-99  
flow 7-101, 7-116  
prerequisites 7-100  
removing 7-105  
routing mesh nets 7-107  
routing premesh trees 7-110  
specifying 7-103  
splitting clock nets 7-103  
structure 7-99  
clock network element tables, path inspector window A-74  
clock sink group  
  clock tree exceptions 7-11  
  preexisting gates 7-12  
  sink group definition 7-9  
  sink group options 7-10  
clock tree  
  design rule constraints priority 7-35  
  exception, float pins 7-60  
  removing 7-61  
  reporting 7-120  
  verifying 7-79  
  viewing 7-127  
clock tree arrival time histogram, displaying 7-132  
clock tree clustering, on-chip-variation-aware 7-46  
clock tree design rule constraint  
  maximum capacitance 7-35  
  maximum fanout 7-35  
  maximum transition time 7-35  
clock tree exceptions  
  defining 7-13  
  don't buffer net 7-24  
  don't size cell 7-25  
  don't touch subtree 7-24, 7-61  
  exclude pin 7-7, 7-19  
  float pin 7-20  
  nonstop pin 7-18  
  per-clock basis 7-13  
  preserve hierarchy 7-26  
  priority 7-17  
  reporting 7-17  
  size-only cells 7-25  
  stop pin 7-7, 7-23  
clock tree fanout browser A-59  
clock tree hierarchy browser  
  defined 7-131  
  displaying 7-132  
clock tree leveled graph view  
  defined 7-134  
  display 7-134  
clock tree optimization  
  ECO routing 7-95  
  multicorner 7-95  
  optimization capabilities 7-93  
    postroute, default 7-94  
    preroute, default 7-94  
    selecting 7-94  
  postroute 7-94  
  preroute 7-94  
  timing analysis, router for 7-95  
  voltage area support 14-74  
clock tree reference  
  defined 7-4  
  specifying 7-27  
clock tree sinks  
  default 7-7  
  defining 7-7, 7-23  
  optimizing 7-85  
clock tree synthesis  
  boundary cell, defined 7-45  
  design rule constraints, viewing 7-36  
  don't touch subtree  
    defined 7-24, 7-61  
    logic-level balancing 7-47  
  exclude pin  
    defined 7-7, 7-19  
    implicit 7-8  
  float pin  
    defined 7-20  
    examples 7-60

modeling hard macros 7-60  
ILM, logic-level balancing 7-47  
logic-level balancing  
defined 7-46  
don't touch subtree 7-47  
enabling 7-47  
hard macro 7-48  
ILM 7-47  
maximum capacitance 7-35  
maximum fanout 7-35  
maximum transition time 7-35  
minimum insertion delay, defined 7-38  
multicorner-multimode 7-59  
multimode 7-91  
nonstop pin  
defined 7-18  
implicit 7-8  
prerequisites  
design 7-3  
library 7-4  
skew, defined 7-38  
stop pin  
defined 7-7, 7-23  
implicit 7-7  
timing goals 7-38  
voltage area support 14-74  
clock tree synthesis options  
defining 7-31  
reporting 7-34  
resetting 7-34  
clock\_opt command 7-81, 14-72  
clock\_opt\_feasibility  
command 7-88  
close\_mw\_cel command A-84  
closing the GUI 2-8  
command  
abbreviation in scripts 2-18  
console, main window 2-27  
displaying options 2-5  
execution at startup 2-3  
history 2-31  
listing for session 2-31  
listing in GUI 2-32  
menu, choosing current task 2-34  
output, redirecting 2-21  
saving session transcript 2-30  
set\_preroute\_focal\_opt\_strategy 6-38  
command line 2-3  
copying commands to command line 2-5  
entering commands 2-4, 2-18  
icc\_shell 2-4  
shell 2-4, 2-18  
X-term window 2-4, 2-18  
command log file  
record and replay GUI session 2-36  
using 2-10  
command scripts, Tcl (tool command language) 2-8  
command.log file 2-10  
commands  
add\_clock\_drivers 7-105  
add\_end\_cap 9-54  
add\_tap\_cell\_array 9-3  
adjust\_premesh\_connection 7-103  
alias 2-20  
all\_rp\_groups 11-85  
all\_rp\_hierarchicals 11-85  
all\_rp\_inclusions 11-85  
all\_rp\_instantiations 11-85  
all\_rp\_references 11-85  
all\_scenarios 3-34  
ambiguous 2-18  
analyze\_rail 13-4  
analyze\_subcircuit 7-113  
balance\_inter\_clock\_delay 7-97  
change\_names 3-54  
change\_working\_design A-110, A-111, A-112  
check\_clock\_tree 7-79  
check\_isolation\_cells 14-54, 14-83  
check\_legality A-103  
check\_level\_shifters 14-78  
check\_mv\_design 14-6, 14-52, 14-82  
check\_noise 10-10

check\_physical\_design 3-19  
check\_routeability 8-6  
check\_rp\_groups 11-61  
check\_timing 3-43  
check\_tlu\_plus\_files 3-38  
choosing in menus 2-5  
clock\_opt 7-81, 14-72  
clock\_opt\_feasibility 7-88  
close\_mw\_cel A-84  
commit\_fp\_plan\_groups 11-53  
commit\_skew\_group 7-142  
compare\_delay\_calculation 3-44  
compile 14-5  
compile\_clock\_tree 7-90  
compile\_premesh\_tree 7-106, 7-108  
compile\_ultra 14-5, 14-47, 14-54  
connect\_supply\_command 14-20  
copy\_floorplan 3-18  
copy\_objects A-90  
copying session log 2-29  
create\_bounds 6-13, A-94  
create\_bounds, exclusive 14-44  
create\_buffer\_tree 6-20  
create\_clock\_mesh 7-103  
create\_edit\_group A-95  
create\_ilm 14-78  
create\_mw\_lib 3-5  
create\_physical\_bus 8-112, 8-115  
create\_physical\_buses\_from\_patterns 8-113  
create\_pin\_guide A-94  
create\_placement 14-53  
create\_placement\_blockage A-94  
create\_plan\_groups A-94  
create\_plan\_groups command A-94  
create\_power\_domain 14-3  
create\_route\_guide 8-8, A-94  
create\_routing\_blockage 8-15, A-94  
create\_supply\_set 14-22  
create\_track A-94  
create\_voltage\_area 14-4, 14-37, 14-39, A-94  
create\_zrt\_shield 9-43  
current\_mw\_cel 3-14, A-109  
define\_routing\_rule 7-39, 8-22  
define\_scaling\_lib\_group 3-42  
define\_user\_attribute A-28  
derive\_pg\_connection 3-20  
derive\_placement\_blockages 6-9  
expand\_objects A-93  
extract\_rc 6-39, 8-121, 12-17  
extract\_rp\_group 11-97  
flatten\_clock\_gating 7-102  
flip\_objects A-93  
Follow Selection A-17  
get\_always\_on\_logic 14-80  
get\_bounds 6-14  
get\_cts\_scenario 7-59  
get\_drc\_errors 8-108  
get\_ilm\_objects 12-26  
get\_ilms 12-26  
get\_license 2-41  
get\_magnet\_cells 6-35  
get\_placement\_blockages 6-5, 6-9  
get\_route\_guides 8-11  
get\_route\_opt\_zrt\_crosstalk\_options 8-75  
get\_routing\_blockages 8-16  
get\_selection 2-28  
get\_timing\_paths A-67, A-68  
get\_voltage\_areas 14-40  
Go Back in Zoom and Pan History A-18  
Go Forward in Zoom and Pan History A-18  
gui\_check\_drc\_errors A-105, A-106  
gui\_get\_layer\_widths A-102  
gui\_mouse\_tool A-88  
gui\_set\_current\_task 2-34  
gui\_set\_flat\_hierarchy\_color A-26, A-27  
gui\_set\_layer\_widths A-102  
gui\_set\_mouse\_tool\_option A-88  
gui\_show\_form 2-13  
gui\_show\_man\_page 2-12  
gui\_start 2-3, 2-7  
gui\_stop 2-8  
gui\_unset\_flat\_hierarchy\_color A-27

gui\_write\_layout\_image A-33, A-34  
help 2-12  
history 2-20, 2-31  
history view 2-31  
icc\_shell 2-4  
insert\_pad\_filler 9-57  
insert\_stdcell\_filler 14-77  
insert\_tap\_cells\_by\_rules 9-5  
insert\_well\_filler 9-55  
interrupting 2-7  
keyboard shortcuts in GUI 2-15  
legalize\_placement 14-53  
license\_users 2-41  
list\_drc\_error\_types 8-108  
magnet\_placement 6-31  
map\_isolation\_cell 14-61  
map\_level\_shifter\_cell 14-52  
map\_retention\_cell 14-65  
move\_objects A-90  
move\_pins\_on\_edge A-91  
Named Zoom and Pan Settings A-18  
open\_mw\_cel A-109  
optimize\_clock\_tree 7-93  
optimize\_pre\_cts\_power 7-70  
order\_rp\_groups 11-98  
Pan to Selection A-15  
place\_opt 6-26, 12-32, 14-4, 14-9, 14-53,  
    14-72, 14-73  
place\_opt\_feasibility 6-22  
preroute\_focal\_opt 6-38  
process\_particle\_probability\_file 9-37, 9-38  
propagate\_constraints 14-78  
psynopt 6-36, 14-4, 14-73  
read\_def 3-18  
read\_drc\_error\_file 8-107  
read\_floorplan 3-18  
read\_parasitics 3-45  
read\_sdc 3-43  
read\_sdf 3-45  
read\_stream 3-56  
read\_verilog 3-13  
recalling 2-20  
redirect 2-21  
redo A-95, A-96  
refine\_placement 6-69  
remove\_all\_spacing\_rules 6-15  
remove\_annotations 3-45  
remove\_bounds 6-14  
remove\_buffer\_tree 6-20  
remove\_clock\_tree 7-61  
remove\_clock\_tree\_exceptions  
    -dont\_buffer\_nets 7-24  
    -dont\_size\_cells 7-25  
    -dont\_touch\_subtrees 7-24  
    -exclude\_pins 7-19  
    -float\_pins 7-22  
    -non\_stop\_pins 7-18  
    -preserve\_hierarchy 7-26  
    -stop\_pins 7-23  
remove\_clock\_tree\_exceptions -  
    -size\_only\_cells 7-25  
remove\_filler\_withViolation 9-54  
remove\_from\_rp\_group 11-95  
remove\_ideal\_network 3-44  
remove\_keepout\_margin 6-5  
remove\_level\_shifters 14-53  
remove\_license 2-42  
remove\_net\_routing\_layer\_constraints 6-41  
remove\_objects A-90  
remove\_placement\_blockage 6-9  
remove\_preferred\_routing\_direction 8-17  
remove\_route\_guide 8-12  
remove\_route\_guides 8-16  
remove\_routing\_blockage 8-16  
remove\_rp\_group\_options 11-87  
remove\_rp\_groups 11-88  
remove\_sdc 3-44  
remove\_self\_gating\_logic 7-65  
remove\_skew\_group 7-142  
remove\_stdcell\_filler  
    -pad 9-57  
    -stdcell 9-53  
    -tap 9-6  
remove\_target\_library\_subset 14-6

remove\_voltage\_area 14-45  
remove\_well\_filler 9-56  
report\_area 12-26  
report\_bounds 6-14  
report\_buffer\_tree 6-20  
report\_cell 14-83  
report\_clock\_timing 7-123  
report\_clock\_tree 7-120  
report\_clock\_tree\_power 7-65  
report\_constraint 7-148  
report\_critical\_area 9-36  
report\_delay\_calculation 6-49  
report\_design 8-89, 12-26  
report\_drc\_error\_type 8-108  
report\_error\_coordinates 8-6  
report\_inter\_clock\_delay\_options 7-77  
report\_keepout\_margin 6-5  
report\_mw\_lib\_reference 3-7  
report\_net\_routing\_layer\_constraints 6-41  
report\_net\_routing\_rules 8-33  
report\_noise\_calculation 10-15  
report\_operating\_conditions 14-84  
report\_physical\_signoff\_options 8-99  
report\_placement\_utilization 6-44  
report\_power 6-51  
report\_power\_guide 14-45  
report\_preferred\_routing\_direction 8-16  
report\_preroute\_focal\_opt\_strategy 6-38  
report\_reference\_cell\_routing\_rule 7-43  
report\_route\_opt\_strategy 8-73  
report\_route\_opt\_zrt\_crosstalk\_options 8-75  
report\_routing\_rules 7-39  
report\_scan\_chain 4-12  
report\_signal\_em 10-21  
report\_signal\_em\_calculation 10-24  
report\_spacing\_rules 6-15  
report\_target\_library\_subset 14-6, 14-84  
report\_timing 6-47, 7-148  
report\_timing\_derate 3-42  
report\_tlu\_plus\_files 3-38  
report\_units 3-8, 10-19  
report\_voltage\_area 14-45, 14-83  
reset\_design 3-44  
reset\_inter\_clock\_delay\_options 7-76  
reset\_timing\_derate 3-42  
resize\_objects A-90  
reusing 2-31  
rotate\_objects A-93  
route\_htree 7-110  
route\_mesh\_net 7-107  
route\_opt 14-72  
route\_zrt\_eco 8-85  
route\_zrt\_group 8-55, 8-57  
rp\_group\_inclusions 11-85  
rp\_group\_instantiations 11-85  
rp\_group\_references 11-86  
save\_mw\_cel 3-51, A-83, A-84, A-111  
saving transcript of session commands 2-32  
set\_ahfs\_options 6-20  
set\_attribute 14-69  
set\_checkpoint\_strategy 6-30  
set\_clock\_tree\_exceptions  
  -dont\_buffer\_nets 7-24  
  -dont\_size\_cells 7-25  
  -dont\_touch\_subtrees 7-24  
  -exclude\_pins 7-19  
  -float\_pin options 7-20, 7-60  
  -non\_stop\_pins 7-18  
  -preserve\_hierarchy 7-26  
  -size\_only\_cells 7-25  
  -stop\_pins 7-23  
set\_clock\_tree\_options 8-31  
set\_clock\_tree\_references 7-27  
set\_congestion\_options 6-11  
set\_cts\_scenario 7-59  
set\_delay\_calculation 3-44  
set\_delay\_estimation\_options 6-40, 6-41, 6-42, 6-43  
set\_design\_attributes 14-59  
set\_em\_options 10-22  
set\_extraction\_options 8-122  
set\_gui\_stroke\_binding A-48  
set\_gui\_stroke\_preferences A-48  
set\_ignored\_layers 8-33

set\_inter\_clock\_delay\_options 7-74  
set\_isolation 14-54  
set\_isolation\_control 14-59  
set\_keepout\_margin 6-4  
set\_left\_right\_filler\_rule 9-53  
set\_level\_shifter\_strategy 14-47  
set\_level\_shifter\_threshold 14-47, 14-49,  
    14-51  
set\_lib\_cell\_spacing\_label 6-14, 6-15  
set\_max\_transition 7-36  
set\_min\_library 3-39, 3-40  
set\_mw\_lib\_reference 3-10  
set\_net\_routing\_layer\_constraints 6-41  
set\_net\_routing\_rule 8-32  
set\_object\_fixed\_edit A-95  
set\_object\_snap\_type A-95, A-98, A-99  
set\_operating\_conditions 3-46, 14-48, 14-78  
set\_optimize\_dft\_options 4-8  
set\_physical\_signoff\_options 8-99, 9-60  
set\_port\_attributes 14-57  
set\_power\_guide 14-45  
set\_power\_net\_to\_voltage\_area 14-77  
set\_preferred\_routing\_direction 8-16  
set\_reference\_cell\_routing\_rule 7-43  
set\_retention 14-63  
set\_route\_opt\_strategy 8-72  
set\_route\_opt\_zrt\_crosstalk\_options 8-75  
set\_rp\_group\_options 11-89  
set\_scope 14-15  
set\_si\_options 3-45, 14-79, A-56  
set\_skew\_group 7-141  
set\_spacing\_label\_rule 6-14, 6-15  
set\_target\_library\_subset 14-5, 14-6  
set\_timing\_derate 3-41  
set\_tlu\_plus\_files 3-36, 3-38, 9-58  
set\_write\_stream\_options 3-55  
split\_clock\_gates 7-71  
split\_clock\_net 7-103  
split\_objects A-90  
spread\_zrt\_wires 9-39  
stroke A-46  
stroke activated commands A-46  
terminating 2-7  
uncommit\_fp\_soft\_macros 11-53  
undo A-95, A-96  
uniquify\_fp\_mw\_cel 3-14  
unset\_power\_guide 14-45  
update\_bounds 6-13  
update\_clock\_latency 7-98  
update\_voltage\_area 14-40  
verify\_route 8-95  
widen\_zrt\_wires 9-40  
write\_def 3-54  
write\_interface\_timing 12-19  
write\_mw\_lib\_files 3-10  
write\_parasitics 3-55, 8-122  
write\_rp\_groups 11-86  
write\_sdc 3-54  
write\_stream 3-55  
Zoom Fit All A-15  
Zoom Follows Selection A-15  
Zoom In 2x A-15  
Zoom Out 2x A-15  
Zoom to Selection A-15  
commit\_fp\_plan\_groups command 11-53  
commit\_skew\_group command 7-142  
compare\_delay\_calculation command 3-44  
compile command 14-5  
compile\_clock\_tree command 7-90  
compile\_premesh\_tree command 7-106,  
    7-108  
compile\_ultra command 14-5, 14-47, 14-54  
compression, relative placement 11-40  
congestion map  
    generating 8-90  
    layer-based 8-90  
congestion options 6-11  
connected\_to\_iso\_cell attribute 14-44  
Connectivity Settings panel A-50  
console  
    command line 2-28  
    entering commands 2-28  
    history view 2-31

log view 2-29  
main window 2-27  
saving log messages 2-29  
searching the transcript 2-29  
window 2-28

constraints  
reading 3-43  
report 7-148  
saving 3-54  
timing 3-43

constraints, voltage area 8-53

conventions for documentation xxxvi

convergent clock path, defined 7-4

Copy tool A-90

copy\_floorplan command 3-18

copy\_objects command A-90

copying  
commands 2-5  
objects A-90  
session log 2-29

coupling capacitance  
extracting 8-122  
scaling 8-122

create floorplan object tools A-94

Create Net tool A-92

Create RDL Route tool A-92

Create Route tool 8-110, A-92

Create Routing Corridor tool A-92

Create Terminal tool A-92

Create Text tool A-93

Create Via tool A-92

create\_bounds command 6-13, A-94  
exclusive 14-44

create\_buffer\_tree command 6-20

create\_clock\_mesh command 7-103

create\_edit\_group command A-95

create\_ilm command 14-78

create\_mw\_lib command 3-5

create\_physical\_bus command 8-112, 8-115

create\_physical\_buses\_from\_patterns  
command 8-113

create\_pin\_guide command A-94

create\_placement command 14-53

create\_placement\_blockage command A-94

create\_plan\_groups command A-94

create\_power\_domain command 14-3

create\_route\_guide command 8-8, A-94

create\_routing\_blockage command 8-15, A-94

create\_supply\_set command 14-22

create\_track command A-94

create\_voltage\_area command 14-4, 14-37,  
14-39, A-94

create\_zrt\_shield command 9-43

creating floorplan objects A-94

critical area  
displaying heat maps 9-38  
encrypting and decrypting the particle  
probability function 9-37

crosstalk  
analysis  
delta delay visual mode 10-14  
noise reports 10-14  
preparation 10-9  
static noise visual mode 10-14  
timing report 10-14

defined 10-3

net lists, path inspector window A-74

optimization  
about 10-7  
postroute 10-8  
signoff optimization 10-15

prevention  
clock shielding 10-6  
clock tree synthesis 10-6  
placement 10-5  
track assignment 10-7

reduction engines 10-7

reduction, during route\_opt 8-74

timing impacts 10-13

cts\_do\_characterization variable 7-119

cts\_enable\_rc\_constraints variable 7-53  
 cts\_fix\_clock\_tree\_sinks variable 7-85  
 cts\_move\_clock\_gate variable 7-84  
 cts\_rc\_relax\_factor variable 7-54  
 cts\_self\_gating\_connect\_scan\_enable variable 7-66  
 cts\_self\_gating\_data\_toggle\_rate\_filter variable 7-66  
 cts\_self\_gating\_num\_regs variable 7-66  
 cts\_self\_gating\_num\_regs\_max\_percent variable 7-66  
 cts\_self\_gating\_num\_regs\_max\_percent\_total\_cell variable 7-66  
 cts\_self\_gating\_reg\_power\_filter variable 7-66  
 cts\_self\_gating\_wns\_backoff variable 7-66  
 cts\_traverse\_dont\_touch\_subtrees variable 7-24  
 cts\_use\_debug\_mode variable 7-119  
 cts\_use\_lib\_max\_fanout variable 7-35  
 cts\_use\_sdc\_max\_fanout variable 7-35  
 current design, setting 3-14  
 current edit cell A-108  
 current task, layout window 2-34  
 current\_mw\_cel command 3-14, A-109  
 Custom Wire tool A-93  
 customer support xxxvii  
 cut piece from object A-91

## D

database, Milkyway  
   about 3-3  
   saving a design 3-51  
 datapath, physical, defined 11-1  
 DEF file  
   reading 3-18  
   writing 3-54  
 define\_routing\_rule command 7-39, 8-22  
 define\_scaling\_lib\_group command 3-42  
 define\_user\_attribute command A-28

delay calculation algorithm  
   Arnoldi 3-44  
   clock Arnoldi 3-44  
   Elmore 3-44  
 postroute  
   default 3-44  
   setting 3-44  
 Delete tool A-90  
 densely-packed objects A-5  
 derating factors for timing library 3-41  
 derive\_pg\_connection command 3-20  
 derive\_placement\_blockages command 6-9  
 design for manufacturing (DFM)  
   critical area heat map displaying 9-38  
   inserting metal fill 9-58  
   wire spreading 9-39  
   wire widening 9-40  
 design overlays, layout view A-40  
 design rule violations  
   analyzing  
     DRC query commands 8-108  
     error browser 8-109  
 designs  
   schematics A-71  
 detail route options  
   descriptions 8-46  
   reporting 8-45  
   setting 8-45  
 detail routing  
   running 8-66  
 dialog boxes  
   finding 2-13  
 direct\_power\_rail\_tie attribute 14-74  
 DISPLAY environment variable  
   checking before startup 2-2  
   overriding 2-3  
 displaying command options 2-5  
 distributing objects A-91  
 distribution tool A-91  
 domain, power 3-19  
 dont\_touch attribute 14-47, 14-48, 14-53

draw rulers A-36  
DRC, interactive editing errors A-103

## E

ECO routing  
  during clock tree optimization 7-95  
ECO routing, running 8-85  
Edit In Place toolbar A-110  
Edit Snapping Settings panel A-98  
Edit tool A-90  
Edit tool (see Move/Resize tool)  
editing object properties A-20  
edit-in-place  
  about A-108  
  current edit cell A-108  
  pop operation A-109  
  push operation A-109  
  setting options A-112  
  workflow A-109  
editor DRC A-94, A-95  
  enabling A-105  
  gui\_check\_drc\_errors command A-105, A-106  
  route editing flow A-103  
  setting options A-107  
  verifying edited nets A-105  
edits  
  redo A-96  
  undo A-96  
electromigration  
  loading net switching information for analysis 10-20  
  performing signal analysis 10-21  
enable level shifter 3-20  
enable-type level shifters  
  inserting 14-54  
  placing 14-53  
end cap  
  adding 9-54  
  defined 9-54

endpoint slack histogram  
  histogram views A-69  
  Timing Views toolbar A-68  
environment variable, DISPLAY 2-2  
environment variables  
  SNPS\_MAX\_QUEUEETIME 2-42  
  SNPS\_MAX\_WAITTIME 2-42  
  SNPSLMD\_QUEUE 2-41  
error browser  
  about A-75  
  filtering error list A-79  
  highlighting nets A-81, A-82, A-103  
  loading error views A-76  
  opening window A-76  
  saving copies of the editor DRC error view A-84  
  saving error view updates A-83  
  saving errors in a report file A-83  
  selecting errors in layout A-81  
  viewing and fixing errors A-77  
  viewing in area A-82  
Error Selection tool A-81  
estimating via resistance 6-42  
exceptions for clock tree synthesis  
  don't buffer net 7-24  
  don't size cell 7-25  
  don't touch subtree 7-24, 7-61  
  exclude pins 7-7, 7-19  
  float pin 7-20, 7-60  
  nonstop pins 7-18  
  preserve hierarchy 7-26  
  size-only cells 7-25  
  stop pins 7-7, 7-23  
exclusive move bounds, always-on synthesis 14-44  
executing  
  command at startup 2-3  
  script at startup 2-3  
exiting IC Compiler 2-10  
Expand Browser toolbar 7-130, A-59  
expand\_objects command A-93

expanding  
objects A-93  
expansion commands A-93  
exploring virtual hierarchy of flat design A-23  
exporting  
GDSII 3-55  
OASIS 3-55  
parasitic data 3-55  
extent 3-19  
extract\_rc command 6-39, 8-121, 12-17  
extract\_rp\_group command 11-97  
extracted timing model 7-78  
extraction  
correlation with StarRC 6-40  
options 8-122  
postroute 8-121

**F**

files, bytecode-compiled 2-40  
filler cell  
inserting pad fillers 9-57  
inserting well fillers 9-55  
removing pad fillers 9-57  
removing standard cell fillers 9-53  
removing standard cell fillers that have  
routing design rule violations 9-54  
removing tap cells 9-6  
removing well fillers 9-56  
filler cells, inserting 9-49  
fix objects A-97  
fix objects for edit A-95  
fixed cells  
legalization 11-49  
movement 6-32  
Flat Design Hierarchy Browser dialog box A-23  
flat design, exploring virtual hierarchy A-23  
flatten\_clock\_gating command 7-102  
flip\_objects command A-93  
flipping object commands A-93

float pin  
defined 7-60  
setting 7-60  
floorplan file, reading 3-18  
floorplan objects, create object tools A-94  
Flyline Settings panel A-49  
flylines  
Analysis toolbar A-48  
displaying A-49  
Flyline Settings panel A-49  
Follow Selection command A-17  
following selected objects in graphic views  
A-17  
functional ECO methods, using 15-2

**G**

GDSII format 3-55  
generated clocks  
as clock tree roots 7-5  
get\_always\_on\_logic command 14-80  
get\_bounds command 6-14  
get\_cts\_scenario command 7-59  
get\_drc\_errors command 8-108  
get\_ilm\_objects command 12-26  
get\_ilms command 12-26  
get\_license command 2-41  
get\_magnet\_cells command 6-35  
get\_placement\_blockages command 6-5, 6-9  
get\_route\_guides command 8-11  
get\_route\_opt\_zrt\_crosstalk\_options  
command 8-75  
get\_routing\_blockages command 8-16  
get\_selection command 2-28  
get\_timing\_paths command A-67, A-68  
get\_voltage\_areas command 14-40  
global routing  
description 8-60  
layer-based congestion map 8-90  
options

- descriptions 8-43
- reporting 8-42
- setting 8-42
- running 8-60
- voltage area support 14-74
- global skew
  - multicorner-multimode 7-38
- global skew, defined 7-38
- Go Back in Zoom and Pan History command A-18
- Go Forward in Zoom and Pan History command A-18
- Graphical User Interface (GUI) 1-5
- grid snapping A-95
- grid spacing A-36
- grids
  - displaying or hiding A-36
  - lithography grid A-36
  - user grid A-36
- groups
  - creating plan groups A-94
  - relative placement, defined 11-10
- guard bands, voltage area 14-41
- GUI 1-5
  - closing 2-8
  - displaying on named terminal 2-3
  - help starting 2-3
  - hiding 2-8
  - opening 2-7
  - starting while executing command 2-3
  - starting while executing script 2-3
- GUI preferences
  - saving 2-35
  - setting 2-35
  - setting GUI command logging preferences 2-36
- GUI windows 2-22
  - menu bar 2-23
  - status bar 2-24
  - toolbars 2-24
  - view windows 2-25
- gui\_check\_drc\_errors command A-105, A-106
- gui\_get\_layer\_widths command A-102
- gui\_mouse\_tool command A-88
- gui\_set\_current\_task command 2-34
- gui\_set\_flat\_hierarchy\_color command A-26, A-27
- gui\_set\_layer\_widths command A-102
- gui\_set\_mouse\_tool\_option command A-88
- gui\_show\_form command 2-13
- gui\_show\_man\_page command 2-12
- gui\_start command 2-3, 2-7
- gui\_stop command 2-8
- gui\_unset\_flat\_hierarchy\_color command A-27
- gui\_write\_layout\_image command A-33, A-34
- guides
  - creating pin guides A-94
  - creating route guides A-94

## H

- help command 2-12
- Help system 2-11, 2-12
  - accessing 2-16
  - choosing browser 2-17
  - configuring Web browser for 2-17
  - searching for text in 2-16
- Hercules
  - design rule checking
    - distributed 8-100
  - environment, setting up 8-98
  - layer mapping file 8-100
- hiding the GUI 2-8
- hierarchy browser
  - exploring design hierarchy A-21
  - logic hierarchy view A-21
- high-fanout nets, buffering 6-20
- high-fanout synthesis
  - during place\_opt 6-20
  - standalone 6-20

using `compile_clock_tree` 7-92  
voltage area support 14-73

high-level design flow, multivoltage designs 14-10

Highlight tool A-3, A-9

Highlight toolbar A-10

highlighting

- critical path A-11
- selected objects A-11
- timing paths A-11

histograms A-2, A-69

- clock arrival histograms 7-132
- endpoint slack histogram A-69
- net capacitance histogram A-69
- path slack histogram A-69

history

- command log 2-31
- view 2-31

history command 2-20

hotkeys report, displaying 2-15

|

IC Compiler 2-3

- exiting 2-10
- Help 2-11
- `icc_shell` commands 2-4
- starting 2-2, 2-3

IC Compiler Help 2-12

IC Compiler packages

- IC Compiler 1-2
- IC Compiler-DP 1-2
- IC Compiler-PC 1-2
- IC Compiler-XP 1-2

`icc_output.txt` file 2-10

`icc_shell` command 2-3

- displaying options 2-5
- listing startup options 2-3
- starting IC Compiler 2-2
- using 2-4, 2-18

`icc_shell` command-line interface 1-5

`icc_shell>` prompt 2-3, 2-4  
ignore attribute, removing 11-87

image

- capturing window or view A-33

importing

- GDSII 3-56
- OASIS 3-56

importing, Verilog 3-13

incremental placement 6-36

In-Design Rail Analysis

- decoupling capacitance analysis 13-15
- electromigration analysis 13-10
- inrush current analysis 13-12
- power network integrity analysis 13-7
- preparing for 13-5
- PrimeRail run directory 13-4
- rail maps, displaying 13-4
- supported analysis types 13-2
- voltage drop analysis 13-8

information

- displaying for objects in graphic views A-13
- displaying InfoTips in layout views A-5

InfoTips A-5

- `insert_pad_filler` command 9-57
- `insert_stdcell_filler` command 14-77
- `insert_tap_cells_by_rules` command 9-5
- `insert_well_filler` command 9-55
- inserting enable-type level shifters, multivoltage designs 14-54

inserting isolation cells, multivoltage designs 14-54

inspecting timing paths A-73

interactive clock tree synthesis 7-144

interactive clock tree synthesis window, displaying 7-130

interactive design rule checking A-95

intercell spacing rules, defining 6-14, 6-15

interclock delay balancing

- clock group, specifying 7-73
- multicorner-multimode 7-73

running 7-97  
timing analysis, router for 7-97  
interclock skew, balancing 7-72  
interface logic model 12-32  
  clock\_opt command 12-32  
  examining in GUI A-39  
  fanin and fanout of chip-level networks,  
    controlling 12-16  
  flow for creating 12-6  
  ILM view 12-27  
  information about, reporting 12-23  
  instantiating and using at the top level 12-27  
  logic included in, controlling 12-10  
  logic-level balancing in clock tree synthesis  
    7-47  
  mirrored 12-9  
  number of latch levels, controlling 12-14  
  overview 12-2  
  propagation of information to the top-level  
    design 12-29  
  reporting information 12-23  
  rotated 12-9  
  route\_opt command 12-33  
  side-load cells  
    controlling 12-13  
  voltage area support 14-78  
interfaces  
  GUI 1-5  
  icc\_shell 1-5  
interrupting commands 2-7  
is\_isolation\_cell attribute 14-46, 14-53, 14-54  
is\_level\_shifter attribute 14-46, 14-53, 14-54  
isolation cell 3-20  
isolation cells  
  and level shifters, multivoltage designs 14-4  
  inserting 14-54  
  requirements, multivoltage designs 14-46  
isolation\_cell\_enable\_pin attribute 14-46,  
  14-54

## J

jog wires, preventing wrong way 8-9

## K

keepout margins  
  cell-specific, setting 6-4  
keyboard shortcuts 2-15  
k-factors  
  multivoltage designs 14-5

## L

layer constraints  
  defining 6-41  
layout editing 8-110, 8-112, 8-113, 8-114,  
  8-115, 11-69  
layout editing tools 8-110, 8-115, A-86  
  Create Custom Wire tool 8-119  
layout tools, analysis A-48  
layout view A-2, A-34  
  refreshing A-19  
  save screenshot of A-33  
layout window 2-33  
legalize\_placement command 14-53  
level shifter 3-20  
level shifter commands, multivoltage designs  
  14-46  
level shifters  
  and isolation cells, multivoltage designs 14-4  
  placing 14-53  
  requirements, multivoltage designs 14-46  
level\_shifter\_enable\_pin attribute 14-46, 14-54  
library data, preparing 1-6  
library groups (scaling) 3-42  
library requirements,  
  multivoltage designs 14-5  
license queuing  
  enabling 2-41  
  environment variables 2-41

- SNPS\_MAX\_QUEUETIME 2-42
  - SNPS\_MAX\_WAITTIME 2-42
  - SNPSLMD\_QUEUE 2-41
  - license\_users command 2-41
  - licenses
    - checking out 2-41
    - enabling queuing 2-41
    - listing 2-41
    - releasing 2-42
    - using 2-40
    - working with 2-40
  - licenses, getting or releasing in GUI 2-43
  - Linux platforms 1-2
  - Linux shell 2-3
  - list\_drc\_error\_types command 8-108
  - listing commands 2-32
  - listing startup options 2-3
  - lithography grid, displaying or hiding A-36
  - locking objects for edit A-95
  - log file
    - record and replay GUI session 2-36
    - using 2-10
  - log interactive operation A-88
  - log view 2-29
  - logic hierarchy view A-21
  - logic libraries 1-6
  - low-effort flow 1-8
  - lwindow
    - save image of A-33
- ## M
- macros
    - voltage area 14-44
  - magnet placement 6-31
  - magnet\_placement command 6-31
  - main library, defined 3-4
  - main window 2-3, 2-26
  - man page viewer 2-14
  - map file for TLUPlus 3-36
  - Map Mode panel 9-38, A-53
  - map modes
    - Analysis toolbar A-48
    - displaying A-53
    - Map Mode panel A-53
  - map\_isolation\_cell command 14-61
  - map\_level\_shifter\_cell command 14-52
  - map\_retention\_cell command 14-65
  - maximum net length optimization, voltage area support 14-73
  - maximum timing information 3-39
  - menu bar 2-23
  - menu commands
    - choosing 2-5
    - finding 2-13
  - menus
    - choosing current task 2-34
    - keyboard shortcuts 2-15
  - metal fill extraction
    - emulation 9-58
    - real 9-58
  - metal fill, inserting 9-58
  - methodology 1-5, 8-3
  - Milkyway database
    - about 3-3
    - saving a design 3-51
  - Milkyway design library
    - changing settings 3-9
    - creating 3-5
    - defined 3-4
    - reporting
      - Milkyway reference libraries 3-7
      - units 3-8, 10-19
  - Milkyway format, saving in 1-8
  - Milkyway reference library
    - changing 3-10
    - defined 3-4
  - minimum insertion delay, defined 7-38
  - minimum timing information 3-39
  - Mouse Tool Options toolbar A-5, A-7, A-87

mouse tools A-90  
    Advanced Route tool A-92  
    Align/Distribute tool A-91  
    Area Push tool A-90  
    Copy tool A-90  
    Create Net tool A-92  
    Create RDL Route tool A-92  
    Create Route tool A-92  
    Create Routing Corridor tool A-92  
    Create Terminal tool A-92  
    Create Text tool A-93  
    Create Via tool A-92  
    Custom Wire tool A-93  
    Delete tool A-90  
    Edit tool (see Move/Resize tool)  
    Highlight tool A-3, A-9  
    Mouse Tools toolbar A-3  
    Move Pins on Edge tool A-91  
    Move/Resize tool  
        move objects A-90  
        resize objects A-90  
    Pan tool A-3  
    Query tool A-3, A-13  
    Reshape tool A-91  
    Ruler tool A-3, A-36  
    Selection tool A-3, A-7  
    Split tool A-90  
    Spread Wire tool A-91  
    Stretch Wire tool A-90  
    Window Stretch tool A-90  
    Zoom In tool A-3  
    Zoom Out tool A-3  
Mouse Tools toolbar A-3  
move bound  
    adding cells to 6-13  
    creating 6-13  
    defined 6-13  
    deleting 6-14  
    exclusive 6-13  
    hard 6-13  
    removing cells from 6-13  
    reporting 6-14  
soft 6-13  
move pins on edge tool A-91  
move\_objects command A-90  
move\_pins\_on\_edge command A-91  
Move/Resize tool  
    moving objects A-90  
    resizing objects A-90  
moving and stretching objects A-90  
moving objects A-90  
    Area Push tool A-90  
moving pins A-91  
multicorner-multimode  
    all\_scenarios command 3-34  
    clock tree synthesis 7-59  
    scenario reduction 3-31  
    set\_min\_library command 3-40  
multiple instances, support for 3-14  
multithreading  
    defined 2-44, 2-45, 8-7  
multivoltage designs  
    always-on power wells 14-44  
    always-on synthesis 14-79  
    creating voltage areas 14-39  
    high-level design flow 14-10  
    identifying characteristics 14-10  
    inserting enable-type level shifters 14-54  
    inserting isolation cells 14-54  
    isolation cell requirements 14-46  
    k-factors 14-5  
    level shifter commands 14-46  
    level shifter placement 14-53  
    level shifter requirements 14-46  
    level shifters and isolation cells 14-4  
    library requirements 14-5  
    logical power and ground connections 3-22  
    nested voltage areas 14-43  
    physical synthesis 14-9  
    placing and optimizing 14-79  
    power and ground pin syntax 14-7  
    power domains 14-2  
    power domains and voltage areas 14-4

target library subsetting 14-6  
voltage areas 14-4

## N

Named Zoom and Pan Settings command A-18  
nested voltage areas, multivoltage designs 14-43  
net capacitance histogram  
  histogram views A-69  
  Timing Views toolbar A-68  
net connectivity  
  Analysis toolbar A-48  
  Connectivity Settings panel A-50  
  displaying A-50  
net layer constraints, specifying 8-33  
net shapes, Create Net tool A-92  
net shielding 9-41  
net switching information, loading 10-20  
net, supply 3-20  
noise modeling 10-10  
nondefault routing rules  
  applying 8-31  
  defining 8-22  
  reporting 8-33

## O

OASIS format 3-55  
object alignment tool A-91  
object copying tool A-90  
object distribution tool A-91  
object expansion commands A-93  
object flipping commands A-93  
object information  
  InfoTips A-5  
  Query tool A-13  
object moving tools  
  MoveResize A-90  
  Stretch Wire A-90

Window Stretch A-90  
object properties A-20  
object removing tool A-90  
object reshaping tool A-91  
object resizing tools  
  MoveResize A-90  
  Stretch Wire A-90  
  Window Stretch A-90  
object rotation commands A-93  
object snapping options for layout editing A-98  
object splitting tool A-90  
object spread tool A-91  
object stretching tool A-90  
objects  
  create floorplan object tools A-94  
  fix or unfix for editing A-97  
  select by name A-29  
  selecting in graphic views A-7  
on-chip-variation, clock tree clustering 7-46  
online Help 2-11, 2-12  
  accessing 2-16  
  choosing browser 2-17  
  configuring Web browser for 2-17  
  searching for text in 2-16  
open\_mw\_cel command A-109  
opening the GUI 2-3, 2-7  
operating condition analysis modes  
  best-case and worst-case 3-39  
  on-chip variation 3-39  
operating conditions 3-38  
optimization feasibility analysis 7-88  
optimize\_clock\_tree command 7-93  
optimize\_pre\_cts\_power command 7-70  
order\_rp\_groups command 11-98  
orientations A-93  
orientations, displaying or hiding for cells A-38  
orienting cells A-93  
overlapping clock path, defined 7-4  
overlapping objects A-5

overlays, layout view A-40  
overriding DISPLAY value 2-3  
overview of interface logic models 12-2  
Overview panel A-35

## P

packages, IC Compiler 1-2  
pad filler  
  inserting 9-57  
  removing 9-57  
Pan to Selection command A-15  
Pan tool A-3  
panels  
  Connectivity Settings panel A-50  
  Edit Snapping Settings panel A-98  
  Flyline Settings panel A-49  
  Map Mode panel A-53  
  Overview panel A-35  
  Query panel A-13  
  Timing Analysis Driver panel A-67  
  View Settings panel  
    layout views A-41  
    schematic views A-72  
  Visual Mode panel A-51  
path data element table, path inspector window  
  A-74  
path inspector  
  panels A-73  
  path schematic A-75  
  viewing path profiles A-70  
path inspector windows A-73  
path profile views  
  timing analysis A-70  
  Timing Views toolbar A-68  
path profiles  
  in path inspector A-73  
  path inspector window A-74  
path schematics A-71  
  in path inspector A-73  
path slack histogram

histogram views A-69  
Timing Views toolbar A-68  
path specifications for TLUPlus 3-36  
path summaries, path inspector window A-74  
paths  
  select A-31  
physical bus  
  creating  
    automatic 8-113  
    manual 8-112  
    modifying 8-114  
    routing 8-115  
physical bus routing tool A-92  
physical bus, modifying 8-114  
physical bus, routing 8-115  
physical data  
  copying 3-18  
  validating 3-19  
physical datapath, defined 11-1  
physical optimization, voltage area support  
  14-74  
physical signoff options  
  reporting 8-99  
  setting 8-99  
physical synthesis  
  multivoltage designs 14-9  
  placing and optimizing designs 14-79  
  voltage-area-aware capabilities 14-72  
physopt\_check\_site\_array\_overlap variable  
  14-38  
physopt\_enable\_via\_res\_support variable  
  6-42  
physopt\_rp\_enable\_orient\_opt variable 11-21  
pin guides  
  creating objects A-94  
pin tapering, controlling 8-26  
place\_opt command 6-26, 12-32, 14-4, 14-9,  
  14-53, 14-72, 14-73  
place\_opt\_feasibility command 6-22  
placement  
  abutted multivoltage design 6-10

- categorized timing report 6-56
- filters 6-57
- incremental 6-36
- magnet 6-31
- multicorner-multimode 6-16
- refining 6-69
- subgroups 6-58
- placement and optimization 1-7
  - checkpointing 6-30
  - congestion-driven 6-31
  - customizing 6-26
  - feasibility 6-22
  - multivoltage 14-79
  - physical synthesis 14-79
  - skip initial placement 6-28
  - Synopsys physical guidance 6-29
- placement area utilization 6-44
- placement blockages
  - creating 6-5
  - creating objects A-94
  - thin channels 6-9
- placement statistics 8-89
- plan groups
  - creating objects A-94
- platforms 1-2
- pop operation, edit-in-place A-109
- port, supply 3-20
- postroute extraction 8-121
- power and ground net associations, voltage area support 14-77
- power and ground network
  - analyzing (see In-Design Rail Analysis)
  - creating logical connections
    - multivoltage designs 3-22
    - single-voltage designs 3-21
  - reporting logical connections 3-20
- power domain 3-19
  - extent 3-19
  - scope 3-19
- power domains
  - definition 14-2
- multivoltage designs 14-2
- voltage areas 14-4
- power state table 3-20
- power statistics 6-51
- power switch 3-20
- preferences
  - saving 2-35
  - setting 2-35
  - setting GUI command logging preferences 2-36
- preferred routing direction
  - reporting 8-16
  - setting 8-16
- prerequisites, routing 8-5
- preroute RC estimation 6-39
- preroute scaling factors, setting 6-41, 6-43
- preroute\_focal\_opt command 6-38
- preview selection A-5
- previewing commands in dialog boxes 2-32
- process scaling factors 8-123
- process\_particle\_probability\_file command 9-37, 9-38
- propagate\_constraints command 14-78
- properties, viewing and editing for selected object A-20
- psynopt command 6-36, 14-4, 14-73
- push operation, edit-in-place A-109
- pushing objects A-90
- PVT operating conditions 3-38
- PVT scaling 3-42

## Q

- Query panel A-13
- Query tool A-3, A-13
- querying objects A-13
- queuing licenses 2-41
- quick flow 1-8
- quitting IC Compiler 2-10

# R

RC calculations, preparing 3-36  
RC estimation 6-39  
  coefficients, specifying 6-42  
  scaling factors, setting 6-41  
  via resistance 6-42  
read\_def command 3-18  
read\_drc\_error\_file command 8-107  
read\_floorplan command 3-18  
read\_parasitics command 3-45  
read\_sdc command 3-43  
read\_sdf command 3-45  
read\_stream command 3-56  
read\_verilog command 3-13  
reading  
  DEF file 3-18  
  Verilog 3-13  
reapply edits A-95  
reapplying edits in layout view A-96  
recalling commands 2-20  
recording GUI session 2-36  
redirect command 2-21  
redirect operator ( > ) 2-21  
redirect operator ( >> ) 2-21  
redirecting command output 2-21  
redo command A-95, A-96  
redo edits A-96  
redrawing the active view A-19  
reference control file  
  writing 3-10  
reference libraries, Milkyway  
  reporting 3-7  
  setting 3-5  
reference, clock tree  
  specifying 7-27  
refine\_placement command 6-69  
refreshing the active view A-19  
relative coordinates A-5  
relative placement

aligning by pins 11-21  
anchoring at a specified location 11-13  
cell placement using bounds 11-50  
changing specific items within a group 11-96  
commands 11-99  
compression 11-40  
considerations for using 11-9  
example script 11-7  
flow 11-5  
group  
  adding items to 11-19  
  adding or removing items from in GUI A-55  
  creating 11-10  
  defined 11-10  
  extracting 11-97  
  ordering extracted 11-98  
  renaming 11-95  
hierarchical group  
  adding 11-31  
  exploring in GUI A-55  
  for instantiation 11-34  
  included, defined 11-31  
  instantiated, defined 11-31  
  syntax to include 11-32  
  syntax to instantiate 11-34  
hierarchy view A-55  
in a design containing obstructions 11-47, 11-48  
incremental relative placement 11-54  
keepout  
  adding 11-45  
  adding or removing in GUI A-55  
leaf cell  
  adding or removing in GUI A-55  
  specifying orientation 11-21  
  syntax to add to group 11-20  
limitations 11-100  
methodology 11-6  
modifying a group 11-89  
modifying information 11-89  
orientation optimization  
  defined 11-21

directing 11-21  
positions for data 11-10  
preserving relative placement structures 11-58  
relative placement information, ignoring 11-87  
removing 11-88  
removing items from a group 11-95  
required inputs 11-9  
straddling 11-39  
ungrouping 11-42  
uniquifying 11-44  
voltage area support 14-79  
writing information to script file 11-86  
relative placement groups  
exploring in GUI A-55  
relative placement hierarchy view A-55  
removing in GUI A-55  
removing items from in GUI A-55  
relative placement hierarchy view A-55  
relative placement view window  
editing 11-76, 11-77  
viewing net connections 11-73  
**remove\_all\_spacing\_rules command** 6-15  
**remove\_annotations command** 3-45  
**remove\_bounds command** 6-14  
**remove\_buffer\_tree command** 6-20  
**remove\_clock\_tree command** 7-61  
**remove\_clock\_tree\_exceptions command**

- dont\_buffer\_nets** 7-24
- dont\_size\_cells** 7-25
- dont\_touch\_subtrees** 7-24
- exclude\_pins** 7-19
- float\_pins** 7-22
- non\_stop\_pins** 7-18
- preserve\_hierarchy** 7-26
- size\_only\_cells** 7-25
- stop\_pins** 7-23

**remove\_filler\_withViolation command** 9-54  
**remove\_from\_rp\_group command** 11-95  
**remove\_ideal\_network command** 3-44  
**remove\_keepout\_margin command** 6-5  
**remove\_level\_shifters command** 14-53  
**remove\_license command** 2-42  
**remove\_net\_routing\_layer\_constraints command** 6-41  
**remove\_objects command** A-90  
**remove\_placement\_blockage command** 6-9  
**remove\_preferred\_routing\_direction command** 8-17  
**remove\_route\_guide command** 8-12  
**remove\_route\_guides command** 8-16  
**remove\_routing\_blockage command** 8-16  
**remove\_rp\_group\_options command** 11-87  
**remove\_rp\_groups command** 11-88  
**remove\_sdc command** 3-44  
**remove\_self\_gating\_logic command** 7-65  
**remove\_skew\_group command** 7-142  
**remove\_stdcell\_filler command**

- pad** 9-57
- stdcell** 9-53
- tap** 9-6

**remove\_target\_library\_subset command** 14-6  
**remove\_voltage\_area command** 14-45  
**remove\_well\_filler command** 9-56  
removing objects A-90  
replay interactive operation A-88  
replaying GUI session 2-36  
report views A-32  
**report\_area command** 12-26  
**report\_bounds command** 6-14  
**report\_buffer\_tree command** 6-20  
**report\_cell command** 14-83  
**report\_clock\_timing command** 7-123  
**report\_clock\_tree command** 7-120  
**report\_clock\_tree\_power command** 7-65  
**report\_constraint command** 7-148  
**report\_critical\_area command** 9-36  
**report\_delay\_calculation command** 6-49  
**report\_design command** 8-89, 12-26

report\_drc\_error\_type command 8-108  
report\_error\_coordinates command 8-6  
report\_inter\_clock\_delay\_options command  
    7-77  
report\_keepout\_margin command 6-5  
report\_milkyway\_version 3-9  
report\_mw\_lib\_reference command 3-7  
report\_net\_routing\_layer\_constraints  
    command 6-41  
report\_net\_routing\_rules command 8-33  
report\_noise\_calculation command 10-15  
report\_operating\_conditions command 14-84  
report\_physical\_signoff\_options command  
    8-99  
report\_placement\_utilization command 6-44  
report\_power command 6-51  
report\_power\_guide command 14-45  
report\_preferred\_routing\_direction command  
    8-16  
report\_preroute\_focal\_opt\_strategy command  
    6-38  
report\_reference\_cell\_routing\_rule command  
    7-43  
report\_route\_opt\_strategy command 8-73  
report\_route\_opt\_zrt\_crosstalk\_options  
    command 8-75  
report\_routing\_rules command 7-39  
report\_scan\_chain command 4-12  
report\_signal\_em command 10-21  
report\_signal\_em\_calculation command 10-24  
report\_spacing\_rules command 6-15  
report\_target\_library\_subset command 14-6,  
    14-84  
report\_timing command 6-47, 7-148  
report\_timing\_derate command 3-42  
report\_tlu\_plus\_files command 3-38  
report\_units command 3-8, 10-19  
report\_voltage\_area command 14-45, 14-83  
report, clock tree  
    generating 7-120  
types 7-120  
reporting  
    cell placement statistics 8-89  
    routing and optimization strategy 8-73  
    routing statistics 8-89  
reports  
    saving A-32  
    viewing A-32  
reset\_design command 3-44  
reset\_inter\_clock\_delay\_options commands  
    7-76  
reset\_timing\_derate command 3-42  
Reshape tool A-91  
resize\_objects command A-90  
resizing objects A-90  
retention register 3-20  
reusing commands 2-31  
reverse edits A-95  
reversing edits in layout view A-96  
rotate object commands A-93  
rotate\_objects command A-93  
rotating objects A-93  
routability, checking 8-6  
route guide  
    creating 8-8  
    creating objects A-94  
    finding 8-11  
    preferred-direction-only 8-9  
    removing 8-12, 8-16  
route\_htree command 7-110  
route\_mesh\_net command 7-107  
route\_opt command 14-72  
route\_zrt\_eco command 8-85  
route\_zrt\_group command 8-55, 8-57  
routing  
    automatic 8-70  
    clock nets 8-55  
    critical nets 8-57  
    ECO 8-85  
    interactive

multiple nets 8-115  
physical bus 8-115  
single net 8-110  
postroute extraction 8-121  
prerequisites 8-5  
route\_opt 8-72  
running individual steps 8-60  
signal nets 8-59  
special nets 8-55, 8-57  
verifying  
  using IC Compiler 8-95  
routing and optimization strategy  
  reporting 8-73  
  setting 8-72  
routing blockage  
  creating 8-15  
  creating objects A-94  
  finding 8-16  
  removing 8-16  
routing corridors  
  Create Routing Corridor tool A-92  
routing direction, setting preferred 8-16  
routing layers  
  specifying 8-33  
routing layers, clock tree  
  default 7-42  
  setting 7-42  
routing rule  
  clock tree  
    default 7-39  
    nondefault 7-39  
  defining 7-39  
  nondefault, defined 7-39  
  reporting 7-39  
routing rules (nondefault), defining 8-22  
routing statistics 8-89  
routing tools  
  Advanced Route A-92  
  Create RDL Route A-92  
  Create Route A-92  
  Custom Wire A-93  
routing tracks, creating objects A-94  
rp\_group\_inclusions command 11-85  
rp\_group\_instantiations command 11-85  
rp\_group\_references command 11-86  
Ruler tool A-3, A-36

## S

save window or view image A-33  
save\_mw\_cel command 3-51, A-83, A-84, A-111  
saving  
  design using Milkyway 3-51  
  designs 1-8  
  log messages 2-29  
  preferences 2-35  
  reports A-32  
  transcript of session commands 2-29, 2-32  
SBPF  
  reading 3-45  
  writing 3-55  
scaling factors  
  process 8-123  
scaling factors, preroute, setting 6-41, 6-43  
scaling library groups 3-42  
scan chains  
  partitioning  
    default 4-8  
    horizontal 4-8  
    vertical 4-8  
  reporting 4-12  
  viewing 4-12  
SCANDEF file, defined 4-3  
scenario definition  
  clock tree synthesis 7-59  
scenario reduction, multicorner-multimode 3-31  
schematic view A-2  
Schematic View panel, path inspector window A-75  
schematic views

design schematics A-71  
path schematics A-71  
refreshing A-19  
symbol view A-71  
Schematics toolbar A-72  
scope 3-19  
Screenshot of layout view A-33  
scripts 2-8  
    command abbreviations in 2-18  
    executing at startup 2-3  
SDC  
    reading 3-43  
    writing 3-54  
SDF files, reading 3-45  
search and repair, running 8-66  
search\_path variable 3-36  
searching the transcript 2-29  
select by name dialog box A-29  
Select By Name tool A-12  
Select By Name toolbar A-12  
select timing paths A-31  
selected objects, following in graphic views  
    A-17  
selecting objects in graphic views A-7  
selecting only highlighted objects A-12  
selection preview A-5  
Selection tool A-3, A-7  
session log 2-29  
set\_ahfs\_options command 6-20  
set\_attribute command 14-69  
set\_checkpoint\_strategy command 6-30  
set\_clock\_tree\_exceptions command  
    -dont\_buffer\_nets 7-24  
    -dont\_size\_cells 7-25  
    -dont\_touch\_subtrees 7-24  
    -exclude\_pins 7-19  
    float pin options 7-20, 7-60  
    -non\_stop\_pins 7-18  
    -preserve\_hierarchy 7-26  
    -size\_only\_cells 7-25  
    -stop\_pins 7-23  
set\_clock\_tree\_options command 8-31  
    -layer\_list 7-42  
    -max\_capacitance 7-35  
    -max\_fanout 7-35  
    -max\_transition 7-35  
    -routing\_rule 7-39  
    -target\_early\_delay 7-38  
    -target\_skew 7-38  
    -use\_default\_routing\_for\_sinks 7-39  
set\_clock\_tree\_references command 7-27  
set\_congestion\_options command 6-11  
set\_cts\_scenario command 7-59  
set\_delay\_calculation command 3-44  
set\_delay\_estimation\_options command 6-40,  
    6-41, 6-42, 6-43  
set\_design\_attributes command 14-59  
set\_em\_options command 10-22  
set\_extraction\_options command 8-122  
set\_gui\_stroke\_binding command A-48  
set\_gui\_stroke\_preferences command A-48  
set\_ignored\_layers command 8-33  
set\_inter\_clock\_delay\_options command 7-74  
set\_isolation command 14-54  
set\_isolation\_control command 14-59  
set\_keepout\_margin command 6-4  
set\_left\_right\_filler\_rule command 9-53  
set\_level\_shifter\_strategy command 14-47  
set\_level\_shifter\_threshold command 14-47,  
    14-49, 14-51  
set\_lib\_cell\_spacing\_label command 6-14,  
    6-15  
set\_max\_transition command 7-36  
set\_min\_library command 3-39, 3-40  
set\_mw\_lib\_reference command 3-10  
set\_net\_routing\_layer\_constraints command  
    6-41  
set\_net\_routing\_rule command 8-32  
set\_object\_fixed\_edit command A-95

set\_object\_snap\_type command A-95, A-98, A-99  
set\_operating\_conditions command 3-46, 14-48, 14-78  
set\_optimize\_dft\_options command 4-8  
set\_physical\_signoff\_options command 8-99, 9-60  
set\_port\_attributes command 14-57  
set\_power\_guide command 14-45  
set\_power\_net\_to\_voltage\_area command 14-77  
set\_preferred\_routing\_direction command 8-16  
set\_preroute\_focal\_opt\_strategy command 6-38  
set\_reference\_cell\_routing\_rule command 7-43  
set\_retention command 14-63  
set\_route\_opt\_strategy command 8-72  
set\_route\_opt\_zrt\_crosstalk\_options command 8-75  
set\_rp\_group\_options command 11-89  
set\_si\_options command 3-45, 14-79, A-56  
set\_skew\_group command 7-141  
set\_spacing\_label\_rule command 6-14, 6-15  
set\_target\_library\_subset command 14-5, 14-6  
set\_timing\_derate command 3-41  
set\_tlu\_plus\_files command 3-36, 3-38, 9-58  
set\_write\_stream\_options command 3-55  
setting preferences 2-35  
setting the current design 3-14  
sh\_command\_log\_file variable 2-10  
shape splitting tool A-90  
shapes, Create Net tool A-92  
shell command line  
  copying commands to command line 2-5  
  entering commands 2-4, 2-18  
shell commands 2-4  
shell interface 1-5  
shielding nets 9-41  
shortcut keys 2-15  
signal electromigration  
  performing analysis 10-21  
signal integrity  
  crosstalk prevention 8-53  
  crosstalk reduction 8-52  
  defined 10-1, 10-3  
  options  
    commands affected 10-4  
    setting 10-4  
signal integrity flow  
  voltage area support 14-79  
signal integrity mode, enabling 8-52  
single net, routing 8-110  
size\_only attribute 14-48, 14-49, 14-54  
skew  
  balancing between clocks 7-72  
  global 7-38  
skew group  
  definition 7-140  
  guidelines 7-140  
snapping options for layout editing A-98  
snapping, enable or disable A-95  
snps\_derived attribute 14-88  
SolvNet  
  accessing xxxvii  
  documentation xxxv  
  Download Center xxxiv  
sparc64 platform 1-2  
SPEF (Standard Parasitic Exchange Format)  
  files  
    reading 3-45  
    writing 3-55  
Split tool A-90  
split\_clock\_gates command 7-71  
split\_clock\_net command 7-103  
split\_objects command A-90  
spread objects tool A-91  
Spread Wire tool A-91

spread\_zrt\_wires command 9-39  
spreading objects A-91  
spreading wires A-91  
standard cell filler  
    removing 9-53  
    removing fillers that have routing rule violations 9-54  
    rules, defining 9-53  
standard cell filler, inserting 9-49  
standard cell row, adding end caps 9-54  
standard-cell filler cell insertion, voltage area support 14-77  
starting IC Compiler 2-2  
    executing commands 2-3  
    executing scripts 2-3  
starting `icc_shell` 2-2  
starting the GUI 2-2  
    listing startup options 2-3  
startup options, `-help` list 2-3  
static noise  
    defined 10-3  
    reporting 10-14  
    violations 10-14  
    visual mode 10-14  
status bar 2-24, A-5  
Status panel, path inspector window A-74  
straddling, in relative placement, defined 11-39  
Stretch Wire tool A-90  
stretching and moving objects A-90  
stretching wires A-90  
stroke activated commands A-46  
stroke commands A-46  
supply net 3-20  
supply port 3-20  
supported platforms 1-2  
Suse platforms 1-2  
switch, power 3-20  
symbol views A-71

**T**

Tab panel, path inspector window A-74  
tap cell  
    inserting 9-5  
    removing 9-6  
tap cell array  
    adding 9-3  
target library subsetting, multivoltage designs 14-6  
target\_library variable 14-6  
task, layout window 2-34  
Tcl (tool command language)  
    scripts 2-8  
    used by IC Compiler 1-5  
TclPro  
    bytecode-compiled files 2-40  
    limitations 2-40  
    procomp 2-40  
technology (.tf) file  
    defined 3-4  
    writing 3-10  
technology file  
    specifying 3-5  
terminals, Create Terminal tool A-92  
terminating commands 2-7  
text, Create Text tool A-93  
tie cell insertion 6-17  
timing analysis  
    histograms A-69  
    path inspector windows A-73  
    preparing 3-36  
    timing analysis driver A-67  
    timing analysis window A-66  
    Timing Views toolbar A-68  
timing analysis driver A-67  
Timing Analysis Driver panel A-67  
timing constraints  
    removing 3-44  
    setting 3-43  
timing goals, clock tree 7-38

timing information  
    maximum 3-39  
    minimum 3-39  
timing libraries 1-6  
    derating factors 3-41  
timing paths  
    analyzing A-66  
    endpoint slack histogram A-69  
    path slack histogram A-69  
    selecting A-31  
    timing analysis driver A-67  
    viewing in path inspector A-73  
timing report 6-47, 7-148  
    crosstalk analysis 10-14  
Timing Views toolbar A-68  
timing\_enable\_multiple\_clocks\_per\_reg  
    variable 7-9  
TLUPlus  
    map file 3-36  
    models 3-36  
    reporting files 3-38  
    specifying paths 3-36  
    validating files 3-38  
toggle snapping A-95  
tool command language (Tcl)  
    scripts 2-8  
    used by IC Compiler 1-5  
tool command language (Tcl) mode 1-5  
toolbars 2-24  
    Analysis toolbar A-48  
    Browsers 7-130, A-58  
    Cells List 3-14  
    console 2-28  
    Edit In Place A-110  
    Expand Browser 7-130, A-59  
    Highlight toolbar A-10  
    Mouse Tool Options toolbar A-5, A-7, A-87  
    Mouse Tools toolbar A-3  
    Schematics A-72  
    Select By Name toolbar A-12  
    Timing Views A-68  
Undo A-96  
View Zoom/Pan toolbar A-15  
Zoom and Pan History toolbar A-18  
tools A-92, A-93  
    Align/Distribute tool A-91  
    Area Push tool A-90  
    Copy tool A-90  
    create floorplan object tools A-94  
    Create Net tool A-92  
    Create RDL Route tool A-92  
    Create Route tool A-92  
    Create Routing Corridor tool A-92  
    Create Terminal tool A-92  
    Create Text tool A-93  
    Create Via tool A-92  
    Delete tool A-90  
    Edit tool (see Move/Resize tool)  
    Highlight tool A-3, A-9  
    layout editing tools A-86  
    left mouse button tools A-3  
    Move Pins on Edge tool A-91  
    Move/Resize tool  
        move objects A-90  
        resize objects A-90  
    Pan tool A-3  
    Query tool A-3, A-13  
    Reshape tool A-91  
    Ruler tool A-3, A-36  
    Select By Name tool A-12  
    Selection tool A-3, A-7  
    Split tool A-90  
    Spread Wire tool A-91  
    Stretch Wire tool A-90  
    Window Stretch tool A-90  
    Zoom In tool A-3  
    Zoom Out tool A-3  
top-level windows 2-22  
track assignment  
    description 8-65  
    options  
        descriptions 8-45  
        reporting 8-45

- setting 8-45
- running 8-65
- transcript of session commands, saving 2-29

## U

- uncommit\_fp\_soft\_macros command 11-53
- undo command A-95, A-96
- undo edits A-96
- Undo toolbar A-96
- unfix objects A-97
- unfix objects for edit A-95
- Unified Power Format (UPF) 14-11
- uniquify\_fp\_mw\_cel command 3-14
- units
  - default 3-4
  - saving with design 3-51
  - saving with SDC 3-54

## UNIX

- DISPLAY environment variable 2-2
- shell 2-3

- UNIX operator
  - append ( >> ) 2-21
  - redirect ( > ) 2-21
- unlocking objects for edit A-95
- unset\_power\_guide command 14-45
- update\_bounds command 6-13
- update\_clock\_latency command 7-98
- update\_voltage\_area command 14-40

## UPF

- mapping retention registers 14-65

- UPF commands
  - map\_retention\_cell 14-65
  - set\_design\_attributes 14-59
  - set\_isolation 14-54
  - set\_isolation\_control 14-59
  - set\_port\_attributes 14-57
  - set\_retention 14-63
- UPF concepts
  - power and ground pin syntax 14-7

- UPF strategy
  - isolation 14-54
- user grid, displaying or hiding A-36
- user interfaces 1-5
- user shapes, Create Net tool A-92
- using aliases 2-20
- utilization 6-44

## V

- variables
  - cts\_do\_characterization 7-119
  - cts\_dont\_touch\_subtrees 7-24
  - cts\_enable\_rc\_constraints 7-53
  - cts\_fix\_clock\_tree\_sinks 7-85
  - cts\_move\_clock\_gate 7-84
  - cts\_rc\_relax\_factor 7-54
  - cts\_self\_gating\_connect\_scan\_enable 7-66
  - cts\_self\_gating\_data\_toggle\_rate\_filter 7-66
  - cts\_self\_gating\_num\_regs 7-66
  - cts\_self\_gating\_num\_regs\_max\_percent 7-66
  - cts\_self\_gating\_num\_regs\_max\_percent\_to\_tal\_cell 7-66
  - cts\_self\_gating\_reg\_power\_filter 7-66
  - cts\_self\_gating\_wns\_backoff 7-66
  - cts\_use\_debug\_mode 7-119
  - cts\_use\_lib\_max\_fanout 7-35
  - cts\_use\_sdc\_max\_fanout 7-35
  - DISPLAY 2-2
  - mv\_no\_cells\_at\_default\_va 6-10
  - physopt\_check\_site\_array\_overlap 14-38
  - physopt\_enable\_via\_res\_support 6-42
  - physopt\_rp\_enable\_orient\_opt 11-21
  - placer\_enable\_enhanced\_router 6-31
  - placer\_max\_cell\_density\_threshold 6-12
  - psynopt\_high\_fanout\_legality\_limit 6-27
  - search\_path 3-36
  - sh\_command\_log\_file 2-10
  - SNPS\_MAX\_QUEUETIME 2-42
  - SNPS\_MAX\_WAITTIME 2-42
  - SNPSLMD\_QUEUE 2-41

target\_library 14-6  
tieoff\_hierarchy\_opt 6-17  
tieoff\_hierarchy\_opt\_keep\_driver 6-17  
timing\_enable\_multiple\_clocks\_per\_reg 7-9  
verify\_route command 8-95  
Verilog  
  reading 3-13  
  writing 3-54  
via arrays, Create Via tool A-92  
via resistance  
  estimating 6-42  
  scaling 6-43  
vias  
  Create Via tool A-92  
View Settings panel  
  design overlays on layout view A-40  
  layer properties in layout view A-44  
  object properties in layout view A-42  
  object properties in schematic view A-72  
  save or load settings A-46  
  using with active layout view A-41  
view window  
  save image of A-33  
view windows 2-25  
View Zoom/Pan toolbar A-15  
viewing  
  man pages 2-14  
  object properties A-20  
  reports A-32  
  scan chains 4-12  
views  
  clock graph A-2  
  clock tree fanout browser A-59  
  design schematics A-71  
  histogram A-2  
  histograms A-69  
  layout A-2, A-34  
  path inspector window A-73  
  path profiles A-70  
  path schematics A-71  
  schematic A-2  
symbol A-71  
virtual flat placement 11-51  
virtual hierarchical cells A-23  
virtual hierarchy routing, voltage area support 14-73  
virtual hierarchy, Flat Design Hierarchy Browser dialog box A-23  
Visual Mode panel A-51  
visual modes  
  Analysis toolbar A-48  
  delta delay 10-14  
  displaying A-51  
  static noise 10-14  
  Visual Mode panel A-51  
voltage and temperature scaling 3-42  
voltage area 3-19  
  defined 8-53  
routing behavior  
  controlling for a net 8-54  
  controlling for the design 8-54  
  default 8-53  
voltage areas  
  creating 14-39  
  creating for multivoltage designs 14-39  
  creating objects A-94  
  guard bands, using 14-41  
  macro cells 14-44  
  multivoltage designs 14-4  
  power domains 14-4  
  power domains, associating 14-39  
  removing 14-45  
  reporting 14-45  
  updating 14-40  
voltage-area-aware capabilities 14-72  
  automatic high-fanout synthesis 14-73  
  clock tree synthesis and optimization 14-74  
  global routing 14-74  
  maximum net length optimization 14-73  
  physical optimization 14-74  
  power and ground nets, associating 14-77  
  signal integrity flow 14-79

standard-cell filler cell insertion 14-77  
using interface logic models 14-78  
using relative placement 14-79  
virtual hierarchy routing 14-73  
voltage-area-based optimization 14-74  
voltage-area-based optimization 14-74

## W

well filler  
  inserting 9-55  
  removing 9-56  
widen\_zrt\_wires command 9-40

Window Stretch tool A-90

windows  
  layout 2-33  
  main 2-3, 2-26  
  menu bar 2-23  
  status bar 2-24  
  timing analysis A-66  
  toolbars 2-24  
  top-level 2-22  
  view windows 2-25  
  working environment 2-22

wire routing tools

  Advanced Route A-92  
  Create RDL Route A-92  
  Create Route A-92  
  Custom Wire A-93

wire spreading 9-39

wire stretching tool A-90

wire widening 9-40

wires

  creating with layout editor 8-119

wires, spreading A-91

working environment 2-22

write\_def command 3-54

write\_interface\_timing 12-19

write\_mw\_lib\_files command 3-10  
write\_parasitics command 3-55, 8-122  
write\_rp\_groups command 11-86  
write\_sdc command 3-54  
write\_stream command 3-55  
writing  
  DEF file 3-54  
  Verilog 3-54

## X

XOR self-gating 7-64

## Y

yield, optimizing  
  displaying critical area heat maps 9-38  
  performing wire spreading 9-39  
  performing wire widening 9-40

## Z

Zoom and Pan History toolbar A-18  
Zoom Fit All command A-15  
Zoom Follows Selection command A-15  
Zoom In 2x command A-15  
Zoom In tool A-3  
Zoom Out 2x command A-15  
Zoom Out tool A-3  
Zoom to Selection command A-15  
Zroute  
  features 8-3  
  flow 8-3  
Zroute options 8-35  
  common route options 8-35  
  detail route options 8-45  
  global route options 8-42  
  track assignment options 8-45