

# **IC Compiler**

## **Implementation**

## **User Guide**

---

Version C-2009.06, June 2009

**SYNOPSYS®**

# Copyright Notice and Proprietary Information

Copyright © 2009 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, AMPS, Astro, Behavior Extracting Synthesis Technology, Cadabra, CATS, Certify, CHIPit, Design Compiler, DesignWare, Formality, HDL Analyst, HSIM, HSPICE, Identify, iN-Phase, Leda, MAST, ModelTools, NanoSim, OpenVera, PathMill, Physical Compiler, PrimeTime, SCOPE, Simply Better Results, SiVL, SNUG, SolvNet, Syndicated, Synplicity, Synplify, Synplify Pro, Synthesis Constraints Optimization Environment, TetraMAX, the Synplicity logo, UMRBus, VCS, Vera, and YIELDirector are registered trademarks of Synopsys, Inc.

## Trademarks (™)

AFGen, Apollo, Astro-Rail, Astro-Xtalk, Aurora, AvanWaves, BEST, Columbia, Columbia-CE, Confirma, Cosmos, CosmosLE, CosmosScope, CRITIC, CustomSim, DC Expert, DC Professional, DC Ultra, Design Analyzer, Design Vision, DesignerHDL, DesignPower, DFTMAX, Direct Silicon Access, Discovery, Eclypse, Encore, EPIC, Galaxy, Galaxy Custom Designer, HANEX, HAPS, HapsTrak, HDL Compiler, Hercules, Hierarchical Optimization Technology, High-performance plus ASIC Prototyping System, HSIM, i-Virtual Stepper, IIICE, in-Sync, iN-Tandem, Jupiter, Jupiter-DP, JupiterXT, JupiterXT-ASIC, Liberty, Libra-Passport, Library Compiler, Magellan, Mars, Mars-Rail, Mars-Xtalk, Milkyway, ModelSource, Module Compiler, MultiPoint, Physical Analyst, Planet, Planet-PL, Polaris, Power Compiler, Raphael, Saturn, Scirocco, Scirocco-i, Star-RCXT, Star-SimXT, System Compiler, System Designer, Taurus, TotalRecall, TSUPREM-4, VCS Express, VCSI, VHDL Compiler, VirSim, and VMC are trademarks of Synopsys, Inc.

## Service Marks (SM)

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

SystemC 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.

# Contents

---

|                                                          |      |
|----------------------------------------------------------|------|
| What's New in This Release . . . . .                     | xxvi |
| About This Guide . . . . .                               | xxvi |
| Customer Support . . . . .                               | xxix |
| <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-4  |
| Methodology Overview . . . . .                           | 1-5  |
| Speeding Up the Basic Flow . . . . .                     | 1-7  |
| <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-6  |
| Opening and Closing the GUI . . . . .                    | 2-7  |
| Using Tcl Scripts . . . . .                              | 2-8  |
| Using Setup Files . . . . .                              | 2-9  |
| Exiting IC Compiler . . . . .                            | 2-10 |

|                                                                      |      |
|----------------------------------------------------------------------|------|
| Getting Help in IC Compiler . . . . .                                | 2-10 |
| Getting Help on the Command Line . . . . .                           | 2-11 |
| Finding Menu Commands and Dialog Boxes. . . . .                      | 2-12 |
| Viewing Man Pages . . . . .                                          | 2-13 |
| Displaying the List of Keyboard Shortcuts . . . . .                  | 2-14 |
| Using Online Help . . . . .                                          | 2-14 |
| Searching for Text . . . . .                                         | 2-15 |
| Configuring the Help Browser . . . . .                               | 2-16 |
| Working With the GUI . . . . .                                       | 2-17 |
| Using GUI Windows. . . . .                                           | 2-17 |
| Menu Bar . . . . .                                                   | 2-18 |
| Toolbars . . . . .                                                   | 2-19 |
| Status Bar . . . . .                                                 | 2-19 |
| View Windows . . . . .                                               | 2-20 |
| Panels. . . . .                                                      | 2-21 |
| Working in the Main Window . . . . .                                 | 2-21 |
| Working With the Console . . . . .                                   | 2-23 |
| Viewing the Session Log . . . . .                                    | 2-24 |
| Viewing the History View . . . . .                                   | 2-26 |
| Previewing <code>icc_shell</code> Commands in Dialog Boxes . . . . . | 2-27 |
| Viewing the Physical Layout . . . . .                                | 2-28 |
| Setting the Menu Task Mode . . . . .                                 | 2-29 |
| Setting the Primary Design. . . . .                                  | 2-29 |
| Setting GUI Preferences . . . . .                                    | 2-30 |
| Reading and Saving Designs . . . . .                                 | 2-30 |
| Reading a Design . . . . .                                           | 2-31 |
| Setting the Current Design . . . . .                                 | 2-32 |
| Saving Designs . . . . .                                             | 2-32 |
| Closing Designs. . . . .                                             | 2-33 |
| Saving or Discarding Design Changes . . . . .                        | 2-34 |
| Archiving Designs . . . . .                                          | 2-36 |
| Using IC Compiler Command-Line Interfaces . . . . .                  | 2-38 |
| Using Wildcard Characters . . . . .                                  | 2-39 |
| Using Aliases. . . . .                                               | 2-40 |
| Listing and Rerunning Previously Entered Commands . . . . .          | 2-40 |
| Reporting Memory Usage and Runtime . . . . .                         | 2-40 |
| Redirecting and Appending Command Output . . . . .                   | 2-41 |

|                                                         |      |
|---------------------------------------------------------|------|
| Checking the Syntax and Semantics of Your Scripts ..... | 2-42 |
| Installation Requirements .....                         | 2-43 |
| Running the Synopsys Syntax Checker.....                | 2-43 |
| Limitations of the Synopsys Syntax Checker.....         | 2-44 |
| Bytecode-Compiled Files.....                            | 2-45 |
| TclPro Limitations .....                                | 2-45 |
| Working With Licenses .....                             | 2-46 |
| Listing the Licenses in Use .....                       | 2-46 |
| Getting Licenses .....                                  | 2-46 |
| Enabling License Queuing.....                           | 2-47 |
| Releasing Licenses .....                                | 2-48 |
| Getting and Releasing Licenses in the GUI.....          | 2-48 |
| <b>3. Preparing the Design</b>                          |      |
| Setting Up the Libraries .....                          | 3-2  |
| Setting Up the Logic Libraries .....                    | 3-2  |
| Defining the Logic Library Settings.....                | 3-3  |
| Validating Logic Libraries .....                        | 3-3  |
| Setting Up the Physical Libraries.....                  | 3-9  |
| Creating a Milkyway Design Library .....                | 3-10 |
| Managing Milkyway Reference Libraries                   |      |
| Using Reference Control Files.....                      | 3-10 |
| Converting a Milkyway Database Model.....               | 3-15 |
| Validating a Milkyway Design Library .....              | 3-18 |
| Opening a Milkyway Design Library .....                 | 3-19 |
| Reporting on a Milkyway Design Library .....            | 3-20 |
| Changing Physical Library Information.....              | 3-21 |
| Saving Physical Library Information .....               | 3-22 |
| Verifying Library Consistency .....                     | 3-23 |
| Reading the Design .....                                | 3-25 |
| Reading a Design in Milkyway Format.....                | 3-25 |
| Reading a Design in ASCII Format .....                  | 3-27 |
| Annotating the Physical Data .....                      | 3-28 |
| Reading DEF Files.....                                  | 3-28 |
| Reading Floorplan Files.....                            | 3-29 |
| Copying Physical Data.....                              | 3-29 |
| Validating Physical Data .....                          | 3-31 |

|                                                                |      |
|----------------------------------------------------------------|------|
| Preparing for Timing Analysis and RC Calculation.....          | 3-31 |
| Setting Up the TLUPlus Files.....                              | 3-32 |
| Back-Annotating Delay or Parasitic Data.....                   | 3-33 |
| Setting Timing Constraints.....                                | 3-33 |
| Specifying the Analysis Mode .....                             | 3-35 |
| Setting the Derating Factors .....                             | 3-36 |
| Setting the Scaling Factors .....                              | 3-36 |
| Selecting Delay Calculation.....                               | 3-37 |
| Saving the Design.....                                         | 3-38 |
| Saving the Design in Milkyway Format .....                     | 3-38 |
| Saving the Design in ASCII Format.....                         | 3-38 |
| Saving the Design for Manufacturing.....                       | 3-39 |
| <b>4. Placement</b>                                            |      |
| Defining Placement Blockages .....                             | 4-2  |
| Defining Keepout Margins .....                                 | 4-2  |
| Defining Global Keepout Margins .....                          | 4-3  |
| Defining Cell-Specific Keepout Margins .....                   | 4-4  |
| Inserting Port Protection Diodes.....                          | 4-5  |
| Defining Area-Based Placement Blockages .....                  | 4-5  |
| Placement Options .....                                        | 4-7  |
| Congestion Options.....                                        | 4-7  |
| Move Bounds.....                                               | 4-8  |
| Intercell and Boundary Spacing Rules .....                     | 4-9  |
| Buffer Strategy for Optimization.....                          | 4-11 |
| Tie Cell Insertion .....                                       | 4-11 |
| Magnet Placement.....                                          | 4-12 |
| Placement and Optimization Attributes .....                    | 4-13 |
| Preparing for High-Fanout Net Synthesis .....                  | 4-14 |
| Performing Clock Tree Synthesis During Placement .....         | 4-15 |
| Performing Placement and Optimization .....                    | 4-15 |
| Saving Intermediate Results During Preroute Optimization ..... | 4-17 |
| Setting Up for Congestion-Driven Placement .....               | 4-18 |
| Using Physical Optimization .....                              | 4-18 |

|                                                                            |      |
|----------------------------------------------------------------------------|------|
| Preroute RC Estimation .....                                               | 4-20 |
| Modifying the RC Coefficients .....                                        | 4-21 |
| Defining Net-Based Layer Constraints .....                                 | 4-22 |
| Introducing Pessimism .....                                                | 4-22 |
| Enabling Via Resistance Estimation .....                                   | 4-24 |
| Scaling the Via Resistance Values .....                                    | 4-24 |
| Manually Specifying Via Resistance Values .....                            | 4-24 |
| Analyzing Placement .....                                                  | 4-25 |
| Placement Area Utilization .....                                           | 4-25 |
| Timing Analysis .....                                                      | 4-27 |
| Power Analysis .....                                                       | 4-31 |
| Placement Analysis Tools in the GUI .....                                  | 4-33 |
| Cell Density Map .....                                                     | 4-34 |
| Congestion Map .....                                                       | 4-37 |
| Hierarchy Visual Mode .....                                                | 4-37 |
| Clock Tree Visual Mode .....                                               | 4-38 |
| Net Connections in Area Visual Mode .....                                  | 4-39 |
| Refining Placement .....                                                   | 4-42 |
| <b>5. Design for Test</b>                                                  |      |
| Overview of the DFT Flow .....                                             | 5-2  |
| Preparing for Physical DFT Using the <code>read_def</code> Flow .....      | 5-3  |
| Performing Scan Synthesis and Generating a SCANDEF File .....              | 5-4  |
| Hierarchical Flow .....                                                    | 5-4  |
| Loading the SCANDEF File .....                                             | 5-5  |
| Generating SCANDEF Data Using the <code>trace_scan_chain</code> Flow ..... | 5-6  |
| Scan Chain Consistency Checking .....                                      | 5-7  |
| Removing SCANDEF Data .....                                                | 5-8  |
| Optimizing Scan Chains .....                                               | 5-8  |
| Placement-Aware Scan Chain Reordering .....                                | 5-9  |
| Clock-Aware Scan Reordering .....                                          | 5-11 |
| Example Optimization Flow .....                                            | 5-11 |
| Viewing Scan Chains .....                                                  | 5-12 |

## 6. Power Optimization

|                                                                |     |
|----------------------------------------------------------------|-----|
| Types of Power Optimization . . . . .                          | 6-2 |
| Strategies To Reduce Leakage Power . . . . .                   | 6-2 |
| Using Multiple Threshold-Voltage Cells . . . . .               | 6-3 |
| Multiple Threshold-Voltage Libraries . . . . .                 | 6-4 |
| Defining Multiple Threshold-Voltage Using Attributes . . . . . | 6-5 |
| Constraining the Leakage Power Optimization . . . . .          | 6-5 |
| Adaptive Leakage Power Optimization . . . . .                  | 6-6 |
| Annotating Switching Activity . . . . .                        | 6-6 |
| Setting the Options For Power Optimization . . . . .           | 6-7 |
| Performing Power Optimization . . . . .                        | 6-8 |
| Low-Power Placement . . . . .                                  | 6-8 |
| Low-Power Clock Tree Synthesis . . . . .                       | 6-9 |
| Low-Power Routing . . . . .                                    | 6-9 |
| Power Optimization Flow Example . . . . .                      | 6-9 |

## 7. Clock Tree Synthesis

|                                                  |      |
|--------------------------------------------------|------|
| 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-6  |
| Cascaded Generated Clocks . . . . .              | 7-6  |
| Identifying the Clock Tree Endpoints . . . . .   | 7-7  |
| Defining the Clock Root Attributes . . . . .     | 7-9  |
| Specifying Clock Tree Exceptions . . . . .       | 7-9  |
| Specifying Nonstop Pins . . . . .                | 7-13 |
| Specifying Exclude Pins . . . . .                | 7-13 |
| Specifying Float Pins . . . . .                  | 7-14 |
| Specifying Stop Pins . . . . .                   | 7-17 |
| Specifying Don't Touch Subtrees . . . . .        | 7-17 |
| Specifying Don't Buffer Nets . . . . .           | 7-18 |
| Specifying Don't Size Cells . . . . .            | 7-18 |

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| Specifying Size-Only Cells . . . . .                                      | 7-19 |
| Preserving the Clock Pins of Existing Hierarchies . . . . .               | 7-19 |
| Specifying the Clock Tree References . . . . .                            | 7-20 |
| Specifying Clock Tree Synthesis Options . . . . .                         | 7-22 |
| Specifying the Clock Tree Synthesis Goals . . . . .                       | 7-26 |
| Setting Clock Tree Design Rule Constraints . . . . .                      | 7-26 |
| Setting Clock Tree Timing Goals . . . . .                                 | 7-28 |
| Setting Level Restrictions . . . . .                                      | 7-29 |
| Setting Clock Tree Routing Options . . . . .                              | 7-29 |
| Specifying Routing Rules . . . . .                                        | 7-30 |
| Shielding Clock Nets . . . . .                                            | 7-31 |
| Specifying Routing Layers . . . . .                                       | 7-33 |
| Inserting Boundary Cells . . . . .                                        | 7-34 |
| Selecting the Clock Tree Clustering . . . . .                             | 7-35 |
| Enabling On-Chip-Variation-Aware Clustering . . . . .                     | 7-35 |
| Enabling Logic-Level Balancing . . . . .                                  | 7-36 |
| Enabling Region-Aware Clock Tree Synthesis . . . . .                      | 7-38 |
| Specifying Clock Tree Optimization Options . . . . .                      | 7-39 |
| Controlling Embedded Clock Tree Optimization . . . . .                    | 7-40 |
| Controlling Preroute Clock Tree Optimization . . . . .                    | 7-41 |
| Controlling Postroute Clock Tree Optimization . . . . .                   | 7-41 |
| Saving Intermediate Results During Preroute Optimization . . . . .        | 7-42 |
| Inserting User-Specified Clock Trees . . . . .                            | 7-43 |
| Reading a Clock Configuration File . . . . .                              | 7-43 |
| Reducing Skew Variation by Using RC Constraint-Based Clustering . . . . . | 7-43 |
| Saving a Clock Configuration File . . . . .                               | 7-44 |
| Defining the Clock Tree Structure . . . . .                               | 7-44 |
| Handling Specific Design Characteristics . . . . .                        | 7-48 |
| Handling Hard Macro Cells . . . . .                                       | 7-48 |
| Handling Existing Clock Trees . . . . .                                   | 7-49 |
| Identifying Existing Clock Trees . . . . .                                | 7-49 |
| Preserving Portions of an Existing Clock Tree . . . . .                   | 7-50 |
| Removing Clock Trees . . . . .                                            | 7-50 |
| Handling Non-Unate Gated Clocks . . . . .                                 | 7-52 |
| Handling Integrated Clock-Gating Cells . . . . .                          | 7-52 |
| Optimizing for Clock Tree QoR . . . . .                                   | 7-52 |

|                                                                 |      |
|-----------------------------------------------------------------|------|
| Optimizing for Power . . . . .                                  | 7-54 |
| Optimizing for Timing on Enable Signals . . . . .               | 7-56 |
| Balancing Multiple Clocks . . . . .                             | 7-58 |
| Defining the Delay Balancing Buffers . . . . .                  | 7-58 |
| Defining a Clock Balance Group . . . . .                        | 7-58 |
| Defining the Interclock Delay Requirements . . . . .            | 7-59 |
| Hierarchical Designs Using Interface Logic Models . . . . .     | 7-61 |
| Multivoltage Designs . . . . .                                  | 7-62 |
| Multicorner-Multimode Designs . . . . .                         | 7-62 |
| Verifying the Clock Trees . . . . .                             | 7-63 |
| Implementing the Clock Trees . . . . .                          | 7-64 |
| Stand-Alone Clock Tree Synthesis Capabilities . . . . .         | 7-70 |
| Performing Clock Tree Power Optimization . . . . .              | 7-70 |
| Performing Clock Tree Synthesis . . . . .                       | 7-70 |
| High-Fanout Net Synthesis . . . . .                             | 7-72 |
| Performing Clock Tree Optimization . . . . .                    | 7-73 |
| Implementing Clock Meshes . . . . .                             | 7-77 |
| Prerequisites for Creating Clock Meshes . . . . .               | 7-78 |
| The Clock Mesh Flow . . . . .                                   | 7-79 |
| Flattening the Logic of Integrated Clock-Gating Cells . . . . . | 7-80 |
| Splitting Clock Nets . . . . .                                  | 7-81 |
| Creating Clock Meshes . . . . .                                 | 7-81 |
| Adding Clock Mesh Drivers . . . . .                             | 7-83 |
| Routing Mesh Nets . . . . .                                     | 7-85 |
| Performing Quick Mesh Analysis . . . . .                        | 7-85 |
| Prerequisites for Clock Mesh Analysis . . . . .                 | 7-85 |
| Quick Mesh Analysis . . . . .                                   | 7-86 |
| Compiling Premesh Trees . . . . .                               | 7-86 |
| Creating H-, T-, or I-Shape Routes for Premesh Trees . . . . .  | 7-88 |
| Routing Clock Nets . . . . .                                    | 7-89 |
| Analyzing Clock Mesh Circuits . . . . .                         | 7-89 |
| Optimizing Meshes with Macros . . . . .                         | 7-91 |
| Implementing Hierarchical Clock Meshes . . . . .                | 7-92 |
| Prerequisites for the Hierarchical Clock Mesh Flow . . . . .    | 7-92 |
| Procedures to Create Hierarchical Clock Mesh . . . . .          | 7-92 |
| Removing Clock Meshes . . . . .                                 | 7-94 |

|                                                                |       |
|----------------------------------------------------------------|-------|
| Performing Multicorner Clock Tree Optimization.....            | 7-95  |
| Specifying Corners for Optimization .....                      | 7-95  |
| Specifying Corners Using Multicorner-Multimode Scenarios ..... | 7-96  |
| Specifying Constraints for Multicorner Optimization .....      | 7-97  |
| Setting Float Pin Constraints .....                            | 7-97  |
| Setting Skew Target Goals .....                                | 7-98  |
| Generating Multicorner Optimization Report.....                | 7-98  |
| Performing Clock Routing After Multicorner Optimization .....  | 7-99  |
| A Sample Script.....                                           | 7-99  |
| Using Batch Mode to Reduce Runtime.....                        | 7-101 |
| Analyzing the Clock Tree Results .....                         | 7-102 |
| Generating Clock Tree Reports .....                            | 7-103 |
| Analyzing Clock Timing .....                                   | 7-105 |
| Analyzing Clock Trees in the GUI .....                         | 7-105 |
| Viewing Clock Trees in the Layout Window .....                 | 7-106 |
| Using the Interactive Clock Tree Synthesis Window.....         | 7-108 |
| Using the Clock Tree Option Viewer.....                        | 7-109 |
| Viewing the Clock Tree Hierarchy.....                          | 7-109 |
| Viewing the Clock Tree Arrival Time Histogram .....            | 7-110 |
| Viewing Clock Latency and Skew in the Clock Graph View .....   | 7-111 |
| Viewing the Fanout or Fanin Schematic .....                    | 7-112 |
| Fine-Tuning the Clock Tree Synthesis Results .....             | 7-112 |
| Using the Useful Skew Technique .....                          | 7-113 |
| skew_opt Details.....                                          | 7-113 |
| skew_opt Flow .....                                            | 7-114 |
| Balancing the Skew Using Skew Groups.....                      | 7-116 |
| Guidelines for Defining Skew Groups.....                       | 7-116 |
| Validating and Committing Skew Groups .....                    | 7-118 |
| Limitations of Using Skew Groups .....                         | 7-119 |
| Resynthesizing the Clock Trees.....                            | 7-119 |
| Validating the Setup .....                                     | 7-119 |
| Resynthesizing the Clock Trees .....                           | 7-120 |
| Modifying the Nondefault Routing Rule .....                    | 7-120 |
| Modifying Clock Trees in the GUI.....                          | 7-121 |
| Inserting a Buffer .....                                       | 7-122 |
| Removing a Buffer .....                                        | 7-122 |
| Moving a Buffer or Gate .....                                  | 7-123 |
| Reparenting a Subtree .....                                    | 7-123 |

|                                                      |       |
|------------------------------------------------------|-------|
| Sizing a Buffer or Gate .....                        | 7-123 |
| Analyzing and Refining the Design.....               | 7-124 |
| <b>8. Routing</b>                                    |       |
| Prerequisites for Routing .....                      | 8-2   |
| Checking Routability .....                           | 8-2   |
| Setting Up for Routing. ....                         | 8-3   |
| Specifying Route Guides .....                        | 8-3   |
| Defining Routing Blockages.....                      | 8-5   |
| Setting the Preferred Routing Direction.....         | 8-6   |
| Using Nondefault Routing Rules .....                 | 8-7   |
| Defining Nondefault Routing Rules.....               | 8-7   |
| Applying Nondefault Routing Rules .....              | 8-8   |
| Reporting Nondefault Routing Rules .....             | 8-9   |
| Specifying the Routing Layers.....                   | 8-9   |
| Specifying the Ignored Layers .....                  | 8-10  |
| Specifying Routing Layers for Specific Nets.....     | 8-11  |
| Setting Net Aggressors .....                         | 8-11  |
| Setting Routing Types .....                          | 8-12  |
| Setting Routing Options.....                         | 8-12  |
| Setting Signal Integrity Options .....               | 8-16  |
| Enabling Distributed Routing.....                    | 8-16  |
| Setting Up the Distributed Routing Network.....      | 8-18  |
| Reporting Distributed Route Jobs.....                | 8-20  |
| Cancelling Distributed Route Jobs .....              | 8-20  |
| Routing Critical Nets.....                           | 8-20  |
| Shielding Clock Nets .....                           | 8-22  |
| Routing Signal Nets .....                            | 8-22  |
| Routing Signal Nets by Using route_opt .....         | 8-23  |
| Setting the Routing and Optimization Strategy.....   | 8-23  |
| Running route_opt .....                              | 8-24  |
| Performing Focal Optimization .....                  | 8-29  |
| Routing Signal Nets by Using Automatic Routing ..... | 8-31  |
| Running Individual Routing Steps .....               | 8-32  |
| Global Routing .....                                 | 8-32  |
| Track Assignment .....                               | 8-35  |

|                                                           |      |
|-----------------------------------------------------------|------|
| Detail Routing . . . . .                                  | 8-35 |
| Search and Repair . . . . .                               | 8-36 |
| Wire and Via Optimization . . . . .                       | 8-36 |
| Shielding Nets. . . . .                                   | 8-36 |
| Performing ECO Routing . . . . .                          | 8-37 |
| Reporting Cell Placement and Routing Statistics . . . . . | 8-39 |
| Verifying the Routed Design . . . . .                     | 8-39 |
| Using the signoff_drc Command . . . . .                   | 8-40 |
| Setting Up the Validation Tool Environment . . . . .      | 8-40 |
| Setting Up The Physical Signoff Options . . . . .         | 8-41 |
| Running the signoff_drc Command . . . . .                 | 8-43 |
| Using the verify_drc Command . . . . .                    | 8-45 |
| Using the verify_route Command . . . . .                  | 8-48 |
| Using the Calibre Interface . . . . .                     | 8-49 |
| Analyzing DRC Violations . . . . .                        | 8-49 |
| Routing Nets and Buses in the GUI . . . . .               | 8-50 |
| Routing Single Nets. . . . .                              | 8-50 |
| Creating Physical Buses . . . . .                         | 8-51 |
| Manual Bus Creation . . . . .                             | 8-51 |
| Automatic Bus Creation . . . . .                          | 8-52 |
| Modifying Buses . . . . .                                 | 8-53 |
| Removing Dangling Wires . . . . .                         | 8-55 |
| Routing Buses or Multiple Nets . . . . .                  | 8-56 |
| Creating Custom Wires . . . . .                           | 8-57 |
| Postroute RC Extraction . . . . .                         | 8-59 |
| <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-4  |
| Removing Tap Cells. . . . .                               | 9-6  |
| Preventing Antenna Problems . . . . .                     | 9-6  |
| Setting the Antenna Mode . . . . .                        | 9-8  |
| Defining Antenna Rules . . . . .                          | 9-11 |

|                                                              |      |
|--------------------------------------------------------------|------|
| The Basic Antenna Rules .....                                | 9-12 |
| The Advanced Antenna Rules .....                             | 9-13 |
| Reporting Antenna Rules .....                                | 9-19 |
| Removing Antenna Rules .....                                 | 9-19 |
| Checking Antenna Rules .....                                 | 9-19 |
| Fixing Antenna Violations .....                              | 9-19 |
| Running Search and Repair .....                              | 9-20 |
| Inserting Diodes .....                                       | 9-20 |
| Connecting Spare Diodes .....                                | 9-22 |
| Setting Detail Route Options to Control Antenna Fixing ..... | 9-24 |
| Reducing Critical Areas .....                                | 9-26 |
| Analyzing Critical Areas .....                               | 9-26 |
| Reporting Critical Areas .....                               | 9-27 |
| Displaying Critical Area Maps .....                          | 9-28 |
| Performing Wire Spreading .....                              | 9-29 |
| Inserting Redundant Vias .....                               | 9-30 |
| Inserting Filler Cells .....                                 | 9-31 |
| Inserting Standard Cell Fillers .....                        | 9-31 |
| Defining the Filler Rules .....                              | 9-31 |
| Inserting the Filler Cells .....                             | 9-32 |
| Removing Filler Cells .....                                  | 9-34 |
| Reporting Filler Cells .....                                 | 9-34 |
| Inserting End Caps .....                                     | 9-34 |
| Inserting Well Fillers .....                                 | 9-35 |
| Inserting Pad Fillers .....                                  | 9-37 |
| Performing Metal Density Filling .....                       | 9-38 |
| IC Compiler Metal Fill .....                                 | 9-39 |
| Sign-Off Metal Fill .....                                    | 9-41 |
| Performing Notch and Gap Filling .....                       | 9-44 |
| Analyzing CMP Thickness Variation Effects .....              | 9-45 |
| Loading the Thickness Data .....                             | 9-45 |
| Displaying Chemical-Mechanical Polishing Maps .....          | 9-46 |
| Lithography Compliance Checking .....                        | 9-48 |
| Detecting LCC Hotspots .....                                 | 9-48 |
| Fixing LCC Hotspots .....                                    | 9-49 |

**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-12 |
| Preventing Crosstalk During Sign-Off Optimization . . . . . | 10-14 |
| Sample Scripts . . . . .                                    | 10-14 |
| Analyzing and Reducing Signal Electromigration . . . . .    | 10-15 |
| Loading Signal Electromigration Constraints . . . . .       | 10-17 |
| Verifying the Electromigration Constraints . . . . .        | 10-18 |
| Verifying the Current Unit . . . . .                        | 10-18 |
| Validating the Design . . . . .                             | 10-18 |
| Loading the Net Switching Information . . . . .             | 10-18 |
| Reading a SAIF File . . . . .                               | 10-19 |
| Annotating the Switching Activity . . . . .                 | 10-19 |
| Updating the Timing . . . . .                               | 10-20 |
| Performing Signal Electromigration Analysis . . . . .       | 10-20 |
| Repairing Electromigration Violations . . . . .             | 10-22 |

**11. Using Interface Logic Models**

|                                                           |       |
|-----------------------------------------------------------|-------|
| Overview of Interface Logic Models . . . . .              | 11-2  |
| Benefits of Using ILMs . . . . .                          | 11-5  |
| Creating ILMs . . . . .                                   | 11-6  |
| Controlling the Logic Included in an ILM . . . . .        | 11-8  |
| Changing the Compaction Level . . . . .                   | 11-9  |
| Retaining Additional Logic . . . . .                      | 11-9  |
| Additional Controls for Noncompact ILMs . . . . .         | 11-14 |
| Storing Parasitic Information in the ILM . . . . .        | 11-15 |
| Storing Signal Integrity Information in the ILM . . . . . | 11-15 |

|                                                                  |       |
|------------------------------------------------------------------|-------|
| Storing Physical Information for ILMs .....                      | 11-16 |
| Creating ILMs for Rotated and Mirrored Instances .....           | 11-17 |
| Creating ILMs for Blocks With Nested ILMs .....                  | 11-17 |
| Creating ILMs for Multiple Blocks .....                          | 11-19 |
| Summary of the ILM Creation Command Options .....                | 11-19 |
| Validating ILMs .....                                            | 11-21 |
| Reporting Information About ILMs .....                           | 11-24 |
| Reporting Design Information .....                               | 11-25 |
| Reporting Area Information .....                                 | 11-25 |
| Reporting ILMs .....                                             | 11-27 |
| Using ILMs in the Top-Level Design .....                         | 11-28 |
| Linking ILMs to the Top-Level Design .....                       | 11-29 |
| Applying Top-Level Constraints .....                             | 11-29 |
| Using the propagate_constraints Command .....                    | 11-30 |
| Handling Rotated and Mirrored ILMs in the Top-Level Design ..... | 11-30 |
| Running the place_opt Command on the Top-Level Design .....      | 11-34 |
| Running the clock_opt Command on the Top-Level Design .....      | 11-35 |
| Running the route_opt Command on the Top-Level Design .....      | 11-36 |
| Performing On-Route Optimization on the Top-Level Design .....   | 11-37 |
| Saving the Floorplan for a Design That Contains ILMs .....       | 11-37 |
| Viewing ILMs in the IC Compiler GUI .....                        | 11-38 |
| Hierarchical Signal Integrity Flow With ILMs .....               | 11-38 |
| Multicorner-Multimode Scenarios and ILMs .....                   | 11-39 |
| Creating ILMs for Multicorner-Multimode Usage .....              | 11-40 |
| Using ILMs in Multicorner-Multimode Scenarios .....              | 11-41 |

## 12. Physical Datapath With Relative Placement

|                                                                 |      |
|-----------------------------------------------------------------|------|
| Introduction to Physical Datapath With Relative Placement ..... | 12-3 |
| Benefits of Relative Placement .....                            | 12-4 |
| Flow for Relative Placement .....                               | 12-5 |
| Methodology for the Relative Placement Flow .....               | 12-6 |
| Sample Script for a Relative Placement Flow .....               | 12-7 |
| Considerations for Using Relative Placement .....               | 12-8 |

|                                                                             |       |
|-----------------------------------------------------------------------------|-------|
| Creating Relative Placement Groups . . . . .                                | 12-9  |
| Anchoring Relative Placement Groups . . . . .                               | 12-11 |
| Applying Compression to Relative Placement Groups . . . . .                 | 12-13 |
| Supporting Compression with Mixed Alignment. . . . .                        | 12-14 |
| Adding Objects to a Group . . . . .                                         | 12-14 |
| Adding Leaf Cells. . . . .                                                  | 12-14 |
| Specifying Orientation for Leaf Cells . . . . .                             | 12-16 |
| Aligning Leaf Cells Within a Column. . . . .                                | 12-16 |
| Automatic Orientation of Relative Placement Groups Based on Data Flow . . . | 12-20 |
| Adding Relative Placement Groups. . . . .                                   | 12-22 |
| Benefits of Hierarchical Relative Placement Groups . . . . .                | 12-22 |
| Including Relative Placement Groups. . . . .                                | 12-23 |
| Instantiating Relative Placement Groups . . . . .                           | 12-25 |
| Using Hierarchical Relative Placement for Straddling . . . . .              | 12-26 |
| Using Hierarchical Relative Placement for Compression . . . . .             | 12-28 |
| Effect of Ungrouping on Hierarchical Relative Placement . . . . .           | 12-30 |
| Effect of Uniquifying on Hierarchical Relative Placement. . . . .           | 12-32 |
| Adding Keepouts . . . . .                                                   | 12-33 |
| Movement Control When Legalizing Relative Placement Groups . . . . .        | 12-35 |
| Placement of Relative Placement Groups . . . . .                            | 12-35 |
| Preserving Relative Placement Cells During Optimization . . . . .           | 12-36 |
| Performing Relative Placement in a Design Containing Obstructions . . . . . | 12-36 |
| Performing Relative Placement in a Design Containing Tap Cells. . . . .     | 12-37 |
| Using Move Bounds to Constrain Relative Placement . . . . .                 | 12-39 |
| Adding Incremental Relative Placement Groups. . . . .                       | 12-39 |
| Supporting Relative Placement Groups in Virtual Flat Placement . . . . .    | 12-40 |
| Postplacement Optimization of Relative Placement Groups. . . . .            | 12-41 |
| Preserving Relative Placement Structures . . . . .                          | 12-41 |
| Buffering and Sizing Strategy for Relative Placement Groups. . . . .        | 12-42 |
| Analyzing the Relative Placement Results . . . . .                          | 12-42 |
| Checking Relative Placement Constraints. . . . .                            | 12-43 |
| Locating a Relative Placement Group . . . . .                               | 12-44 |
| Working With Relative Placement Groups in the GUI. . . . .                  | 12-45 |
| Using the Relative Placement Hierarchy Browser . . . . .                    | 12-45 |
| Viewing Relative Placement Groups . . . . .                                 | 12-46 |
| Viewing Relative Placement Group Net Connections . . . . .                  | 12-47 |

|                                                                  |       |
|------------------------------------------------------------------|-------|
| Viewing Net Connectivity . . . . .                               | 12-48 |
| Moving Relative Placement Groups . . . . .                       | 12-49 |
| Editing and Creating Relative Placement Groups . . . . .         | 12-49 |
| Querying Relative Placement Groups . . . . .                     | 12-51 |
| Saving Relative Placement Information . . . . .                  | 12-53 |
| Ignoring Relative Placement Constraints . . . . .                | 12-54 |
| Removing Relative Placement Groups . . . . .                     | 12-54 |
| Changing Relative Placement Information . . . . .                | 12-55 |
| Reporting the Attributes of a Relative Placement Group . . . . . | 12-56 |
| Changing the Attributes of a Relative Placement Group . . . . .  | 12-56 |
| Setting Relative Placement Group Attributes . . . . .            | 12-56 |
| Removing Relative Placement Group Attributes . . . . .           | 12-58 |
| Renaming a Group . . . . .                                       | 12-59 |
| Removing Objects From a Group . . . . .                          | 12-59 |
| Changing Specific Objects Within a Group . . . . .               | 12-60 |
| Changing the Attributes of Cells Within a Group . . . . .        | 12-60 |
| Deriving Relative Placement Groups . . . . .                     | 12-61 |
| Extracting a Relative Placement Group . . . . .                  | 12-61 |
| Ordering Extracted Relative Placement Groups . . . . .           | 12-62 |
| Summary of Relative Placement Commands . . . . .                 | 12-63 |
| Limitations of Relative Placement . . . . .                      | 12-64 |

## 13. Multivoltage Design Flow

|                                                               |      |
|---------------------------------------------------------------|------|
| Multivoltage Designs . . . . .                                | 13-2 |
| Power Domains . . . . .                                       | 13-2 |
| Defining Power Domains . . . . .                              | 13-3 |
| Voltage Areas . . . . .                                       | 13-4 |
| Associating Power Domains and Voltage Areas . . . . .         | 13-4 |
| Level-Shifter and Isolation Cells . . . . .                   | 13-4 |
| Basic Library Requirements for Multivoltage Designs . . . . . | 13-5 |
| Physical Synthesis . . . . .                                  | 13-6 |
| High-Level Design Flow for Multivoltage Designs . . . . .     | 13-6 |
| Target Library Subsetting . . . . .                           | 13-7 |

|                                                                              |       |
|------------------------------------------------------------------------------|-------|
| UPF Flow for Multivoltage Designs . . . . .                                  | 13-8  |
| Defining Power Domains and Supply Networks . . . . .                         | 13-11 |
| Power Domains . . . . .                                                      | 13-11 |
| Hierarchy and Scope . . . . .                                                | 13-12 |
| Creating Power Domains . . . . .                                             | 13-13 |
| Power and Ground Supply Network . . . . .                                    | 13-14 |
| Creating Supply Ports . . . . .                                              | 13-14 |
| Creating Supply Nets . . . . .                                               | 13-16 |
| Connecting Supply Nets . . . . .                                             | 13-16 |
| Specifying the Primary Supply Net for a Power Domain . . . . .               | 13-17 |
| Creating a Power Switch . . . . .                                            | 13-17 |
| Adding Port State Information to Supply Ports . . . . .                      | 13-18 |
| Creating a Power State Table . . . . .                                       | 13-18 |
| Defining the States of the Supply Nets . . . . .                             | 13-19 |
| Connecting Power and Ground Nets . . . . .                                   | 13-19 |
| Defining and Using Voltage Areas . . . . .                                   | 13-20 |
| Creating Voltage Areas . . . . .                                             | 13-23 |
| Updating Voltage Areas in a Design . . . . .                                 | 13-24 |
| Including Guard Bands With Voltage Areas . . . . .                           | 13-25 |
| Handling Nested Voltage Areas . . . . .                                      | 13-27 |
| Voltage Area Support for Macros . . . . .                                    | 13-28 |
| Defining Always-On Power Wells Within Voltage Areas . . . . .                | 13-28 |
| Removing Voltage Areas From the Design . . . . .                             | 13-29 |
| Reporting on the Voltage Areas of a Design . . . . .                         | 13-29 |
| Handling Level Shifters and Isolation Cells . . . . .                        | 13-29 |
| Level-Shifter and Isolation Cell Requirements . . . . .                      | 13-30 |
| Level-Shifter Commands . . . . .                                             | 13-30 |
| Level-Shifter Threshold (Automatic and User-Specified) . . . . .             | 13-31 |
| Inserting Buffer-Type Level Shifters . . . . .                               | 13-33 |
| Associating Specific Library Cells With the Level-Shifter Strategy . . . . . | 13-35 |
| Inserting Isolation Cells and Enable-Type Level Shifters . . . . .           | 13-36 |
| Associating Specific Library Cells With the Isolation Strategy . . . . .     | 13-36 |
| Placing Level Shifters . . . . .                                             | 13-37 |
| Handling Always-On Logic . . . . .                                           | 13-37 |
| Marking Always-On Library Cells . . . . .                                    | 13-38 |
| Marking Always-On Pins . . . . .                                             | 13-39 |

|                                                                                             |       |
|---------------------------------------------------------------------------------------------|-------|
| Marking Pass-Gate Library Pins . . . . .                                                    | 13-39 |
| Sample IC Compiler Script for UPF Flow . . . . .                                            | 13-39 |
| Voltage-Area-Aware Capabilities . . . . .                                                   | 13-42 |
| Automatic High-Fanout Synthesis . . . . .                                                   | 13-42 |
| Virtual Hierarchy Routing . . . . .                                                         | 13-42 |
| Maximum Net Length Optimization . . . . .                                                   | 13-43 |
| Voltage-Area-Based Optimization . . . . .                                                   | 13-43 |
| Voltage-Area-Based Clock Tree Synthesis and Optimization . . . . .                          | 13-43 |
| Voltage-Area-Based Global Routing . . . . .                                                 | 13-44 |
| Voltage-Area-Based Power and Ground Net Associations . . . . .                              | 13-44 |
| Voltage-Area-Based Standard-Cell Filler Cell Insertion . . . . .                            | 13-44 |
| Interface Logic Model Hierarchical Flow . . . . .                                           | 13-44 |
| Multivoltage Relative Placement Capability . . . . .                                        | 13-45 |
| Hierarchical Signal Integrity Flow . . . . .                                                | 13-46 |
| Multicorner-Multimode Designs . . . . .                                                     | 13-46 |
| Placing and Optimizing the Design . . . . .                                                 | 13-46 |
| Handling Isolation Cells and Always-On Clock Paths<br>During Clock Tree Synthesis . . . . . | 13-47 |
| Checks and Reporting Commands for Multivoltage Designs . . . . .                            | 13-48 |
| Multivoltage Specific Checks . . . . .                                                      | 13-48 |
| Multivoltage Specific Reports . . . . .                                                     | 13-49 |
| Hierarchical UPF Flow . . . . .                                                             | 13-50 |
| Design Compiler to IC Compiler Interface . . . . .                                          | 13-51 |
| Guidelines For Hierarchical UPF Flow . . . . .                                              | 13-52 |
| Methodology Guidelines . . . . .                                                            | 13-52 |
| Interface Guidelines . . . . .                                                              | 13-52 |
| Implementation Guidelines . . . . .                                                         | 13-52 |
| Full-Chip Design Planning . . . . .                                                         | 13-53 |
| Block-Level Place and Route . . . . .                                                       | 13-56 |
| Top-Level Place and Route . . . . .                                                         | 13-57 |
| Non-UPF Flow For Multivoltage Designs . . . . .                                             | 13-57 |
| Using Power Domains . . . . .                                                               | 13-57 |
| Power Domain Commands . . . . .                                                             | 13-57 |
| Connecting Power and Ground Nets . . . . .                                                  | 13-58 |
| Sample IC Compiler Script For Non-UPF Flow . . . . .                                        | 13-58 |

## 14. Using Multicorner-Multimode Technology

|                                                                                        |       |
|----------------------------------------------------------------------------------------|-------|
| Basic Multicorner-Multimode Concepts . . . . .                                         | 14-2  |
| Scenario Definition. . . . .                                                           | 14-2  |
| Concurrent Multicorner-Multimode Optimization and Timing Analysis . . . . .            | 14-2  |
| Basic Multicorner-Multimode Flow . . . . .                                             | 14-3  |
| Setup Considerations . . . . .                                                         | 14-4  |
| Multicorner Library Considerations. . . . .                                            | 14-5  |
| Link Libraries With Equal Nominal PVT Values. . . . .                                  | 14-5  |
| Link Library Example . . . . .                                                         | 14-6  |
| Distinct PVT Requirements . . . . .                                                    | 14-7  |
| Unsupported k-factors . . . . .                                                        | 14-8  |
| Automatic Detection of Driving Cell Library . . . . .                                  | 14-8  |
| Automatic Inference of Operating Conditions<br>for Macro Cells and Pad Cells . . . . . | 14-9  |
| Relating the Minimum Library to the Maximum Library . . . . .                          | 14-11 |
| Unique Identification of Libraries Based on File Names . . . . .                       | 14-12 |
| Using Multicorner-Multimode Commands. . . . .                                          | 14-12 |
| Scenario Management. . . . .                                                           | 14-13 |
| Multicorner-Multimode Optimization . . . . .                                           | 14-17 |
| Scaling Resistance and Capacitance . . . . .                                           | 14-17 |
| Filtering Coupling Capacitances. . . . .                                               | 14-18 |
| Using Scenario Reduction. . . . .                                                      | 14-18 |
| Using the get_dominant_scenarios Command. . . . .                                      | 14-19 |
| Automatic Scenario Reduction During Core Command Execution. . . . .                    | 14-20 |
| Preroute Hold Fixing . . . . .                                                         | 14-21 |
| Using the Clock Tree Synthesis Scenario . . . . .                                      | 14-21 |
| Using Interface Logic Models With Multicorner-Multimode Scenarios. . . . .             | 14-22 |
| Reporting Commands for Multicorner-Multimode . . . . .                                 | 14-23 |
| report_scenario_options. . . . .                                                       | 14-23 |
| report_scenarios . . . . .                                                             | 14-24 |
| Reporting Commands That Support the -scenario Option . . . . .                         | 14-24 |
| Commands That Report the Current Scenario. . . . .                                     | 14-25 |
| Reporting Examples . . . . .                                                           | 14-26 |
| Multicorner-Multimode Script Example. . . . .                                          | 14-31 |

## 15. ECO Flow

|                                                                   |       |
|-------------------------------------------------------------------|-------|
| ECO Flow Overview .....                                           | 15-2  |
| ECO Recommended Flows .....                                       | 15-3  |
| ECO Flows and Hierarchical Designs.....                           | 15-4  |
| ECO Flows and Multivoltage/UPF Designs .....                      | 15-4  |
| ECO Limitations .....                                             | 15-5  |
| Removing Tie Cells.....                                           | 15-5  |
| Unconstrained ECO Flow.....                                       | 15-6  |
| Creating ECO Changes and Updating the Design .....                | 15-6  |
| Updating With a Verilog Netlist .....                             | 15-7  |
| Updating With Tcl Commands .....                                  | 15-8  |
| Updating Placement .....                                          | 15-10 |
| Updating Routing .....                                            | 15-10 |
| Freeze Silicon ECO Flow .....                                     | 15-11 |
| Inserting Spare Cells .....                                       | 15-11 |
| Inserting Spare Cells Using a Verilog Netlist .....               | 15-12 |
| Inserting Spare Cells Using <code>insert_spare_cells</code> ..... | 15-16 |
| Creating ECO Changes and Updating the Design .....                | 15-16 |
| Finalizing the Freeze Silicon Flow .....                          | 15-17 |
| Updating Routing .....                                            | 15-17 |

## 16. Sign-Off Driven Design Closure

|                                                                         |       |
|-------------------------------------------------------------------------|-------|
| Sign-Off Driven Design Closure Overview .....                           | 16-3  |
| Key Features .....                                                      | 16-3  |
| Sign-Off Driven Design Closure Methodology .....                        | 16-5  |
| Automatic IC Compiler Sign-Off Driven Design Closure .....              | 16-5  |
| Manual IC Compiler Sign-Off Driven Design Closure .....                 | 16-7  |
| Usage Guidelines .....                                                  | 16-10 |
| PrimeTime and Star-RCXT Version Requirements .....                      | 16-10 |
| Entry Requirements for IC Compiler Sign-Off Driven Design Closure ..... | 16-11 |
| General Guidelines .....                                                | 16-11 |
| Scenario Differences Between IC Compiler and PrimeTime .....            | 16-14 |
| Multicorner-Multimode Guidelines .....                                  | 16-15 |

|                                                   |       |
|---------------------------------------------------|-------|
| PrimeTime and Star-RCXT Customizing Options ..... | 16-18 |
| PrimeTime and Star-RCXT Correlations .....        | 16-22 |
| Rail Voltage Information Update .....             | 16-24 |
| Troubleshooting and Problem Solving .....         | 16-24 |

## Appendix A. Using GUI Tools

|                                             |      |
|---------------------------------------------|------|
| Viewing a Design .....                      | A-2  |
| Selecting a Mouse Tool .....                | A-3  |
| Previewing Objects in a Layout View .....   | A-6  |
| Selecting Objects .....                     | A-7  |
| Highlighting Objects .....                  | A-8  |
| Viewing Object Information .....            | A-11 |
| Magnifying and Traversing the Design .....  | A-13 |
| Following Selected Objects .....            | A-15 |
| Reusing Zoom and Pan Settings .....         | A-15 |
| Redrawing the Active View .....             | A-16 |
| Viewing and Editing Object Properties ..... | A-17 |
| Exploring the Design Hierarchy .....        | A-18 |
| Selecting and Viewing Timing Paths .....    | A-19 |
| Viewing Reports .....                       | A-20 |
| Searching for Objects by Name .....         | A-21 |
| Saving an Image of a Window or View .....   | A-23 |
| Visualizing the Physical Design .....       | A-24 |
| Navigating Through Layout Views .....       | A-25 |
| Displaying Grid Lines .....                 | A-26 |
| Drawing Rulers .....                        | A-26 |
| Adjusting the Color Brightness .....        | A-28 |
| Displaying Cell Orientations .....          | A-28 |
| Examining ILM Blocks .....                  | A-29 |
| Viewing Design Overlays .....               | A-30 |
| Setting and Saving View Properties .....    | A-31 |
| Using Stroke Activated Commands .....       | A-35 |
| Analyzing the Physical Design .....         | A-37 |
| Using Visual Analysis Modes .....           | A-37 |
| Displaying Flylines .....                   | A-38 |
| Displaying Net Connectivity .....           | A-39 |

|                                                                   |      |
|-------------------------------------------------------------------|------|
| Using Visual Modes . . . . .                                      | A-40 |
| Using Map Modes . . . . .                                         | A-42 |
| Analyzing Clock Trees . . . . .                                   | A-44 |
| Opening an Interactive Clock Tree Synthesis Window . . . . .      | A-44 |
| Exploring Clock Tree Structures . . . . .                         | A-46 |
| Highlighting the Critical Paths . . . . .                         | A-48 |
| Examining Clock Tree Timing . . . . .                             | A-48 |
| Exploring Relative Placement Groups . . . . .                     | A-49 |
| Analyzing Signal Integrity . . . . .                              | A-49 |
| Examining Routing and Verification Errors . . . . .               | A-50 |
| Filtering Errors in the Error List . . . . .                      | A-54 |
| Selecting Errors in the Layout View . . . . .                     | A-54 |
| Examining Nets Associated With Detail Routing Errors . . . . .    | A-55 |
| Examining Net Nodes Associated With Open Locator Errors . . . . . | A-56 |
| Examining Errors in an Area . . . . .                             | A-56 |
| Saving the Error List Information in a File . . . . .             | A-57 |
| Editing the Physical Layout . . . . .                             | A-57 |
| Working in the Editing Environment . . . . .                      | A-59 |
| Fixing and Unfixing Objects for Edits . . . . .                   | A-60 |
| Changing the Way Objects Snap to a Grid . . . . .                 | A-61 |
| Editing Groups of Objects . . . . .                               | A-62 |
| Reversing and Reapplying Edit Changes . . . . .                   | A-63 |
| Editing Objects Interactively . . . . .                           | A-64 |
| Selecting Objects by Name . . . . .                               | A-66 |
| Selecting Only the Highlighted Objects . . . . .                  | A-67 |
| Moving, Resizing, Modifying, and Removing Objects . . . . .       | A-67 |
| Routing Nets and Physical Busses . . . . .                        | A-69 |
| Aligning and Distributing Objects . . . . .                       | A-70 |
| Creating Floorplan Objects . . . . .                              | A-71 |
| Analyzing Timing Paths . . . . .                                  | A-71 |
| Opening a Timing Analysis Window . . . . .                        | A-72 |
| Viewing Timing Path Details . . . . .                             | A-72 |
| Using Timing Analysis Views . . . . .                             | A-74 |
| Viewing Histograms . . . . .                                      | A-74 |
| Examining Path Profiles . . . . .                                 | A-76 |
| Viewing Design and Path Schematics . . . . .                      | A-76 |
| Inspecting a Timing Path . . . . .                                | A-78 |

## **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 Documentation on the Web, which is available through SolvNet at the following address:

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

You might also want to refer to 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 command syntax.                                                                                                                                                                                                                  |
| <i>Courier italic</i> | Indicates a user-defined value in Synopsys syntax, such as <i>object_name</i> . (A user-defined value that is not Synopsys syntax, such as a user-defined value in a Verilog or VHDL statement, is indicated by regular text font italic.) |
| <b>Courier bold</b>   | Indicates user input—text you type verbatim—in Synopsys syntax and examples. (User input that is not Synopsys syntax, such as a user name or password you enter in a GUI, is indicated by regular text font bold.)                         |
| [ ]                   | Denotes optional parameters, such as<br><i>pin1 [pin2 ... pinN]</i>                                                                                                                                                                        |
|                       | Indicates a choice among alternatives, such as<br>low   medium   high<br>(This example indicates that you can enter one of three possible values for an option: low, medium, or high.)                                                     |
| -                     | Connects terms that are read as a single term by the system, such as<br><i>set_annotated_delay</i>                                                                                                                                         |
| Control-c             | Indicates a keyboard combination, such as holding down the Control 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 an electronic 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 on the Web, and “Enter a Call to the Support Center.”

To access SolvNet, go to the SolvNet Web page at 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 or in the footer.

---

### 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 call to your local support center from the Web by going to <https://solvnet.synopsys.com> (Synopsys user name and password required), and then clicking “Enter a Call to the Support Center.”
- Send an e-mail message to your local support center.
  - E-mail [support\\_center@synopsys.com](mailto: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 the continental United States.
  - Call (650) 584-4200 from Canada.
  - 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 Operating Systems and Keywords*

| Platform    | Operating system                             | Platform keyword                             |
|-------------|----------------------------------------------|----------------------------------------------|
| AMD Opteron | Red Hat Enterprise Linux v4, v5 <sup>1</sup> | amd64                                        |
| EM64T       | SUSE Enterprise Linux 9, 10 <sup>1</sup>     | suse64 (64-bit mode)<br>suse32 (32-bit mode) |
| IA-32 (x86) | Red Hat Enterprise Linux v4, 5 <sup>1</sup>  | linux                                        |
| Sun SPARC   | Solaris 9, 10 <sup>1</sup>                   | sparc64                                      |
| X86_64      | Solaris 10                                   | x86sol64                                     |

1. *Binary-compatible hardware platform or operating system. Note, however, that binary compatibility is not guaranteed. See <http://www.synopsys.com/products/platforms/b-foundation.html> for latest information.*

---

## 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.

Note:

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

Low-power design capabilities, including multivoltage and multithreshold-CMOS (MTCMOS), are available only in the IC Compiler, IC Compiler-PC, and IC Compiler-DP packages.

The following advanced features are available only in the IC Compiler and IC Compiler-PC packages: relative placement, power-aware placement, low power clock tree synthesis, 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: sign-off driven closure with incremental PrimeTime and Star-RCXT, Zroute, advanced design rules 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-Hier     |                     |                        |                        | X                      |
| Galaxy-FP-MV       |                     |                        |                        | X                      |
| Galaxy-FP-AdvCTS   |                     |                        |                        | X                      |
| Galaxy-FP-AdvTech  |                     |                        |                        | X                      |
| Galaxy-PSYN        | X                   | X                      | X                      |                        |
| Galaxy-MultiRoute4 | X <sup>1</sup>      | X <sup>1</sup>         |                        |                        |
| Galaxy-MultiRoute8 | X <sup>2</sup>      | X <sup>2</sup>         |                        |                        |
| Galaxy-Power       | X                   | X                      |                        |                        |
| Galaxy-PNR         | X                   | X                      |                        |                        |
| Galaxy-AdvCTS      | X                   |                        | X                      |                        |
| Galaxy-AdvTech     | X                   |                        | X                      |                        |
| Galaxy-MV          | X                   |                        | X                      |                        |
| Galaxy-Prototype   | X                   |                        | X                      |                        |

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

| Licenses        | IC Compiler package | IC Compiler-XP package | IC Compiler-PC package | IC Compiler-DP package |
|-----------------|---------------------|------------------------|------------------------|------------------------|
| Galaxy-AdvRules | X                   |                        |                        |                        |
| Galaxy-DFT      | X                   |                        |                        |                        |
| Galaxy-DFY      | X                   |                        |                        |                        |
| Galaxy-IU       | X                   |                        |                        |                        |
| Galaxy-Zroute   | X                   |                        |                        |                        |
| Power Compiler  |                     |                        | X <sup>3</sup>         |                        |

1. This optional license is required to perform distributed routing with three or four CPUs.
2. This optional license is required to perform distributed routing with more than four CPUs.
3. 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-13 and “[Getting Help in IC Compiler](#)” on page 2-10).

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 4, “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, search and repair, 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.”](#)

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-38.](#)

The IC Compiler reference methodology (SolvNet article 021624) 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 `place_opt` 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](#)
- [Working With the GUI](#)
- [Reading and Saving Designs](#)
- [Archiving Designs](#)
- [Using IC Compiler Command-Line Interfaces](#)
- [Checking the Syntax and Semantics of Your Scripts](#)
- [Working With Licenses](#)

---

## 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](#)
  - [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 parameters 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`) in Unified Power Format (UPF) mode.

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

```
% icc_shell -gui
```

If you are not using UPF commands, you must indicate this by specifying the `-non_upf_mode` option.

```
% icc_shell -non_upf_mode
```

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] [-non_upf_mode]</code>            |
| IC Compiler-XP      | <code>icc_shell -xp_mode [-gui] [-non_upf_mode]</code>   |
| IC Compiler-PC      | <code>icc_shell -psyn_mode [-gui] [-non_upf_mode]</code> |
| IC Compiler-DP      | <code>icc_shell -dp_mode [-gui] [-non_upf_mode]</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 `-x` and `-f` 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-11.

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 provides 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 use the arrow keys and the Enter key to select the appropriate name.

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 IC Compiler Command-Line Interfaces](#)” on page 2-38.

---

## 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 Control) 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-14.

---

## 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 Control-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 Control-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 Control-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 `start_gui` or `start`.

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

`icc_shell> gui_start -f 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.

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. You can define scripts in your setup file or in separate script files.

To run a script defined in a setup file,

1. Define the script in your setup file.
2. Start the IC Compiler GUI.
3. Enter the script name on the `icc_shell` command line.

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

Note:

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

You can run all the scripts defined in your setup file or in another script file by selecting the file name in the Execute Script File dialog box.

To run scripts from a file,

1. Create the script file with a `.tcl` extension.
2. Choose File > Execute Scripts.

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

3. Navigate to the directory that contains the script file you want to run.
4. If you need to display file names that do not have a script file extension, select “All Files (\*)” in the “File type” list.
5. Select the file name.

## 6. Click Open.

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

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-42.

---

## 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 parameters 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 setup files 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 cannot edit these files.

If settings conflict between files with the same name, IC Compiler gives precedence to settings in your project directory over settings in your home directory and to settings in your home directory over settings in the installation directory. This order of precedence allows you to set generic settings in the home directory and specific 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-30.

For more information about using IC Compiler setup files, see IC Compiler online Help.

---

## Exiting IC Compiler

You can end the session and exit IC Compiler at any time. If you have modified a design and have not saved the changes, IC Compiler prompts you to save the design. You can save or discard the changes before you exit.

Note:

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-31.

To exit IC Compiler,

- Choose File > Exit.

If you do not have any unsaved design changes, an IC Compiler message box appears. Do one of the following:

- To exit, click OK.
- To continue the session, click Cancel.

If you have unsaved design changes, the Exit IC Compiler dialog box appears with a list of designs that have unsaved changes. Do one of the following:

- To save all design changes, click Save All.
- To discard all design changes, click Discard All.
- To save or discard changes for individual designs, select “Show advanced options” to display additional options in the list of designs, set options as needed, and click OK or Apply.

For details about setting advanced options, see “[Saving or Discarding Design Changes](#)” on page 2-34.

Alternatively, you can exit IC Compiler by entering the `exit` or `quit` command on the command line in the console or in `icc_shell`. IC Compiler displays the message box but does not prompt you to save design changes. You can also exit IC Compiler by pressing Control-c three times in the shell (IC Compiler exits immediately, without displaying the message box).

---

## 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 the 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 an online 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 description of an `icc_shell` command, variable, or variable group,

- Enter `help` followed by the command or variable name:

```
icc_shell> help command_or_variable
```

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-13](#).

---

## 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 menu task mode 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 menu task mode. For menu commands in the layout window, the task mode can be Block Implementation, Design Planning, or All. For menu commands in other windows, the task mode is always All. To learn more about menu task modes in the layout window, see “[Setting the Menu Task Mode](#)” on page 2-29.

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 menu task modes 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 IC Compiler online 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 type of online Help:

- Contextual Help pages that display information about the current interactive editing or visualization tool in GUI
- A Web browser-based online 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.

The IC Compiler online Help system is a browser-based HTML Help system, which 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 the IC Compiler Help system in your Web browser,

1. Choose Help > Online Help.

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

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 online 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
  - Is 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 the IC Compiler online Help system:

- Firefox version 1.5 or 2.0
- Mozilla 1.7

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

To set the browser for the current GUI session,

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

```
set_app_var 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 the Help system from within the IC Compiler GUI (choose Help > IC Compiler Online Help) or stand-alone in your Web browser. To open the online Help from within the GUI, the browser executable file must be specified in your UNIX or Linux path variable.

IC Compiler online Help makes extensive use of JavaScript and style sheets. If your browser encounters problems displaying online Help, 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 online Help might work on a stand-alone basis in Internet Explorer versions 6.0 and later, it is not tested in this browser.

---

## 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](#)

---

## 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

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 Top Level.

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 up 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 up 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 IC Compiler online 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 on past functions. You can even reenter commands you've 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-30.

## 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 Menu Task Mode

The layout window provides two overlapping sets of menu commands. By default, the menus are set to display commands for block implementation tools. You can change the menus to display commands for design planning or all commands.

To set the design task mode,

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

The design modes simplify the menus, allowing you to more quickly choose the menu commands you need.

## 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-71](#) and “[Analyzing Clock Trees](#)” on page [A-44](#).

---

## 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 IC Compiler online Help.

---

## Reading and Saving Designs

IC Compiler reads and saves designs in a Milkyway library. You can open a design simply by opening the Milkyway library and then opening the Milkyway design. When you make changes in a design, you can save the changes anytime during the session.

When the GUI is open, you can use the File toolbar, shown in [Figure 2-3](#), to open and save designs. By default, the File toolbar is located on the left end of the toolbar area in the main and layout windows.

*Figure 2-3 File Toolbar*



IC Compiler is built on the Synopsys Milkyway design database—it can directly access design data without time-consuming and error-prone translation steps.

You can also save (or discard) design changes when you close a design, close the Milkyway library, or exit IC Compiler.

For information about reading and saving designs, see the following sections:

- [Reading a Design](#)
- [Setting the Current Design](#)
- [Saving Designs](#)
- [Closing Designs](#)
- [Saving or Discarding Design Changes](#)

Before you can read a design, you must prepare the design and set up your libraries. In addition, you can use IC Compiler to import design information and save it in the Milkyway database or to export a design for use with tools that do not use Milkyway. For details, see [Chapter 3, “Preparing the Design.”](#)

---

## Reading a Design

IC Compiler reads design information by first opening the Milkyway design library and then opening the design. You can read a design in the GUI or in `icc_shell` (with the GUI open or closed).

When you open a design, IC Compiler

- Locks the Milkyway design 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. 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.

- 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.

To read a Milkyway design,

1. Click the  button on the File toolbar, or choose File > Open Design.

The Open Design dialog box appears.

2. If you have not already opened the Milkyway library, type the library name in the “Library name” box.

Alternatively, you can click the browse button, select the library name in the Select Library dialog box, and click OK.

The names of designs in the library appear in a list in the dialog box.

3. Select a design name in the list.
4. Click OK.

---

## Setting the Current 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. When multiple designs are open, you can reset the current design to a different design.

To change the current design,

- In the main window, select a design name in the list on the Cells List toolbar.

Alternatively, you can use the `current_mw_cel` command.

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.

---

## Saving Designs

If you make changes in the design, you can save it for use with IC Compiler or other tools based on the Milkyway database. When you save the design, IC Compiler automatically updates the Milkyway database.

To save designs,

1. Click the  button on the File toolbar, or choose File > Save Design.

The Save Design dialog box appears with a list of designs that have unsaved changes.

2. Do one of the following:

- To save all design changes, click Save All.

- To save or discard changes for individual designs, select “Show advanced options” to display additional options in the list of designs, set options as needed, and click OK or Apply.

For details about setting advanced options, see [“Saving or Discarding Design Changes” on page 2-34](#).

Alternatively, you can use the `save_mw_cel` command with the `-design` option and a list of design names.

```
icc_shell> save_mw_cel -design design_name
```

If you do not use `-design`, IC Compiler saves the current design (when you choose File > Save in the main window) or the primary design for the window (when you choose File > Save in a layout window).

---

## 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 save or discard all design changes and close the designs,

1. Choose File > Close Design.

If you have only one design open and have not made any unsaved changes, IC Compiler closes the design automatically. Otherwise, the Close Design dialog box appears with a list of designs that have unsaved changes.

2. If the Close Design dialog box appears, do one of the following:

- To save all design changes and close the designs, click Save All.
- To discard all design changes and close the designs, click Discard All.
- To save or discard changes and close individual designs, select “Show advanced options” to display additional options in the list of designs, set options as needed, and click OK or Apply.

For details about setting advanced options, see [“Saving or Discarding Design Changes” on page 2-34](#).

Alternatively, you can use the `close_mw_cel` command. However, this command automatically discards any unsaved changes in open designs.

If you need to open another Milkyway library, you must first close the one that is already opened. If you have unsaved changes in one or more designs, you can save or discard the changes before closing the library.

To save or discard all design changes and close the library,

1. Choose File > Close Library.

If you have only one design open and have not made any unsaved changes, IC Compiler closes the library automatically. Otherwise, the Close Library dialog box appears with a list of designs that have unsaved changes.

2. If the Close Library dialog box appears, do one of the following:

- To save all design changes and close the designs, click Save All.
- To discard all design changes and close the designs, click Discard All.
- To save or discard changes for individual designs, select “Show advanced options” to display additional options in the list of designs, set options as needed, and click OK or Apply.

For details about setting advanced options, see “[Saving Designs](#)” on page 2-32.

Alternatively, you can use the `close_mw_lib` command. However, this command automatically discards any unsaved changes in open designs.

---

## Saving or Discarding Design Changes

When you save designs, close designs, close the design library, or exit IC Compiler, you can set advanced options to save or discard the changes for individual designs. For each open design, you can

- 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
- Convert a design to the previous version of the Milkyway data model.
- Close a design after saving or discarding changes

You can also specify a list of scenarios with constraints that you need to save with the designs.

To save or discard changes for individual designs,

1. Do one of the following:

- To save designs, click the  button on the File toolbar, or choose File > Save Design.  
The Save Design dialog box appears.

- To close designs, choose File > Close Design.  
The Close Design dialog box appears.
- To close the design library, choose File > Close Library.  
The Close Library dialog box appears.
- To exit IC Compiler, choose File > Exit.  
The Exit IC Compiler dialog box appears.

2. Select “Show advanced options.”

The dialog box displays additional options and additional columns in the list of designs.

3. (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.

4. (Optional) To convert the design to the previous version of the Milkyway data model, select the "Convert to previous schema version" option.

**Caution:**

When you convert the design, make sure you select the Save As option to save it with a different name. If you have unsaved changes in a design, you must save the design before converting it to the previous data model.

5. (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.

6. 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 a new version of a 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 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 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 Save As option is selected.

- 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.

## 7. Click OK or Apply.

Alternatively, you can use the `save_mw_cel` command with the `-design` option and a list of design names.

```
icc_shell> save_mw_cel -design design_name
```

If you do not use `-design`, IC Compiler saves the current design. To save a copy of the design with a different name, include the `-as` option.

```
icc_shell> save_mw_cel -design design_name -as new_name
```

To save the top-level design together with its subdesigns and attached files in a single CEL version, include the `-hierarchy` option.

```
icc_shell> save_mw_cel -design design_name -hierarchy
```

---

## 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 copies the following files to the specified archive directory:

- The designs specified in the `-design` option

Use the following naming convention to specify the designs you want to archive:

`design_name.version_number`

If you do not specify a version, the `archive_design` command copies the latest version of the design.

The design files are copied to the `mw_lib` directory.

- The cells in the source Milkyway library that are referenced by the specified designs. These design files are also copied to the `mw_lib` directory.
- 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.

- 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.

- The logic libraries for the specified designs

When archiving logic libraries, the `archive_design` command checks the `target_library` and the `link_library` variables to identify the logic libraries to archive. These two variables contain file names that may or may 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.

In addition, the `archive_design` 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.

---

## Using IC Compiler Command-Line Interfaces

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. Separate multiple arguments with commas or spaces. You can enclose arguments in parentheses.

Arguments are separated by commas or spaces and can be enclosed in parentheses. 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. Nonpositional 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.

---

## 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 stand-alone 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 stand-alone 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 Sample 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
pwd foo
```

*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
^

/disk/scripts/ex1.tcl:12 (numArgs) wrong # args
pwd foo
^
```

---

## Limitations of the Synopsys Syntax Checker

The following limitations apply to the Synopsys Syntax Checker:

- Command abbreviations are not checked. Use of abbreviated commands will show up as undefined procedures.
- Aliases created with the `alias` command are not expanded and will 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], will show up as undefined procedures, unless represented as {A[15:0]}.
- User-defined procedures enhanced with the `define_proc_attribute` 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
```

Once 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_QUEUEETIME` 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_QUEUEETIME` 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.

# 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](#)
- [Annotating the Physical Data](#)
- [Preparing for Timing Analysis and RC Calculation](#)
- [Saving the Design](#)

---

## 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 Library Consistency](#)
- 

### 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), Composite Current Source (CCS) models (either compact or noncompact), or both. IC Compiler automatically selects the timing model to use based on the contents of the logic libraries. If the logic libraries contain only CCS models, IC Compiler uses CCS models. If the libraries contain nonlinear delay models (NLDMs) or both NLDM and Composite Current Source (CCS) models, IC Compiler uses the NLDM models. The selected models are used for both preroute and postroute delay calculations.

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.

This section describes the following tasks:

- [Defining the Logic Library Settings](#)
- [Validating Logic Libraries](#)

## Defining the Logic Library Settings

IC Compiler uses variables to define the logic library settings. In each session, you must define the values for the following variables so that IC Compiler can access the libraries:

- `search_path`  
Lists the paths where IC Compiler can locate the logic libraries.
- `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 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.

If you are performing simultaneous minimum and maximum timing analysis, the logic libraries specified by the `link_library` variable are used for both maximum and minimum timing information, unless 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
```

To find out which libraries have been set to be the minimum and maximum libraries, use the `list_libs` command. In the generated report, the letter "m" appears next to the minimum library and the letter "M" appears next to the maximum library.

## Validating Logic Libraries

Use the `check_library` command to check the quality of a logic library. Use this command before or after you setup your design to ensure that the libraries do not have problems. You can perform selective checks by setting the options using `set_check_library_options` command. If you do not set any options using the `set_check_library_options` command, the `check_library` command performs default checking.

To perform logic library checks, you must enable the specific checks you want by running the `set_check_library_options` command. [Table 3-1](#) shows the logic library checks and the `set_check_library_options` command options used to enable them.

*Table 3-1 Logic Library Checks*

| Option                                                               | Description                                                                                    |
|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| <code>-compare {construct value}</code>                              | General logic library consistency checking                                                     |
| <code>-mcmm</code>                                                   | Logic library consistency checking for multicorner-multimode (MCMM)                            |
| <code>-scaling {timing noise power}</code>                           | Logic library consistency checking for CCS timing, CCS noise, and CCS or NLDM power scaling    |
| <code>-tolerance {type relative_tolerance absolute_tolerance}</code> | Specifies a relative tolerance and an absolute tolerance for characterization value comparison |
| <code>-upf</code>                                                    | Logic library consistency checking for multivoltage and UPF                                    |
| <code>-validate</code>                                               | Logic library consistency checking for library characterization                                |
| <code>-logical</code>                                                | Specify to enable all the logic library checks                                                 |
| <code>-reset</code>                                                  | Specify to reset the logic library checks to the default settings                              |
| <code>-all</code>                                                    | Specify to enable all check for logic and physical libraries                                   |

Specify the option for each check that you would like to enable, or if you want to enable all logic library checks, use the `-logical` option.

To report on the values of logic library consistency checking options set by the `set_check_library_options` command, use the `report_check_library_options` command.

```
icc_shell> report_check_library_options -logic
```

You can use the `-default` option to report on the default options.

## General Logic Checks

The `check_library` command performs the following logic versus logic library general checks:

- Library group

For the library group, the `check_library` command reports the library version and the library type. The library type indicates whether the library is power and ground pin based. The command also checks if the libraries have the same units and the same slew trip points for CCS timing scaling. The command checks if the libraries have the default operating conditions that are defined. The `check_library` command performs these checks by default with the exception of the trip points check. Use the `set_check_library_options -scaling timing` command to perform the trip points check.

- Cell group

The `check_library` command checks for the same number of cells in each library. It also checks that the `area`, `function_id`, `dont_use`, and `dont_touch` attributes for cells with the same name are consistent. The `check_library` command performs these checks by default.

- Pin and PG pin groups in the cells

The `check_library` command checks if the libraries have the same number of pins, including the power and ground (PG) pins. The command also checks if the PG pin names, directions, types, functions and `voltage_name` in the two libraries are the same. Apart from these checks, the command also checks if the two libraries have the same

- Input or `output_signal_level` for rail-based libraries and the same `related_power_pin` or `related_ground_pin` for power and ground pin based libraries
- Derived `pin_number` attribute values

If there is a mismatch, the `check_library` command checks the order of pins in each cell group and function Boolean expressions, and others that may also affect the mismatch and are unknown at this point.

The `check_library` command performs these checks by default.

- Timing arcs

The `check_library` command checks for timing arcs with matching related pins, timing type, timing sense, and when conditions across the libraries. In any two sets of logic (technology) libraries with the same cell group, if such timing arcs are used in at least one design, they are checked for consistency between these libraries. The `check_library` command performs these checks by default.

For the libraries to pass a flow check, the general logic checks should not have any problems.

## Specific Logic Checks

The `check_library` command performs the following checks when you use various options of the `set_check_library_options` command:

- Use the `set_check_library_options -compare construct` command to specify that the `check_library` command compares all groups, subgroups, attributes, and characterized values such as timing, power, and current between two libraries.
- Use the `set_check_library_options -compare value` command to specify that the `check_library` command compares two libraries for all characterized values.

## Special Checks

The following flows and applications require checking in addition to the general checks:

- CCS timing scaling

Use the `set_check_library_options -scaling timing` command to specify that the `check_library` command performs the following checks for CCS timing scaling:

- The number of CCS timing driver model load indexes must be the same for each timing arc.
- The output load indexes in each CCS timing driver model timing arc must be the same.
- For setup and hold pessimism reduction, all load and slew indexes should be the same across the libraries.
- Receiver models across all scaling libraries exist and they should be of the same type.
- The order of the receiver and noise models, and the conditional `when` and default pin models are the same across the libraries.
- The base curve\_x is the same across the libraries at a number of points and for each value for Compact CCS.
- All libraries have either the compressed or original format for driver data.
- Characterization waveform type between two libraries should be the same. The command checks for cell or pin level attributes such as `driver_waveform`, `driver_waveform_rise`, `driver_waveform_fall`, and `driver_waveform_name` in the `normalized_driver_waveform` group.

- CCS noise scaling checks

Use the `set_check_library_options -scaling noise` command to specify that the `check_library` command performs the following checks for CCS noise scaling:

- The `input_voltage` and `output_voltage` indexes for CCS noise models in the libraries across the scaling groups are the same percentage of VDD.
- The command checks that the conditional `when` pin models and the receiver models are in the same order across the libraries.
- The number of CCS noise models is the same across the libraries for all pins and arcs.
- Power scaling checks

Use the `set_check_library_options -scaling power` command to specify that the `check_library` command performs the following checks for CCS or NLDM power scaling to ensure that the libraries have the same:

- Set of `dynamic_current` and `leakage_current` groups for each cell
- Set of `intrinsic_parasitic` and `leakage_power` tables for each cell
- `power_cell_type` attribute for each cell
- Set of `internal_power` tables for each pin or cell
- Voltage scaling checks

For voltage scaling, the `check_library` command checks that the voltages are no more than 20 percent apart for good accuracy. This check is performed for reporting and does not determine the success or failure of the check.

- Multivoltage and UPF checks

Use the `set_check_library_options -upf` command to specify the following checks for multivoltage or UPF flows:

- Different PVT values for different characterizations
- NLDM or CCS model under different voltage conditions exists
- Level shifter, isolation, retention, and switch cells exist with consistent and complete attributes
- The `voltage_map` and `pg_pin` groups exist in a multiple power and ground pin based library with consistent attributes
- The same `power_down_function` for output or inout pins
- Power data exists for all operating conditions

- Multicorner-multimode checks

Use the `set_check_library_options -mcmm` command to specify the following checks for a multicorner-multimode flow:

- Different PVT values for different characterizations between two libraries for different operation conditions, that is, libraries with same-name cells, which have different nominal PVT values
- Same cell attributes such as `dont_use`, `dont_touch`, and `black box`
- The same `power_down_function` for output or inout pins
- Power data exists for all operating conditions
- Characterization value comparison

Use the `set_check_library_options -tolerance {type rel_tol abs_tol}` command to specify a relative tolerance and an absolute tolerance for characterization value comparison, such as delay values.

The valid values for the `type` argument are `time`, `power`, `current`, and `capacitance`. If the `type` argument is not specified, the values are for output load capacitance. To specify an absolute tolerance, do not include the unit. The unit in the first library is used.

The following example specifies tolerances for time and power.

```
-tolerance {time 0.1 0.2 power 0.3 0.4}
```

If you do not specify tolerances for a type, the default values are used. The following default values are consistent with the settings for PrimeTime and the Library Quality Assurance System:

|                    | Load Index | Time     | Power |
|--------------------|------------|----------|-------|
| Relative Tolerance | 0.01       | 0.04     | 0.04  |
| Absolute Tolerance | 0.001 pF   | 0.015 ns | 5 pW  |

If you want to determine whether two libraries are identical by comparing them by groups and by attributes, it is recommended that you set the tolerances to smaller values.

- Library characterization checks

Use the `set_check_library_options -validate` command to specify the following checks for library characterization using the Library Quality Assurance System:

- The same output load index for each individual cell between CCS and NLDM models.  
The same load indexes for CCS driver or receiver.
- The same number of NLDM delay and slew indexes and values.

- Difference of delays between NLDM and CCS timing within an acceptable range for both compact CCS and expanded CCS
- The command checking that two CCS driver model current waveforms, including compact CCS with expanded CCS data, are consistent within an acceptable margin.
- Inverter and buffer cell checks

The `check_library` command also reports on the existence of inverter and buffer cells and total numbers among libraries. Use the `set_check_library_options -logic` command to specify that the `check_library` command performs this check.

---

## Setting Up the Physical Libraries

IC Compiler uses Milkyway reference libraries and technology (.tf) files to provide 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 files provide technology-specific information such as the names and characteristics (physical and electrical) for 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.

If you have not already created a Milkyway library for your design (by using another tool that uses Milkyway), you need to create one by using the IC Compiler tool. 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](#)
- [Managing Milkyway Reference Libraries Using Reference Control Files](#)
- [Converting a Milkyway Database Model](#)
- [Validating a Milkyway Design Library](#)
- [Opening a Milkyway Design Library](#)
- [Reporting on a Milkyway Design Library](#)
- [Changing Physical Library Information](#)
- [Saving Physical Library Information](#)

## Creating a Milkyway Design Library

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

At a minimum, you must specify the technology file and the Milkyway reference libraries that are used for the design, as well as the name of the Milkyway design library. In addition, you can specify the bus naming style and hierarchy separator character used in the design. If you do not specify a hierarchy separator character, a slash (/) is used. If you do not specify the bus naming style, %d is used. [Table 3-2](#) shows the command options (and GUI fields) used to specify these items.

*Table 3-2 Options for Creating a Milkyway Design Library*

| Task                                      | Command Line Option                                                                                   | GUI Field                                                     |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| Specify technology file                   | <code>-technology file_name</code>                                                                    | "Technology file"                                             |
| Specify Milkyway reference libraries      | <code>-mw_reference_library file_names</code><br>or<br><code>-reference_control_file file_name</code> | "Input reference libraries"<br>or<br>"Reference control file" |
| Specify Milkyway design library name      | <code>library_name</code>                                                                             | "New library path"<br>and<br>"New library name"               |
| Specify bus naming style                  | <code>-bus_naming_style style</code>                                                                  | "Bus naming style"                                            |
| Specify the hierarchy separator character | <code>-hier_separator char</code>                                                                     | "Hierarchical separator"                                      |

## Managing Milkyway Reference Libraries Using Reference Control Files

You can access cells in another library using a reference library that is linked to the library that you are working in. Each Milkyway Design Library can have at least one reference library that links to it. You can update the link between the Milkyway design library and the reference libraries anytime.

As indicated in [Table 3-2](#), you can use one of the following two ways to specify the Milkyway Reference Libraries, when you are creating a design library using the `create_mw_lib` command:

- By using the `-mw_reference_library` option.
- In a reference control file and then creating a link to the reference control file using the `-reference_control_file` option.

The explicit way to define how one library references another library is through using a reference control file.

This section describes how to define, create, and manage a reference control file in the following sections:

- [Reference Control File](#)
- [Creating a New Reference Library Link](#)
- [Modifying a Reference Library Link](#)
- [Moving or Copying a Design Library](#)

### Reference Control File

A reference control file is an ASCII file that stores information about links between the reference libraries and the design library.

The syntax for creating a reference control file is

```
LIBRARY Milkyway_design_library_name
  REFERENCE Milkyway_reference_library_name
  REFERENCE Milkyway_reference_library_name
...
...
```

The following example is of a reference control file that represents the hierarchical reference libraries in the Milkyway database:

```
LIBRARY design_lib.mw
  REFERENCE /absolute_path/libs/refLib1
  REFERENCE /absolute_path/libs/refLib2
LIBRARY /absolute_path/libs/refLib1
  REFERENCE /absolute_path/libs/refLib1_A
  REFERENCE /absolute_path/libs/refLib1_B
LIBRARY /absolute_path/libs/refLib1_A
  REFERENCE /absolute_path/libs/refLib1_AA
LIBRARY /absolute_path/libs/refLib2
  REFERENCE /absolute_path/libs/refLib2_A
```

Note:

Use absolute paths in the control file mode to document where the data originates.

For example, if your design references the refLib1 library, which, in turn references refLib1\_A and refLib1\_B libraries as child references, and if each of these libraries has child references to a reference library, you could define these references in a reference control file, as shown in [Example 3-1](#).

### Example 3-1 Reference Control File

```
LIBRARY /absolute_path/libraries/refLib1
REFERENCE /absolute_path/libraries/refLib1_A
REFERENCE /absolute_path/libraries/refLib1_B
LIBRARY /absolute_path/libraries/refLib2
REFERENCE /absolute_path/ref_libraries/refLib2_A
LIBRARY /absolute_path/libraries/refLib1_AA
REFERENCE /absolute_path/ref_libraries/refLib1_AA
```

If the refLib1 library contains cell A, which references cells B and C, IC Compiler first searches refLib1\_A for the cell; then, if the cell is not found, it searches refLib1\_B. If cell B in refLib1\_A references another cell, the referenced cell must exist in refLib1\_AA. If refLib1\_AA and refLib1\_BB both contain a cell with the same name, the hierarchy of the control file explicitly states which library the referenced cell should come from. [Figure 3-1](#) illustrates the hierarchy of libraries and how they are referenced.

*Figure 3-1 Illustration of Hierarchical Libraries*



### Creating a New Reference Library Link

Before creating the Milkyway design library, you need to create an ASCII reference control file, using the syntax explained in the previous section. The reference control file specifies the Milkyway Reference Libraries that you want to link with your Milkyway design library.

To create your Milkyway design use the `create_mw_lib -reference_control_file` command.

The `-reference_control_file` option specifies the linking information between your Milkyway design library and Milkyway reference. The following example illustrates this syntax:

```
create_mw_lib
    -technology mytech.tf
    -reference_control_file my_ref_ctr_file design.mw
```

### Modifying a Reference Library Link

To modify the reference control link when you have already established the reference library link for your Milkyway design library,

- Write out the reference control file from the existing Milkyway library. You can use the `write_mw_lib_files` command to create the Milkyway Reference Control file from the Milkyway design library, using this syntax:

```
write_mw_lib_files
    -reference_control_file
    -output refCtr.out design.mw
```

- Use the output ASCII reference control file to manipulate the reference control links, as shown in the following example:

The following is an example of what the file looks like before modification:

```
LIBRARY design_lib.mw
    REFERENCE /home/libs/refLib1
    REFERENCE /home/libs/refLib2
LIBRARY /home/libs/refLib1
    REFERENCE /home/libs/refLib1_A
    REFERENCE /home/libs/refLib1_B
LIBRARY /home/libs/refLib1_A
    REFERENCE /home/libs/refLib1_AA
LIBRARY /home/libs/refLib2
    REFERENCE /home/libs/refLib2_A
```

Edit the file to link the new reference library, `refLib3`, to the Milkyway design library. Remove the hierarchical link of the existing reference library, `refLib2`, from the existing file. The following is an example of what the edited file looks like:

```
LIBRARY design_lib.mw
    REFERENCE /home/libs/refLib1
    REFERENCE /home/libs/refLib3
LIBRARY /home/libs/refLib1
    REFERENCE /home/libs/refLib1_A
    REFERENCE /home/libs/refLib1_B
LIBRARY /home/libs/refLib1_A
    REFERENCE /home/libs/refLib1_AA
```

- Re-apply the updated reference control file to the Milkyway design library, using the `set_mw_lib_reference` command to set or change the reference library for the Milkyway design library. The `set_mw_lib_reference` command updates the new reference links to the disk.

Note:

Close your Milkyway Design Library before using this command.

```
close_mw_lib design.mw
set_mw_lib_reference
    -reference_control_file refCtr.out design.mw
```

### Moving or Copying a Design Library

Information about the reference control libraries is stored in the database. To move or copy your Milkyway design library and its reference libraries from one disk to another disk, update your reference control link of the Milkyway design library to resolve the undefined link path to your reference libraries. To resolve this problem:

- Before moving or copying your Milkyway libraries to a new disk, capture the reference control linking information of your Milkyway design. Use the `write_mw_lib_files` command to write out the reference control files of the Milkyway design library:

```
write_mw_lib_files
    -reference_control_file
    -output refCtr.out design.mw
```

- Move or copy the Milkyway design library directory, the reference libraries directories, and the Milkyway reference control file to the new location.
- Modify the reference control file to update the new path of your reference control files.

The following file is an example of what the reference control file looks like before modification:

```
LIBRARY design_lib.mw
    REFERENCE /home/old_disk/libs/refLib1
    REFERENCE /home/old_disk/libs/refLib2
LIBRARY /home/old_disk/libs/refLib1
    REFERENCE /home/old_disk/libs/refLib1_A
    REFERENCE /home/old_disk/libs/refLib1_B
LIBRARY /home/old_disk/libs/refLib1_A
    REFERENCE /home/old_disk/libs/refLib1_AA
LIBRARY /home/old_disk/libs/refLib2
    REFERENCE /home/old_disk/libs/refLib2_A
```

Edit the file as illustrated to update the reference control file to the new location:

```
LIBRARY design_lib.mw
  REFERENCE /home/new_disk/libs/refLib1
  REFERENCE /home/new_disk/libs/refLib2
LIBRARY /home/new_disk/libs/refLib1
  REFERENCE /home/new_disk/libs/refLib1_A
  REFERENCE /home/new_disk/libs/refLib1_B
LIBRARY /home/new_disk/libs/refLib1_A
  REFERENCE /home/new_disk/libs/refLib1_AA
LIBRARY /home/new_disk/libs/refLib2
  REFERENCE /home/new_disk/libs/refLib2_A
```

- To update the Milkyway design library with the updated Milkyway reference control file and to resolve the linking issue, use the `set_mw_lib_reference` command.

```
set_mw_lib_reference
  -reference_control_file updated_refCtr design.mw
```

## Converting a Milkyway Database Model

To work with IC Compiler version C-2009.06, existing Milkyway design libraries must be converted to the new database model. Before converting a Milkyway design library, you should create a backup copy of the design library with the previous database model.

### **Caution:**

You cannot use designs saved with the new Milkyway database model in Synopsys tools with a version prior to B-2008.09, such as Astro, Jupiter, or older versions of IC Compiler.

There are two ways to convert a Milkyway design to the new database model:

- Manual conversion by using the `convert_mw_lib` command
- Automatic conversion by using the `open_mw_cel` command

### Note:

Both the `convert_mw_lib` and the `open_mw_cel` commands convert the specified design but not the designs in the Milkyway reference libraries, unless they are used in the Milkyway design library. The `convert_mw_lib` command does not convert the child macro CELs that are in the reference library, even if they are referenced by the top-level design. The CEL views and the Interface Logic Model (ILM) views of the design are converted. Database model conversion does not affect FRAM view cells.

Both the `convert_mw_lib -previous` and the `open_mw_lib -previous` commands will not convert the database model of the design from version C-2009.06 to version B-2008.09 of the database model if the designs have a wire master index that is greater than 255. An error message is displayed, and the command exits. To convert such a design, use the `remove_route_by_type` command to delete all wires before converting the design. You must perform routing on the design again after the database model has been converted.

## Manual conversion

To minimize the runtime and memory consumption due to automatic database model conversion when opening a design, you should manually convert designs to the new database model. To manually convert a design to the new database model, use the `convert_mw_lib` command.

You can either convert all designs in the Milkyway design library, using the `-all` option, or you can specify a design to convert, using the `-cell_name` option. The `convert_mw_lib` command also converts all of the opened design's child macro cells that are in the same design library. It does not convert the child macro cells that are located in a reference library. The `convert_mw_lib` command opens the design, converts its database model, and saves it with an incremental version number. If the top level design refers to CEL or ILM views of the design in the reference library:

- The views that are loaded are converted in the memory
- The converted views of the design are not saved to the disk
- The ILM views generated using Synopsys tool version B-2008.09 and its service packs need not be re-created in the tool version C-2009.06

Note:

ILMs that are created using versions earlier than Synopsys tool version B-2008.09 are not converted. CEL views created using Synopsys tool version A-2007.12 or earlier can be converted in IC Compiler version C-2009.06.

To save time when converting a Milkyway design library to the new database model, use the `remove_mw_cel` command to remove cells in your design library that are no longer required before you run the `convert_mw_lib` command.

The syntax of the `convert_mw_lib` command is

```
convert_mw_lib mw_lib -all | -cell_name mw_cell | -previous
```

where

*mw\_lib*

Specifies the Milkyway design library containing the cells to be converted.

`-cell_name mw_cell`

This option converts the specified cell and saves it. Note that the name of the view must not be specified in this option. To convert a specific view, such as `cell_name.ilm` or `cell_name.cel`, use the `open_mw_cel` command.

-all

This option converts all the cells in the design library.

-previous

This option converts the database model of the design from version C-2009.06 to version B-2008.09 of the database model.

You must specify either the `-cell_name` or the `-all` option when you run the `convert_mw_lib` command.

For example, to convert all designs in the `my_mw_lib` Milkyway design library to the new database model, enter the following command:

```
icc_shell> convert_mw_lib my_mw_lib -all
```

### Automatic conversion

When you use the `open_mw_cel` command to open a Milkyway design, it checks the database model version and automatically updates the database model, if necessary.

When opening a hierarchical design using the `open_mw_cel` command, irrespective of whether the soft macro cells are in the design library or the reference library, the MW-365 warning message is displayed. The MW-365 message lists the macro cell and its library name pairs, and recommends using the `convert_mw_lib` command to convert the design.

The `open_mw_cel` command does not save the converted design. To save the converted design, you must use the `save_mw_cel` command. To keep a copy of an older data model when using the `open_mw_cel` command, use the `save_mw_cel -as` command. If you do not save it, the next time you use the `open_mw_cel` command to open the design, it automatically converts it again. The `save_mw_cel` command prints a message after a design is converted, indicating that Synopsys tools with a version prior to C-2009.06 cannot open it. Use the `-as` option or the `-increase_version` option to prevent overwriting the current design.

If you open a design that uses an older database model in read-only mode, the `open_mw_cel` command issues an error and exits. If the design in the reference library is marked read-only, the `open_mw_cel` command converts it in the memory. If the design in the Milkyway design library is marked read-only, the command displays a message indicating that the design is read-only.

For more information about the `open_mw_cel` command, see “[Reading a Design in Milkyway Format](#)” on page [3-25](#).

## Validating a Milkyway Design Library

You can use the `check_library` command to check the quality of a Milkyway design library. To perform these physical library checks, you must enable the specific checks you want by running the `set_check_library_options` command (by default, the `check_library` command does not perform physical library checks). [Table 3-3](#) shows the physical library checks and the options used to enable them.

*Table 3-3 Physical Library Checks*

| Use this option                     | To check for                                                                                                                          |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| <code>-antenna</code>               | Missing antenna properties for cells and missing antenna rules for routing layers                                                     |
| <code>-drc</code>                   | Design rule constraint (DRC) violations in the routing (FRAM) view of the cells (requires write permission for the library directory) |
| <code>-phys_property {types}</code> | Physical properties (you can specify one or more of the following types: place, route, cell, and metal_density)                       |
| <code>-physical_only_cell</code>    | Physical-only cells, such as filler cells with and without metal, diode cells with antenna properties, and corner cells               |
| <code>-rectilinear_cell</code>      | Coordinates of cells with rectangular or rectilinear boundaries                                                                       |
| <code>-routeability</code>          | The on-track accessibility of the physical pins                                                                                       |
| <code>-same_name_cell</code>        | Cells with identical names in different reference libraries                                                                           |
| <code>-signal_em</code>             | Missing signal electromigration rules for routing layers                                                                              |
| <code>-tech</code>                  | The quality of the technology data for a reference library                                                                            |
| <code>-tech_consistency</code>      | Consistency in the technology data between the design library and the reference libraries                                             |
| <code>-view_comparison</code>       | Consistency between the layout (CEL) view and the routing (FRAM) view of the cells                                                    |

Specify the option for each check that you would like to enable, or to enable all physical library checks, use the `-physical` option.

To reset the library checks to the default settings (no physical library checks), run the `set_check_library_options -reset` command.

To see the enabled physical library checks, run the `report_check_library_options -physical` command.

If `check_library` reports any physical library problems, you should fix these problems before you process your design. For more information about physical libraries, see the *IC Compiler Data Preparation Using Milkyway User Guide*.

### 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 EM checking results here) ...  
#END_CHECK_SIGNALEM  
...  
#END_CHECK_LIBRARY
```

If the signal electromigration constraints are not defined in the design library, 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:

You can also use the Milkyway tool to update the design library, as described in the *IC Compiler Data Preparation Using Milkyway 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 in the GUI).

If you have specified the TLUPlus files before you open the Milkyway design library, IC Compiler performs consistency checks between the library files in the Milkyway design library and the TLUPlus files, to ensure that you have a valid library setup; otherwise, you must manually perform this validation by running the `check_tlu_plus_files` command after defining the TLUPlus settings (for more information, see “[Setting Up the TLUPlus Files](#) on page 3-32).

## Reporting on a Milkyway Design Library

To report on the reference libraries attached to the design library, use the `-mw_reference_library` option:

```
icc_shell> report_mw_lib -mw_reference_library design_library_name
```

To report on the units used in the design library, use the `report_units` command:

```
icc_shell> report_units
```

To report on the Milkyway data model version and the revision information of a specified cell, use the `report_milkyway_version` command:

```
icc_shell> report_milkyway_version -all
```

This command reports the following information:

- The cell data model version
- The product version that is compatible with the cell data model version
- The product release version that created the initial design
- The cell's initial creation time
- The product release version that modified the design last
- The cell's last modification time

Note:

All cells must be closed when running this command.

You can report on all cells in the current Milkyway design library by using the `-all` option or you can report on a specific cell by using the `-cell` option. Either the `-all` or the `-cell` option must be specified. If neither option is specified, this command displays an error message and exits. If both options are specified, the `-all` option takes precedence, and a report is generated for all the cells in the design library.

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

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

```
icc_shell> open_mw_lib design
icc_shell> report_milkyway_version -cell top
Cell                  top.CEL;2
Data Model            2.1
Compatible Product    2007.12 and older
Creator               2007.03
Creation Time         Thu Apr  5 22:46:12 2007
Modifier              2007.12
Modification Time     Fri Aug 15 13:01:51 2008
1
```

## Changing Physical Library Information

You can change the technology file and Milkyway reference libraries associated with your design library, as long as the design library you are changing is not already open.

If the Milkyway design library you want to change is open, close it by using the `close_mw_lib` command (or by choosing File > Close Library in the GUI).

### Changing the Technology File

To modify the technology file data associated with a Milkyway design library,

1. Generate an editable version of the technology file associated with the Milkyway design library.

To generate an editable version of the technology file, use the `write_mw_lib_files -technology` command (or choose File > Export > Write Library File in the GUI). You specify the name of the generated technology file by using the `-output` option.

```
icc_shell> write_mw_lib_files -technology -output new_tech.tf \
my_design.mw
```

2. Modify the generated technology file.
3. Attach the modified technology file to the Milkyway design library

To change the technology file attached to the Milkyway design library, use the `set_mw_technology_file` command (or choose File > Set Technology File in the GUI) to specify the new technology file name and the name of the design library.

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
```

Note:

If you already have a technology file that contains the updated data, use step 3 to attach the new technology file and ignore steps 1 and 2.

## Changing the Milkyway Reference Libraries

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

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 {./lib/new_mw_ref} my_design
```

## Saving Physical Library Information

To save the technology or reference control information in a file for later use, use the `write_mw_lib_files` command (or choose File > Export > Write Library File in the GUI). 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. See [Table 3-4](#) for options for saving physical library information.

*Table 3-4 Options for Saving Physical Library Information*

| Task                                      | Command Line Option                  | GUI Field                     |
|-------------------------------------------|--------------------------------------|-------------------------------|
| Specify the input Milkyway design library | <code>libName</code>                 | “Library name”                |
| Save the technology file                  | <code>-technology</code>             | “Dump technology file”        |
| Save the reference control file           | <code>-reference_control_file</code> | “Dump reference control file” |
| Specify output file name                  | <code>-output file_name</code>       | “Output file”                 |

For example, to output the reference control file for the `my_design` design library to a file called `ref.out`, enter the following command:

```
icc_shell> write_mw_lib_files -reference_control_file \
-output ref.out my_design
```

---

## Verifying Library Consistency

Consistency between the logic library and the physical library is critical to achieving good results. Before you process your design, ensure that your libraries are consistent by running the `check_library` command.

```
icc_shell> check_library
```

By default, the `check_library` command performs consistency checks between the logic libraries specified in the `link_library` variable and the physical libraries that are referenced in the current Milkyway design library. You can also explicitly specify logic libraries by using the `-logic_library_name` option or Milkyway reference libraries by using the `-mw_library_name` option. The libraries that you explicitly specify override the default libraries.

The `-logic_library_name` option specifies a list of logic libraries to be checked for consistency. If the `-logic_library_name` option is not explicitly specified but the `set_min_library max_library` command option is specified, IC Compiler checks the minimum and maximum libraries as a pair. If neither the `-logic_library_name` option nor the minimum and maximum libraries are specified but the `link_library` and `search_path` variables are set, the command groups the libraries in the list by cell set, and within each group, it checks the consistencies across all the libraries. Libraries that cannot be paired are not checked.

Use the `-cells` option to specify a list of cell names to check. If the cell names are not specified, all the cells in the library are checked. The `check_library` command returns a status message indicating whether the check was successful or not.

By default, the `check_library` command performs the following consistency checks between the logic library and the physical library and verifies that:

- All cells exist in both the logic library and the physical library, including any physical-only cells.
- The pins on each cell are consistent between the logic library and the physical library.

This validation includes consistency in naming, direction, and type, including power and ground pins.

**Note:**

If the logic library does not contain `pg_pin` definitions, IC Compiler uses the power and ground pins as defined in the physical library.

You can also perform the following consistency checks, by setting the appropriate options with the `set_check_library_options` command:

- Verify that the area for each cell (except pad cells) is consistent between the logic library and the physical library.

```
icc_shell> set_check_library_options -cell_area
```

- Verify that the cell footprints are consistent between the logic library and the physical library.

```
icc_shell> set_check_library_options -cell_footprint
```

- Verify that the same bus naming style is used in the logic library and the physical library.

```
icc_shell> set_check_library_options -bus_delimiter
```

Specify the option for each check that you would like to enable, or to enable all consistency checks, use the `-logic_vs_physical` option.

To prevent the lines from breaking when the column overflows, use the `set_check_library_options -nosplit` command.

To reset the library checks to the default settings (cell name and pin consistency checks), run the `set_check_library_options -reset` command.

To see the enabled library consistency library checks, run the `report_check_library_options -logic_vs_physical` command.

If `check_library` reports any inconsistencies, you must fix these inconsistencies before you process your design. For more information about logic libraries, see the Library Compiler documentation. For more information about physical libraries, see the *IC Compiler Data Preparation Using Milkyway User Guide*.

---

## Reading the Design

IC Compiler can read designs in either Milkyway or ASCII (Verilog, DEF, and SDC) format.

In either case, before reading in the design, you must perform the following tasks:

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

```
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-19.

```
icc_shell> open_mw_lib design_library_name.mw
```

Note:

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

The following sections explain how to open designs:

- [Reading a Design in Milkyway 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 choosing File > Open Design in the GUI).

```
icc_shell> open_mw_cel design_name
```

Note:

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 version and automatically updates the database, if necessary.

The `open_mw_cel` command converts the design being opened.

For more information about converting the database model, see “[Converting a Milkyway Database Model](#)” on page 3-15.

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

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

Note:

To prevent rerunning the checks, the design must pass the checks and be saved by using IC Compiler version B-2008.09-SP4 or later versions. IC Compiler does not recognize that the design has passed the checks in a previous version.

- Locks the design, which prevents other copies of it from being used and updated while you are working on it.

If you want to use the same Milkyway design for multiple runs, copy the design (use the `copy_mw_cel` command or choose File > Copy Design in the GUI) to make a uniquely named copy of the design that you can open.

```
icc_shell> open_mw_lib DL.mw
icc_shell> copy_mw_cel -from CEL1 -to CEL1_cp1
icc_shell> open_mw_cel CEL1_cp1
```

---

## Reading a Design in ASCII Format

When you are ready to read a design in ASCII format, you first open the Milkyway design library and then read the Verilog, constraint, and DEF data for the design. After you read in the design, IC Compiler stores the design in Milkyway format for use in future sessions.

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 in the GUI).

The Verilog netlist file is a structural or gate-level design in one file.

```
icc_shell> read_verilog -dirty_netlist design.v
```

Note:

If you are using a bottom-up flow, you must have FRAM views for all blocks in the top-level design; otherwise, the `read_verilog` command fails.

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. Annotate the physical data on the design.

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

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

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

---

## 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 in the GUI).

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

By default, the `read_def` command is additive and adds the physical data in the DEF file to the existing physical data in the design. To avoid this, deselect Incremental in the GUI or use the `-no_incremental` option on the command line.

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 on 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
```

For detailed information about the `read_def` command, see the *IC Compiler Data Preparation Using Milkyway User Guide*.

---

## 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 in the GUI). This file is a script that contains information about the floorplan. For more information about creating a floorplan file, see the *IC Compiler Design Planning User Guide*.

Note:

If the power and ground nets are not explicitly defined in your netlist, you must create the power and ground connections by using the `derive_pg_connection` command before reading the floorplan file. For information about how to do this, see the *IC Compiler Design Planning User Guide*.

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

```
icc_shell> read_floorplan floorplan_file_name
```

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

---

## 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 in the GUI).

Note:

It is up to the user to ensure netlist consistency between the designs. No netlist consistency checks are performed during the copy process.

Specify the design from which to copy the physical data by using the `-from` option (or in the “From cell” field in the GUI).

Note:

The GUI has “Library name” and “To cell” fields. These fields are automatically filled in with the current Milkyway design library and current design, respectively. You cannot change these values.

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

This command copies the following physical data:

- General floorplan data

This includes information such as the design boundary, the core boundary, the placement rows, the placement sites, and the wire tracks.

- Obstructions

These include information such as placement blockages (soft and hard), keepout margins (soft and hard), all route guides, and move bounds (soft and hard).

- Cell instances

These include fixed, soft-fixed, and placed cells (such as macros, pads, and preplaced standard cells), as well as physical cells (such as corner pads, filler cells, and via cells).

Note:

All cell instances are copied; there is no way to select specific cell types to copy.

- Preroutes

These include power and ground preroutes, clock preroutes, signal preroutes, and shieldings.

- Power net connections

- Plan groups

- Macro cell placement (optional)

To copy the macro cell placement information, use the `-macro` option (or select “Copy macro placement” in the GUI).

- I/O pad placement (optional)

To copy the I/O pad placement information, use the `-pad` option (or select “Copy IO pad placement” in the GUI).

- Filler cell placement (optional)

To copy the filler cell placement information, use the `-filler` option (or select “Copy Filler cells placement” in the GUI).

- Power plan (optional)

To connect the power nets and copy the power planning information, use the `-power_plan` option (or select “Connect power net and copy power planning data” in the GUI).

The command does not copy the following data:

- SCANDEF
- Voltage areas and power domains
- Data from the FILL view, such as floating metal fill or notch and gap

By default, the `copy_floorplan` command overwrites the existing physical data in the design. To avoid this, use the `-incremental` option (or select Incremental in the GUI).

Note:

The `copy_floorplan -incremental` command copies the ROWS from the source cell to the destination cell, even though there are already ROWS in the destination cell.

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

---

## Validating Physical Data

To validate the physical data in your design, run the `check_physical_design` command. This command verifies that the current design can be linked, that the placement area is defined, and that all ports have a location. In addition, it verifies that the TLUPlus files are consistent with the physical libraries and verifies the validity of the ILMs.

---

## Preparing for Timing Analysis and RC Calculation

IC Compiler provides RC calculation technology and timing analysis capabilities for both preroute and postroute data. Before you perform RC calculation and timing analysis, you must complete the following tasks:

- Set up the TLUPlus files
- (Optional) Back-annotate delay or parasitic data
- Set the timing constraints
- Specify the analysis mode
- (Optional) Set the derating factors
- Select delay calculation

The following sections describe these tasks.

---

## 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 Star-RCXT 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 mandatory 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 to find the files.

```
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
```

After specifying the TLUPlus files, you must 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 performs consistency checks for 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. To perform a consistency check on TLUPlus files, IC Compiler compares the parameters in the TLUPlus files with the corresponding fields in the technology file.

IC Compiler provides several commands for working with the TLUPlus file settings. [Table 3-5](#) lists these commands and their functions.

*Table 3-5 Commands for Working With the TLUPlus File Settings*

| Task                               | Command                            | GUI             |
|------------------------------------|------------------------------------|-----------------|
| Define the TLUPlus file settings   | <code>set_tlu_plus_files</code>    | File > Set TLU+ |
| Validate the TLUPlus file settings | <code>check_tlu_plus_files</code>  | N/A             |
| Report the TLUPlus file settings   | <code>report_tlu_plus_files</code> | N/A             |

## 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 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 in the GUI). 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.

---

## Setting Timing Constraints

At a minimum, the timing constraints must contain a clock definition for each clock signal, as well as input and output arrival times 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 following constraints for each clock: `set_clock_uncertainty`, `set_clock_latency`, and `set_clock_transition`.

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 in the GUI).

```
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-2). If the SDC file does contain unit settings, they must be consistent with those in the main library; otherwise, `read_sdc` fails. If this happens, update the units and constraint values in the SDC file and rerun `read_sdc`.

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 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.

---

## Specifying the Analysis Mode

Semiconductor device parameters can vary with conditions such as fabrication process, operating temperature, and power supply voltage. The `set_operating_conditions` command specifies the operating conditions for analysis, so that IC Compiler uses the appropriate set of parameter values in the technology library. When you run the `set_operating_conditions` command, you can specify either a maximum operating condition (`-max` option) only or both a minimum operating condition (`-min` option) and a maximum operating condition (`-max` option).

IC Compiler offers two analysis modes with respect to operating conditions:

- Best-case and worst-case (default)

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`)

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.

If you are performing simultaneous minimum and maximum timing analysis, the logic libraries specified by the `link_library` variable are used for both maximum and minimum timing information, unless 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
```

To find out which libraries have been set to be the minimum and maximum libraries, use the `list_libs` command. In the generated report, the letter "m" appears next to the minimum library and the letter "M" appears next to the maximum library.

---

## Setting the Derating Factors

If your timing library does not include 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
```

For more information about the `set_timing_derate` command, see the man page.

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.

---

## Setting the Scaling Factors

If you are using a multivoltage or multicorner design flow, you need timing information for each operating condition. Rather than having separate libraries for each operating condition, you can take advantage of voltage and temperature scaling to get the required timing information.

IC Compiler uses scaling library groups to implement voltage and temperature scaling. IC Compiler derives the timing data for a specified operating condition by interpolating the data from the libraries in the scaling library group.

To specify the libraries in the scaling library group, use the `define_scaling_lib_group` command. A scaling library group must contain at least two libraries, and the libraries must meet the following conditions:

- Each library contains CCS (or mixed CCS and NLDM) models
- The cell data is consistent among the libraries in terms of
  - Cell names
  - Number and names of pins
  - Number and names of timing arcs

It is not necessary for the cells, pins, or timing arcs to be defined in the same order in each library, as long as the data is consistent.

Note:

The `check_library` command does not check for consistency among the libraries in the scaling library group. You must manually ensure consistency among these libraries.

To set a scaling library group on a set of ports or cells, use the `set_scaling_lib_group` command. You can define either a minimum and a maximum scaling library group, or a single scaling library group to be used for both minimum and maximum scaling.

To remove the scaling library group from a set of ports or cells, use the `remove_scaling_lib_group` command.

---

## Selecting Delay Calculation

By default, IC Compiler uses Elmore delay calculation for both preroute and postroute delay calculations. For postroute delay calculations, you can choose to use Arnoldi delay calculation either for clock nets only or for all nets. Elmore delay calculation is faster, but its results do not always correlate with the PrimeTime and PrimeTime SI results. The Arnoldi calculation is best used for designs with smaller geometries and highly resistive nets, but it requires more runtime and memory.

If you are not sure which calculation method to use, 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
```

---

## Saving the Design

You can save the design for use with Milkyway design tools, with design tools that do not use Milkyway, and for manufacturing. If you are going to work 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-38. 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-38. If you have completed the design and are ready for manufacturing, save it in GDSII or Oasis format, as explained in “[Saving the Design for Manufacturing](#)” on page 3-39.

---

### Saving the Design in Milkyway Format

To save the design in Milkyway format, use the `save_mw_cel` command (or choose File > Save Design in the GUI).

If your design does not have unit settings, IC Compiler applies the default settings from the main library and saves them when you save the design. For more information about the main library and its default settings, see “[Setting Up the Logic Libraries](#)” on page 3-2.

Note:

When you exit the IC Compiler GUI, the Exit IC Compiler dialog box gives you the option of automatically saving your design in Milkyway format. For more information about this dialog box, see [Chapter 2, “Working With IC Compiler.”](#)

---

### Saving the Design in ASCII Format

To export the design to ASCII format,

1. Ensure that the object names in the design are Verilog-compliant by using the `change_names` command.

```
icc_shell> change_names -hierarchy -rule verilog
```

2. Write Verilog data for the design by using the `write_verilog` command.

```
icc_shell> write_verilog design_name.v
```

3. Write the physical data to DEF files by using the `write_def` command (or by choosing File > Export > Write DEF in the GUI).

```
icc_shell> write_def -out design_name.def
```

4. 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-2.

5. Write the RC extraction data to the parasitic netlist by using the `write_parasitics` command (or by choosing File > Export > Write Parasitics in the GUI).

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” field 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
```

---

## Saving the Design for Manufacturing

After you have finished the design, you can export the design library in GDSII or Oasis format for manufacturing.

To export the design library for manufacturing,

- Use the `write_stream` command with at least the name of the exported file. You can also specify the following:
  - Name of the library containing the layout cells if not using the currently opened library
  - Cells to be output if not all cells in the design are being output
  - Output format (if not using GDSII)
  - Name of the file listing the cells (if using GDSII format)

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



# 4

## Placement

---

This chapter describes the IC Compiler placement and optimization capabilities.

This chapter contains the following sections:

- [Defining Placement Blockages](#)
- [Placement Options](#)
- [Preparing for High-Fanout Net Synthesis](#)
- [Performing Clock Tree Synthesis During Placement](#)
- [Performing Placement and Optimization](#)
- [Using Physical Optimization](#)
- [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 put 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 4-1](#)) around the boundary of fixed macros in your design in which no other cells are placed.

*Figure 4-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 4-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 4-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 .6 \
           -min_padding_per_macro .1 -max_padding_per_macro 0.2
```

For more information on 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.

## 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 will be 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.

## Defining Area-Based Placement Blockages

Hard placement blockages can be defined in the DEF as shown in [Example 4-1](#).

### *Example 4-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 with the `create_placement_blockage` command (or choose Floorplan > Create Placement Blockage in the GUI). This is the command syntax:

```
create_placement_blockage
  -bbox {llx lly urx ury}
  [-type hard | soft | pin | hard_macro | partial]
  [-blocked_layers string]
  [-blocked_percentage integer]
  [-name blockage_name]
```

For example, to create a soft placement blockage in the area enclosed by a rectangle with corners at (10, 20) and (100, 200), you would use the following command:

```
icc_shell> create_placement_blockage -bbox {10 20 100 200} -type soft
```

The **-type** option specifies the type of blockage: **hard**, **soft**, **pin**, **hard\_macro**, or **partial**. Each type of blockage restricts usage of the specified area in the following ways:

- A **hard** blockage prevents the placement of standard cells and hard macros.
- A **soft** blockage prevents the placement of standard cells and hard macros unless the congestion is too high to allow placement elsewhere.
- A **pin** blockage prevents the global router from routing in the area and the pin placer from assigning pins to the area. You can optionally specify which layers are blocked with the **-blocked\_layers** option. If you do not specify the layers, all layers are blocked.
- A **hard\_macro** blockage prevents the placement of hard macros, but not standard cells.
- A **partial** blockage partially prevents placement of cells in an area. The **-blocked\_percentage integer** option must be used to specify the percentage of the area that is blocked.

For example, to set a partial blockage of 40 percent of the area enclosed by the rectangle with corners at (10,20) and (100,200), you would use the following command:

```
icc_shell> create_placement_blockage -bbox {10 20 100 200} \  
-type partial -blocked_percentage 40
```

In this example, the specified area has a blockage of 40 percent, so the maximum allowed cell density is 60 percent. Partial blockage applies only to coarse placement. It has no effect on legalization or optimization.

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\_blockage** or **remove\_placement\_blockage** command.

You can display and select placement blockages in the layout view of the GUI.

To report placement blockages in the design, use the **report\_placement\_blockages** command.

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.

---

## Placement Options

There are many configuration settings that affect the behavior of placement in IC Compiler, including the following controls:

- [Congestion Options](#)
  - [Move Bounds](#)
  - [Intercell and Boundary Spacing Rules](#)
  - [Buffer Strategy for Optimization](#)
  - [Tie Cell Insertion](#)
  - [Magnet Placement](#)
  - [Placement and Optimization Attributes](#)
- 

### 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 {X1 Y1 X2 Y2}]
```

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_option` and `remove_congestion_option` commands. To report congestion conditions, use the `report_congestion` command. You can visualize congestion conditions by using the global route congestion visual mode as described in “[Congestion Map](#)” on page 4-37.

---

## 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.

---

## 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 0 to 1 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_lib_cell` 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.

---

## 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 will not degrade the quality of results (QoR).

---

## 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 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 can be set with the `set_max_capacitance` or `set_attribute` command. The `set_attribute` command can be used to specify explicitly both the maximum fanout and maximum capacitance constraints for objects in the design.

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.

---

## 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 the best results, perform magnet placement before the 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
```

| 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>                     |

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
```

| To do this                                                                                                                                                           | Use this option                 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Get the fixed (or soft fixed) cells that can be moved                                                                                                                | -move_fixed<br>-move_soft_fixed |
| Get the cells in the specified number of logic levels from the magnet                                                                                                | -logical_level <i>number</i>    |
| Get the cells encountered between magnet cells and sequential cells                                                                                                  | -stop_by_sequential_cells       |
| Exclude the buffers and inverters                                                                                                                                    | -exclude_buffers                |
| 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 -logical_level. | -stop_points <i>object_list</i> |

## Placement and Optimization Attributes

[Table 4-1](#) lists the restrictions imposed on the placement and optimization of cells by attributes.

*Table 4-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 |

*Table 4-1 Restrictions Imposed by Placement and Optimization Attributes (Continued)*

| Attribute                                                                               | Coarse placement  | Detail placement | Optimization                           |
|-----------------------------------------------------------------------------------------|-------------------|------------------|----------------------------------------|
| <code>cts_in_place_size_only</code><br>(imposed on clock sinks by clock tree synthesis) | Cannot move cells | No restrictions  | Can resize cells only if there is room |
| <code>dont_touch</code>                                                                 | No restrictions   | No restrictions  | Cannot move, rotate, or resize cells   |

## 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.

You can choose to disable this capability by setting the `-optimize_buffer_trees` option of the `set_ahfs_options` command to false, changing it from its default of true. Then, you need to perform the following tasks before running high-fanout net synthesis:

- Control the medium- and high-fanout thresholds by using the `-mf_thresh` and `-hf_thresh` options respectively.
- Specify the effort used to remove existing buffer and inverter trees by using the `-remove_effort` option.

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 `place_opt`, you can use the `create_buffer_tree` command to run standalone high-fanout net synthesis.

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.

---

## 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.

[Table 4-2](#) describes the available `place_opt` options.

*Table 4-2 The place\_opt Options*

| GUI object                                              | Command option                           | Description                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Effort radio button                                     | <code>-effort low   medium   high</code> | Improve 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>              | Recover area for cells not on timing-critical paths.                                                                                                                                                                                                                                                                              |
| “Power optimization” check box                          | <code>-power</code>                      | Optimize leakage power and dynamic power and perform low-power placement.<br>The power optimizations and low-power placement capability must be previously enabled. For more information, see <a href="#">Chapter 6, “Power Optimization.”</a>                                                                                    |
| “Clock compilation, optimization and routing” check box | <code>-cts</code>                        | Run 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> |
| “Number of CPUs” field                                  | <code>-num_cpus number</code>            | Use additional CPUs.<br>By default, IC Compiler uses one CPU.                                                                                                                                                                                                                                                                     |
| “Reorder scan during placement” check box               | <code>-optimize_dft</code>               | Reorder scan chains.<br>For more information, see <a href="#">Chapter 5, “Design for Test.”</a>                                                                                                                                                                                                                                   |

*Table 4-2 The place\_opt Options (Continued)*

| GUI object                      | Command option | Description                                                                                               |
|---------------------------------|----------------|-----------------------------------------------------------------------------------------------------------|
| "Minimize congestion" check box | -congestion    | Reduce congestion for improved routability. For best results, use this option only for congested designs. |

## Saving Intermediate Results During Preroute Optimization

You can enable `place_opt` checkpointing to analyze your designs during preroute optimization by using `set_checkpoint_strategy -enable`. 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_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_gates`, `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.

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 the global route congestion map for congestion removal during placement. If you set the `placer_enable_enhanced_route` variable to true, the placer uses the detail router's global route congestion map during placement.

You can specify which detail router's global route congestion map to use.

- To use the classic global route congestion map, enter

```
icc_shell> set_route_mode_options -zroute false
```

- To use the Zroute global route congestion map, enter

```
icc_shell> set_route_mode_options -zroute true
```

You should set the `-zroute` option of the `set_route_mode_options` command before running the `place_opt -congestion` or `create_placement -congestion` command. If you do not specify the option, the default is false. For better correlation with the detail router, you should use the Zroute global route congestion map for congestion removal.

Because the placer invokes the detail router's global route, using either the classic or Zroute global route congestion map for congestion-driven placement slightly increases runtime.

---

## 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, but it can also perform power optimizations if

you specify power constraints. 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 4-3](#) shows the options supported by the `psynopt` command.

*Table 4-3 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> |
| <b>Note:</b><br>To restrict area recovery to high-density areas, set the <code>physopt_density_area_recovery</code> variable to true.                                    |                                  |
| 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> .                                                    |                                  |

*Table 4-3 The psynopt Options*

| To do this                                                                                                                                                                                                                                                 | Use this option                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| 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> |
| Run the on-route optimization flow. You can use this option with <code>-in_place_size_only</code> . You cannot use this option with <code>-size_only</code> .                                                                                              | <code>-on_route</code>           |
| Reduce congestion to improve routability.                                                                                                                                                                                                                  | <code>-congestion</code>         |
| Enable back-annotation-based optimization.                                                                                                                                                                                                                 | <code>-use_annotation</code>     |
| Activate the power optimizations that are enabled by the <code>set_power_options</code> command. By default, only leakage power optimization is enabled, but you can also enable dynamic power optimization for use with the <code>psynopt</code> command. | <code>-power</code>              |
| Enable only power optimizations.                                                                                                                                                                                                                           | <code>-only_power</code>         |
| For more information, see <a href="#">Chapter 6, “Power Optimization.”</a>                                                                                                                                                                                 |                                  |

---

## 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-32](#).

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 4-21](#).

- 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 CEL 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 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.

---

## 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, and the power consumption characteristics with the `report_power` 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:

```
report_placement_utilization
  [-non_fixed_only]
  [-grid_size float]
  [-verbose]
  [-coordinates {X1 Y1 X2 Y2}]
```

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%)
1

```

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. On the other hand, 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 4-3](#). 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 4-3 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 input/output 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]
```

The `-include` and `-exclude` options are new for this release. You can use these options to explicitly specify the types of timing checks to include or exclude during execution of the command. By default, the types of timing checks performed are defined in the `timing_check_defaults` variable, which is also new for the current release.

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 `check_timing` command options or by setting the `timing_check_defaults` variable. For details, see the man pages for the `check_timing` command and `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 short | full | full_clock | full_clock_expanded | only | end]
[-delay 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]
[-scenario 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                6.45
data required time                  6.45
data arrival time                  -4.31
-----
slack (MET)                         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 4-4](#). 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 on generating these views, see the topic “Visual Mode panel” in the IC Compiler online help, or refer to [Appendix A, “Using GUI Tools.”](#)

*Figure 4-4 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]
[-hier]
[-hier_level 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]
[-scenario 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

```

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`.

Using the GUI, you can display color-coded power density maps for the chip. From the Power menu, select the desired type of power density map: leakage, internal, switching, dynamic, or total power density. This opens the Map Mode panel, in which you click the Reload button and then OK to display the power density map. An example of a total power density map is shown in [Figure 4-5](#). For more information, see the topic “power density maps” in the IC Compiler online help, or refer to [Appendix A, “Using GUI Tools.”](#)

*Figure 4-5 Total Power Density Map*



## 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 4-6](#) shows the types of visual reports available in the Visual Mode and Map Mode panels.

*Figure 4-6 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 4-7](#) shows a typical cell density map.

Figure 4-7 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 4-8](#). Otherwise, the text values are omitted from the display. [Figure 4-8](#) shows both a solid-filled grid display and an unfilled grid display.

Figure 4-8 Cell Density Maps With and Without Solid Filled Grids



## Congestion Map

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 4-9](#).

*Figure 4-9 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. For more information about the congestion map, see [“Global Routing” on page 8-32](#).

## 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 4-10](#). A histogram-like bar graph shows the number of cells belonging to each top-level block, identified by name.

**Figure 4-10 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 4-11](#) 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 4-11 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 4-12](#) 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 4-12 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 Area panel. See [Figure 4-13](#). 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 4-13 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 4-14](#).

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 4-14 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 on 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 power violations after you run `place_opt`, adjust the `place_opt` options and rerun `place_opt`, as described in “[Performing Placement and Optimization](#)” on page 4-15.

If your design shows small timing or power violations after you run `place_opt`, run `psynopt` to fix these violations, as described in “[Using Physical Optimization](#)” on page 4-18.

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 4-4](#) describes the available `refine_placement` options.

*Table 4-4 refine\_placement Options*

| GUI object                                                 | Command option                                             | Description                                                                                                                                                              |
|------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| “Congestion optimization effort” radio button              | <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” radio button                   | <code>-perturbation_level min   medium   high   max</code> |                                                                                                                                                                          |
| “Whole chip” radio button                                  | N/A                                                        | Perform incremental placement and legalization on the entire chip.                                                                                                       |
| “Specified region” radio button, plus Coordinates list     | <code>-coordinate {X1 Y1 X2 Y2}</code>                     | Perform incremental placement and legalization on the specified region.                                                                                                  |
| “Snap to” list box                                         | N/A                                                        |                                                                                                                                                                          |
| “Ignore scan-chain connections during placement” check box | <code>-ignore_scan</code>                                  |                                                                                                                                                                          |
| “Number of CPUs” list box                                  | <code>-num_cpus number</code>                              | Use additional CPUs.<br>By default, IC Compiler uses one CPU.                                                                                                            |

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
```



# 5

## 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 in order 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 Using the read\\_def Flow](#)
- [Generating SCANDEF Data Using the trace\\_scan\\_chain Flow](#)
- [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 5-1](#)). SCANDEF can specify chain stubs that are contiguous subsets of scan cells of a logical scan chain.

*Figure 5-1 Comparing Views of Scan Chains*



There are two major flows for performing physical DFT in IC Compiler:

- The SCANDEF flow (recommended) accepts SCANDEF data (a subset of DEF) generated by DFT Compiler. Scan chain repartitioning and reordering are supported.
- The `trace_scan_chain` flow is used when a SCANDEF file is not available; in this case, IC Compiler internally generates SCANDEF data when you identify the scan chain endpoints for tracing. Only scan chain reordering is 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 5-2](#) shows the overall physical DFT flow in IC Compiler.

*Figure 5-2 Overview of Physical DFT Flow in IC Compiler*



## Preparing for Physical DFT Using the `read_def` Flow

The SCANDEF flow is recommended when you use DFT Compiler for DFT insertion and use 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

In the SCANDEF flow, 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 are 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 -rule 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 will later need to perform DFT optimization at the block level, and create an interface logic model (ILM). At the top level, you will need to read the top-level SCANDEF and block-level ILMs.

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*.

Make sure you propagate the placement, keep out, and delay data to the top level blocks before performing the `place_opt` and `clock_opt` DFT optimizations. For details on the hierarchical flow, please see [Chapter 11, “Using Interface Logic 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

For the SCANDEF flow, 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`, or `read_ddc`, or `import_design` 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 on this process, see [“Scan Chain Consistency Checking” on page 5-7](#).

## Generating SCANDEF Data Using the `trace_scan_chain` Flow

If you don't have a SCANDEF file and cannot generate one using the `write_scan_def` command in Design Compiler, you can generate internal SCANDEF data by using the `trace_scan_chain` command. You can then perform physical DFT optimizations.

Note that using `trace_scan_chain` instead of a SCANDEF file might result in lower QoR of the physically aware optimizations because the `trace_scan_chain` command cannot infer the PARTITION attribute. Scan cells will only be reordered within individual chain stubs.

The `trace_scan_chain` command traces backward through the scan chain stub starting at the user-specified endpoint. It automatically traces through scan cells and single-input gates (buffers and inverters). Any other multi-input cell in the scan chain requires you to specify the scan-in and scan-out pin for the reference of that cell instance using `set_scan_pin_type`. All instances of that reference in the current design must use the same input pin for scan chain connections.

The START and STOP points for the chain stub must be carefully selected to ensure reordering any enclosed cell will not disturb test or mission mode functionality. For example, if the STOP point feeds mission mode logic in addition to the scan network, changing the last scan cell may cause mission mode logic to become incorrect as shown in [Figure 5-3](#).

Likewise, if lockup latches are traced, causing scan cells of different clock domains or edges to be mixed, the scan chain may fail to shift.

*Figure 5-3 Specifying STOP Point for the `trace_scan_chain` Command*



The `trace_scan_chain` command attempts to create chain stubs that will reorder properly; however, the created stubs may differ from the user specification. For example, `trace_scan_chain` can move START or STOP points to avoid reordering non-scan cells. Multiple chain stubs can be created from a single `trace_scan_chain` call due to the stub being split during the trace. Splitting can happen at multiple-input combinational gates for which `set_scan_pin_type` has been specified and at voltage level shifters. Buffers and inverters in the scan path will be placed in an ORDERED list adjacent to a scan cell, as they cannot be reordered by themselves. Currently, chains with mixed clock domains or mixed edges are not supported in a single `trace_scan_chain` call. You have to specify START and STOP points so that the stubs connected to the lockup latches or edge-boundary scan cells are split into two. The following example shows a typical `trace_scan_chain` flow.

```
# when encountering an instance of mx02d0 from lib sc, trace
# back on pin I1.
set_scan_pin_type -type in -ref_pin \
  [get_physical_lib_pins sc/mx02d0/I1]
set_scan_pin_type -type out -ref_pin \
  [get_physical_lib_pins sc/mx02d0/Z]

# trace backwards from fanin of uc0re/U186/Z
trace_scan_chain -from uc0re/U23/Q -to uc0re/U186/Z

# trace backwards from port out[2]
trace_scan_chain -from in[2] -to out[2]

# sanity check
check_scan_chain
```

## 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 will be 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

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. 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, or that was created from the `trace_scan_chain` command. Note, however, that physical DFT optimizations cannot be done without 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

The `place_opt -optimize_dft` command can repartition and reorder the scan chains, based on scan cell locations. Repartitioning involves swapping scan chain components across scan chains so that the scan chains will contain components that are near each other. Using the placement information to optimize the scan chain provides the following benefits:

- Reduces scan chain wire length
- Minimizes congestion and improves routability

[Figure 5-4](#) 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 5-4 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 `place_opt` and `clock_opt`.

To repartition and reorder the scan chains using placement information, select “Reorder scan during placement” in the Core Placement and Optimization dialog box (Placement > Core Placement and Optimization) or use the `-optimize_dft` option when you run the `place_opt` command. The `optimize_dft` stand-alone command is also available.

After repartitioning, the scan chains should consist of scan cells that are physically near each other, as shown in [Figure 5-5](#). This represents a design with many scan chains.

Figure 5-5 Repartitioned Scan Chains



For designs with a small number of scan chains, horizontal or vertical partitioning is done as shown in [Figure 5-6](#). 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 `report_optimize_dft_options`. The output during DFT optimizations will indicate if repartitioning was done, and, if so, what kind.

Figure 5-6 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

The `clock_opt` command reorders the scan chains to minimize the number of clock buffer crossings in the scan chain. Minimizing the number of buffer crossings can reduce hold time violations in the scan chain.

To reorder the scan chains using clock information, use the `-optimize_dft` option when you run the `clock_opt` command. The `optimize_dft -clock_buffer` stand-alone function is also available. In the GUI, select the “Reorder scan cells” setting in the “Core CTS and Optimization” dialog box (Clock > Core CTS and Optimization).

---

## Example Optimization Flow

The following example shows a typical physical DFT optimization flow:

```
# following read_def, read_ddc, or trace_scan_chain  
  
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 window 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 cursor over a scan chain component, a tooltip box pops up and displays the object's properties, including the scan chain to which it belongs.

# 6

## 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](#)
- [Strategies To Reduce Leakage Power](#)
- [Annotating Switching Activity](#)
- [Setting the Options For Power Optimization](#)
- [Performing Power Optimization](#)
- [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 “[Low-Power Clock Tree Synthesis](#)” on page 6-9.

- Static 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. To perform dynamic power optimization, you must explicitly specify the option. You can also specify the effort for each of these types of optimization.

IC Compiler supports power reduction at each step of the optimization flow. For more details, see “[Performing Power Optimization](#)” on page 6-8. 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 6-6.

---

## Strategies To Reduce Leakage Power

Because leakage power is a function of device characteristics, reducing the leakage power involves choosing devices that dissipate lower leakage power. 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 more when threshold voltage is high. 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. For more details on using multiple threshold-voltage cells, see “[Using Multiple Threshold-Voltage Cells](#)” on page 6-3. For more

details on how IC Compiler chooses cells of specific threshold-voltage to obtain maximum power reduction during various stages of optimization, see “[Adaptive Leakage Power Optimization](#)” on page 6-6.

## 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. So, using lower-threshold cells to reduce the leakage can violate the timing constraints of the design. [Figure 6-1](#) shows the relationships between the various characteristics of a cell for a specific threshold voltage.

*Figure 6-1 Trade off of Various Characteristics of a Cell*



One of the techniques to reduce the leakage power is to have higher-threshold voltage cells in the timing-critical path and lower-threshold voltage cells on the other paths. However this requires that your target library support multiple threshold-voltage cells. Alternatively, you can set attributes to associate the cells in your library with specific threshold-voltage.

## 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 lower threshold-voltage value can switch from one logic to another quickly but have higher leakage dissipation. Cells with higher threshold value have lower leakage dissipation but have higher switching delay.

Liberty library syntax supports cells of different threshold-voltages in the same library using the `default_threshold_voltage_group` attribute. This attribute defined at the library level 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 "hight_vt_cell";  
...  
}  
cell (AND1_L)  
...  
    threshold_voltage_group "low_vt_cell";  
...  
}
```

## Defining Multiple Threshold-Voltage 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 to libraries high_vt_library and
low_vt_library, 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] -type string \
default_threshold_voltage_group "HVT"
set_attribute [get_libs $LVT_lib] -type string \
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] -type string \
default_threshold_voltage_group "HVT";
set_attribute [get_libs $all_vt_lib] -type string \
set_attribute [get_lib_cells ${all_vt_lib}/FAST] -type string \
threshold_voltage_group "LVT";
```

## Constraining the Leakage Power Optimization

When you have multithreshold voltage cells, either supported in the technology library or supported by setting appropriate attributes on the library cells, IC Compiler chooses cells belonging to appropriate threshold-voltage groups to minimize the leakage power without violating the timing and design rule constraints. You can use the `set_max_lvth_percentage` command to specify the maximum percentage of the total design area that can be occupied by the lower threshold-voltage cells. Using this command, you can specify the categories or the groups to be used as the low threshold-voltage group. When you run the `place_opt`, `psyn_opt` and `route_opt` commands with the `-power` option, the tool honors the constraint set by the `set_max_lvth_percentage` command. However clock tree synthesis does not honor the constraint set by this command.

The `set_max_lvth_percentage` command has the following syntax:

```
set_max_lvth_percentage [-lvth_groups low_vth_groups] [-reset] [value]
```

The `-lvth_groups` option can be used to specify the list of threshold-voltage groups that can be used as the low voltage-threshold group.

The `value` specifies the maximum percentage of the total design area that can be occupied by cells belonging to the low threshold-voltage group. The value of the `max_lvth` can be between 0 and 100.

If you have already set the maximum percentage constraint on the low threshold-voltage cells, reset the value by using the `-reset` option.

Use the `report_threshold_voltage_group` command to report the percentages of different multivoltage cells in the design.

---

## Adaptive Leakage Power Optimization

During 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 optimization feature of 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 appropriate threshold-voltage cells that simultaneously optimize for power, timing, area, and congestion.

The adaptive leakage optimization feature is enabled by default and it gets enabled when you use the `-power` option of the `place_opt`, `clock_opt`, and `route_opt` commands. For more details on how to perform power optimization during various stages IC Compiler flow, see “[Performing Power Optimization](#)” on page 6-8.

---

## 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 path
```

- Specifying the switching activity

You can specify the switching activity 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.

---

## Setting the Options For Power Optimization

To suit your design requirements you can specify the effort and type of power optimization required, using the `set_power_options` command. The options you specify using this command are honored during the various optimization stages in the flow, such as placement, clock tree synthesis, routing and so on. However, to exercise these settings, you must use the `-power` option supported by the core commands. The `set_power_options` command has the following syntax:

```
set_power_options
[-default]
[-leakage true | false]
[-dynamic true | false]
[-low_power_placement true | false]
[-clock_gating true | false]
[-leakage_effort low | high]
[-dynamic_effort low | high]
```

When you use the `-default` option, only leakage power optimization is enabled. Any settings that you specified previously are lost. This is because the default value of the `-leakage` option is `true`. The default value of the `-dynamic` option is `false`.

You can also specify the effort for both leakage and dynamic power optimization using the `-leakage_effort` and `-dynamic_effort` options, respectively. While the default value of the `-leakage_effort` option is `high`, the default value of the `-dynamic_effort` option is `low`.

When you set the `-low_power_placement` option to `true`, IC Compiler performs power-aware placement during placement optimization. The default value of this option is `false`. For more details on power optimization during placement see, “[Low-Power Placement](#)” on page 6-8

When you set the `-clock_gating` option to `true`, IC Compiler restructures the clock gates during clock tree synthesis. The default value of this option is `false`. For more details on power optimization during clock tree synthesis, see “[Low-Power Clock Tree Synthesis](#)” on page 6-9

To see the current settings, use the `report_power_options` command.

For more details on how to power optimization, see “[Performing Power Optimization](#)” on page 6-8.

---

## Performing Power Optimization

To perform power optimization, you must first specify the options for the optimization using the `set_power_options` command as described in the section “[Setting the Options For Power Optimization](#)” on page 6-7. The options that you set using the `set_power_options` command are honored by the core commands, `place_opt`, `psyn_opt`, `clock_opt` and `route_opt`. However, you must use the `-power` option supported by these commands to enable power optimization. For leakage optimization in multicorner-multimode designs, you require additional scenario specific settings. For more details see [Chapter 14, “Using Multicorner-Multimode Technology](#).

The following sections discuss how to perform power optimization at various stages of the IC Compiler flow.

---

### Low-Power Placement

To perform low-power placement optimization, use the `-power` option of the `place_opt` command. The tool uses the adaptive leakage optimization feature to optimize for leakage power. For more details on adaptive leakage optimization, see “[Adaptive Leakage Power Optimization](#)” on page 6-6.

The options that you have set using the `set_power_options` command are honored during the placement optimization. If you have set the `-low_power_placement` option of the `set_power_options` command, to `true`, IC Compiler performs power-aware placement, based on the switching activity. The tool identifies nets with higher switching activity and tries to shorten the wire lengths of such nets. Though low-power placement reduces the overall dynamic and leakage power, the area might degrade slightly.

If you do not specify the power options using the `set_power_options` command, and you use the `-power` option of the `place_opt` command, IC Compiler performs only leakage power optimization during placement.

To perform power optimization during incremental placement, use the `-power` option of the `psynopt` command. To perform only power optimization during incremental placement, use the `-only_power` option.

```
icc_shell> psynopt -only_power
```

To perform low-power placement in the GUI, choose Placement > Core Placement and Optimization, and then select Power Optimization.

---

## Low-Power Clock Tree Synthesis

To perform power optimization during clock tree synthesis, use the `-power` option of the `clock_opt` command. The type of power optimization that is performed is determined by the settings you specified using the `set_power_options` command. If you have set the `-clock_gating` option of the `set_power_options` command to `true`, IC Compiler restructures the clock-gates during clock tree synthesis to reduce the dynamic power.

To control the power optimization during pre-clock tree synthesis, you can use the `set_optimize_pre_cts_power_options` command. This command performs power optimization before the clock tree synthesis stage. It also honors the `-clock_gating` and `-low_power_placement` options of the `set_power_options` command.

---

## Low-Power Routing

When you use the `-power` option of the `route_opt` command IC Compiler performs topology-based leakage power optimization. It uses the adaptive leakage power optimization feature to reduce the leakage power. For more details on adaptive leakage power optimization, see “[Adaptive Leakage Power Optimization](#)” on page 6-6.

During incremental routing, you can use the `-only_power_recovery` option to perform leakage power optimization.

Alternatively, in the GUI, choose Route > Core Routing and Optimization, and then select Perform Power Optimization.

---

## Power Optimization Flow Example

The following example script shows how to set the power optimization options for the IC Compiler flow.

```
place_opt -power
set_power_options -low_power_placement true
place_opt -power
psynopt -power
clock_opt -power
route_opt -power
```



# 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
- 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
- Implementing Hierarchical Clock Meshes

- Removing Clock Meshes
- Performing Multicorner Clock Tree Optimization
- 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-20.

- 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-49.

- 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-103.

---

## 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 will 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 clock tree that 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 `create_clock` or `create_generated_clock`, 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-103](#).

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-9](#).

---

## 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. [Table 7-1](#) summarizes the clock tree exceptions supported by IC Compiler and the command option or GUI object used to specify them.

**Table 7-1 Clock Tree Exceptions**

| <b>Command option</b>                                                                                                                                     | <b>GUI object</b>                                                                                                                                 | <b>Description</b>                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Pin Exceptions</b>                                                                                                                                     |                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                        |
| -non_stop_pins                                                                                                                                            | “Non stop pins” field                                                                                                                             | Nonstop pins are pins through which clock tree tracing continues.<br>For more information, see “ <a href="#">Specifying Nonstop Pins</a> ” on page 7-13.                                                                                                                                                                                               |
| -exclude_pins                                                                                                                                             | “Exclude pins” field                                                                                                                              | 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-13. |
| -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” field<br>“Max delay fall” field<br>“Max delay rise” field<br>“Min delay fall” field<br>“Min delay rise” field<br>“Logic level” field | 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-14.                                                                                                                                                                                        |
| -stop_pins                                                                                                                                                | “Stop pins” field                                                                                                                                 | 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-17.                     |
| -dont_touch_subtrees                                                                                                                                      | “Don’t touch subtree pins” field                                                                                                                  | 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-17.                                                               |

*Table 7-1 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” field | 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” on page 7-18</a> .                                                                                                                               |
| <b>Cell Exceptions</b>      |                           |                                                                                                                                                                                                                                                                                                                                                                |
| -dont_size_cells            | “Don’t size cells” field  | 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” on page 7-18</a> .                                                                                                                                                                          |
| -size_only_cells            | “Size only cells” field   | 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” on page 7-19</a>                                                                                                                                          |
| <b>Hierarchy Exceptions</b> |                           |                                                                                                                                                                                                                                                                                                                                                                |
| -preserve_hierarchy         |                           | 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” on page 7-19</a> |

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 as follows:

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.

To remove clock tree exceptions, use the `remove_clock_tree_exceptions` command or choose Clock > Remove Clock Tree Exceptions in the GUI.

To see the clock tree exceptions defined for your design, generate a clock tree exceptions report by running the `report_clock_tree -exceptions` command or by choosing choose Clock > Report Clock Tree in the GUI and selecting Exceptions.

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.

---

## 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-4](#).

*Figure 7-4 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-36.

**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-2](#) describes the edge-aware float pin behavior.

*Table 7-2 Edge-Aware Float Pins Delays*

| Options specified                                                                                                                                                                                    | Active edge          | Comments                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fall delays only:<br><code>-float_pin_max_delay_fall</code><br><code>-float_pin_min_delay_fall</code>                                                                                                | 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><code>-float_pin_max_delay_rise</code><br><code>-float_pin_min_delay_rise</code>                                                                                                | 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><code>-float_pin_max_delay_fall</code><br><code>-float_pin_max_delay_rise</code><br><code>-float_pin_min_delay_fall</code><br><code>-float_pin_min_delay_rise</code> | 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><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 above 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-5](#):

```
# 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-5* *Float Pin Timing*



For an example of defining float pins, see [“Handling Hard Macro Cells” on page 7-48](#).

To remove the float pin definition from a pin, use the `remove_clock_tree_exceptions -float_pins` command.

---

## 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 will 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-6](#).

*Figure 7-6 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-3** 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-3 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)     |
| 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`.

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.

## Specifying Clock Tree Synthesis Options

[Table 7-4](#) 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-4](#) summarizes the clock tree synthesis options supported by IC Compiler and the command option or GUI object used to specify them.

*Table 7-4 Clock Tree Synthesis Options*

| Option                                                                                                                         | Scope               | Default         | Description                                          |
|--------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------|------------------------------------------------------|
| <b>Clock Tree Selection Options</b>                                                                                            |                     |                 |                                                      |
| -clock_trees<br>("Clock tree" field)                                                                                           | N/A                 | All clock trees | Specifies the clock trees that the options apply to. |
| <b>Clock Tree Design Rule Constraints</b><br>(see “ <a href="#">Setting Clock Tree Design Rule Constraints</a> ” on page 7-26) |                     |                 |                                                      |
| -max_capacitance<br>("Max capacitance" field in the "Target and CTO" tab)                                                      | global or per-clock | 0.6 pF          | Specifies the maximum capacitance constraint.        |
| -max_fanout<br>("Max fanout" field in the "Target and CTO" tab)                                                                | global or per-clock | 2000            | Specifies the maximum fanout constraint.             |
| -max_transition<br>("Max transition" field in the "Target and CTO" tab)                                                        | global or per-clock | 0.5 ns          | Specifies the maximum transition time constraint.    |

**Table 7-4 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-28)       |                     |                                     |                                                                                                    |
| -target_skew<br>(“Target skew” field in the “Target and CTO” tab)                                           | global or per-clock | 0                                   | Specifies the maximum skew goal.                                                                   |
| -target_early_delay<br>(“Target early delay” field in the “Target and CTO” tab)                             | global or per-clock | 0                                   | Specifies the minimum insertion delay goal.                                                        |
| <b>Clock Tree Level Restrictions</b> (see “ <a href="#">Setting Level Restrictions</a> ” on page 7-29)      |                     |                                     |                                                                                                    |
| -max_buffer_levels<br>(“Max buffer levels” field in the “Target and CTO” tab)                               | global or per-clock | 20                                  | Specifies the maximum number of clock tree levels.                                                 |
| <b>Clock Tree Routing Options</b> (see “ <a href="#">Setting Clock Tree Routing Options</a> ” on page 7-29) |                     |                                     |                                                                                                    |
| -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” field 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. |

**Table 7-4 Clock Tree Synthesis Options (Continued)**

| Option                                                                                                                        | Scope               | Default                                 | Description                                          |
|-------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------------------------------|------------------------------------------------------|
| <b>Boundary Cell Insertion</b> (see “ <a href="#">Inserting Boundary Cells</a> ” on page 7-34)                                |                     |                                         |                                                      |
| -insert_boundary_cell<br>(“Insert boundary cell” check box)                                                                   | global              | Disabled                                | Enables boundary cell insertion.                     |
| <b>Clock Tree Clustering</b><br>(see “ <a href="#">Selecting the Clock Tree Clustering</a> ” on page 7-35)                    |                     |                                         |                                                      |
| -ocv_clustering<br>(“OCV clustering” check box)                                                                               | global              | Clustering based on minimum wire length | Selects clustering based on on-chip variation (OCV). |
| <b>Logic Level Balancing</b> (see “ <a href="#">Enabling Logic-Level Balancing</a> ” on page 7-36)                            |                     |                                         |                                                      |
| -logic_level_balance<br>(“Logic level balance” check box)                                                                     | global              | Disabled                                | Enables logic-level balancing.                       |
| <b>Embedded Clock Tree Optimizations</b><br>(see “ <a href="#">Specifying Clock Tree Optimization Options</a> ” on page 7-39) |                     |                                         |                                                      |
| -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.           |
| -delay_insertion<br>(“Delay insertion” check box)                                                                             | global or per-clock | Disabled                                | Enables delay insertion during optimization.         |
| -gate_relocation<br>(“Gate relocation” check box)                                                                             | global or per-clock | Enabled                                 | Enables gate relocation during optimization.         |

**Table 7-4 Clock Tree Synthesis Options (Continued)**

| Option                                                                                                                      | Scope               | Default  | Description                                                                                    |
|-----------------------------------------------------------------------------------------------------------------------------|---------------------|----------|------------------------------------------------------------------------------------------------|
| <code>-gate_sizing</code><br>("Gate sizing" check box)                                                                      | global or per-clock | Disabled | Enables gate sizing during optimization.                                                       |
| <b>Clock Tree Configuration File Options</b><br>(see " <a href="#">Inserting User-Specified Clock Trees</a> " on page 7-43) |                     |          |                                                                                                |
| <code>-config_file_read</code><br>("Read file" field in "Configuration files" box)                                          |                     |          |                                                                                                |
| <code>-config_file_write</code><br>("Write file" field in "Configuration files" box)                                        | global              | None     | Specifies the clock configuration file to read.                                                |
|                                                                                                                             |                     |          | Specifies the name of the clock configuration file that is written after 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 clock tree synthesis options to their default values, 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-5](#) 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-5 Clock Tree Synthesis Design Rule Constraints*

| <b>Variable Settings</b>      |                                                                                                                                                                       |                                                                                                                                                                                                 |                                                                                           |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| <b>Design Rule Constraint</b> | 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:<br><code>cts_force_user_constraints = true</code> |
| Maximum Capacitance           | 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                                                            |
| Maximum Transition Time       | 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                                                            |
| Maximum Fanout                | 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-103](#). 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 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-58.

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 datapaths (global skew).

If you do not specify a maximum skew value, IC Compiler uses 0 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) or for all clocks (by omitting the `-clock_trees` option).

---

## Setting Level Restrictions

By default, IC Compiler allows a maximum of 20 levels in each subtree of a clock tree. If you require a different value, use the `set_clock_tree_options -max_buffer_levels` command to specify the maximum number of levels per subtree.

You can specify the maximum level count 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:

During clock tree synthesis, the maximum number of levels has priority over the clock tree design rule constraints.

For example, the following command specifies that all subtrees of the clock tree CLK are to have a maximum of four levels as shown in [Figure 7-7](#):

```
icc_shell> set_clock_tree_options -clock_trees CLK -max_buffer_levels 4
```

*Figure 7-7 Maximum Clock Buffer Levels*




---

## 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

## 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-43. Clock tree routing rules defined in a clock configuration file override those set by using `set_clock_tree_options`.

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-8](#) shows the flow of both clock shielding methodologies.

*Figure 7-8 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, use the `set_clock_tree_options` command.

The syntax is

```
set_clock_tree_options [-clock_tree_name clock_tree_name]
                      [-root pin_name]
                      [-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 stand-alone commands such as `route_global`, `route_detail`, and `route_auto`, or the `route_opt` command. After routing signal nets, you can add shielding to the routed clock nets using the `create_auto_shield` command. Alternatively, you can choose to add shielding to the routed clock nets before routing signal nets.

The syntax is

```
create_auto_shield [-nets {collection of nets}]
                   [-with_ground]
                   [-ignore_shielding_net_pins]
```

The following sample 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_tree_name CLK \
    -root [get_ports 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_auto_shield -nets $clock_nets
```

## 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-43. Clock tree layer constraints defined in a clock configuration file override those set by using `set_clock_tree_options`.

By default, IC Compiler treats this 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_droute_options -name hardMinLayerConx -value 1
```

Note:

If you have defined layer constraints on signal nets, you must reset this option to 0 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.

---

## 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-20.)
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-43.

Note:

As of version Z-2007.03-SP3, IC Compiler no longer considers the `cts_target_transition` and `cts_target_cap` values during clustering. To control the transition time and maximum capacitance constraints, use `set_clock_tree_options` to define the clock tree synthesis values for these constraints and set the `cts_force_user_constraints` variable to true.

## 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 will be 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 `-ocv_clustering` when these options are set, IC Compiler ignores the `-ocv_clustering` option. If you specify a clock tree configuration file after setting `-ocv_clustering`, 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-9](#) shows a clock tree that was synthesized using logic-level balancing.

*Figure 7-9 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-10](#).

*Figure 7-10 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 interface logic 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-11](#), IC Compiler uses four as the number of logic levels in the don't touch subtree.

*Figure 7-11 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 level information for the entire design. It does not remove 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-35

**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. To enable region-aware clock tree synthesis, set the `cts_region_aware` variable to true, changing it from its default of false.

Region-aware clock tree synthesis can identify the following region constraints:

- Logic modules with move bounds
- 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 move bounds.
2. Partitions a design into regions according to constraints such as voltage areas, plan groups, and move bounds: hard and exclusive, as shown in [Figure 7-12](#).
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-12 Design Partitions*



## Specifying Clock Tree Optimization Options

IC Compiler optimizes the clock trees by using embedded clock tree optimization during clock tree synthesis (`clock_opt` or `compile_clock_tree` command), preroute clock tree optimization (`clock_opt` or `optimize_clock_tree` command), and postroute clock tree optimization (`optimize_clock_tree` command). During these optimization phases, IC Compiler can perform several optimization tasks, which you can enable or disable by setting the appropriate options.

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-26.

---

## 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-6](#) shows the available options and their default values.

*Table 7-6 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.                                                                  |
| <code>-delay_insertion</code>   | false   | 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>       | 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-7](#). You cannot independently control these tasks for `clock_opt`.

To set the optimization options for stand-alone 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-7](#) shows the available options and their default values.

*Table 7-7 Preroute 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.                                                                  |
| <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-8](#) shows the available options and their default values.

*Table 7-8 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 4-17.

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-44.

---

### 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-30](#).

`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-33.

`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

- Hard macro cells
- Preexisting clock trees
- Non-unate gated clocks
- Integrated clock-gating (ICG) cells
- Multiple clocks (with balanced skew)
- Hierarchical designs
- Multivoltage designs
- Multimode designs

The following sections describe how to use IC Compiler clock tree synthesis with these design styles.

---

### 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-14.

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_pin [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” field 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-64.

**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 will 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-17](#).

## 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-9](#) shows how clock tree removal is affected by the structure of the clock tree.

*Table 7-9 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.                                       |
| Interface logic model (ILM)                                         | Preserved. Traversal (and clock tree removal) continues past the ILM.                                                                |
| Inverter                                                            | Removed in pairs only. If a clock tree contains a single inverter, it is not removed.                                                |
| Isolation cell                                                      | Preserved.                                                                                                                           |
| 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-13](#).

*Figure 7-13 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 not only consider the impact on power and timing, but also on clock tree QoR. The methodology that you use to insert integrated clock-gating cells (ICGs) and to optimize the clock tree depends on your power and clock tree QoR goals. For detailed information about inserting integrated clock-gating cells, see the clock-gating information in the *Power Compiler User Guide*.

## 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 -object 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-26.)

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 interface logic model.
- All fanout of the clock-gating cell is inside an interface logic 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-20).
2. Specify the clock tree synthesis options (as described in “[Specifying Clock Tree Synthesis Options](#)” on page 7-22) and exceptions (as described in “[Specifying Clock Tree Exceptions](#)” on page 7-9).
3. Enable the power optimization techniques by using the `set_power_options` command:
  - Specify `-clock_gating true` to enable physical optimization of the integrated clock-gating cells.
  - Specify `-low_power_placement true` to enable power-aware placement of the integrated clock-gating cells and registers.

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 6-6.

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 of 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 of the `set_optimize_pre_cts_power_options` command.

7. Perform clock tree power optimization.

To perform stand-alone 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-64.

**Note:**

When you run the `clock_opt -power` command, IC Compiler also performs leakage optimization and dynamic power optimization, if you have enabled these optimizations by using the `set_power_options` command.

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-56](#)

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 `size_only` 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` stand-alone command does not invoke the `psynopt` command. For more information on clock tree power optimization, see “[Optimizing for Power](#)” on page 7-54.

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-113

---

## 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 stand-alone 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-64. For information about running stand-alone interclock delay balancing, see “[Running Interclock Delay Balancing](#)” on page 7-75.

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-20.

### 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” field in the GUI). You can also assign a name to the balance group by using the `-balance_group_name` option (or the “Group name” field 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.

## 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” field in the GUI)
- `-offset_to` (or “Offset to” field in the GUI)
- `-offset_from` (or “Offset from clock” in the GUI)
- `-offset_from_group` (or “Offset from clock group” field 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” field 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.

### **Using the Clock Latency Specification**

The clock latency is specified by using the SDC `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 select “Honor latency defined in SDC” in the GUI).

---

## Hierarchical Designs Using Interface Logic Models

You can use interface logic models (ILMs) to increase the capacity and reduce the runtime for 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.

During clock tree synthesis and optimization, IC Compiler

- Identifies any ILMs inside a clock tree

When a clock defined at the top level goes through an ILM, IC Compiler inserts guide buffers before the ILM clock input pin and after the ILM clock output pins. The nets between the input guide buffer and output guide buffers are marked as don't buffer nets.

- Honors clocks or generated clocks defined on an ILM port or a pin internal to the ILM

When a clock is defined on an ILM input port or in an ILM, IC Compiler inserts guide buffers after the ILM clock output pins. Clock nets within the ILM (up to the guide buffers) are marked as don't buffer nets.

- 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 explicit stop pins, exclude pins, and sink pins on an ILM port or inside an ILM

For more information about interface logic models, see [Chapter 11, “Using Interface Logic Models.”](#)

---

## 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.
- 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.

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 (listed above) 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 13, “Multivoltage Design Flow.”](#)

---

## Multicorner-Multimode Designs

To perform clock tree synthesis and optimization in a multicorner-multimode design, you must specify which scenario to use for clock tree synthesis and optimization by using the `set_cts_scenario` command. To see the current clock tree synthesis scenario, run the `get_cts_scenario` command.

For more information about multicorner clock tree optimization, see [“Performing Multicorner Clock Tree Optimization” on page 7-95.](#)

For details about working with multicorner-multimode designs, see [Chapter 14, “Using Multicorner-Multimode Technology.”](#)

## 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-14](#), 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-14 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

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-103.

---

## 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, clock tree optimization, 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 throughout the clock tree synthesis and optimization process to estimate the wire delay and capacitance. For better correlation with postroute timing, you can use the integrated clock global router to estimate the wire delay and capacitance during the clock tree optimization and interclock delay balancing phases. To enable the integrated clock global router for these phases, use a high effort when you run the `clock_opt` command.

**Table 7-10** describes the options you can specify for the `clock_opt` command.

*Table 7-10 Clock Tree Synthesis and Optimization Options*

| Command option                    | GUI object                                                                               | Description                                                                                                                                                                                                                                                |
|-----------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                               | “CTS, clock routing, extraction, optimization and fix hold time violations” radio button | Selects the default <code>clock_opt</code> behavior.                                                                                                                                                                                                       |
| N/A                               | “Allow cell insertion and deletion” radio button                                         | 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>-cts_effort</code>          | “CTS effort” check box                                                                   | Selects clock tree synthesis effort: low (default) or high.                                                                                                                                                                                                |
| <code>-fix_hold_all_clocks</code> | “Fix hold time violation for all clocks” check box                                       | Fix hold time violations.                                                                                                                                                                                                                                  |
| <code>-in_place_size_only</code>  | “Minimal ECO placement changes” radio button                                             | Restrict placement and timing optimization to gate sizing only when there is enough space.<br><br>You cannot use this option with <code>-size_only</code> .<br><br>For more information, see “ <a href="#">Using Physical Optimization</a> ” on page 4-18. |
| <code>-inter_clock_balance</code> | “Balance interclock delay” check box                                                     | Enables interclock delay balancing.                                                                                                                                                                                                                        |
| <code>-no_clock_route</code>      | “Route clock nets” check box (unchecked for <code>-no_clock_route</code> )               | Do not perform clock routing.                                                                                                                                                                                                                              |

**Table 7-10 Clock Tree Synthesis and Optimization Options (Continued)**

| <b>Command option</b>              | <b>GUI object</b>                                                                                        | <b>Description</b>                                                                                                                                                                                                                  |
|------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-only_cts</code>             | “CTS only (CTS, CTO, clock routing)” radio button                                                        | Do not perform extraction, optimization, or hold time fixing.                                                                                                                                                                       |
| <code>-only_hold_time</code>       | “Fix hold timing only after CTS” check box                                                               | Perform 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)” radio button | 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.<br>For more information about scan designs in IC Compiler, see <a href="#">Chapter 5, “Design for Test.”</a>                                                                                       |
| <code>-power</code>                | “Power optimization” check box                                                                           | Perform the power optimizations enabled by <code>set_power_options</code> .<br>For more information, see <a href="#">“Handling Integrated Clock-Gating Cells” on page 7-52</a> and <a href="#">Chapter 6, “Power Optimization.”</a> |
| <code>-size_only</code>            | “Sizing changes only” radio button                                                                       | Restrict placement and timing optimization to gate sizing only.<br>You cannot use this option with <code>-in_place_size_only</code> .<br>For more information, see <a href="#">“Using Physical Optimization” on page 4-18.</a>      |
| <code>-update_clock_latency</code> | “Update real and virtual clock latencies” check box                                                      | Enables updating of clock latency values.                                                                                                                                                                                           |

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-54, 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 interface logic models (ILMs).

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 stand-alone process, using the `compile_clock_tree` command, as described in “[Performing Clock Tree Synthesis](#)” on page 7-70.

### 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 stand-alone process, using the `optimize_clock_tree` command, as described in “[Performing Clock Tree Optimization on page 7-73](#)”.

### 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-58](#)”, 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 stand-alone process, using the `balance_inter_clock_delay` command, as described in “[Running Interclock Delay Balancing on page 7-75](#)”.

### 5. Performs detail routing of the clock nets

You can also perform detail routing of the clock nets as a stand-alone process, using the `route_group -all_clock_nets` 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 stand-alone process, using the `update_clock_latency` command, as described in “[Adjusting the I/O Timing on page 7-76](#)”.

## 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 5, “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 optimization and `-power`. For more information about these options, see [Table 7-10 on page 7-65](#).

You can also run only placement and timing optimization as a stand-alone process, using the `psynopt` command. For more information about the `psynopt` command, see [“Using Physical Optimization” on page 4-18](#).

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) Performs power optimization

You can perform leakage power optimization and dynamic power optimization during the `clock_opt` process by enabling the selected optimizations with the `set_power_options` command and using the `-power` option of the `clock_opt` command. To enable leakage power optimization, use the `set_power_options -leakage` command. To enable dynamic power optimization, use the `set_power_options -dynamic` command.

## 12. (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.

After running the `clock_opt` command, analyze the results as described in [“Analyzing the Clock Tree Results” on page 7-102](#).

---

## Stand-Alone 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 stand-alone 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

The script in [Example 7-1](#) provides an example of performing clock tree synthesis and optimization by using the stand-alone capabilities. The following sections provide details about these capabilities.

*Example 7-1 Clock Tree Synthesis and Optimization Using Stand-Alone Capabilities*

```
optimize_pre_cts_power
compile_clock_tree
optimize_clock_tree
balance_inter_clock_delay
route_group -all_clock_nets
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-54](#).

### 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-64](#)) and can also be run as a stand-alone 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 if the `cts_fix_beyond_clock_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 start point to an end point 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 stand-alone 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” field).

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.

## 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” field).

**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-20.

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-26.

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-64) and can also be run as a stand-alone process before clock routing, after clock tree routing, or after detail routing. Typically, you would perform stand-alone clock tree optimization when timing optimization or incremental placement disturbs the clock skew or clock insertion delay.

To perform stand-alone clock tree optimization, use the `optimize_clock_tree` command or choose Clock > Optimize Clock Tree in the GUI.

IC Compiler provides the following incremental optimization capabilities: buffer relocation (`-buffer_relocation` option), buffer sizing (`-buffer_sizing` option), delay insertion (`-delay_insertion` option), gate relocation (`-gate_relocation` option), and gate sizing (`-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, 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.

To run multicorner clock tree optimization, you use the `-enable_multicorner` option to specify at least one corner before running either the `clock_opt` or `optimize_clock_tree` command. IC Compiler automatically enables the integrated clock global router and sets the `-clock_arnoldi` option, as shown in the following example:

```
icc_shell> set_clock_tree_optimization_options -enable_multicorner all
icc_shell> clock_opt
```

or

```
icc_shell> set_clock_tree_optimization_options -enable_multicorner all
icc_shell> optimize_clock_tree
```

For more information about multicorner clock tree optimization, see “[Performing Multicorner Clock Tree Optimization](#)” on page 7-95.

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-11](#) shows the supported routing stage keywords.

*Table 7-11 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.

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.

### **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-64) or as a stand-alone process.

For information about defining the interclock delay balancing requirements, see “[Balancing Multiple Clocks](#)” on page 7-58.

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 stand-alone interclock delay balancing, use the `balance_inter_clock_delay` command or choose Clock > Balance Interclock Delay in the GUI.

## 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.

## 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-15](#) 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-15 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-16 shows the flow to follow when IC Compiler is used to create clock meshes.

Figure 7-16 IC Compiler Clock Mesh Flow



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](#)
- 

## **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 will be 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 `remove_clock_gating` 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 `split_clock_net -isolate` 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 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 select 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-17](#) shows an example of a resulting clock mesh using the `-num_straps {5 5}` option.

*Figure 7-17 A Clock Mesh Created with the `-num_straps {5 5}` Option*



[Figure 7-18](#) shows an example of a clock mesh that is created on the clk net.

*Figure 7-18 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
```

## 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-19](#) shows an example of a resulting mesh after inserting mesh drivers.

*Figure 7-19 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. 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 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 -name
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 \
    -config {{-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-20](#) shows an example of a clock mesh with mesh drivers and premesh trees.

*Figure 7-20 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-83](#) 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 will 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.

For a net that has one driver and four loads, you can create an H-shape route. The following example shows an H-shape route by using the M7 metal layer for vertical wires and the M6 layer for horizontal wires for the routing topology. When the topology is finished, IC Compiler invokes the comb router to connect the pins. The comb router might choose layers other than M6 and M7 to ensure a DRC-clean design.

```
icc_shell> route_htree -nets [get_nets {ccc*L3_net* ccc*L2_net*}] \
    -layer {M6 M7} -orientation {H}
```

For a net that has one driver and two loads, you can 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` to create a T-shape route.

[Figure 7-21](#) shows the premesh tree structure of H-shape routes.

*Figure 7-21 H-Tree Structure*



---

## Routing Clock Nets

After you complete the routing of mesh drivers and premesh trees, perform detail routing of the clock nets by using `route_group -all_clock_nets` command or choose Route > Net Group Routing in the GUI.

---

## 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-85](#) for more information.
- You must complete the routing of the clock network.
- If you want to use Star-RCXT for extraction and for signoff accuracy, define Star-RCXT 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 Star-RCXT 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 multcorner-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_file` option.

If your clock tree has multi-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-16 on page 7-79](#), 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. 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.

---

### 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, refer to the “[Prerequisites for Creating Clock Meshes](#)” on page [7-78](#).

---

### 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-16](#) 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-22](#) shows the design flow for implementing hierarchical clock mesh.

*Figure 7-22 Design Flow for Implementing Hierarchical Clock Mesh*



---

## Removing Clock Meshes

To remove the clock mesh of a clock, use the `remove_clock_mesh` command. This 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-12](#) describes the options of the `remove_clock_mesh` command.

*Table 7-12 remove\_clock\_mesh Command Options*

| To do this                                  | Use this option          |
|---------------------------------------------|--------------------------|
| Specify a list of clock trees to be removed | <code>-clock_tree</code> |
| Remove the premesh tree                     | <code>-premesh</code>    |
| Remove the routes of the premesh tree       | <code>-route_only</code> |
| Remove the postmesh tree                    | <code>-postmesh</code>   |
| Remove the routes of the clock mesh         | <code>-clockmesh</code>  |

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.

---

## 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 (`-clock_arnoldi`) to obtain the best clock network correlation and to ensure accurate insertion delay and skew.

---

### Specifying Corners for Optimization

To run multicorner clock tree optimization, you must first specify scenario corners by either using `set_clock_tree_optimization_options -enable_multicorner` (or choosing Clock > Set Clock Tree Optimization Options to select the Specify Multicorner Optimization check box in the GUI). If you do not specify any scenario corner, IC Compiler assigns the corner that is the maximum corner of the default clock tree synthesis scenario.

IC Compiler determines the default clock tree synthesis scenario as follows:

- Use the clock tree synthesis scenario as the default if the default is defined.
- Use the current scenario as the default if the clock tree synthesis scenario is not defined.
- Use both the maximum and minimum corners of regular synthesis if no other scenario is defined.

Every scenario has a maximum and minimum corner. For example, to specify both the maximum and minimum corners of the default clock tree synthesis scenario, enter the following command:

```
icc_shell> set_clock_tree_optimization_options \
    -enable_multicorner "default:max default:min"
```

If you want to use a scenario other than the default clock tree synthesis one, you can specify the scenarios that you define such as `scn1` and `scn2`, as shown in the following example. For more information about defining a scenario, see [“Using the Clock Tree Synthesis Scenario” on page 14-21](#). Note that IC Compiler first uses the maximum corner of the default clock tree synthesis scenario to optimize a design even if the maximum corner is not specified or the default clock tree synthesis scenario is not active. Therefore, five corners are used for multicorner clock tree optimization in the following example:

```
icc_shell> set_clock_tree_optimization_options \
    -enable_multicorner "scn1:max scn1:min scn2:max scn4:min"
```

To use both the maximum and minimum corners of all active scenarios, including the maximum corner of the default clock tree synthesis scenario, enter the following command:

```
icc_shell> set_clock_tree_optimization_options -enable_multicorner all
```

If two corners contain the identical library, process, voltage, temperature, and TLUPlus model specifications, IC Compiler performs only one optimization process.

Note:

Clock definitions and exceptions are taken from either the clock tree synthesis scenario or the current scenario if the clock tree synthesis scenario is not defined (By default, the clock tree synthesis scenario is the scenario you set up to run `optimize_clock_tree`). The library, process, voltage, temperature, and TLUPlus model information are taken from the scenarios specified by the `-enable_multicorner` option.

---

## Specifying Corners Using Multicorner-Multimode Scenarios

You can use multicorner-multimode scenarios to specify clock tree optimization corners. Each multicorner-multimode scenario has two corners: one maximum and one minimum corner. For each corner, you define an operating condition and parasitic information files, using the `set_operating_conditions` command and the `set_tlu_plus_files` command respectively. For each scenario, you associate the cell libraries of both maximum and minimum corners, using the `set_scaling_lib_group` command, not the `set_min_library` command. The `set_min_library` command, which associates a maximum library with a minimum library across all scenarios, is not scenario-specific; therefore, you use the `set_scaling_lib_group` command instead. The following shows an example of one scenario declaration:

```
icc_shell> define_scaling_lib_group -name slow $lib_slow
icc_shell> define_scaling_lib_group -name fast $lib_fast
icc_shell> create_scenario scn1
icc_shell> set_operating_conditions -max $opcond_slow -min $opcond_fast
icc_shell> set_tlu_plus_files -max_tluplus $tlu_high_r \
           -min_tluplus $tlu_low_r -tech2itf_map $tlu_map
icc_shell> set_scaling_lib_group -max slow -min fast
```

---

## Specifying Constraints for Multicorner Optimization

IC Compiler applies the same design rule constraints that clock tree optimization uses to all corners that you specify during multicorner clock tree optimization except the following:

- Float pin constraints
- Skew target goals

### Setting Float Pin Constraints

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
```

## Setting Skew Target Goals

By default, you specify the same skew target goal for all corners using the following command:

```
icc_shell> set_clock_tree_options -target_skew 0.050
```

You can specify various skew target goals for different corners in a multicorner-multimode design as follows:

```
icc_shell> set_clock_tree_options -corner_target_skew \
"scn1:max=0.100 scn_cts:max=0.050 scn2:min=0.070"
```

---

## Generating Multicorner Optimization Report

To generate a clock tree report for a particular scenario corner, you use the `current_scenario` command to set your current scenario before running the `report_clock_tree` command. For example, to report clock trees of scn1, scn2, and scn3 scenarios, enter the following:

```
icc_shell> set_cts_scenario scn1
icc_shell> optimize_clock_tree
icc_shell> current_scenario scn1
icc_shell> report_clock_tree
icc_shell> report_clock_tree -op min

icc_shell> current_scenario scn2
icc_shell> report_clock_tree
icc_shell> report_clock_tree -op min

icc_shell> current_scenario scn3
icc_shell> report_clock_tree
icc_shell> report_clock_tree -op min
```

Note:

When running the `optimize_clock_tree` command during multicorner clock tree optimization, IC Compiler automatically uses the high effort level, enables the integrated clock global router, and sets the `clock_arnoldi` option.

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
```

---

## Performing Clock Routing After Multicorner Optimization

After you finish multicorner clock tree optimization, you can perform clock routing using either the classic router or Zroute.

The classic router supports both the integrated clock global routing and balanced-mode routing. To achieve the best correlation results when using multicorner clock tree optimization, IC Compiler enables the integrated clock global router and saves clock global routing information in the Milkway database. 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 set the global route incremental model automatically.

For information about using Zroute to perform clock routing, see the *IC Compiler Zroute User Guide*.

---

## A Sample Script

The following sample script shows an example of running multicorner clock tree optimization:

```
create_scenario scn_cts
set_operating_conditions \
    -max $opcond_slow -max_library $lib_slow \
    -min $opcond_fast -min_library $lib_fast
set_tlu_plus_files \
    -max_tluplus $tlu_high_r \
    -min_tluplus $tlu_low_r \
    -tech2itf_map $tlu_map
```

```
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_options \
    -corner_target_skew "scnf1:max=0.100 scn_cts:max=0.050 scn2:min=0.070"
set_clock_tree_optimization_options \
    -enable_multicorner "scn1:max scn1:min scn2:max scn2:min"

set_cts_scenario scn_cts
optimize_clock_tree

current_scenario scn_ctl
report_clock_tree
report_clock_tree -op min

current_scenario scn1
report_clock_tree
report_clock_tree -op min

current_scenario scn2
report_clock_tree
report_clock_tree -op min

route_group -all_clock_nets
```

---

## 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 the batch mode with `compile_clock_tree`:

```
icc_shell> cts_batch_mode_enable  
icc_shell> compile_clock_tree -clock c1  
icc_shell> compile_clock_tree -clock c2  
icc_shell> cts_batch_mode_status  
...  
icc_shell> compile_clock_tree -clock c3  
...  
icc_shell> cts_batch_mode_disable
```

The `reset_cts_batch_mode` command disables the 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 the batch mode or normal mode.

Using the batch mode for `compile_clock_tree` 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 `skew_opt`, `get_attribute`, `set_attribute`, `insert_buffer`, `remove_buffer`, `save_mw_cel`, `set_clock_tree_references`, and `latency` commands.

To use the batch mode with `clock_opt`, 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 `clock_opt`, the average runtime improvement is about 5 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-103](#))
- Analyzing the clock tree timing (as described in “[Analyzing Clock Timing](#)” on [page 7-105](#))
- Verifying the placement of the clock instances, using the IC Compiler GUI (as described in “[Analyzing Clock Trees in the GUI](#)” on [page 7-105](#))

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-124](#).

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-26](#).

- 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-28](#).

- User-defined level restrictions (maximum level count)

For more information about user-defined level restrictions, see “[Setting Level Restrictions](#)” on [page 7-29](#).

- 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. To limit the report to specific clock trees, use the `-clock_trees`. To generate the report for a specific operating condition, use the `-operating_condition` option. [Table 7-13](#) shows the clock tree reports that are supported by IC Compiler.

*Table 7-13 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 interface logic models, and nets connected to boundary cells or pad cells. |
| All DRC violators              | <code>-all_drc_violators</code><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                     | <code>-exceptions</code><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              | <code>-level_info</code><br>“Level information” check box                                | Reports on the structural and timing characteristics for all levels of the clock trees.                                                                                                                                                                                                                                                                                  |

*Table 7-13 Clock Tree Reports (Continued)*

| <b>Report type</b> | <b>Command option<br/>GUI object)</b>                                                         | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                                                                                                                                                                                                                                                                                                                                                                                 |
| Structure          | -structure<br>“Clock tree structure” radio button                                             | Lists the structure of the clock tree.                                                                                                                                                                                                                                                                                                                                                                       |
|                    | -partial_structure_within_exceptions<br>“Clock tree structure within exceptions” radio button | 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.                                                                                                                                                                                                                                                        |
| Summary            | -summary<br>“Summary” check box                                                               | Reports the global clock skew summary.                                                                                                                                                                                                                                                                                                                                                                       |

---

## Analyzing Clock Timing

The timing characteristics of the clock network are important in any high-performance design. To obtain detailed information on 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-14](#) 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, include the `-cts_mode` switch. IC Compiler gathers the requested information and reports it in the specified order.

*Table 7-14 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>         |

---

## 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

- Fanin and fanout schematics

The following sections describe these windows.

## **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-15](#) describes the clock tree display choices. You must select at least one level or cell type.

*Table 7-15 Clock Tree Display Choices*

| Partition name           | Description                                                       |
|--------------------------|-------------------------------------------------------------------|
| 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. |

*Table 7-15 Clock Tree Display Choices (Continued)*

| <b>Partition name</b> | <b>Description</b>                                                  |
|-----------------------|---------------------------------------------------------------------|
| 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-23](#), 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-23 Browsers Toolbar*



The Expand Browser toolbar, shown in [Figure 7-24](#), 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-24 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

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 cursor 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 above two ways 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

## 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](#)

The following sections describe these methods.

---

## 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 interface logic 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 will only adjust the latency 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` 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` 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_clk 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_group -all_clock_nets
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_group -all_clock_nets
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-26](#) shows the flow to follow when IC Compiler is used to define skew groups.

*Figure 7-25 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.
- Only one level of dependency is allowed between skew groups.

For example, skew group A is dependent on skew group B, so no skew groups should be dependent on skew group A.

- No dependency loop between skew groups is allowed.

For example, skew group A is dependent on skew group B, and skew group B should not be dependent on other skew groups.

- If one skew group is dependent on other skew groups, only one of which is allowed to have independent subtrees.

For example, skew group A is dependent on skew groups B, C, and D, so only one skew group out of B, C, and D is allowed to have independent subtrees.

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-26](#).

```
icc_shell> set_skew_group -name grp1 {reg_0_/CLK gen_ck_reg_1_/CLK}
```

*Figure 7-26 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-50). 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-64) or by using stand-alone clock tree synthesis (as described in “[Performing Clock Tree Synthesis](#)” on page 7-70).

---

## 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” field). 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” field). 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-29.

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-16](#) shows the capabilities supported by interactive clock tree synthesis and the menu option used to invoke this capability.

*Table 7-16 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

---

This chapter describes the routing capabilities of the IC Compiler classic router. For information about Zroute, see the *IC Compiler Zroute User Guide*.

This chapter contains the following sections:

- [Prerequisites for Routing](#)
- [Checking Routability](#)
- [Setting Up for Routing](#)
- [Routing Critical Nets](#)
- [Routing Signal Nets](#)
- [Shielding Nets](#)
- [Performing ECO Routing](#)
- [Reporting Cell Placement and Routing Statistics](#)
- [Verifying the Routed Design](#)
- [Routing Nets and Buses in the GUI](#)
- [Postroute RC Extraction](#)

---

## Prerequisites for Routing

Before you can 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.

If you are using the IC Compiler package, which includes routing, you can perform routing and postroute optimization with IC Compiler. If you are using the IC Compiler-PC package, you need to export the design (see “[Saving the Design](#)” on page [3-38](#)) so that you can perform routing with another tool.

---

## 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 cell in your design (*top\_cell\_name.err*), with a list of violations 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-50](#) and the “Examining Routing and Verification Errors” topic in IC Compiler Help.

---

## Setting Up for Routing

You can specify general routing setups for the classic router to use whenever you perform routing. The following sections describe how to specify these setups:

- [Specifying Route Guides](#)
  - [Defining Routing Blockages](#)
  - [Setting the Preferred Routing Direction](#)
  - [Using Nondefault Routing Rules](#)
  - [Specifying the Routing Layers](#)
  - [Setting Net Aggressors](#)
  - [Setting Routing Types](#)
  - [Setting Routing Options](#)
  - [Setting Signal Integrity Options](#)
  - [Enabling Distributed Routing](#)
- 

## Specifying Route Guides

You can create or remove route guides that do the following for a specific area of your design:

- Prevent routing for signal or prerouted nets
- Change the wiring direction
- Control wiring density
- Fix violations

To create a route guide, use the `create_route_guide` command (or choose Floorplan > Create Route Guide in the GUI). [Table 8-1](#) defines the `create_route_guide` options. For more information about these options, see the man page.

*Table 8-1 create\_route\_guide Command Options*

| <b>Command option</b>                                 | <b>GUI object</b>                                         | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-name name</code>                               | Name box                                                  | Specifies the name of the route guide.                                                                                                                                                                                                                                                                                                                                                                                            |
| <code>-repair_as_single_sbox</code>                   | “Repair as single SBox” check box                         | Enables fixing of violations.                                                                                                                                                                                                                                                                                                                                                                                                     |
| <code>-no_signal_layers layers</code>                 | “No signal route on layers” check box and list            | Prevents the routing of signal wires on the specified layers.                                                                                                                                                                                                                                                                                                                                                                     |
| <code>-zero_min_spacing</code>                        | “Zero min-spacing” check box                              | Allows the routing of wires within the keepout margin of the route guide.                                                                                                                                                                                                                                                                                                                                                         |
| <code>-no_preroute_layers layers</code>               | “No automatic preroutes on layers” check box and list     | Prevents automatic preroutes on the specified layers.                                                                                                                                                                                                                                                                                                                                                                             |
| <code>-preferred_direction_only_layers layers</code>  | “Layers with preferred direction only” check box and list | Specifies the layers that must be routed in the preferred direction.                                                                                                                                                                                                                                                                                                                                                              |
| <code>-horizontal_track_utilization percentage</code> | Horizontal box in “Route track utilization” section       | Specifies the allowable horizontal track utilization.                                                                                                                                                                                                                                                                                                                                                                             |
| <code>-vertical_track_utilization percentage</code>   | Vertical box in “Route track utilization” section         | Specifies the allowable vertical track utilization.                                                                                                                                                                                                                                                                                                                                                                               |
| <code>-coordinate rectangle</code>                    | Coordinates box                                           | Specifies the coordinates for the route guide.<br><br>In 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.<br><br>From the command line, the snapping is controlled by the <code>set_object_snap_type</code> command. |
| <code>-switch_preferred_direction</code>              | “Switch preferred direction” check box                    | Switches the preferred wiring direction.                                                                                                                                                                                                                                                                                                                                                                                          |

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 rectangular areas that encompass (`-within {{x1 y1} {x2 y2}}`) or touch (`-touch {{x1 y1} {x2 y2}}`) the guides.

To remove route guides, use the `remove_route_guides` command. You can remove a collection of route guides, such as that returned by the `get_route_guides` command; all route guides (`-all`); or a specific named route guide (`-name`).

For more information about the `get_route_guides` or `remove_route_guide` command, see its man page.

---

## Defining Routing Blockages

A routing blockage defines a region where no routing is allowed on a specific layer. You define routing blockages by using the `create_routing_blockage` command. To define a routing blockage, you must specify

- 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.

- 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.

For example, to create rectangular routing blockages on the metal1 and via1 blockage layers, enter the following command:

```
icc_shell> create_routing_blockage \
-layers {metal1Blockage via1Blockage} -bbox {x1 y1 x2 y2}
```

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`) or by using rectangular areas that encompass (`-within {{x1 y1} {x2 y2}}`) or touch (`-touch {{x1 y1} {x2 y2}}`) the blockages.

To remove routing blockages, use the `remove_routing_blockage` command.

For more information about the `get_routing_blockages` or `remove_routing_blockage` command, see its man page.

---

## 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, will override the settings made with the `set_preferred_routing_direction` command.

Use the `report_preferred_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 sample report.

### *Example 8-1 Preferred Direction Report*

```
*****
Report : Layers
Design : core_chip
Version: Y-2006.06
Date   : Thu Mar 23 03:43:06 2006
*****
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
```

## Using Nondefault Routing Rules

IC Compiler supports the use of nondefault routing rules, both for routing and for shielding. Before you can use a nondefault routing rule, you must define it. The following sections describe how to define and apply nondefault routing rules.

### Defining Nondefault Routing Rules

You define nondefault or default routing rules for specific nets by using the `define_routing_rule` command (or by choosing Route > Routing Setup > Define Routing Rule in the GUI). These rules define wire width and spacing rules and via types. [Table 8-2](#) defines the `define_routing_rule` options. For more information about these options, see the man page.

*Table 8-2 define\_routing\_rule Command Options*

| Command option                                                            | GUI object                                                                 | Description                                                           |
|---------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------|
| <code>rule_name</code>                                                    | “New rule name” box                                                        | Specifies the name of the rule. This argument is required.            |
| <code>-reference_rule_name</code><br><code>-default_reference_rule</code> | “Reference rule” section<br>Specified radio button<br>Default radio button | Specifies the name of the reference rule.<br>This option is required. |
| <code>-taper_level</code>                                                 | “Taper level” box                                                          | Specifies the tapering level.<br>The default tapering level is 1.     |

*Table 8-2 define\_routing\_rule Command Options (Continued)*

| <b>Command option</b> | <b>GUI object</b>                   | <b>Description</b>                                                                        |
|-----------------------|-------------------------------------|-------------------------------------------------------------------------------------------|
| -snap_to_track        | “Snap to track” check box           | Snaps shielding wires to the track when selected.<br>By default, snapping is not enabled. |
| -multiplier_width     | “Multiplier width” box              | Specifies the layer width multiplier.                                                     |
| -multiplier_spacing   | “Multiplier spacing” box            | Specifies the layer spacing multiplier.                                                   |
| -widths               | Metal table section<br>Width column | Specifies the width and spacing rules.                                                    |
| -spacings             | Spacing column                      |                                                                                           |
| -shield_widths        | “Shield width” column               |                                                                                           |
| -shield_spacings      | “Shield spacing” column             |                                                                                           |
| -via_cuts             | “Contact table” section             | Specifies the via types.                                                                  |

## Applying Nondefault Routing Rules

To apply a net 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-3](#) defines the `set_net_routing_rule` options. For more information about these options, see the man page.

*Table 8-3 set\_net\_routing\_rule Command Options*

| <b>Command option</b>                                                                     | <b>GUI object</b>          | <b>Description</b>                                                              |
|-------------------------------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------|
| <code>list_of_nets</code>                                                                 | Nets box                   | Specifies the nets to which to apply the rule.<br>This argument is required.    |
| <code>-rule rule_name</code>                                                              | “Routing rule” box         | Specifies the name of the nondefault rule to apply.<br>This option is required. |
| <code>-top_layer_probe</code><br><code>AnyPort   OutPort  </code><br><code>AllPort</code> | “Top layer probe mode” box | Specifies which ports to use for top-layer probing.<br>The default is AnyPort.  |

*Table 8-3 set\_net\_routing\_rule Command Options (Continued)*

| Command option                            | GUI object                        | Description                                                                                                                                                                                                                 |
|-------------------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -reroute normal  <br>minorchange   freeze | “Net re-routability” box          | Specifies when to reroute nets.<br>The default is normal.                                                                                                                                                                   |
| -timing_driven_spacing                    | “Timing driven spacing” check box | When timing-driven spacing is enabled, IC Compiler adds space between critical nets and nets that are parallel to them to reduce the intralayer coupling capacitances.<br>By default, timing-driven spacing is not enabled. |

## Reporting Nondefault Routing Rules

To report the nets that have nondefault routing rules, use the `report_net_routing_rules` command.

```
icc_shell> report_net_routing_rules [get_nets *]
```

In addition, 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.

---

## 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 setting the `hardMaxLayerConx` detail 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 setting the `hardMinLayerConx` detail route option. This option applies to both to 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).

[Table 8-4](#) shows the `set_ignored_layers` options. For more information about these options, see the man page.

*Table 8-4 set\_ignored\_layers Command Options*

| Command option                                   | GUI object                                              | Description                                                                                                                                          |
|--------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-min_routing_layer name</code>             | “Minimum routing layer” check box and list              | Specifies the lowest routing layer. IC Compiler uses the specified layer and the layers above it for routing.                                        |
| <code>-max_routing_layer name</code>             | “Maximum routing layer” check box and list              | Specifies the highest routing layer. IC Compiler uses the specified layer and the layers below it for routing.                                       |
| <code>-rc_congestion_ignored_layers names</code> | “Select layers to be ignored in RC computation” section | Specifies the layers to ignore for RC and congestion estimation.<br>By default, RC and congestion estimation use the layers you specify for routing. |

For example, to define layers M2 through M7 for routing, use the following command:

```
icc_shell> set_ignored_layers \
      -min_routing_layer M2 -max_routing_layer M7
```

To define the same layers for routing and to force the RC and congestion estimation functions to ignore the M1, M2, M8, and M9 layers, 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}
```

## 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).

[Table 8-5](#) shows the `set_net_routing_layer_constraints` options. For more information about these options, see the man page.

*Table 8-5 set\_net\_routing\_layer\_constraints Command Options*

| Command option                    | GUI object                   | Description                                                                                                                       |
|-----------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| <code>nets</code>                 | “Specified nets” box         | Specifies the nets to which to apply the routing constraints.<br>This argument is required.                                       |
| <code>-min_layer_name name</code> | “Minimum routing layer” list | Specifies the lowest routing layer. IC Compiler uses the specified layer and the layers above it for routing the specified nets.  |
| <code>-max_layer_name name</code> | “Maximum routing layer” list | Specifies the highest routing layer. IC Compiler uses the specified layer and the layers below it for routing the specified nets. |

For example, to define layers M2 through M7 for routing net n1, use the following command:

```
icc_shell> set_net_routing_layer_constraints -min_layer_name M2
-max_layer_name M7 [get_nets n1]
```

---

## Setting Net Aggressors

To minimize crosstalk-induced noise, you can specify the aggressors for a victim net. Crosstalk prevention during postroute optimization uses that information to minimize the crosstalk-induced noise from the aggressor nets.

To specify aggressors for a victim net, use the `set_net_aggressors` command (or choose Route > Routing Setup > Set Net Aggressors in the GUI). To specify the victim net, use the `-victim_net` option (or the “Victim net” box in the GUI). To specify the aggressor nets, use the `-aggressor_nets` option (or the “Aggressor nets” box in the GUI).

---

## Setting Routing Types

For debugging, you can set or change the routing types of wires, vias, or paths to indicate which classic router routing engine is to route them.

To specify a routing of any type, use the `set_route_type` command (or choose Route > Routing Setup > Set Route Type in the GUI).

- For signal nets, you can specify the following route types: `detail_route` or `user`.

```
icc_shell> set_route_type -signal type objects
```

- For clock nets, you can specify the following route types: `ring`, `strap`, `tie_off`, or `user`.

```
icc_shell> set_route_type -clock type objects
```

- For power and ground nets, you can specify the following route types: `ring`, `strap`, `tie_off`, `user`, `std_cell_pin_conn`, or `macro/IO_pin_conn`.

```
icc_shell> set_route_type -pg type objects
```

To remove a routing type, use the `remove_route_by_type` command (or choose Route > Delete Route in the GUI).

---

## Setting Routing Options

You can specify options that control how the classic router performs global routing, track assignment, and detail routing, as well as miscellaneous routing options.

- To set routing options, use the `set_route_options` command (or choose Route > Routing Setup > Set Route Options in the GUI). To reset the options to their default values, use `set_route_options -default` (or click Default in the GUI).
- To report the settings of all routing options, use the `report_route_options` command.

Note:

You can set additional global route options by using the `set_groute_options` command. You can set additional detail route options by using the `set_droute_options` command. For more information about these commands, see the man pages.

**Table 8-6** lists the routing options set by the `set_route_options` command.

*Table 8-6 set\_route\_options Command Options*

| Option                                                                               | Valid values                                                    | Description                                                                                                   |
|--------------------------------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| <b>Global routing options (Global Routing tab in the GUI)</b>                        |                                                                 |                                                                                                               |
| <code>-groute_skew_control</code><br>("Skew control" check box in the GUI)           | <code>true</code>   <code>false</code>                          | Enables (true) or disables (false) skew control during global routing.<br>The default is <code>false</code> . |
| <code>-groute_skew_weight</code><br>("Skew control Weight" box in the GUI)           | <code>int</code><br>(must be between 1 and 10)                  | Specifies the weight associated with skew control.<br>The default is 5.                                       |
| <code>-groute_timing_driven</code><br>("Timing driven" check box in the GUI)         | <code>true</code>   <code>false</code>                          | Enables (true) or disables (false) timing-driven global routing.<br>The default is <code>false</code> .       |
| <code>-groute_timing_driven_weight</code><br>("Timing driven Weight" box in the GUI) | <code>int</code><br>(must be between 1 and 7)                   | Specifies the weight associated with timing-driven global routing.<br>The default is 4.                       |
| <code>-groute_congestion_weight</code><br>("Congestion weight" box in the GUI)       | <code>int</code><br>(must be between 1 and 12)                  | Specifies the weight associated with congestion-driven global routing.<br>The default is 4.                   |
| <code>-groute_clock_routing</code><br>("Clock routing" radio buttons in the GUI)     | <code>normal</code>   <code>comb</code>   <code>balanced</code> | Specifies the global-routing clock topology.<br>The default is <code>balanced</code> .                        |
| <code>-groute_incremental</code><br>(Incremental check box in the GUI)               | <code>true</code>   <code>false</code>                          | Enables (true) or disables (false) incremental global routing.<br>The default is <code>false</code> .         |

*Table 8-6 set\_route\_options Command Options (Continued)*

| Option                                                                                          | Valid values                      | Description                                                                                                  |
|-------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------|
| <b>Track assignment options (Track Assign tab in the GUI)</b>                                   |                                   |                                                                                                              |
| -track_assign_timing_driven<br>("Timing driven" check box in the GUI)                           | true   false                      | Enables (true) or disables (false) timing-driven track assignment.<br>The default is false.                  |
| -track_assign_timing_driven_weight<br>("Timing driven" Weight box in the GUI)                   | int<br>(must be between 1 and 10) | Specifies the weight associated with timing-driven track assignment.<br>The default is 1.                    |
| <b>Detail routing options (Detail Routing tab in the GUI)</b>                                   |                                   |                                                                                                              |
| -droute_connect_tie_off<br>("Connect tie off" check box in the GUI)                             | true   false                      | Enables (true) or disables (false) connection of tie-off nets during detail routing.<br>The default is true. |
| -droute_connect_open_nets<br>("Connect open nets" check box in the GUI)                         | true   false                      | Enables (true) or disables (false) connection of open nets during detail routing.<br>The default is true.    |
| -droute_reroute_user_wires<br>("Reroute user wires" check box in the GUI)                       | true   false                      | Specifies whether the router can reroute user-created wires.<br>The default is false.                        |
| -droute_CTS_nets<br>("Change CTS nets" radio buttons in the GUI)                                | normal   minor_change_only        | Specifies whether only minor changes can be made to clock nets.<br>The default is minor_change_only.         |
| -droute_single_row_column_via_array<br>("Single row column via array" radio buttons in the GUI) | center   optimize                 | Specifies how to handle via arrays that consist of a single row and single column.<br>The default is center. |

*Table 8-6 set\_route\_options Command Options (Continued)*

| Option                                                                                            | Valid values                      | Description                                                                                                          |
|---------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------|
| -droute_stack_via_less_than_min_area<br>("Stack via less than min area" radio buttons in the GUI) | forbid   add_metal_stub           | Specifies how to handle stacked via arrays that do not meet the minimum area rule.<br>The default is add_metal_stub. |
| -droute_stack_via_less_than_min_area_cost<br>("Stack via less than min area Cost" box in the GUI) | int<br>(must be between 1 and 10) | Controls the cost associated with adding metal stubs.<br>The default is 0.                                           |

**Miscellaneous options (Miscellaneous tab in the GUI)**

|                        |                          |                                                                                  |
|------------------------|--------------------------|----------------------------------------------------------------------------------|
| -poly_pin_access       | auto   off               | Controls poly pin access is handled.<br>The default is auto.                     |
| -drc_distance          | diagonal   manhattan     | Specifies how to measure distances for DRC checking.<br>The default is diagonal. |
| -same_net_notch        | ignore   check_and_fix   | Specifies whether to check the same net notch rule.<br>The default is ignore.    |
| -fat_wire_check        | quick   merge_then_check | Controls how the fat wire check is handled.<br>The default is merge_then_check.  |
| -fat_blockage_as       | thin_wire   fat_wire     | Specifies how to treat fat blockages.<br>The default is fat_wire.                |
| -wire_contact_eol_rule | ignore   check_and_fix   | Specifies whether check the end-of-line rule.<br>The default is ignore.          |

---

## Setting Signal Integrity Options

By default, the classic router does not perform crosstalk reduction. If you enable signal integrity mode, the classic router 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
```

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 `threshold_noise_ratio` common route option.

When you enable crosstalk prevention, the classic router 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.

---

## Enabling Distributed Routing

You can use distributed routing to decrease the runtime for the following routing commands:

- `route_opt`
- `route_group`
- `route_auto`
- `route_detail`
- `route_search_repair`
- `route_eco`
- `route_spreadwires`
- `insert_redundant_vias`
- `optimize_wire_via`
- `verify_route`

Note:

You can also use distributed routing for the following power and ground routing commands: `create_power_straps` and `preroute_standard_cells`. These commands are described in the *IC Compiler Design Planning User Guide*.

To perform distributed routing, you must

1. Have the appropriate licenses

To perform distributed routing using three or four CPUs, you must have the Galaxy-MultiRoute4 license. To perform distributed routing using more than four CPUs, you must have the Galaxy-MultiRoute8 license.

2. Set up the network

To set up the network for distributed routing, run the `set_distributed_route` command (or choose File > Distributed Route Jobs > Set Distributed Route in the GUI). For more information about setting up the network, see the following section, “[Setting Up the Distributed Routing Network](#).”

3. Select the partitioning method

Distributed routing divides the design into several routing partitions, based on size and congestion. These partitions are then routed on separate CPUs, in parallel, greatly reducing the overall runtime. One CPU is used to reassemble the partitions. For example, with four CPUs available, a typical runtime improvement would be a 3.5x reduction in overall routing time.

By default, the classic router uses a two-pass partitioning method. If your design is very large, you might be able to reduce runtime by using the one-pass method instead. To use the one-pass method, set the `droute_enable_one_pass_partitioning` variable to 1.

4. Invoke distributed routing

To enable distributed routing for all routing commands that support distributed routing, set the `droute_numCPUs` variable to a number greater than one before running the routing commands.

To invoke distributed routing for a specific routing command, use the `-num_cpu` option to specify multiple CPUs when you run the routing command.

Note:

If you specify both the `droute_numCPUs` variable and the `-num_cpu` command option, the value specified by the `-num_cpu` option overrides the value specified by the `droute_numCPUs` variable. In addition, the number of CPUs specified must be less than or equal to the number of CPUs defined by the `set_distributed_route` command.

## Setting Up the Distributed Routing Network

The classic router supports distributed routing operations by using either a package called *jp* to set up the communication between jobs on a network or by using resources under the control of the Load Sharing Facility (LSF) network. The following sections describe how to set up the network for distributed routing using each of these methods.

### Setting Up Distributed Routing With *jp*

To set up distributed routing with the *jp* package,

1. If you are using processors on other machines, create a *.rhosts* file in your home directory.

The *.rhosts* file specifies the remote machines that you can access (one entry per line). You might need to specify the complete host name, including the domain name.

To determine the host name to put in the *.rhosts* file,

- a. Log in the machine you want to use by using the (*rlogin*) shell command.
- b. Determine the host name by using the *finger -l* shell command.

To be safe, you can include both the simple and the complete host name for each remote machine, as shown in the following sample *.rhosts* file.

```
machineName1  
machineName1.domain.company.com  
machineName2  
machineName2.domain.company.com
```

2. Open the Milkyway design library, as described in [Chapter 3, “Preparing the Design.”](#)

3. Run the *set\_distributed\_route* command to specify the following:

- The machines to use (*-jp\_machines* option)

You can specify up to 16 machines, including the current machine.

If you are using only the current machine, you do not need to specify this option, because this is the default.

For example, to use *machineName1*, *machineName2*, and *machineName3* in addition to the current machine, enter

```
icc_shell> set_distributed_route \  
          -jp_machines {machineName1 machineName2 machineName3}
```

- The maximum number of CPUs to use on each machine (*-jp\_limit* option)

For each machine for which you want to limit the number of CPUs used, specify the machine name and the maximum number of CPUs. The machine name must match a machine specified in the *-jp\_machines* option. If you do not specify a limit for a machine, distributed routing will use all CPUs on that machine.

For example, to use a maximum of two CPUs on each machine, enter

```
icc_shell> set_distributed_route \
    -jp_limit {machineName1 2 machineName2 2 machineName3 2}
```

- The location of the executable file for each machine (-jp\_bin option)

By default, distributed routing uses the location of the current `icc_shell` executable. If the executable file for a remote machine is in a location other than the default location, you must specify the machine name and the executable location for that machine. The machine name must match a machine specified in the `-jp_machines` option.

For example, to specify the executable for `machineName1`, enter

```
icc_shell> set_distributed_route \
    -jp_bin {machineName1 /machineName1/$SYNOPSYS/bin/icc_shell}
```

where `$SYNOPSYS` is the path to the installation directory.

- The location of the Milkyway design library (-jp\_lib option)

By default, distributed routing uses the location of the current Milkyway design library. If the design library for a remote machine is in a location other than the default location, you must specify the machine name and the design library location for that machine. The machine name must match a machine specified in the `-jp_machines` option.

Note:

When using the `jp` package, you can disconnect the network used for distributed routing by using the `set_distributed_route -jp_disconnect` option. This command disconnects all previously defined remote machines. You can also use the `close_distributed_route` command to close all the sockets and shut down the daemons.

## Setting Up Distributed Routing With LSF

To set up distributed routing with LSF, run the `set_distributed_route` command to

- Select LSF as the distributed routing method (-lsf option)
- Specify the LSF bsub command options to use when submitting jobs (-lsf\_advanced option)

By default, distributed routing with LSF does not use any `bsub` options. For more control over the job submissions, you can specify the `bsub` options to use. Common `bsub` options include `-q` (the queue to which to submit the jobs), `-m` (the machines to which to submit the jobs), and `-M` (the minimum memory required). For more information about the `bsub` command options, see the LSF documentation.

## Reporting Distributed Route Jobs

To get information about a specific distributed route job, use the `report_distributed_route` command. You must use the `-job` option to identify the job to report. To get the job identification number, use a system command such as the UNIX `top` or `ps` command.

## Cancelling Distributed Route Jobs

To cancel an active distributed route job, use the `remove_distributed_route` command. You must use the `-job` option to identify the job to cancel. To get the job identification number, use a system command such as the UNIX `top` or `ps` command.

## Routing Critical Nets

You can preroute a group of nets, such as clock nets, before routing the rest of the nets in the design. Taking this step can help you find timing problems. For example, you can route clock and bus pins to prerouted clock and bus wires and then perform timing analysis on these nets. If the timing results are satisfactory, you can route the remaining nets.

To preroute a group of nets, use the `route_group` command (or choose Route > Net Group Route in the GUI). To route all clock nets, use the `-all_clock_nets` option (or select the “All clock nets” radio button in the GUI); otherwise, you can specify a collection of nets to route by using the `-nets` option (or the “Specified nets” box in the GUI).

For example, to route all clock nets, enter

```
icc_shell> route_group -all_clock_nets
```

[Table 8-7](#) lists the options for the `route_group` command.

*Table 8-7 route\_group Command Options*

| Option                                                              | Valid values | Description                                                                                                                              |
|---------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-no_global</code><br>(“Global route” check box in the GUI)    | N/A          | Skips the global routing phase.<br>By default, <code>route_group</code> performs global routing, track assignment, and detail routing.   |
| <code>-no_track</code><br>(“Track assignment” check box in the GUI) | N/A          | Skips the track assignment phase.<br>By default, <code>route_group</code> performs global routing, track assignment, and detail routing. |

**Table 8-7 route\_group Command Options (Continued)**

| <b>Option</b>                                                                                 | <b>Valid values</b>                      | <b>Description</b>                                                                                                                                                                                          |
|-----------------------------------------------------------------------------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -no_detail<br>("Detail route" check box in the GUI)                                           | N/A                                      | Skips the detail routing phase.<br>By default, <code>route_group</code> performs global routing, track assignment, and detail routing.                                                                      |
| -nets<br>("Specified nets" radio button and text box in GUI)                                  | <i>collection_of_nets</i>                | Specifies the nets to route.<br>Either this option or -all_clock_nets is required.                                                                                                                          |
| -all_clock_nets<br>("All clock nets" radio button in the GUI)                                 | N/A                                      | Routes all clock nets.<br>Either this option or -nets is required.                                                                                                                                          |
| -dont_optimize_routing_pattern<br>("Optimize routing pattern" check box in the GUI)           | N/A                                      | Disables optimization of the routing pattern.<br>By default, the routing pattern is optimized.                                                                                                              |
| -utilize_dangling_wires<br>("Utilize dangling wires" check box in the GUI)                    | N/A                                      | Enables reuse of existing dangling routes to fix open nets.<br>By default, the router does not reuse existing dangling routes.                                                                              |
| -trim_antenna_of_user_wires<br>("Trim wire segments of prerouted wires" check box in the GUI) | N/A                                      | Enables trimming for wire segments of prerouted wires.<br>By default, the router does not trim wire segments of prerouted wires.                                                                            |
| -num_cpus<br>("Clock routing" radio buttons in the GUI)                                       | <i>int</i><br>(must be between 1 and 63) | Specifies the number of CPUs to use for distributed routing. For information about setting up for distributed routing, see <a href="#">"Enabling Distributed Routing" on page 8-16</a><br>The default is 1. |

---

## Shielding Clock Nets

The classic router 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-7.

Note:

If you do not define the shielding spacing for clock nets, the classic router adds default spacing as shield spacing on clock nets.

After defining the nondefault routing rules and routing the clock nets, shield the clock nets by using the `create_auto_shield` command (or choosing Route > Create Auto Shield in the GUI). For information about shielding nets, see “[Shielding Nets](#)” on page 8-36.

---

## 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 `route_opt` core command

The `route_opt` command performs global routing, track assignment, detail routing, search and repair, and postroute optimization.

- Use automatic routing (the `route_auto` basic command)

The `route_auto` basic command performs global routing, track assignment, and detail routing.

When you run `route_auto`, the classic router reads the design database before starting routing and updates the database when all routing steps are done. If you stop auto-routing before it performs detail routing, the classic router checks the input data when you restart routing with this command.

- Use the basic commands to perform the stand-alone routing tasks

To perform global routing, use the `route_global` command. To perform track assignment, use the `route_track` command. To perform detail routing, use the `route_detail` command. To perform search and repair, use the `route_search_repair` command.

When you run a stand-alone routing command, such as `route_global` or `route_detail`, the classic router 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, the classic router 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 stand-alone routing commands instead of `route_opt` or automatic routing.

## Routing Signal Nets by Using `route_opt`

Before you use the `route_opt` command to route the signal nets, you must define the routing options, as described in “[Setting Routing Options](#)” on page 8-12 and set the `route_opt` routing and optimization strategy, as described in the following section. If logical DRC violations remain after running `route_opt`, you can use focal optimization to address these remaining violations, as described in “[Performing Focal Optimization](#)” on page 8-29.

## 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. For more information, see the man page.

*Table 8-8 set\_route\_opt\_strategy Options*

| Command option                                                                                         | Valid values                                    | Description                                                                                                                                                                                                                                              |
|--------------------------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-fix_hold_mode</code><br>(“Fix hold optimization stage” radio buttons in the GUI)                | <code>all</code>   <code>route_base</code>      | The stages for which hold optimization is performed.<br>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>-xtalk_reduction_loops</code><br>(“Maximum crosstalk reduction cycles” box in the GUI)           | <code>int</code><br>(must be between -1 and 10) | The maximum number of crosstalk reduction optimization cycles.<br>The default is 2.                                                                                                                                                                      |
| <code>-search_repair_loops</code><br>(“Maximum initial route Search and Repair cycles” box in the GUI) | <code>int</code><br>(must be between 0 and 500) | The maximum number of initial routing search and repair iterations.<br>The classic router default is 15.                                                                                                                                                 |

*Table 8-8 set\_route\_opt\_strategy Options (Continued)*

| <b>Command option</b>                                                                                                              | <b>Valid values</b>                        | <b>Description</b>                                                                                                            |
|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| <code>-eco_route_search_repair_loops</code><br>("Maximum ECO Search and Repair cycles" box in the GUI)                             | <i>int</i><br>(must be between 0 and 500)  | The maximum number of ECO search and repair iterations.<br>The classic router default is 5.                                   |
| <code>-optimize_wire_via_search_repair_loops</code><br>("Maximum ECO Search and Repair cycles" box in the GUI)                     | <i>int</i><br>(must be between 0 and 500)  | The maximum number of search and repair iterations for optimizing wires and vias.<br>The classic router default is 5.         |
| <code>-route_drc_threshold</code><br>("Route violations threshold to trigger the reduction Search and Repair loop" box in the GUI) | <i>int</i>                                 | The threshold number of routing violations before limiting search-and-repair to one iteration.<br>The default is 3000.        |
| <code>-route_run_time_limit</code><br>("Run time limit" box in the GUI)                                                            | <i>int</i><br>(must be between -1 and 500) | The maximum CPU time, in minutes, allowed for optimizing wires and vias.<br>The default is -1, which means there is no limit. |

To report your settings, use the `report_route_opt_strategy` command.

## Running route\_opt

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 not timing-driven. To enable timing-driven global routing, use the `set_route_options -groute_timing_driven true` command (or choose Route > Routing Setup > Set Route Options in the GUI and select "Timing driven" in the Global Routing tab).

- Track assignment

By default, track assignment is not timing-driven and does not do crosstalk prevention.

To enable timing-driven track assignment, use the `set_route_options -track_assign_timing_driven true` command (or choose Route > Routing Setup > Set Route Options in the GUI and select "Timing driven" in the Track Assign tab).

To enable crosstalk-prevention mode, set the signal integrity options as described in “[Setting Signal Integrity Options](#)” on page 8-16 and use the `-xtalk_reduction` or `-only_xtalk_reduction` option when you run `route_opt`.

- Detail routing

By default, detail routing is not timing-driven. To enable timing-driven detail routing, use the `set_route_options -droute_timing_driven true` command (or choose Route > Routing Setup > Set Route Options in the GUI and select “Timing driven” in the Detail Routing tab).

- Search and repair

- Postroute optimization

In addition to performing routing optimization, you can perform the following optimizations: signal integrity, leakage power, wire length and via count reduction, and area recovery.

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 enable signal integrity optimization, set the signal integrity options as described in “[Setting Signal Integrity Options](#)” on page 8-16 and use the `-xtalk_reduction` option when you run `route_opt`.

To enable leakage power optimization, use the `-power` option when you run `route_opt`. For information about leakage power optimization, see “[Adaptive Leakage Power Optimization](#)” on page 6-6.

To enable wire and via optimization, use the `-optimize_wire_via` option when you run `route_opt`.

To enable area recovery, use the `-area_recovery` option when you run `route_opt`.

If you want to analyze the routing results before performing postroute optimization, first run `route_opt` without postroute optimization (`-initial_route_only` option), and then run `route_opt` with postroute optimization only (`-skip_initial_routing` option).

```
icc_shell> route_opt -initial_route_only
# analyze routing results
icc_shell> route_opt -skip_initial_routing
```

## Saving Intermediate Results

To save intermediate `route_opt` results, enable checkpointing by setting the `routeopt_checkpoint` variable to true. When checkpointing is enabled, `route_opt` saves the design after each major stage. [Table 8-9](#) shows the designs saved by `route_opt` checkpointing.

*Table 8-9 Designs Saved By route\_opt Checkpointing*

| Design name                       | Saved after                              |
|-----------------------------------|------------------------------------------|
| <code>design_name_RT</code>       | Initial routing                          |
| <code>design_name_ORPRT</code>    | Wire and via optimization                |
| <code>design_name_OR_n</code>     | Each postroute optimization pass         |
| <code>design_name_ECORT_n</code>  | Each ECO routing pass                    |
| <code>design_name_RCRED</code>    | Crosstalk reduction                      |
| <code>design_name_POR</code>      | Power optimization                       |
| <code>design_name_PECORT</code>   | Power optimization ECO routing           |
| <code>design_name_HOLD_PRE</code> | Preroute-based hold optimization         |
| <code>design_name_HOLD</code>     | Global-route-based hold optimization     |
| <code>design_name_INCOR</code>    | Optimization after incremental route_opt |
| <code>design_name_HOLD</code>     | ECO routing after incremental route_opt  |

## Summary of route\_opt Options

**Table 8-10** describes all the `route_opt` options. For more information, see the man page.

*Table 8-10 route\_opt Command Options*

| Command option                              | GUI object                                             | Description                                                                                                                                                                            |
|---------------------------------------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-effort low   medium   high</code>    | Effort radio buttons                                   | Specifies the optimization effort level. Higher effort levels provide more aggressive optimization at a runtime cost.<br>The default is <code>medium</code> .                          |
| <code>-stage global   track   detail</code> | “Run optimization after” radio buttons                 | Specifies the last routing stage performed by <code>route_opt</code> before performing optimization.<br>By default, <code>route_opt</code> performs optimization after detail routing. |
| <code>-xtalk_reduction</code>               | “Crosstalk reduction and SI optimization” radio button | Performs crosstalk reduction and signal integrity optimization.<br>By default, <code>route_opt</code> does not perform crosstalk reduction or signal integrity optimization.           |
| <code>-only_xtalk_reduction</code>          | “Crosstalk reduction optimization only” radio button   | Performs only crosstalk reduction (not signal integrity optimization).<br>By default, <code>route_opt</code> does not perform crosstalk reduction or signal integrity optimization.    |
| <code>-power</code>                         | “Perform power optimization” check box                 | Performs leakage power optimization.<br>By default, <code>route_opt</code> does not perform leakage power optimization.                                                                |
| <code>-skip_initial_route</code>            | “Skip initial routing” check box                       | Performs postroute optimization without routing.                                                                                                                                       |
| <code>-initial_route_only</code>            | “Initial routing only” check box                       | Performs only initial routing without postroute optimization.                                                                                                                          |
| <code>-size_only</code>                     | “Sizing only optimization” check box                   | Resolves setup time violations by sizing only.                                                                                                                                         |

*Table 8-10 route\_opt Command Options (Continued)*

| <b>Command option</b>                                       | <b>GUI object</b>                                                        | <b>Description</b>                                                                                                                                                                                            |
|-------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-optimize_wire_via</code>                             | “Optimize wire and via routing” check box                                | Performs wire and via optimization. By default, <code>route_opt</code> does not perform wire and via optimization.                                                                                            |
| <code>-area_recovery</code>                                 | “Recover area for cells that are not on critical timing paths” check box | Recovers area for cells not on critical paths.<br>To restrict area recovery to high-density areas, set the <code>physopt_density_area_recovery</code> variable to true.                                       |
| <code>-wire_size</code>                                     | “Use wire sizing to fix setup time violations” check box                 | Determines whether wire sizing is used to fix setup time violations.                                                                                                                                          |
| <code>-incremental</code>                                   | “Incremental mode” check box                                             | Performs incremental postroute optimization.                                                                                                                                                                  |
| <code>-incremental -only_wire_size</code>                   | “Timing optimization only with wire size” radio button                   | Performs only wire sizing to resolve setup time violations during incremental mode.                                                                                                                           |
| <code>-incremental -only_hold_time</code>                   | “Hold timing optimization only” radio button                             | Resolves only hold time violations during incremental mode. Use the <code>set_fix_hold</code> command to enable hold time fixing.                                                                             |
| <code>-incremental -only_area_recovery</code>               | “Area recovery only” radio button                                        | Performs only area recovery during incremental mode.<br>To restrict area recovery to high-density areas, set the <code>physopt_density_area_recovery</code> variable to true.                                 |
| <code>-incremental -only_design_rule</code>                 | “Fix design rules only” radio button                                     | Performs only logical design rule fixing during incremental mode.                                                                                                                                             |
| <code>-incremental -only_power_recovery</code>              | “Power recovery only” radio button                                       | Performs only power recovery during incremental mode.                                                                                                                                                         |
| <code>-num_cpus</code><br>(“Number of CPUs” box in the GUI) | <i>int</i><br>(must be between 1 and 63)                                 | Specifies the number of CPUs to use for distributed routing. For information about setting up for distributed routing, see “ <a href="#">Enabling Distributed Routing</a> ” on page 8-16<br>The default is 1. |

## 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.

For each run, you must specify the focus of the optimization, setup, hold, or logical DRCs, 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 the next section “[Endpoint File Format](#).”
- 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 the next section “[Endpoint File Format](#).”
- To fix all 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-30.

By default, the `focal_opt` command uses medium effort to fix the remaining violations. When using medium effort, `focal_opt` explores more solution spaces than `route_opt` 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 re-estimation. Due to the additional runtime required for high effort, you should use this only when you have a few remaining violations to close.

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, `focal_opt` might violate other constraints to fix the prioritized violations.

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`).

### Endpoint File Format

To fix specific setup or hold violations, 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                                               |        |

The best way to generate these lines is by editing the file generated by the `report_constraint` command.

### Net File Format

To fix specific logical DRC violations, 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) |
|-----------------------|------|------------------|

The best way to generate these lines is by editing the file generated by the `report_constraint` command.

---

## Routing Signal Nets by Using Automatic Routing

Before you use automatic routing to route the signal nets, you must define the routing options as described in “[Setting Routing Options](#)” on page 8-12.

To run automatic routing, use the `route_auto` command (or choose Route > Auto Route in the GUI). By default, the `route_auto` command sequentially invokes global routing, track assignment, and detail routing.

[Table 8-11](#) describes the `route_auto` command options. For more information, see the man page.

*Table 8-11 route\_auto Command Options*

| Command option                                                                                | Valid values | Description                                                                                                                                |
|-----------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-no_global</code><br>(“Global route” check box in Run section in the GUI)               | N/A          | Skips global routing.                                                                                                                      |
| <code>-no_track</code><br>(“Track assignment” check box in Run section in the GUI)            | N/A          | Skips track assignment.                                                                                                                    |
| <code>-no_detail</code><br>(“Detail route” check box in Run section in the GUI)               | N/A          | Skips detail routing.                                                                                                                      |
| <code>-save_after_global_route</code><br>(“Global route” check box in Run section in the GUI) | N/A          | Controls whether the design is saved after global routing.<br><br>When specified, the tool saves the design in a CEL view named auto_GR.   |
| <code>-save_after_track</code><br>(“Track assignment” check box in Run section in the GUI)    | N/A          | Controls whether the design is saved after track assignment.<br><br>When specified, the tool saves the design in a CEL view named auto_TA. |
| <code>-save_after_detail_route</code><br>(“Detail route” check box in Run section in the GUI) | N/A          | Controls whether the design is saved after detail routing.<br><br>When specified, the tool saves the design in a CEL view named auto_DR.   |

*Table 8-11 route\_auto Command Options (Continued)*

| Command option                                                           | Valid values                       | Description                                                                                                                                                                                                 |
|--------------------------------------------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -search_repair_loop<br>("Maximum Search & Repair cycles" box in the GUI) | int<br>(must be between 0 and 500) | Specifies the maximum number of search and repair loops.<br>The default is 0.                                                                                                                               |
| -effort<br>(Effort radio buttons in the GUI)                             | minimum   low   medium   high      | Specifies the effort level for auto-routing.<br>The default is medium.                                                                                                                                      |
| -num_cpus<br>("Number of CPUs" box in the GUI)                           | int<br>(must be between 0 and 500) | Specifies the number of CPUs to use for distributed routing. For information about setting up for distributed routing, see <a href="#">"Enabling Distributed Routing" on page 8-16</a><br>The default is 1. |

## Running Individual Routing Steps

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](#)
- [Search and Repair](#)
- [Wire and Via Optimization](#)

## Global Routing

Global routing maps general pathways through the design for each unrouted net (signal nets and clock nets).

To perform global routing, use the `route_global` command (or choose Route > Global Route in the GUI). By default, the classic router performs medium-effort global routing. To change the effort level, use the `-effort` option.

The global router performs the following tasks:

- Divides the chip into square units called global routing cells.

The height and width of the global routing cells are determined by using the average height of the standard cells.

- Assigns nets to the global routing cells through which they pass.

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.

- Determines the demand for routing tracks, both horizontally and vertically, through each global routing cell, based on the locations of the cell pins and their respective unroute connections.

The global router considers spacing and wide-wire variable routing rules, as well as shielding variable routing rules, when calculating congestion.

- Reports the overflow for each metal layer.

The overflow is the number of tracks still needed after the global router assigns nets to the available wire tracks in a global routing cell. It is calculated as the number of tracks needed minus the number of available tracks in a given direction through a global routing cell. The higher the overflow value, the worse the overflow. A negative overflow value (underflow) indicates that all required routes can be accommodated.

The classic router can reduce overflows by detouring nets around congested areas and increasing the wire length. To analyze the congestion, you can examine the global routing report that appears in the command window and display congestion maps. To generate a congestion map without performing global routing, use the `route_global -congestion_map_only` command. To display the congestion map, choose Route > Global Route Congestion Map in the GUI.

[Example 8-2](#) shows an example of the overflow results reported during global routing.

#### *Example 8-2 Overflow Results in Global Routing Report*

```
phase5. Routing result:
phase5. Both Dirs: Overflow = 95 Max = 4 GRCs = 69 (0.03%)
phase5. H routing: Overflow = 14 Max = 2 (1 GRCs) GRCs = 13 (0.01%)
phase5. V routing: Overflow = 81 Max = 4 (1 GRCs) GRCs = 56 (0.02%)
phase5. METAL      : Overflow = 14 Max = 2 (1 GRCs) GRCs = 13 (0.01%)
phase5. METAL2     : Overflow = 81 Max = 4 (1 GRCs) GRCs = 56 (0.05%)
phase5. METAL3     : Overflow = 0 Max = 0 GRCs = 0 (0.00%)
phase5. METAL4     : Overflow = 0 Max = 0 GRCs = 0 (0.00%)
phase5. METAL5     : Overflow = 0 Max = 0 GRCs = 0 (0.00%)
phase5. METAL6     : Overflow = 0 Max = 0 GRCs = 0 (0.00%)
```

[Figure 8-1](#) shows an example of a congestion map.

*Figure 8-1 Global Route Congestion Map*



The congestion map shows the borders between global routing cells highlighted with different colors representing different levels of overflow. The overflow values shown in the congestion map are determined by combining the overflow and underflow of all selected layers; they do not represent the maximum overflow values.

By default, all metal layers are selected in the congestion map. To display the congestion map for a subset of layers, select (or deselect) the layers in the Map Mode dialog box. 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 dialog box 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 in the Map Mode dialog box.

## Track Assignment

Before you perform detail routing, run track assignment to specify which tracks within each global routing cell are to be used for each net. Track assignment operates on the entire design at once; it can make long routes straight and reduce the number of vias, whereas the detail routing routes a small area at a time.

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.

To perform track assignment, use the `route_track` command (or choose Route > Track Assignment in the GUI).

## Detail Routing

Detail routing uses the general pathways suggested by global routing and track assignment to route the nets (paths and contacts).

To perform detail routing, use the `route_detail` command (or choose Route > Detail Route in the GUI).

By default, stand-alone detail routing

- Performs track assignment before detail routing  
To skip track assignment, use the `-track_assign skip` option.
- Does not have a runtime limit  
If you need to limit the runtime, specify the maximum number of minutes by using the `-run_time_limit` option.
- Uses one CPU  
If you are performing distributed routing, specify the number of CPUs by using the `-num_cpus` option. For information about setting up for distributed routing, see “[Enabling Distributed Routing](#)” on page 8-16.
- Does not perform any search and repair passes  
To change the maximum number of search and repair passes, use the `-search_repair_loop` option.

## Search and Repair

During search-and-repair routing passes, the classic router searches for DRC violations and reroutes wires in an effort to avoid violations. The classic router does not add metal stubs on frozen nets to fix DRC violations, even when the nets have DRC violations.

To run stand-alone search-and-repair routing, use the `route_search_repair` command (or choose Route > Search-and-Repair Route in the GUI). By default, the `route_search_repair` command performs 50 search-and-repair passes. To change the maximum number of passes, use the `-loop` option.

If you need to limit the search-and-repair runtime, specify the maximum number of minutes by using the `-run_time_limit` option. You can reduce the turnaround time for running search-and-repair routing by using distributed routing. To use distributed routing, specify the number of CPUs by using the `-num_cpus` option. For information about setting up for distributed routing, see “[Enabling Distributed Routing](#)” on page 8-16.

For more information about the `route_search_repair` command, see the man page.

## Wire and Via Optimization

To optimize wires and vias, use the `optimize_wire_via` command (or choose Route > Optimize Wire Via in the GUI). By default, the `optimize_wire_via` command performs 20 search-and-repair passes. To change the maximum number of search-and-repair passes, use the `-search_repair_loop` option.

If you need to limit the wire and via optimization runtime, specify the maximum number of minutes by using the `-run_time_limit` option. You can reduce the turnaround time for running wire and via optimization by using distributed routing. To use distributed routing, specify the number of CPUs by using the `-num_cpus` option. For information about setting up for distributed routing, see “[Enabling Distributed Routing](#)” on page 8-16.

For more information about the `optimize_wire_via` command, see the man page.

---

## 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.

Before you shield nets, you must define the shielding rules with the `define_routing_rule` command and assign these rules to the nets to be shielded with the `set_net_routing_rule` command. (See “[Using Nondefault Routing Rules](#)” on page 8-7.)

To shield nets with defined rules, use the `create_auto_shield` command (or choose Route > Create Shield in the GUI).

By default, the `create_auto_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 perform coaxial shielding, use the `-coaxial_above` and `-coaxial_below` options. 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.

## 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_eco` command (or choose Route > ECO Route in the GUI).

By default, the ECO router connects open nets and then fixes design rule violations in the design. All the open nets are run sequentially through global routing, track assignment, and detail routing. The ECO router can reroute existing wires to fix DRC violations. You can modify the default behavior by using the `route_eco` command options.

[Table 8-12](#) describes the `route_eco` command options. For more information, see the man page.

*Table 8-12 route\_eco Command Options*

| Command option                                                                     | Valid values | Description             |
|------------------------------------------------------------------------------------|--------------|-------------------------|
| <code>-no_global</code><br>("Global route" check box in Run section in the GUI)    | N/A          | Skips global routing.   |
| <code>-no_track</code><br>("Track assignment" check box in Run section in the GUI) | N/A          | Skips track assignment. |
| <code>-no_detail</code><br>("Detail route" check box in Run section in the GUI)    | N/A          | Skips detail routing.   |

**Table 8-12 route\_eco Command Options (Continued)**

| <b>Command option</b>                                                                | <b>Valid values</b>                                              | <b>Description</b>                                                                                                                                                                                            |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -auto<br>(Auto check box in the Run section in the GUI)                              | N/A                                                              | Enables automatic region-based ECO routing.<br>You must use this option with the -region_based option.                                                                                                        |
| -region_based<br>("Region based nets filename" box in the GUI)                       | <i>string</i>                                                    | Specifies the name of the file that contains the list of nets on which to perform region-based ECO routing.<br>You must use this option with the -auto option.                                                |
| -search_repair_loop<br>("Maximum Search & Repair cycles" box in the GUI)             | <i>int</i><br>(must be between 0 and 500)                        | Specifies the maximum number of search and repair loops.<br>The default is 20.                                                                                                                                |
| -reroute<br>("Reroute nets" radio buttons in the GUI)                                | any_nets   modified_nets_on_ly   modified_nets_first_then_others | Controls which nets can be rerouted to fix DRC violations.<br>The default is any_nets.                                                                                                                        |
| -utilize_dangling_wires<br>("Utilize dangling wires" check box in the GUI)           | N/A                                                              | Enables the reuse of existing dangling routes to fix open nets.                                                                                                                                               |
| -freeze_routing_on_layer<br>("Freeze routing on layers" list in the GUI)             | <i>list_of_layers</i>                                            | Prevents routing changes on the specified layers.                                                                                                                                                             |
| -freeze_vias_on_frozen_metal<br>("Freeze vias on frozen metal" check box in the GUI) | N/A                                                              | Freezes vias on frozen metal layers.                                                                                                                                                                          |
| -num_cpus<br>("Number of CPUs" box in the GUI)                                       | <i>int</i><br>(must be between 1 and 500)                        | Specifies the number of CPUs to use for distributed routing. For information about setting up for distributed routing, see " <a href="#">Enabling Distributed Routing</a> " on page 8-16<br>The default is 1. |

---

## 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` command (or choose Design > Report Design in the GUI, and then select “Show physical”).

---

## Verifying the Routed Design

After you have completed routing with the classic router, you can check the design for routing design rule violations.

**Note:**

The classic router uses center lines to determine connectivity. If your design contains wires with zero wire extension, the `verify_route` command might report open and spacing violations due to these zero extension wires. To fix this problem, use the `convert_wire_ends` command to convert all wires with zero extension into wires with half-width extensions. If the `convert_wire_ends` command cannot convert a wire, it issues a warning message and removes the wire from the design cell. Because the `convert_wire_ends` command modifies the wire end information and, in some cases, removes wires, write commands such as `write_def` generate output files that are different from the original input files. For more information about the `convert_wire_ends` commands, see the man page.

IC Compiler provides the following methods for verifying the routed design:

- Use the IC Validator or Hercules tool to check the routing design rules defined in the foundry runset.

To use this method, run the `signoff_drc` command or choose Verification > Signoff DRC in the GUI.

**Note:**

An IC Validator or Hercules license is required to run the `signoff_drc` command.

- Use the Hercules tool to check the routing design rules defined in the Milkyway technology file.

To use this method, run the `verify_drc` command or choose Verification > DRC in the GUI.

**Note:**

A Hercules license is required to run the `verify_drc` command.

- Use the IC Compiler DRC checking engine to check the routing design rules defined in the Milkyway technology file.

To use this method, run the `verify_route` command or choose Route > Verify Route in the GUI.

- Import the DRC checking results from the Calibre tool.

The following sections describe these methods.

---

## Using the `signoff_drc` Command

The `signoff_drc` command performs routing DRC checking by using the IC Validator or Hercules tool with the foundry runset and reports all the errors in the top-level design by expanding the lower-level errors without merging them.

To use `signoff_drc` to perform DRC checking,

- Set up the validation tool environment.
- Set up the physical signoff options.
- Run the `signoff_drc` command.

The following sections describe these tasks.

## Setting Up the Validation Tool Environment

You can use either IC Validator or Hercules to perform routing DRC 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_2009.06
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 version C-2009.06 of IC Compiler, you must use version C-2009.06 of IC Validator.

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_2006.12_SP2-4
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). The settings that you specify are saved in the Milkyway design library.

[Table 8-13](#) shows the physical signoff options that apply to the `signoff_drc` command.

*Table 8-13 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 DRC 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 filename</code><br>(DRC box in the GUI "Foundry runset" area) | Specifies the foundry runset to use for DRC checking (required).                                                                                                                                                                                                                    |
| <code>-mapfile filename</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 Runset File</a> ".                                                                                                                  |

**Table 8-13 Physical Signoff Options for signoff\_drc (Continued)**

| <b>Command option</b>                                                                             | <b>Description</b>                                                                                                                           |
|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-dp_hosts {host_list}</code><br>(Hosts box in the GUI “Distributed processing” area)        | Defines the distributed processing options (optional).<br>For more information, see “ <a href="#">Performing Distributed DRC Checking</a> .” |
| <code>-num_cpus int</code><br>(“Number of CPU’s” box in the GUI<br>“Distributed processing” area) |                                                                                                                                              |

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 Runset File

In general, the Milkyway technology file and the 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 DRC Checking

By default, the `signoff_drc` command uses a single process to perform DRC checking. To reduce the runtime used for DRC checking, you can use distributed processing. To enable distributed processing, you must identify the CPUs to be used with the `-dp_hosts` option of the `set_physical_signoff_options` command and specify the number of CPUs to use. You can specify the number of CPUs to use either with the `-num_cpus` option of the `set_physical_signoff_options` command, which defines the default number of CPUs to use for distributed processing, or with the `-num_cpus` option of the `signoff_drc` command, which overrides the value set by the `set_physical_signoff_options` command and defines the number of CPUs to use for that run. The number of CPUs that you specify must be less than or equal to the number of hosts that you specify. To use multiple CPUs on a given host, you must include the host name multiple times in the host list.

## Running the `signoff_drc` Command

By default, the `signoff_drc` command uses the FRAM view to check 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 “Cell view” radio button 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 restrict the DRC checking to specific areas of the chip, to specific design rules, and to specific layers.

- To restrict the checking to specific areas of the chip,
  - If you are using the command line, use the `-bounding_box` 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” radio button in the “Check DRC violations on” area in the GUI).

After you complete DRC checks on the routing layers, you can perform a quick DRC 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)” radio button 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 cell file that you can use to report or display the DRC violations. By default, the error cell file generated by `signoff_drc` is called `design_sdrc.err`. You can control this name by using the `-error_cell` option (or the “Error cell name” box in the GUI). For information about using the error cell file to debug DRC violations, see [“Analyzing DRC Violations” on page 8-49](#).

In addition to the error cell file, the `signoff_drc` command generates the following files, which you can use for debugging:

- `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.log`

This file contains any errors that occurred during the `signoff_drc` run.

- `./run_details/design.sum`

This file contains the detailed Hercules log file.

By default, these files are places in a directory called `signoff_drc_run` under the current working directory. 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.

---

## Using the `verify_drc` Command

If you do not have a foundry runset, you can use the `verify_drc` command to perform DRC checking with a runset based on the design rules defined in the Milkyway technology file.

Note:

The `verify_drc` command does not check design rules for technologies at the 45-nm process node and below. To check design rules for these technologies, you must use the `signoff_drc` command.

For information about the routing design rules and the technology file attributes that define them, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

The `verify_drc` command generates a Hercules DRC runset based on the design rules defined in the Milkyway technology file, and then runs Hercules to check for DRC violations. A Hercules license is required to run the `verify_drc` command. For more information about Hercules, see the Hercules documentation, which is available on SolvNet.

To use `verify_drc` to perform DRC checking,

- Set up the Hercules environment

For information about setting up the Hercules environment, see “[Setting Up the Validation Tool Environment](#)” on page 8-40.

- Run the `verify_drc` command.

By default, the `verify_drc` command checks and reports the DRC violations for the entire design. To perform these checks only in a specific region, specify the coordinates of the region by using the `-selected_area` option (or by specifying the coordinates in the “Selected area” box in the “DRC Area” tab in the GUI). To perform these checks for the entire design, except for a specific region, specify the coordinates of the excluded region by using the `-excluded_area` option (or by specifying the coordinates in the “Whole chip except area” box in the “DRC Area” tab in the GUI).

**Table 8-14** lists the design rules checked by the `verify_drc` command.

*Table 8-14 Design Rules Checked by verify\_drc*

| Rule                                                                                                                                                      | Checked by default | Command option to enable or disable/<br>Check box in the “DRC Rules” tab in GUI                                             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Minimum and maximum width                                                                                                                                 | Yes                | <code>-ignore_width</code><br>“Minimum and maximum width rule” check box                                                    |
| Metal spacing (includes minimum spacing, same-net spacing, fat metal spacing, the fat metal parallel length rule, and the fat metal extension range rule) | Yes                | <code>-ignore_spacing</code><br>“All spacing related rules” check box                                                       |
| Minimum area                                                                                                                                              | Yes                | <code>-ignore_area</code><br>“Minimum area” check box                                                                       |
| Metal density                                                                                                                                             | Yes                | <code>-ignore_density</code><br>“Metal density rules” check box                                                             |
| Minimum enclosed area (default and fat metal)                                                                                                             | Yes                | <code>-ignore_enclosed_area</code><br>“Basic minimum enclosed area rule and fat table minimum enclosed area rule” check box |
| Minimum number of consecutive short edges                                                                                                                 | Yes                | <code>-ignore_min_edge_length</code><br>“Minimum number of consecutive short edges rule”                                    |
| Blockages on metal layers                                                                                                                                 | No                 | <code>-check_blockage</code><br>“Blockages on metal layers” check box                                                       |
| Via size rule                                                                                                                                             | No                 | <code>-check_via_size</code><br>“Via size rule” check box                                                                   |
| Via spacing (includes minimum spacing, the fat contact rule, the fat contact spacing rule, and the fat contact extension range rule)                      | Yes                | <code>-ignore_via_spacing</code><br>“Via spacing rules” check box                                                           |
| Maximum number of via stack layers                                                                                                                        | Yes                | <code>-ignore_stack_level</code><br>“Maximum number of stack layer rule” check box                                          |

**Table 8-14 Design Rules Checked by verify\_drc (Continued)**

| Rule                                                   | Checked by default | Command option to enable or disable/<br>Check box in the “DRC Rules” tab in GUI                                         |
|--------------------------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| Stack via rule                                         | Yes                | -ignore_stackable<br>“Stack via rule” check box                                                                         |
| Maximum number of adjacent vias and enclosed via rules | Yes                | -ignore_adjacent_via<br>“Maximum number of adjacent via and enclosed via rules” check box                               |
| Minimum number of fat vias                             | Yes                | -ignore_min_via_number<br>Minimum number of vias defined in the fat contact table (including extension range) check box |
| Via array size and spacing between via arrays          | No                 | -check_via_farm<br>“Via array size and spacing between two via arrays” check box                                        |
| Via enclosure rule                                     | No                 | -check_enclosure<br>“Via Enclosure rule” check box                                                                      |
| End-of-line rule                                       | No                 | -check_end_of_line<br>“End of line rule” check box                                                                      |
| Fat poly contact rule                                  | No                 | -check_fat_poly_contact<br>“Fat poly contact rule” check box                                                            |

The Hercules runset file generated by `verify_drc` is saved in `adrc/adrc.ev`. You can change the directory to which the runset file is saved by using the `-dir` option (or the “Hercules runset directory” box in the GUI).

The `verify_drc` command creates a Milkyway error cell file that you can use to report or display the DRC violations. By default, the `verify_drc` command generates an error cell file called `design_adrc.err`. You can control this name by using the `-error_cell` option (or the “Error cell name” box in the GUI). For information about using the error cell file to debug DRC violations, see See “[Analyzing DRC Violations](#)” on page 8-49.

---

## Using the `verify_route` Command

The `verify_route` command checks for routing DRC violations by running an internal DRC checker that checks the design rules defined in the Milkyway technology file. The `verify_route` command also checks for open nets.

Note:

Unlike the `signoff_drc` and `verify_drc` commands, which check the design rules for all objects, the `verify_route` command checks only objects with a signal routing type. For more information about routing types, see “[Setting Routing Types](#)” on page 8-12.

For information about the routing design rules and the technology file attributes that define them, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

By default, the `verify_route` command checks and reports the DRC violations and open nets for the entire design. To perform these checks only in a specific region, specify the coordinates of the region by using the `-bounding_box` option (or by specifying the coordinates in the “DRC Area” area in the GUI). To prevent checking of the DRC violations, use the `-no_drc` option when you run `verify_route`. To prevent checking for open nets, use the `-noOpens` option when you run `verify_route`.

You can reduce the `verify_route` runtime by using distributed processing. For information about how to use distributed processing, see “[Enabling Distributed Routing](#)” on page 8-16.

You can also use the `verify_route` command to check for antenna violations. For more information about checking for and fixing antenna violations, see “[Preventing Antenna Problems](#)” on page 9-6.

The `verify_route` command can create a Milkyway error cell file that you can use to report or display the DRC violations. To output a Milkyway error cell file, use the `-output filename` option when you run the `verify_route` command. For information about using the error cell file to debug DRC violations, see See “[Analyzing DRC Violations](#)” on page 8-49.

---

## Using the Calibre Interface

You can perform DRC checking with the Calibre tool, convert the Calibre DRC error file to a Milkyway error cell file, and then report or view the errors in IC Compiler. To convert the Calibre DRC error file to a Milkyway error cell file, 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 cell file called `cell_name.err`, where `cell_name` is derived from the Calibre error report. You can specify a name for the Milkyway error cell file 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 cell file 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 “[Examining Routing and Verification Errors](#)” on page A-50.

---

## Analyzing DRC Violations

After you have generated an error cell file, either by running one of the Synopsys DRC checking commands or by converting the Calibre results to an error cell file, you can analyze the DRC violations by

- Generating a report that lists the location of each error.

To report the location of each violation, use the `report_error_coordinates` command.

- Viewing the errors in the error browser.

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 detailed information about using the error browser, see “[Examining Routing and Verification Errors](#)” on page A-50 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.

---

## 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.

---

### Routing Single Nets

You can route nets interactively in the active layout view by drawing the route segments with the 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. 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-56](#).

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.

You can reverse and reapply Create Route tool operations by using the GUI undo and redo capabilities.

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 > Advanced > 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 > Advanced > 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 value is 8.

- To set the maximum number of nets in the bus, select or type a value in the Max box. The default value is 128.
- To set the number of signals permitted in the bus, select or type a value in the “Multiple of” box. The default value 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 > Advanced > 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.

---

## Removing Dangling Wires

You can clean up antennas or other dangling wires on routed nets and physical buses. Note that the operation to remove dangling wires is not reversible and that it clears the Undo and Redo lists.

To remove dangling wires from routed buses,

1. Choose Edit > Advanced > 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. In the Physical Buses dialog box, select one or more physical buses.
3. Click the Beautify button.

The Remove Dangling Wires dialog box appears. The names of the nets in the selected buses appear in the Nets box.

4. (Optional) To specify different nets, type the net name in the nets box.

Alternatively, you can select the nets or click the browse button and select the net names in the dialog box that appears.

5. (Optional) To remove dangling wires only on specific layers, select the Specified option under Layers and select the layers in the layer list.

The All option is selected by default, which means the tool removes dangling wires on all layers.

6. (Optional) To remove dangling wires only on nets with specific route type attributes, select the Specified option under "Route types" and select or deselect the types as needed. The type options are User, Detailed route, and Clock.

The All option is selected by default, which means the tool removes dangling wires on nets of all route types.

7. If you do not want the tool to perform design rule checking by running the `verify_route` command before removing the dangling wires, select the "No rerun DRC" option.
8. Click OK or Apply.

Alternatively, you can use the `remove_dangling_wires` command. For details, see the man page.

---

## 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 (). 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-50.

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, 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 rule, 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.

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.

---

## 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 default values, 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. In the active layout view, click the start point for the routes.

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 Advanced Route Tool 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 Escape 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 will 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.

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-32).

- 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.

Autoextraction 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-15](#).

*Table 8-15 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>                                                  |
| 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_metal_fill_extraction</code><br>none   floating   grounded<br>  auto |
| Control whether virtual shield extraction is performed. The default is true.                                                                 | <code>-virtual_shield_extraction</code><br>true   false                          |
| Specify the fanout threshold. The default is 1000 pins.                                                                                      | <code>-fan_out_thres count</code>                                                |

*Table 8-15 set\_extraction\_options Command Options (Continued)*

| To do this                | Use this |
|---------------------------|----------|
| Reset extraction options. | -default |

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](#)
- [Preventing Antenna Problems](#)
- [Reducing Critical Areas](#)
- [Inserting Redundant Vias](#)
- [Inserting Filler Cells](#)
- [Performing Metal Density Filling](#)
- [Performing Notch and Gap Filling](#)
- [Analyzing CMP Thickness Variation Effects](#)
- [Lithography Compliance Checking](#)

## 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, it is recommended that you 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_area_collection]
  [-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]

```

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_layer {M1, M2}
```

You must specify the name of the reference cell to be used for tap insertion using `-master_cell_name name` and the required distance, in microns, between taps using `-distance distance`. The specified distance should be approximately twice the maximum diffusion-to-tap value specified in the technology design rule. Use the `-voltage_area voltage_area_collection` option to restrict tap insertion to specific voltage areas.

You can specify the insertion pattern 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.

## 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.

---

## Preventing Antenna Problems

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 the metal antenna area divided by the input pin gate area is less than the maximum antenna ratio given by the foundry:

$$(antenna-area)/(gate-area) < (max-antenna-ratio)$$

The antenna rules are categorized into basic and advanced rules. For process nodes above 0.18  $\mu\text{m}$ , use the basic antenna rules.

[Figure 9-2](#) shows how to use IC Compiler to perform antenna checking and fixing.

*Figure 9-2 IC Compiler Antenna Methodology*



## Setting the Antenna Mode

IC Compiler supports single-layer, accumulative ratio, accumulative area, and advanced antenna modes.

Using the basic antenna rules, you can select one of the first three antenna modes and decide the area, which can be either surface (polygon) or sidewall, to use for antenna area calculation. Set the `doAntennaConx` detail route option to select an antenna mode and the `useSideWallForAntenna` (0 for surface area) detail route option to choose an area:

- Single-layer mode (Set `doAntennaConx` to 1)
- Accumulative ratio mode (Set `doAntennaConx` to 2)
- Accumulative area mode (Set `doAntennaConx` to 3)
- Advanced mode (Set `doAntennaConx` to 4)

This section discusses only the first three modes using the surface area. For the advanced antenna mode, use the `-mode` option to decide a mode and follow the advanced antenna rules. For more information, see “[Setting the Antenna Mode for the Advanced Antenna Rules](#)” on page 9-13.

[Figure 9-3](#) shows a layout example with a lateral view, which is used to explain antenna modes in [Table 9-1](#): single-layer mode, accumulative ratio mode, and accumulative area mode.

*Figure 9-3 Layout Example*



*Table 9-1 Antenna Modes and Ratios*

| <b>Antenna Mode</b>                                                                                                                                  | <b>Antenna Ratio</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>Single-layer mode (ignores all lower-layer segments; allows best routability):</p> <pre>set_droute_options \ -name doAntennaConx \ -value 1</pre> | <p>antenna_ratio = connected metal area of the layer / total gate area</p> <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> |

*Table 9-1 Antenna Modes and Ratios (Continued)*

| <b>Antenna Mode</b>                                                                                                                                    | <b>Antenna Ratio</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Accumulative ratio mode<br>(includes lower-layer<br>segments to the input pins):<br><br><pre>set_droute_options \ -name doAntennaConx \ -value 2</pre> | <p>antenna_ratio = accumulation of ratios for the layer and layers below</p> <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: M1b / Gate1 + M2b / Gate1 + (M3b + M3c) / (Gate1 + Gate2)</li> <li>• Gate2: M1c / Gate2 + M2d / Gate2 + (M3b + M3c) / (Gate1 + Gate2)</li> <li>• Gate3: M1d / Gate3 + M2e / Gate3 + M3d / Gate3</li> </ul> <p>m4 ratios</p> <ul style="list-style-type: none"> <li>• Gate1: M1b / Gate1 + M2b / Gate1 + (M3b + M3c) / (Gate1 + Gate2) + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</li> <li>• Gate2: M1c / Gate2 + M2d / Gate2 + (M3b + M3c) / (Gate1 + Gate2) + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</li> <li>• Gate3: M1d / Gate3 + M2e / Gate3 + M3d / Gate3 + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</li> </ul> |

*Table 9-1 Antenna Modes and Ratios (Continued)*

| Antenna Mode                                                                                                                                              | Antenna Ratio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Accumulative area mode<br>(includes all lower-layer segments; allows least routability):<br><br>set_droute_options \<br>-name doAntennaConx \<br>-value 3 | <p>antenna_ratio = all connected metal areas / total gate area</p> <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> |

## Defining Antenna Rules

IC Compiler reads the antenna data that is prepared by Milkyway to fix antenna violations. If a sidewall is used for antenna calculation, you need to define the metal thickness by specifying the `unitMinThickness`, `unitNomThickness`, and `unitMaxThickness` attributes in each layer section of the technology file.

The following three factors influence the computation of antenna rules:

- The antenna mode to identify which metal piece to count
  - Single-layer mode
  - Accumulative ratio mode
  - Accumulative area mode
  - Advanced mode

- The antenna area calculation
  - Surface area = W x L
  - Sidewall area = (W + L) x 2 x thickness
- Protection from diodes and pins

## The Basic Antenna Rules

The basic antenna rules define the maximum antenna ratio (antenna area to gate area) for metal layers and cut layers.

To use the basic antenna rules, set the `doAntennaConx` detail route option to 1, 2, or 3, depending on which metal pieces you want to count. For example, to set the antenna mode to single-layer mode, enter,

```
icc_shell> set_droute_options -name doAntennaConx -value 1
```

You must also specify whether you want to use surface area or sidewall area. To select the area, set the `useSideWallForAntenna` detail route option to 0 (the default) for surface area. Set the option to 1 for sidewall area. Note that this option is ignored when `doAntennaConx` is set to 4 for advanced antenna mode.

After setting the antenna mode and the area, use the following detail route options to define the maximum antenna ratio:

- `maxAntennaRatio`

This option defines the maximum antenna ratio for metal layers. For example,

```
icc_shell> set_droute_options -name maxAntennaRatio -value 300
```

- `maxCutAntennaRatio`

This option defines the maximum antenna ratio for cut layers. For example,

```
icc_shell> set_droute_options -name maxCutAntennaRatio -value 20
```

To get a report on the options that have been set with the `set_droute_options` command, use the `report_droute_options` command as shown in the following example:

```
icc_shell> report_droute_options
```

The part of the report showing the antenna settings looks like this:

```
Integer Option for droute doAntennaConx 1
#      range [0,4], default=0, stored in cell;
;;      0: no charge-collecting antenna checking;
;;      [1-4] check and avoid charge-collecting antenna;
;;          1: ignore all lower-layer segments, (best routability);
;;          2: include lower-layer segments to the input pins;
;;          3: include all lower-layer segments (worst routability).
;;          4: (advanced mode) use antenna rules defined in libraries
;;              for a combination of mode 1 - 3 and limited diode protection
...
Integer Option for droute maxAntennaRatio 300
...
```

## The Advanced Antenna Rules

The advanced antenna rules give you more control over defining antenna rules. You can define the rules per layer and specify the diode ratios.

### Setting the Antenna Mode for the Advanced Antenna Rules

To use the advanced antenna rules, set the `doAntennaConx` detail route option to 4 and define the antenna rules by using the `define_antenna_rule` and `define_antenna_layer_rule` commands. You specify which metal pieces to count during antenna calculation by using the `-mode` option. [Table 9-2](#) shows the description for each mode.

*Table 9-2 Antenna Models Using the -mode Option*

| Antenna Mode                     | Description                                                                  |
|----------------------------------|------------------------------------------------------------------------------|
| Mode 1: Single-layer             | Uses surface area and ignores all lower-layer segments.                      |
| Mode 2:<br>Accumulative<br>ratio | Uses surface area which includes all lower-layer segments to the input pins. |
| Mode 3:<br>Accumulative<br>area  | Uses surface area which includes all lower-layer segments.                   |
| Mode 4: Single-layer             | Uses sidewall area and ignores all lower-layer segments.                     |

*Table 9-2 Antenna Models Using the -mode Option*

| <b>Antenna Mode</b>              | <b>Description</b>                                                            |
|----------------------------------|-------------------------------------------------------------------------------|
| Mode 5:<br>Accumulative<br>ratio | Uses sidewall area which includes all lower-layer segments to the input pins. |
| Mode 6:<br>Accumulative<br>area  | Uses sidewall area which includes all lower-layer segments.                   |

For example, to set the advanced antenna mode and to use the advanced antenna rules, enter the following commands:

```
icc_shell> set_droute_options -name doAntennexConx -value 4
icc_shell> define_antenna_rule mw_lib -mode mode \
           -diode_mode diode_mode \
           -metal_ratio metal_ratio \
           -cut_ratio cut_ratio \
           [-protected_metal_scale metal_scale] \
           [-protected_cut_scale cut_scale]
icc_shell> define_antenna_layer_rule mw_lib -mode mode \
           -layer layer_name \
           -ratio ratio \
           [-pratio pratio] \
           [-nratio nratio] \
           -diode_ratio {v0 v1 v2 v3 [v4]} \
           [-scale_factor scale_factor]
```

### Setting the Diode Mode

Antenna ratio calculation with diode protection is based on the vector {v0 v1 v2 v3 [v4]}{s0 s1 s2 s3 s4 s5} that you specify by using the -diode\_ratio option of the define\_antenna\_layer\_rule command. The 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 default value of the vector {v0 v1 v2 v3 [v4]} is {0 0 1 0 0} and can be written as {v0 v1 v2 v3} = {0 0 1 0} without the upper limit diode protection v4. Both vectors, {0 0 1 0 0} and {0 0 1 0}, indicate that the upper limit of the diode protection is 0.

The value of diode protection,  $dp$ , is recorded on each output pin of a cell. If the value of the diode protection of an output pin is  $dp$ , the antenna ratio is calculated as follows:

- For diode modes 0 to 4, use vector  $\{v0\ v1\ v2\ v3\}$  to calculate the allowable max-antenna-ratio.
- For diode modes 5 to 8, use vector  $\{v0\ v1\ v2\ v3\}$  to calculate the antenna ratio.
- For diode modes 9 and 10, use vector  $\{v0\ v1\ v2\ v3\ v4\}$  to calculate the allowable max-antenna-ratio.
- For diode modes 11 and 12, use both vectors  $\{v0\ v1\ v2\ v3\ v4\}$  and  $\{s0\ s1\ s2\ s3\ s4\ s5\}$  to calculate the allowable max-antenna ratio.

Note that vector  $\{s0\ s1\ s2\ s3\ s4\ s5\}$  is used for diode modes 11 and 12 only.

[Table 9-3](#) shows how to calculate the antenna ratio for each diode mode.

*Table 9-3 Antenna Ratio Calculation Based on Diode Mode*

| Diode Mode         | Allowable Ratio Calculation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Diode modes 2 to 4 | allowable max-antenna-ratio <ul style="list-style-type: none"> <li>• <math>dp &gt; 0</math>, if <math>v4 \neq 0</math>, the allowable max-antenna-ratio = <math>\min(((dp + v1) * v2 + v3), v4)</math></li> <li>• <math>dp &gt; 0</math>, if <math>v4 == 0</math>, the allowable max-antenna-ratio = <math>(dp + v1) * v2 + v3</math></li> <li>• When <math>dp \leq v0</math>, the allowable max-antenna-ratio = layerMaxRatio</li> </ul>                                                                  |
| Diode mode 5       | $\text{antenna ratio} = \text{metal\_area} / (\text{gate\_area} + \text{equi\_gate\_area})$ <ul style="list-style-type: none"> <li>• if <math>\text{max\_diode\_protection} \leq v0</math>, <math>\text{equi\_gate\_area} = 0</math></li> <li>• else if (<math>v4 \neq 0</math>), <math>\text{equi\_gate\_area} = \min(((\text{max\_diode\_protection} + v1) * v2 + v3), v4)</math></li> <li>• else <math>\text{equi\_gate\_area} = (\text{max\_diode\_protection} + v1) * v2 + v3</math></li> </ul>       |
| Diode mode 6       | $\text{antenna ratio} = \text{metal\_area} / (\text{gate\_area} + \text{equi\_gate\_area})$ <ul style="list-style-type: none"> <li>• if <math>\text{total\_diode\_protection} \leq v0</math>, <math>\text{equi\_gate\_area} = 0</math></li> <li>• else if (<math>v4 \neq 0</math>), <math>\text{equi\_gate\_area} = \min(((\text{total\_diode\_protection} + v1) * v2 + v3), v4)</math></li> <li>• else <math>\text{equi\_gate\_area} = (\text{total\_diode\_protection} + v1) * v2 + v3</math></li> </ul> |

*Table 9-3 Antenna Ratio Calculation Based on Diode Mode (Continued)*

| <b>Diode Mode</b> | <b>Allowable Ratio Calculation</b>                                                                                                                                                                                                                                                                                                                                   |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Diode mode 7      | <pre>antenna ratio = (metal_area - equi_metal_area) / gate_area • if max_diode_protection &lt;= v0, equi_metal_area = 0 • else if (v4 &gt;&gt; 0), equi_metal_area = min (((max_diode_protection + v1) * v2 + v3), v4) • else equi_metal_area = (max_diode_protection + v1) * v2 + v3 • if equi_metal_area &gt; metal_area, equi_metal_area = metal_area</pre>       |
| Diode mode 8      | <pre>antenna ratio = (metal_area - equi_metal_area) / gate_area • if total_diode_protection &lt;= v0, equi_metal_area = 0 • else if (v4 &gt;&gt; 0), equi_metal_area = min (((total_diode_protection + v1) * v2 + v3), v4) • else equi_metal_area = (total_diode_protection + v1) * v2 + v3 • if equi_metal_area &gt; metal_area, equi_metal_area = metal_area</pre> |
| Diode mode 9      | <pre>antenna ratio = scale * meta_area / gate_area • if max_diode_protection &lt;= v0, scale = 1.0 • else scale = max (1 / ((max_diode_protection + v1) * v2 + v3), v4)</pre>                                                                                                                                                                                        |
| Diode mode 10     | <pre>antenna ratio = scale * metal_area / gate_area • If total_diode_protection &lt;= v0, scale = 1.0 • else scale = max (1 / ((total_diode_protection + v1) * v2 + v3), v4)</pre>                                                                                                                                                                                   |
| Diode mode 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>                       |

*Table 9-3 Antenna Ratio Calculation Based on Diode Mode (Continued)*

| Diode Mode    | Allowable Ratio Calculation                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Diode mode 12 | antenna ratio = scale * metal_area / gate_area<br><ul style="list-style-type: none"> <li>• If total_diode_protection &lt; v0, scale = s0</li> <li>• If total_diode_protection &lt; v1, scale = s1</li> <li>• If total_diode_protection &lt; v2, scale = s2</li> <li>• If total_diode_protection &lt; v3, scale = s3</li> <li>• If total_diode_protection &lt; v4, scale = s4</li> <li>• If total_diode_protection &gt;= v4, scale = s5</li> </ul> |

### Example for Diode Modes 2, 3 and 4

The vector {v0 v1 v2 v3} is {0.7 0.0 200 2000}, three diodes are connected to a single net, and the value layerMaxRatio is 400.

Diode A: diode protection=0.5, allowable ratio is 400 if protected  
Diode B: diode protection=1.0, allowable ratio is 2200 if protected  
Diode C: diode protection=1.5, allowable ratio is 2200 if protected

The antenna ratio calculation of a route net:

Diode mode 2: allowable ratio = 2300 (maximum value)  
Diode mode 3: allowable ratio = 400+2200+2300 = 4900  
Diode mode 4: allowable ratio = ((0.5+1.0+1.5)\*200)+2000 = 2600

### Example for Diode Modes 5 and 6

The vector {v0 v1 v2 v3} is {0.0 0 1 0}, three diodes are connected to a single net, and the value of layerMaxRatio is 400.

Gate area of input pin = 0.6  
Diode A: diode protection = 0.5  
Diode B: diode protection = 1.0  
Diode C: diode protection = 1.5  
Total diode protection = 0.5+1.0+1.5 = 3.0

The antenna ratio calculation of a route net:

Diode mode 5: (Maximum diode protection value dp = 1.5)  
Antenna ratio = metal\_area/(gate\_area + equi\_gate\_area)  
= metal\_area/(0.6+((1.5+0)\*1+0))  
= metal\_area/2.1  
Diode mode 6: (Total diode protection value dp = 3.0)  
Antenna ratio = metal\_area/(gate\_area + equi\_gate\_area)  
= metal\_area/(0.6+((3.0+0)\*1))  
= metal\_area/3.6

## Example for Diode Modes 7 and 8

The vector {v0 v1 v2 v3} is {0.7 0.0 150 800}, three diodes are connected to a single net, and the value of layerMaxRatio is 400.

```
Diode A: diode protection = 0.5
Diode B: diode protection = 1.0
Diode C: diode protection = 1.5
Total diode protection = 0.5+1.0+1.5 = 3.0
```

The antenna ratio calculation of a route net:

```
Diode mode 7: (Use maximum dp to compute equi_metal_area)
Antenna ratio = (metal_area - equi_metal_area)/gate_area
                = (metal_area - ((1.5+0)*150+800))/gate_area
                = (metal_area - 1025)/gate_area
Diode mode 8: (Use total dp to compute equi_metal_area)
Antenna ratio = (metal_area - equi_metal_area)/gate_area
                = (metal_area - ((3.0+0)*150+800))/gate_area
                = (metal_area - 1250)/gate_area
```

The following shows an example of the advanced 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}
```

## Reporting Antenna Rules

You can get a report of 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 antenna rules you set by using the `remove_antenna_rules` command. For example,

```
icc_shell> remove_antenna_rules design
```

## Checking Antenna Rules

After the antenna modes and rules are defined, you can proceed with antenna rules checking. The design rule checker of the detail router checks antenna rules automatically. Every routing command checks and reports the number of antenna violations as follows:

```
#### Total nets not meeting constraints = 116
```

where the number represents the number of nets with antenna violations.

To get a detailed report of antenna violations, you can use `verify_route -antenna` or the `report_antenna_ratio` command. Alternatively, you can choose Route > Verify Route or Route > Report Antenna Ratio in the GUI to get an antenna violation report.

Note:

You can set the `topAntennaFixRange` and `maxAntennaPinCount` detail route options to speed up the runtime of antenna checking and fixing.

---

## Fixing Antenna Violations

You can fix antenna violations either before or after running the `route_opt` command. If both antenna fixing and routing optimization are needed, running `route_opt` first can shorten the overall turnaround time. However, running `route_opt` after antenna fixing can generate a good layout initially. Note that you need to keep the design as DRC-clean as possible before the antenna fixing step. When DRC violations have been eliminated, you can fix the antenna violations by performing search and repair step and diode insertion. Before performing these tasks, ensure that the antenna mode is set and that the antenna rules are defined as described in the previous sections.

## Running Search and Repair

After antenna checking and fixing, run search and repair to fix antenna violations. For example,

```
icc_shell> route_search_repair -loop 20 -rerun_drc
```

Search and repair performs two types of metal-jog operations for antenna fixing. Both approaches decrease the antenna ratio by splitting a large metal polygon into several upper-level polygons.

- Break the antenna with a higher-level metal segment.

Use 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.

- Move down to a lower-level metal.

Use 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.

For more information about search and repair, see [“Search and Repair” on page 8-36](#)

## Inserting Diodes

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.

Based on the results of the antenna checking, IC Compiler inserts a diode cell or multiple diodes when the antenna ratio requires the protection of more than one diode for each violation.

The diode port of the diode cell must be defined as such in the library. In the Milkyway environment, you can use the `write_def` command to define diode pins. For details, see the *Milkyway Environment Data Preparation User Guide*. In addition, the diode protection value must be defined in the physical library. For details, see the description of the `antenna_diffusion_area` attribute in the *Library Compiler Physical Libraries User Guide* and the *Library Compiler Physical Libraries Reference Manual*.

To minimize the impact on the existing placement and routing, you can choose to freeze the existing cell placement and the routing so that the diode cells can be placed in existing empty spaces only. You can also choose to complete the routing of the diode cells during the insertion process when the cell placement is already frozen. Whenever possible, IC Compiler ties the diode cells to the existing wires without ripping up and rerouting the entire net.

IC Compiler considers voltage areas when inserting diode cells and also observes the logic hierarchy assignments for diode cells.

To fix antenna violations, use the `insert_diode` command or choose Finishing > Insert Diode in the GUI. For example,

```
icc_shell> insert_diode -signal_route_options advanced
```

By default, the `insert_diode` command triggers the internal antenna checker to identify the antenna violations and then inserts one or multiple diode cells for each violation. For diode modes 2, 5, and 7, the `insert_diode` command inserts only one diode cell to fix an antenna violation. For diode modes 3, 4, 6, and 8, the `insert_diode` command inserts multiple diodes as needed to fix an antenna violation.

This is the full command syntax:

```
insert_diode
[-nets collection_of_nets]
[-antenna_check_engine internal | hercules]
[-internal_check_option all | top_layer_only]
[-no_auto_cell_selection]
[-diode_cells collection_of_diode_cells]
[-prefix prefix_name]
[-use_hierarchical_diode_instance_name]
[-same_row]
[[-dont_freeze_existing_placement] |
 [-routing skip | when_all_violations_are_gone | always]]
[-signal_route_options ignore_lower_layers | include_lower_layers|
   include_all_lower_layers | advanced]
[-max_ratio max_ratio_number]
```

By default, all nets are checked for antenna violations. To restrict checking to a list of nets, use the `-nets` option. By default, IC Compiler uses its own internal antenna checker. To use the external Hercules check instead, specify `-antenna_check_engine hercules`. To report only top-level antenna violations rather than all violations, specify `-internal_check_option top_layer_only`.

By default, any diode cells can be used for fixing. To specify which diode cells to use, specify `-no_auto_cell_selection` together with `-diode_cells cell_collection`. To attempt diode insertion in the same row as the violation, use the `-same_row` option; by default, there is no preferred row for insertion.

By default, diode insertion does not disturb existing standard cells. To allow existing cells to be moved to make room for inserted diodes, use the `-dont_freeze_existing_placement` option. The `-routing` option lets you specify whether to perform routing: `always`, `when_all_violations_are_gone`, or `skip`.

Use `-signal_route_options` to specify the rules used for antenna checking: `ignore_lower_layers`, `include_lower_layers`, `include_all_lower_layers`, or `advanced`. The `-max_ratio` option specifies the maximum allowable ratio of wiring area to gate area to be used for antenna checking, overriding the default antenna checking rules.

For more information on the command options, see the man page for the `insert_diode` command.

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 nets specified; 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]
```

## Connecting Spare Diodes

Instead of inserting new diodes to fix antenna violations, you can insert spare diodes at the same time as standard cell placement and then connect the spare diodes as needed when antenna violations are found. The unused spare diodes are left unconnected. This technique lets you fix antenna violations without disturbing the placement of existing standard cells. However, you must allocate some placement area to accommodate the spare diodes. Adding more spare diodes uses more area resources but makes antenna fixing easier because a nearby spare diode is more likely to be available where needed.

The diode port of the diode cell must be defined as such in the library. In the Milkyway environment, you can use the `write_def` command to define diode pins. For details, see the *IC Compiler Data Preparation Using Milkyway User Guide*. In addition, the diode protection value must be defined in the physical library. For details, see the description of the `antenna_diffusion_area` attribute in the *Library Compiler Physical Libraries User Guide* and the *Library Compiler Physical Libraries Reference Manual*.

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-11.

To fix antenna violations by connecting spare diodes, use the `connect_spare_diode` command or choose Finishing > Connect Spare Diode in the GUI. For example,

```
icc_shell> connect_spare_diode
```

The `connect_spare_diode` command checks for antenna violations and fixes those violations by connecting the problem nets to nearby spare diodes. This is the full command syntax:

```
connect_spare_diode
[-exclude_nets collection_of_nets]
[-antenna_check_engine internal | hercules]
[-internal_check_option all | top_layer_only]
[-routing skip | route]
[-distance distance_number]
[-signal_route_options ignore_lower_layers |
    include_lower_layers| include_all_lower_layers | advanced]
[-max_ratio max_ratio_number]
```

The `-antenna_check_engine` option specifies which antenna checking engine to use, either the IC Compiler internal antenna checker (`internal`, the default) or the external Hercules antenna checker (`hercules`). If the internal checker is being used, the `-internal_check_option` option specifies whether to report all antenna violations (`all`) or only the top-layer violations (`top_layer_only`).

The `-distance` option specifies the maximum distance from the problem net that is searched for a spare diode. If no spare diode can be found within this distance, the command reports an error. You specify the distance as an integer multiple of the global routing cell size. The default is 10, which means that spare diode cells should be made available within 10 global routing cell lengths of anywhere an antenna violation might occur. For example, an array of spare diode cells with a spacing of 14 global routing cell lengths might be sufficient.

The `-exclude_nets` option specifies a collection of nets that should not be connected to diodes. If you do not set this option, all nets are connected to diodes.

The `connect_spare_diode` command finds each antenna violation, identifies one or more nearby spare diodes required for fixing, and sets the net ID of the diode pins to the name of the problem net that must be connected. The number of diodes required to fix a particular antenna violation depends on the antenna checking method. By default, the command also invokes the detailed router in ECO mode to perform the required routing between the problem net and the diode. However, if you use `-routing skip`, the routing step is skipped. In that case, you can perform the necessary routing separately at a later time. Detailed routing should be complete before you attempt to connect the spare diodes.

By default, the `connect_spare_diode` command uses the antenna-checking mode specified by `doAntennaConx` option detail route option, as explained in “[Defining Antenna Rules](#)” on page 9-11. You can override the `set_droute_options` setting by using `-signal_route_options` in the `connect_spare_diode` command. The four possible override settings are `ignore_lower_layers`, `include_lower_layers`, `include_all_lower_layers`, and `advanced`. These settings correspond to the `doAntennaConx` antenna mode settings of 1, 2, 3, and 4, respectively. The `doAntennaConx`

antenna mode must be set to 1, 2, 3, or 4 (not 0) or `-signal_route_options` must be used in the `connect_spare_diode` command, even if the external Hercules antenna checker is being used.

By default, for antenna mode settings of 1, 2, or 3, the `connect_spare_diode` command checks for an antenna-to-gate area ratio that exceeds the `maxAntennaRatio` parameter of the `set_droute_options` command, as explained in “[Defining Antenna Rules](#)” on [page 9-11](#). You can override the `set_droute_options` setting by using the `-max_ratio` option in the `connect_spare_diode` command.

You can also perform the functions of the `connect_spare_diode` command in the GUI by choosing Finishing > Connect Spare Diode.

## Setting Detail Route Options to Control Antenna Fixing

You can set the detail route options listed in [Table 9-4](#) to fix antenna violations by using the `set_droute_options` command. The option settings are stored with the cell.

*Table 9-4 Detail Route Options*

| Option                             | Range        | Default     | Description                                                                                                                                                                                                                                  |
|------------------------------------|--------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>useSideWallForAntenna</code> | [0, 1]       | 0           | 0: Uses the wire area to compute antenna ratio.<br>1: Uses the wire sidewall area to compute antenna ratio.<br>You need to specify the thickness in the technology file. This option is ignored when <code>doAntennaConx</code> is set to 4. |
| <code>maxCutAntennaRatio</code>    | [0, 1000000] | 0           | 0: Does not compute cut area.<br>N: The ratio of the total area of the charge-collecting antenna cuts to the total gate size should not exceed the value N.<br>This option is ignored when <code>doAntennaConx</code> is set to 4.           |
| <code>maxAntennaRatio</code>       | [0, 1000000] | 10000<br>00 | N: The ratio of the total area of the charge-collecting antenna to the total gate size should not exceed the value N.<br>This option is ignored when <code>doAntennaConx</code> is set to 4.                                                 |

**Table 9-4 Detail Route Options (Continued)**

| <b>Option</b>               | <b>Range</b>        | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------|---------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| maxAntennaPinCount          | [-1, 1000000]       | -1             | -1: Checks antenna on all nets.<br>N: Skips checking antenna on nets with more than N pins.                                                                                                                                                                                                                                                                                                             |
| minAntennaRatioScale        | [0.000, 1.000]      | 0.000          | N: Shows the minimal antenna ratio scale for diode modes 11 and 12.                                                                                                                                                                                                                                                                                                                                     |
| maxAntennaRatioScale        | [0.000, 1.000]      | 1.000          | N: Shows the maximal antenna ratio scale for diode modes 11 and 12.                                                                                                                                                                                                                                                                                                                                     |
| topAntennaFixRange          | [-1, 10]            | -1             | -1: Fixes all top-layer antenna violations by pushing wires down.<br>N: Fixes only top-layer antenna violations if the ratio is less than [safeRatio x (1 + 0.1 * N)] to avoid pushing too many wires to lower layers.<br>This option is valid only when doAntennaConx is set to 4 (Note: When topAntennaFixRange is set, the log file also shows the number of nets that are not fixed by the router). |
| dontMergeGateForAntenna     | [0, 1]              | 0              | When 2 or more input gates are connected,<br>0: The router adds their areas together to compute antenna ratio.<br>1: The router does not add the area of connected input gates.                                                                                                                                                                                                                         |
| outputPinDischarge          | [0, 1]              | 1              | 0: Assumes that no output pin can discharge static electricity.<br>1: Assumes that output pins discharge static electricity.<br>This option is ignored when doAntennaConx is set to 4.                                                                                                                                                                                                                  |
| defaultTopPinExtAntennaArea | [0.000, 1000000.00] | 0.000          | N: Sets the default extAntennaArea value at all metal layers for top-cell pins without specifying the defineExtAntennaArea value in the TDF. This option replaces breakAntennaToTopPin.                                                                                                                                                                                                                 |

*Table 9-4 Detail Route Options (Continued)*

| Option                   | Range               | Default | Description                                                                                                                                                                                                                                                                 |
|--------------------------|---------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| defaultTopPinExtGateSize | [0.000, 1000000.00] | 0.000   | N: Sets the default extGateSize value for top-cell pins without specifying the defineExtAntennaGateSize value in the TDF.                                                                                                                                                   |
| breakAntennaToTopPin     | [0, 2]              | 0       | 0: Treats top-level pins as floating.<br>1: Treats top-level pins as they are connected to a huge antenna and breaks the antenna (Requires a jumper at top metal layer).<br>2: Connects all input pins to top-level pins only through the highest routing layer of the net. |
| checkAntennaOnPG         | [0, 1]              | 0       | 0: Does not check antenna on power and ground nets.<br>1: Checks antenna on power and ground nets.                                                                                                                                                                          |

## 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 will cause circuit failure (a yield loss). A conductive defect causes a short fault, and a nonconductive defect causes an open fault.

The following sections describe how to

- Analyze critical areas
- Reduce critical area short faults by performing wire spreading

---

## Analyzing 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 written to a heatmap text file. You can see the critical area results graphically by displaying critical area heat maps.

## Reporting Critical Areas

To report critical areas, use the `report_critical_area` command (or choose Finishing > Report Critical Area Map in the GUI). This is the command syntax:

```
report_critical_area
  [-particle_distr_func_file filename]
  [-input_layers layerlist]
  [-fault_type short | open]
  [-tsmc_encr_particle_distr_file]
  [-layer_alias_DSD_format layeraliaslist]
  [-suppress_zeros_in_report]
  [-multiparticle_report_format]
```

For example,

```
icc_shell> report_critical_area -fault_type {open} -input_layers {m2 m3}
```

In the command, specify the fault type (short or open), the input layers to be analyzed, and the name of the input file containing the particle distribution function to be used for analysis. Use the `-multiparticle_report_format` option to generate a report containing the critical area analysis result of each individual particle size; use this option when you need the critical area analysis result of each particle size instead of normalized results.

Often the particle probability function is considered proprietary data. When security for a sensitive particle distribution file from a foundry is important, you can use the `process_particle_probability_file` command to encrypt and decrypt the particle probability function. Critical area analysis can work with such an encrypted information.

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 with its options.

| To do this                                                                                                                                                                                                                                                                                                                                                                 | Use this option |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Specify the name of the key used to encrypt <code>-key string</code> and decrypt the particle probability function. The string can be a combination of letters and numbers. The key specified for the encryption of a file must be identical to that specified for decryption. The command fails if they do not match. The key must be a minimum of eight characters long. |                 |

| To do this                                                                                                                                                                                                                                                                                                                                                                                                    | Use this option                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| Specify the name of the input file. If it is a text file, the output will be an encrypted file. If it is an encrypted file, the output will be a text file.                                                                                                                                                                                                                                                   | <code>-input_file file_name</code>  |
| Specify the name of the output file. If none is specified, an output file name will be created, based on the name of the input file ( <i>input_file_name_out</i> ).                                                                                                                                                                                                                                           | <code>-output_file file_name</code> |
| Critical area analysis takes the encrypted file as its input and processes it without the key. The output will be the heat map based on the encrypted particle probability function; it will be 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 for the current design,

1. Specify the type of defect to display by choosing one of the following:
  - Finishing > Open Critical Area Map
  - Finishing > Short Critical Area Map
 The 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 Open Critical Area Map Data dialog box, from which you can run the `report_critical_area` 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 finished routing, you can perform wire spreading to increase the average spacing between wire, which reduces the critical area short faults and therefore improves yield.

The `route_spreadwires` command can make the following changes to the layout:

- Widen the spaces between wires (move wires on the same layer)
- Move wires to the upper or lower metal layers as needed, to resolve DRC violations caused by widening spaces

Because any change to the routing pattern can affect the timing, IC Compiler provides timing-driven wire spreading to minimize the timing impact. When you enable timing-driven wire spreading, the router calls the timer and marks all the timing-critical nets. The wire spreading process does not touch these nets, so as to preserve the timing.

In most cases, timing is improved, due to the wider net spacing produced by wire spreading. However, having too many timing-violated nets in the design can have a negative impact on the final critical area improvement. Often, when too many nets have violations, the cause is that only a limited number of segments can be moved during spreading. To allow more nets to be spread, set the setup slack threshold option to a negative value. For example, if this option is set to  $-0.5$ , the router spreads all nets that have slack greater than  $-0.5$ . The default is  $0.0$ .

To perform wire spreading, use the `route_spreadwires` command (or choose Finishing > Route Spread Wires in the GUI). This is the command syntax:

```
route_spreadwires
[-timing_driven]
[-search_repair_loop number_of_loops]
[-setup_slack_threshold setup_time]
[-min_jog_length min_ratio]
[-num_cpus number_of_cpus]
```

For example,

```
icc_shell> route_spreadwires -widen_wires -search_repair_loop 6 \
-timing_driven -setup_slack_threshold 0.15
```

Use the `-timing_driven` and `-setup_slack_threshold` options to consider timing during wire spreading. In that case, the command finds the timing-critical nets (those having a slack less than the specified threshold value) and prevents spreading from being performed on them. The `-min_jog_length` option sets the minimum ratio of jog length to layer pitch, thereby establishing a minimum jog size. The `-search_repair_loop` and `-num_cpus` options control the computing resources used for wire spreading.

---

## Inserting Redundant Vias

After routing and postrouting optimization, you can replace single-cut vias with multiple-cut via arrays (a process sometimes called via doubling) or with a different via with the same layers. The via is replaced only if the via array or the new via does not introduce DRC violations.

To insert redundant vias, use the `insert_redundant_vias` command (or choose Finishing > Insert Redundant Vias). This is the command syntax:

```
insert_redundant_vias
  -from_via list_of_from_vias
  -to_via list_of_to_vias
  [-to_via_x_size list_of_x-sizes]
  [-to_via_y_size list_of_y-sizes]
  [-via_array_no_swap]
  [-optimize_level level_of_optimization]
  [-num_cpus number_of_cpus]
  [-auto_mode preview | insert]
```

There are two redundant via insertion methods: manual and automatic.

The manual method uses the `-from_via`, `-to_via`, `-to_via_x_size`, and `-to_via_y_size` options to customize the insertion process by specifying which kinds of redundant vias are inserted and the allowed array dimensions. For example, the following command replaces all VIA23 single-cut vias with 1x3 VIA23 arrays and all VIA34 single-cut vias with 5x1 VIA34 arrays:

```
icc_shell> insert_redundant_vias \
           -from_via {VIA23 VIA34} -to_via {VIA23 VIA34} \
           -to_via_x_size {1 5} -to_via_y_size {3 1}
```

The automatic method uses the `-auto_mode` option. If you use the `-auto_mode insert` option, the command inserts the default vias defined in the technology file as redundant vias for all layers. For example,

```
icc_shell> insert_redundant_vias -auto_mode insert
```

If you use the `-auto_mode preview` option, the command lists all of the vias on all the layers without referencing the technology file. You can then cut and paste part or all of the listed vias into a new manual-method command that specifies the `-to_via` and `-from_via` options.

The Insert Redundant Vias dialog box in the GUI (Finishing > Insert Redundant Vias) is very helpful in setting the options for the `insert_redundant_vias` command.

---

## 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

After placement and clock tree synthesis (if applicable) have been completed, you can fill empty spaces in the standard cell rows with instances of reference filler cells to make sure all power nets are connected. Multiheight filler cells are allowed.

One method of improving the stability of the power supply is to add decoupling capacitors as filler cells. However, these filler cells often contain metal internally, and they can cause a short or a spacing rule violation with existing metal routes in the design. During insertion, filler cells with metal are retained only when they do not cause DRC violations.

To insert standard cell fillers,

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. Use the `insert_stdcell_filler` command (or choose Finishing > Insert Standard Cell Filler in the GUI) to insert the standard cell fillers.

The following sections provide more information about these steps.

### 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.

## Inserting the Filler Cells

To insert standard cell fillers, use the `insert_stdcell_filler` command or choose Finishing > Insert Standard Cell Filler in the GUI. [Table 9-5](#) shows the available options.

*Table 9-5 Options for Inserting the Filler Cells*

| Option                                             | Description                                                               |
|----------------------------------------------------|---------------------------------------------------------------------------|
| <code>-cell_without_metal</code>                   | Specifies the list of filler cells to use.                                |
| <code>-cell_with_metal</code>                      | Specifies the master filler cells to use.                                 |
| <code>-bounding_box</code>                         | Specifies the rectangular region to insert filler cells.                  |
| <code>-dont_respect_hard_placement_blockage</code> | Specifies whether to respect hard placement blockage.                     |
| <code>-dont_respect_soft_placement_blockage</code> | Specifies whether to respect soft placement blockage.                     |
| <code>-between_std_cells_only</code>               | Inserts filler cells between two standard cells only.                     |
| <code>-randomize</code>                            | Specifies whether to randomize the selection of filler cells.             |
| <code>-respect_overlap</code>                      | Specifies whether to respect standard-cell overlap check points.          |
| <code>-cell_without_metal_prefix</code>            | Inserts a prefix to the instance names of the filler cells without metal. |

*Table 9-5 Options for Inserting the Filler Cells (Continued)*

| Option                   | Description                                                                          |
|--------------------------|--------------------------------------------------------------------------------------|
| -cell_with_metal_prefix  | Inserts a prefix to the instance names of the filler cells with metal.               |
| -avoid_layers            | Prevents insertion of filler cells under the specified metal layers.                 |
| -connect_to_power        | Specifies the power connection.                                                      |
| -connect_to_ground       | Specifies the ground connection.                                                     |
| -voltage_area            | Specifies the voltage areas to insert filler cells.                                  |
| -vt_filler               | Specifies the threshold voltage cells to be used as voltage threshold fillers.       |
| -check_only              | Runs the command in checking mode, rather than insertion mode.                       |
| -restore_filler_snapshot | Restores the filler cell placement of the snapshot previously created.               |
| -vt_filler_prefix        | Specifies the prefix for the collection of threshold voltage fillers to be inserted. |
| -respect_keepout         | Specifies whether to respect keepout margins.                                        |

The following example fills empty spaces between standard cells with filler cells FILL\_4X, FILL\_2X, and FILL\_1X, in that order of preference, in the bounding box with corners at (10,10) and (5000,5000). By specifying the filler cells from largest to smallest, the total number of filler cells is minimized by adding the larger filler cells first. Cells with metal where they do not cause DRC violations, and cells without metal are used otherwise. No filler cells are inserted under metal 3 or metal 4 preroutes.

```
icc_shell> insert_stdcell_filler \
    -cell_without_metal {FILL_4X FILL_2X FILL_1X} \
    -cell_with_metal {FILL_4XM FILL_2XM FILL_1XM} \
    -bounding_box {{10.0 10.0} {5000.0 5000.0}} \
    -between_std_cells_only -avoid_filler_under {M3 M4}
```

For more information about the `insert_stdcell_filler` command, see the man page.

## 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.

## 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.

---

## 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, be sure to 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.

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.

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-4](#) shows the alignments and fill boxes that occur as a result of the various settings.

*Figure 9-4 Filler Alignment*



The `insert_well_filler` command also has options to specify the following:

- Whether to ignore the PR 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. It is recommended that you 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, 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.

---

## Performing Metal Density Filling

After routing, you can fill the empty tracks in the design with metal wires to meet the metal density rules required by most fabrication processes. This should be done before layout versus schematic (LVS) connectivity verification, design rule checking (DRC), and layout parasitic extraction.

When you define minimum and maximum metal density rules in the technology file, IC Compiler tries to create fill within the specified ranges.

The router does not recognize dummy metal that the GDS reader creates in the FILL view because the dummy metal areas are created as polygons, not wires. However, if they are converted to rectangles and marked with the Fill Track route type attribute, the router will recognize them correctly. Use the `convert_fill_polygons` command to convert the existing FILL view polygons to rectangles and to mark the rectangles with the Fill Track route type. This command should be called as part of data preparation so that the router does not have a problem reading the fill wires. The syntax is

```
convert_fill_polygons -library library_name -from cell_name -to cell_name
```

where *library\_name* is the name of the Milkyway library containing the design cell to modify and *cell\_name* is the name of the design cell to modify.

The `convert_fill_polygons` command converts the input cell’s FILL view polygons to rectangles and then stores the cell in the FILL view of the specified output cell name. The input cell is not actually modified unless the output cell name is the same as the input cell name.

IC Compiler supports both real and emulation metal fill extraction.

- To perform emulation metal fill extraction, you must specify the emulation TLUPlus files by using the `-max_emulation_tluplus` and `-min_emulation_tluplus` options of the `set_tlu_plus_files` command.
- To perform real metal fill extraction, you must specify the `-real_metalfill_extraction` option of the `set_extraction_options` command. IC Compiler can treat the metal fill polygons as either floating or grounded. You can either specify how to treat the metal fill polygons (use the `floating` or `grounded` keyword) or let IC Compiler determine the treatment, based on the fill wire track property (use the `auto` keyword). When you use the `none` keyword (the default), fill is not considered during extraction.

In addition to specifying the `-real_metalfill_extraction` option, you must specify TLUPlus files without any emulation information, using the `set_tlu_plus_files` command.

Note:

IC Compiler uses non-emulation TLUPlus files when `set_extraction_options -real_metalfill_extraction` is set to `auto`, `floating`, or `grounded`. Therefore, you should select real metal fill for extraction only after the metal fill objects have been added.

There are two ways to perform metal fill: by using the internal IC Compiler metal fill capability (`insert_metal_filler` command or Finishing > Insert Metal Filler in the GUI) or by invoking the external Hercules metal fill capability (the `signoff_metal_fill` command or Finishing > Signoff Metal Fill in the GUI). Using the Hercules metal fill capability ensures DRC conformance and produces better quality of results, but requires a Hercules license.

---

## IC Compiler Metal Fill

To perform metal density filling in IC Compiler, use the `insert_metal_filler` command (or choose Finishing > Insert Metal Filler in the GUI). This is the command syntax:

```
insert_metal_filler
[-out self | cellview_name]
[-purge]
[-bounding_box {{llx lly} {urx ury}}]
[-dont_overwrite]
[-timing_driven]
[-insert_as_instance instance_name]
[-tie_to_net none | ground | net_name]
[-create_floating_vias]
[-floating_via_ftr_spacing]
[-routing_space route_space]
[-from_metal from_metal_number]
[-to_metal to_metal_number]
[-width {layer width}]
[-space {layer space_between_fills}]
[-min_length {layer min_length}]
[-max_length {layer max_length}]
[-space_to_route {layer keep_from_metal_space}]
[-space_to_pg {layer keep_from_pg_nets_space}]
[-stagger {layer}]
[-x_offset {layer x_distance}]
[-y_offset {layer y_distance}]
[-dont_snap_fill_to_track]
[-fill_poly]
[-distance_to_boundary poly_to_cell_distance]
```

You can use the `-width`, `-space`, `-min_length`, `-max_length`, `-space_to_route`, `-space_to_pg`, `-x_offset`, and `-y_offset` options to specify the fill characteristics of one or more layers. You specify each characteristic using one or more pairs of values. Each pair consists of a layer name such as poly, m1, or m2; followed by the value. For example,

```
icc_shell> insert_metal_filler \
    -width {m1 0.1} \
    -space {poly 0.1} \
    -min_length {m1 2 m2 2 m3 2} \
    -max_length {m1 10 m2 10 m3 10}
```

This example fills tracks using width 0.1 for metal 1 and spacing 0.1 for poly, with lengths ranging from 2 to 10 for metal 1, metal 2, and metal 3. The default values are used for the remaining metal fill characteristics not specified explicitly in the command.

These are the fill characteristics you can set:

- `-width`: the width of fill tracks
- `-space`: the spacing between fill tracks on the same layer
- `-min_length`: the minimum length of fill tracks
- `-max_length`: the maximum length of fill tracks
- `-space_to_route`: the space to keep away from existing metal
- `-space_to_pg`: the space to keep away from power and ground nets
- `-x_offset`: the x-offset for staggered fill tracks
- `-y_offset`: the y-offset for staggered fill tracks

Fill tracks are staggered if you use the `-x_offset`, `-y_offset`, or `-stagger` option. In that case, if you do not want the fill snapped to wire tracks, use the `-dont_snap_fill_to_track` option.

Use the `-purge` option to remove, rather than insert, metal fill. You can remove fill-track objects from a specified range of layers using `-from_metal` and `-to_metal`. Otherwise, the `-purge` option removes fill-track objects from all layers.

The `insert_metal_filler` command also has options to specify the following:

- Whether to modify the current cell (the default) or write the output to a new cell
- A bounding box in which to insert metal fill
- The net to which the metal fill must be connected
- The space between normal routing wires and the fill metal, expressed as a multiplier of the minimum spacing for the layer (default 1.0)

- The range of layer numbers to fill
- Whether to fill poly layers as well as metal layers (metal layers only by default)
- Whether to create floating vias, and if so, the required spacing
- Whether to check for timing effects during metal fill
- The spacing of poly to the cell boundary

---

## Sign-Off Metal Fill

Using the external IC Validator or Hercules metal fill capability ensures DRC conformance and produces the best quality of results. However, it requires either a separate IC Validator or Hercules license. Without leaving IC Compiler, you can invoke IC Validator or Hercules to create, view, and change metal fill by using the `signoff_metal_fill` command or Finishing > Signoff Metal Fill in the GUI.

You should do one of following environment setups before performing metal fill.

- Set up the Hercules environment

If you plan to use Hercules metal fill from the IC Compiler environment, perform any required setup in the Hercules environment before you invoke IC Compiler. For setup information, see the *Hercules General Usage Information* guide, which is available on SolvNet.

- Set up the IC Validator environment

For designs that are at 32-nm process node or less, you should use the IC Validator metal fill. You must specify the location of the IC Validator executable by using the `PRIMEYIELD_HOME_DIR` environment variable. You should set this variable in your `.cshrc` file. For example,

```
setenv PRIMEYIELD_HOME_DIR /root_dir/primeyield_2009.06
set path = ($PRIMEYIELD_HOME_DIR/bin/AMD.64 $path)
```

You must ensure that the version of IC Validator executable that you specify is compatible with the version of IC Compiler that you are using. For IC Compiler version C-2009.06, you should use IC Validator version C-2009.06 or later.

For more information about IC Validator, see the IC Validator documentation, which is available on SolvNet.

In IC Compiler, the design must be fully routed and DRC-clean. 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.

To prepare for sign-off 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 performing 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 with the `report_physical_signoff_options` command. For more information, see the man page for the command.

To perform metal fill, use the `signoff_metal_fill` command or choose Finishing > Signoff Metal Fill in the GUI.

[Table 9-6](#) describes all the `signoff_metal_fill` options. For more information, see the man page.

*Table 9-6 signoff\_metal\_fill Command Options*

| To do this                                                                                                                                                                                                                                        | Use this option                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| Specify the name of the new FILL view created by the command. The default is <code>cell_name.FILL</code> . This option is mutually exclusive with the <code>-purge</code> , <code>-eco</code> , and <code>-append</code> options.                 | <code>-output_view</code>             |
| Remove metal fill in the default FILL view of the current cell. The fill is removed from the layers that are specified with the <code>-select_layers</code> option, or the whole FILL view is removed if <code>-select_layers</code> is not used. | <code>-purge</code>                   |
| Use the option with the <code>-select_layers</code> option and either the <code>-bounding_boxes</code> or <code>-excluded_bounding_boxes</code> option to perform post-ECO, layer-based fill removal and refilling.                               | <code>-eco</code>                     |
| Insert metal fill incrementally on the existing FILL view.                                                                                                                                                                                        | <code>-append</code>                  |
| Indicate a list of layers where the command inserts or removes metal fill.                                                                                                                                                                        | <code>-select_layers</code>           |
| Specify a list of rectangle bounding boxes where the command inserts or removes metal fill. The default is the whole chip.                                                                                                                        | <code>-bounding_boxes</code>          |
| Specify a list of rectangle bounding boxes where the command cannot insert or remove metal fill.                                                                                                                                                  | <code>-excluded_bounding_boxes</code> |

*Table 9-6 signoff\_metal\_fill Command Options*

| To do this                                                                                                                                                                    | Use this option |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Specify the mode of metal fill that IC Validator or Hercules generates. By default, the mode in the runset is used. This option is mutually exclusive with the -purge option. | -mode           |
| Specify the path of working directory.                                                                                                                                        | -run_dir        |
| The following example removes all metal fill on layers m1 and m3 and then refills those two layers. The other layers are not affected.                                        |                 |

```
icc_shell> signoff_metal_fill -eco -select_layers {m1 m3}
```

The following example fills all empty regions on metal1 outside the bounding box with corners at (100,150) and (300,200).

```
icc_shell> signoff_metal_fill -select_layers {m1} \
-excluded_bounding_boxes {{100 150} {300 200}}
```

In a layout view in the GUI, you can display metal fill that has been added. In the View Settings panel (View > Toolbars > View Settings), set the View Level to 1, and under the Layers tab, toggle on the Datatypes option. Toggle on the view of the desired fill layer.

After performing metal fill, you can do extraction for timing analysis using the real metal fill, as shown in the following example:

```
icc_shell> set_extraction_options -real_metalfill_extraction floating
...
icc_shell> extract_rc -coupling_cap
...
icc_shell> report_timing
...
icc_shell> report_qor
...
```

---

## Performing Notch and Gap Filling

After routing is complete, you can fill notches and gaps that are smaller than the minimum distance limit between objects of the same net on the same layer. The generated notch-and-gap-filling information is stored in the FILL view cell and can be used when you translate your design data to GDSII format.

To perform notch and gap filling, use the `insert_ng_filler` command (or choose Finishing > Insert Notch Gap Filler in the GUI). This is the command syntax:

```
insert_ng_filler
  [-include_existing_notch_gap_fill_cell]
  [-skip_filling_child_cell]
  [-dont_apply_fat_wire_rule]
  [-dont_fill_corner_to_corner]
  [-out outname]
  [-notch_layer_data_type notch_datatype]
  [-gap_layer_data_type gap_datatype]
  [-layers layer_list]
```

For example,

```
icc_shell> insert_ng_filler -include_exisitng_notch_gap_fill_cell \
           -dont_apply_fat_wire_fule -out test.err
```

The command has options to specify the following:

- Whether to use existing notch and gap cells existing in the netlist and having the .FILL extension
- Whether to skip reading the child cell's port data and applying fill on those ports.
- Whether to ignore the fat wire rule when filling notches and gaps
- Whether to ignore corner-to-corner notch errors
- Whether to save the notch and gap errors into a file
- The notch layer data type and gap layer data type numbers
- The list of layers for which to fill notches and gaps

You can also perform notch and gap filling during the search-and-repair process. Doing so enables the router to correct DRC violations as it fills notches and gaps, including violations of 90-nm rules. Set the relevant routing option using the command `set_route_options -same_net_notch_check_and_fix` (or choose Route > Routing Setup > Set Route Options in the GUI and select the corresponding option under the Miscellaneous tab). This setting instructs the router to fix same-net notch violations during the search-and-repair process. For more information, see “[Search and Repair](#)” on page 8-36.

---

## Analyzing CMP Thickness Variation Effects

You can load a parasitic netlist with thickness variation effects generated by the Star-RCXT tool and view chemical-mechanical polishing (CMP) maps to examine thickness variations or hotspots in your design.

---

### Loading the Thickness Data

Before you can display a chemical-mechanical polishing map during a session, you must load the thickness data from a file. The thickness data comes from the Star-RCXT tool.

To load the thickness variation file,

- Use the `read_cmp_thickness -filename string` command.

The information in the file is saved to the database and used for the display of the chemical-mechanical polishing thickness variation and hotspot maps.

The named file can be in single-layer or multilayer format. It contains information for each tile in the entire chip and provides information for each metal layer.

- For single-layer format, the entries of each tile on each line are as follows:

```
"X Coordinate"  
"Y Coordinate"  
"Thickness Variation"
```

- For multilayer format, the entries of each tile on each line are as follows:

```
"X Coordinate"  
"Y Coordinate"  
"Lower Thickness Variation"  
"Upper Thickness Variation"  
"Density Percent"  
"Cumulative Topography"  
"Oxide Thickness"  
"Metal Thickness"
```

---

## Displaying Chemical-Mechanical Polishing Maps

You can display either a thickness variation or a hotspot type of chemical-mechanical polishing map.

To display a thickness variation map for the current design,

1. Choose Finishing > CMP Thickness.

The Map Mode panel appears.

2. Select a metal layer for which thickness variations are to be displayed.
3. Modify the thickness value ranges by changing (or removing) the maximum or minimum threshold values.
4. Click Apply.

To display a hotspot map for the current design,

1. Choose Finishing > Hot Spot.

The Map Mode panel appears.

2. Select a metal layer for which hotspots are to be displayed.
3. Set or adjust thickness variation, topography variation, average topography variation, or other rules. You can set or adjust the following rules. Variances shown in red on the map are hotspots based on the rule setting.

- Rule 1: Thickness variation from average

Computes the average chemical-mechanical polishing variation for all the tiles in the design. If any tile has a chemical-mechanical polishing variation more than the specified percentage from the average for that layer, it is shown in red.

- Rule 2: Thickness variation from neighbors

Computes the average thickness variation for all the neighbors of each tile. If the thickness variation of the current tile varies by more than the specified percentage from the average value of its neighbors, it is shown in red.

- Rule 3: Topography variation from average

Computes the average cumulative topography of all the tiles of the layer. If the cumulative topography of a tile is off by more than the specified percentage from the average topography of that layer, it is shown in red.

- Rule 4: Topography variation from neighbors

Computes the average cumulative topography for all the neighbors of each tile. If the thickness variation of the current tile varies by more than the specified percentage from the average value of its neighbors, it is shown in red.

- Rule 5: Oxide thickness gradient

For each tile in the design, calculates the maximum value of absolute difference between its oxide thickness and that of its neighbors on the same layer. If this absolute difference is greater than the specified value, this tile is shown in red.

- Rule 6: Row topography

For each row on the specified layer, computes the maximum and minimum values of cumulative topography. If the difference between the maximum and minimum values is greater than the specified value, the entire row is shown in red.

- Rule 7: Column topography

For each column on the specified layer, computes the maximum and minimum values of cumulative topography. If the difference between the maximum and minimum values is greater than the specified threshold, the entire column is shown in red.

- Rule 8: Dishing/Antidishing

For each tile on the specified layer, computes the absolute value of difference between metal thickness and oxide thickness. If this value is greater than the specified threshold, that tile is shown in red.

#### 4. Click Apply.

Before you can display a chemical-mechanical polishing map during a session, you must load the thickness data from a file. The thickness data comes from the Star-RCXT tool.

To load the thickness data for the current design,

1. Click the Reload button on the Map Mode panel.

2. In the file browser dialog box that appears, navigate to the directory where the file is located and select the file name.

Alternatively, you can type the name in the “File name” box.

3. Click Open.

For more information about using chemical-mechanical polishing maps, see the “Examining Chemical Mechanical Polishing Maps” topic in IC Compiler Help.

---

## Lithography Compliance Checking

Lithography compliance checking (LCC) is a method of increasing yields by analyzing the chip layout in detail for conditions that can lead to lithography defects and that cannot be fixed by ordinary optical proximity correction methods. PrimeYield LCC is a Synopsys product designed to find these conditions and generate reports on LCC hotspots (locations of potential defects). It simulates the full resolution-enhancement technology tape-out flow using the same production-baseline technology and manufacturing models as those used by foundries and integrated device manufacturers. It reports the location and type of each occurrence of lithographic sensitivity to potential defects such as line-end narrowing and line-end bridging. It ranks these problems by severity and presents them for review.

In IC Compiler, you can detect potential defect locations with the `detect_lcc_hotspot` command, which invokes PrimeYield LCC in the background to find the hotspots. You can view the reported hotspots in the IC Compiler GUI and fix them with the `fix_lcc_hotspot` command. The fixing command repairs the reported conditions by moving, filling, and widening routes and by adding, deleting, and moving vias; or in cases where these local fixing methods cannot be used effectively, it rips up and reroutes the problem net.

PrimeYield LCC licensing is required to use these commands. The PrimeYield LCC and Hercules version used by IC Compiler must be the same as the version used to generate the LCC data files. For information on setting up and using PrimeYield LCC, see the *PrimeYield LCC User Guide* provided with the PrimeYield LCC product.

LCC detection should be performed only on a DRC-clean design after via optimization and critical area reduction have been completed.

---

## Detecting LCC Hotspots

The `detect_lcc_hotspot` command invokes PrimeYield to detect potential lithography-related defects. This is the full command syntax:

```
detect_lcc_hotspot
  -lcc_file_path lcc_path_name
  -layers list_of_layers
  [-dp_hosts list_of_dp_hosts]
```

For example,

```
icc_shell> detect_lcc_hotspot \
           -lcc_file_path /LCC/full-chip \
           -layers {M2 M3 M4} \
           -dp_hosts {lin1 lin2 lin3 lin4 lin5 lin6 lin7 lin8}
```

This command performs full-chip LCC detection and produces two fixing guidance files in the working directory, out00 and fout00. These two files contains hotspot information and guidance for local fixing and reroute fixing. They are required to run the `fix_lcc_hotspot` command.

The hotspot detection process also produces an error cell named `top_cell_name_lcc.err`. You can open this error cell in the GUI using Verification > Error Browser and view the hotspots in the current design. Each hotspot is highlighted as a DRC error.

In the `detect_lcc_hotspot` command, you must specify the full path name of the directory containing the PrimeYield runset files necessary for full-chip LCC detection. For information on preparing runset files, see the *PrimeYield LCC User Guide* provided with the PrimeYield LCC product; or see the article “Using PrimeYield LCC,” available as SolvNet article 023079. You must also specify the layers to be checked.

The `detect_lcc_hotspot` command requires distributed processing because of the long runtime for full-chip LCC detection. You can specify the machines to be used with the `-dp_hosts` option, the `.dprc` file under the working directory, or the `.dprc` file specified under the `lcc_path_name` directory. Running hotspot detection on a single CPU is not supported.

The distributed processing engine used by `detect_lcc_hotspot` is different from that used by the `fix_lcc_hotspot` command and many other routing commands. You do not need to run the `set_distributed_route` command before `detect_lcc_hotspot`. If you run `set_distributed_route`, you should run `remove_distributed_route` before `detect_lcc_hotspot` to release the reserved network resources. Otherwise, the communication port between machines might become occupied and block distributed processing functionality.

---

## Fixing LCC Hotspots

The `fix_lcc_hotspot` command attempts to fix hotspots previously detected with the `detect_lcc_hotspot` command. The design must be DRC-clean to obtain maximum fixing quality and to ensure iteration convergence. The two fixing guidance files generated by the `detect_lcc_hotspot` command, `out00` and `fout00`, must be present the working directory.

This is the full command syntax of the LCC hotspot-fixing command:

```
fix_lcc_hotspot
  -lcc_file_path lcc_path_name
  [-types list_of_types]
  [-level level]
  [-num_loops number_of_loops]
  [-num_cpus number_of_cpus]
```

For example,

```
icc_shell> set_distributed_route \
           -jp_machines {linux1 linux2 linux3 linux4 linux5}

icc_shell> fix_lcc_hotspot \
           -lcc_file_path /root/LCC/Local-LCC \
           -types {line space lineend slotend} \
           -level 1 -num_cpus 10
```

Distributed processing is recommended because runtimes can be long. First run the `set_distributed_route` command to set up the machines to be used. Then, in the `fix_lcc_hotspot` command, set the `-num_cpus` option to a value greater than 1. For more information on distributed routing, see the “[Enabling Distributed Routing](#)” on page 8-16.

In the `fix_lcc_hotspot` command, you must specify the full path name of the same LCC directory used by the `detect_lcc_hotspot` command. This is the directory containing the PrimeYield LCC runset files necessary for full-chip LCC detection. You can optionally specify the types of hotspots to fix, the hotspot severity levels to fix, the maximum number of fixing loops to attempt, and the number of CPUs to use.

The `-types` option specifies the types of hotspots to fix, which can be any combination of `line`, `lineend`, `space`, `slotend`, and `voc` (via overlay check). The default behavior is to fix all types of hotspots.

The `-levels` option specifies the severity levels to fix. If you use this option, the command attempts to fix only the hotspots having a severity number equal to or less than the specified number. Lower numbers represent the more severe hotspots.

There are two severity level systems, LCC-t and LCC-g. IC Compiler gets the severity level system, either LCC-t or LCC-g, from the LCC runsets. You need to know which level system is being used so you can enter an appropriate level number. The LCC-g system has the possible level values 1, 2, 3, 4, and 5. If you specify `-levels 3` in this system, the command fixes only the hotspots having a severity level of 1, 2, or 3. The default maximum severity value for this system is 2.

The `fix_lcc_hotspot` command attempts to fix LCC hotspots using multiple iterations of fixing and rechecking. In each iteration, it first tries to fix hotspots by local-fixing and rerouting. New DRC violations or new LCC hotspots might occur as a result of fixing, so it performs internal DRC checking and launches LCC checking jobs to check the changed patterns. This process is repeated until there are no more LCC hotspots or DRC violations, or until the number of iterations reaches the maximum value specified by the `-num_loops` option. Most designs that can converge do so in less than 10 iterations.

## **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.

The following conditions can impact signal integrity:

- Crosstalk

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.

- Signal electromigration

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 IC 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 (using interface logic models). When creating an interface logic model for use in a hierarchical signal integrity flow, you must use the `-include_xtalk` option when you run the `create_ilm` command.

IC Compiler signal integrity analysis and optimization supports 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), then a functional failure will result.

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 post-routing 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 Sign-Off Optimization
  - Sample 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`, `psynopt -on_route`, 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” field              | <code>-route_xtalk_prevention_threshold</code>                                                    | 0.45                     |
| <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-31.

---

## 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.

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 of 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_options -groute_timing_driven true` command (or by choosing Route > Routing Setup > Set Route Options in the GUI and selecting “Timing driven” in the Global Routing tab).

- Timing-driven track assignment

Enable timing-driven track assignment by using the `set_route_options -track_assign_timing_driven true` command (or by choosing Route > Routing Setup > Set Route Options in the GUI and selecting “Timing driven” in the Track Assign tab).

## 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 `set_si_options -delta_delay true`.

- Hold time optimization with crosstalk delta delay

To perform hold fixing in addition to setup fixing with crosstalk delta delay, use the `-min_delta_delay true` option together with `-delta_delay true` in the `set_si_options` command.

- Total slew optimization

To consider crosstalk-induced slew effects during maximum transition time design rule fixing, use the `-max_transition_mode total_slew` option together with `-delta_delay true` in 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
```

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-2, to ensure that you are using the correct timing and noise models
- The Arnoldi delay calculation algorithm, as described in “[Selecting Delay Calculation](#)” on page 3-37
- The types of crosstalk analysis to perform

You can select delta delay (`set_si_options -delta_delay true`), minimum delta delay (`-min_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.

- 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 will induce 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 will be 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 may 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 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. On the other hand, when the aggressor and victim switch in opposite directions, the transition time of the victim is longer because of a larger effective capacitance, and the result is likely to be 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:

- Choose Timing > Static Noise Visual Mode.

The Visual Mode panel appears.

- Click Reload.

The Static Noise Visual Mode dialog box appears.

- Specify the analysis options.

- Click OK.

- Display the Static Noise Analysis window by following these steps:

- Choose Timing > Static Noise Analysis.

The Static Noise Analysis dialog box appears.

- Specify the analysis options.
- 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 Sign-Off Optimization

During sign-off 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  
To perform hold fixing with crosstalk delta delay, run `set_si_options -min_delta_delay true`.
- 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.

---

## Sample Scripts

[Example 10-1](#) shows a sample 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 a sample script for running the block-level hierarchical signal integrity flow.

#### *Example 10-2 Block-Level Hierarchical 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
save_mw_cel
create_ilm -include_xtalk
```

---

## 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 is 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
set_switching_activity -toggle_rate 1.0 \
    -static_probability 0.5 [get_net net_name]
propagate_switching_activity

# perform timing update
update_timing

# perform signal EM analysis
report_signal_em -repair "repair_file" -verbose \

```

```
[get_nets -hier *] > signal_em.rpt

# repair signal EM violations source repair_file
route_opt -incremental
```

---

## 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 Milkyway, to load the signal electromigration constraints in .plib format into the design library, use a script similar to the following:

```
read_plib
setFormField "Import Plib" "Library Name" "design_library"
setFormField "Import Plib" "Tech PLIB/PDB File" \
"signal_em_constraintsplib"
setFormField "Import Plib" "Overwrite Existing Tech" "1"
formOK "Import Plib"
```

IC Compiler currently does not support electromigration constraints in ALF format. To convert electromigration data in ALF format to .plib format, use a Milkyway script similar to the following one:

```
auAlfToDB
formDefault "ALF Loader"
setFormField "ALF Loader" "Lib Name" "design_library"
setFormField "ALF Loader" "Alf Model File Name"
"signal_em_constraints.alf"
formOK "ALF Loader"

cmDumpPlib
formDefault "Dump Plib File"
setFormField "Dump Plib File" "Signal EM info" "1"
setFormField "Dump Plib File" "Antenna Rules" "0"
setFormField "Dump Plib File" "Other Tech info" "0"
setFormField "Dump Plib File" "Library Name" "design_library"
setFormField "Dump Plib File" "Plib File Name" "dump_signal_emplib"
formOK "Dump Plib File"
```

If the signal electromigration constraints are not defined in the design library, 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 EM 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-21:

```
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-33. 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-33; or extract the data, as described in “[Postroute RC Extraction](#)” on page 8-59.

---

## 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-3](#) shows a sample SAIF file. For more information about the SAIF file, see the *Power Compiler User Guide*.

*Example 10-3 Sample 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 probably 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 value of 1 is used when it is not specified.

---

## Updating the Timing

To perform signal electromigration analysis, IC Compiler must perform a timing update to calculate the slew rate on each output pin and thereby determine the current density of each wire and via. Before a timing update, be sure that the timing constraints have been specified, for example, by loading a Synopsys Design Constraints (SDC) file.

To update the design timing, use the `update_timing` command:

```
icc_shell> update_timing
```

During a timing update, if parasitics have not already been loaded with the `read_parasitics` command, IC Compiler automatically performs parasitic extraction.

---

## 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 post-routing stage to repair electromigration.

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.

```
icc_shell> report_signal_em -verbose
```

The `report_signal_em` command generates the following:

- A report that lists the signal electromigration violations
- A repair file that you can use during the search-and-repair process to fix the violations

When you perform signal electromigration analysis, the tool computes three current density values:

- Average

The average current density 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 density 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 density 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 generated report displays these values for all violating nets. [Example 10-4](#) shows a sample report.

#### *Example 10-4 Sample Signal Electromigration Report*

```
*****
Report : signal-electromigration
Design : TEST
Version: C-2009.06-ICC
Date   : Wed May 20 15:35:59 2009
*****

net: 'net1'
switching activity: 0.0333333/ns
  Met/Via    Layer    Width/Cut  Mode  Eff_Avg   Eff_Rms   Eff_Peak   Rel_Avg   Rel_RMS   Rel_Peak
  Metal      32       M2        0.07   min     9.66e-17  4.20e-01  1.57e-05  2.27e-15  8.26e-01  2.04e-05
  Metal      32       M2        0.07   max     6.01e-17  4.51e-01  1.34e-05  1.41e-15  8.88e-01  1.74e-05
  Via        52       V2        2      min     5.73e-08  1.33e-02  1.13e-03  1.38e-06  0.00e+00  0.00e+00
  Via        52       V2        2      max     3.04e-08  1.92e-02  1.17e-03  7.33e-07  0.00e+00  0.00e+00
```

The report fields are

- `Met/Via` and `Layer` denote the metal or via edge and the corresponding layer number.

**Note:**

Because no actual geometries exist in the virtual routing stage, the `Met/Via` and `Layer` fields are not present in prerouting analysis.

- `Width/Cut` lists the width of the net segment or the number of via cuts.
- `Mode` is `min` or `max`, which designates the corner on which the calculation is based.
- `Eff_Avg`, `Eff_Rms`, and `Eff_Peak` show the calculated average, root mean square, and peak currents, respectively. These values are in terms of the current units defined in the Milkyway design library.
- `Rel_Avg`, `Rel_RMS`, and `Rel_Peak` show the ratio of the calculated value to the constraint value for the average, root mean square, and peak currents, respectively.

## Repairing Electromigration Violations

If `report_signal_em` finds violations, it generates a repair file. The name of the repair file is specified by the required `-repair_file` option. The repair file defines variable routing rules, such as width and contact constraints, for those nets that violate the current constraints. The router follows these rules to route or reroute these nets. For example, there might be an increased wire width constraint for a specific metal layer to help fix a signal electromigration problem.

[Example 10-5](#) shows a sample repair file.

***Example 10-5 Sample Repair File***

```
define_routing_rule em_rule_3666 \
    -widths { METAL1 0.96 METAL2 1.12 METAL3 1.12 METAL4 1.12 } \
    -via_cuts { via1 3x3 via2 3x3 via3 3x3 } \
    -taper_level 4
set_net_routing_rule {n5514} -rule em_rule_3666
```

To load the variable routing rules, use the `source` command.

```
icc_shell> source repair_file
```

After you load the repair file, run `route_opt -incremental` to reroute violating nets.

If there are only a few signal electromigration violations and the design has enough margin for timing closure, you can quickly fix signal electromigration violations by running search and repair:

```
icc_shell> route_search_repair
```



# 11

## Using Interface Logic Models

---

An interface logic model (ILM) is a structural model of a circuit that is modeled as a smaller circuit representing the interface logic of the block. The model contains the cells whose timing is affected by or affects the external environment of a block. ILMs enhance capacity and reduce runtime for top-level optimization.

The concepts and tasks related to using ILMs in IC Compiler are presented in the following sections:

- [Overview of Interface Logic Models](#)
- [Creating ILMs](#)
- [Validating ILMs](#)
- [Reporting Information About ILMs](#)
- [Using ILMs in the Top-Level Design](#)
- [Viewing ILMs in the IC Compiler GUI](#)
- [Hierarchical Signal Integrity Flow With ILMs](#)
- [Multicorner-Multimode Scenarios and ILMs](#)

## Overview of Interface Logic Models

Interface logic models (ILMs) are used in IC Compiler to reduce the number of design objects and memory requirements when the tool performs top-level optimization on large designs. In an ILM, the gate-level netlist for a block is modeled by a partial gate-level netlist that contains only the needed interface logic of the block and possibly the logic you manually associate with the interface logic. All other logic is removed.

[Figure 11-1](#) shows a block and its interface logic model. The logic between the input port and the first register is preserved, as is the logic between the last register and the output port. Clock connections to the preserved registers are kept as well. Logic associated with pure combinational input-port-to-output-port timing paths (A to X) is also preserved. The remaining logic is discarded.

*Figure 11-1 A Block and Its Interface Logic Model*



You can use ILMs in all hierarchical design flows supported by IC Compiler, including

- 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. For an abutted layout style, IC Compiler supports automatic pin detection and RC extraction. Thus, the extraction engine sees pins from abutted ILMs as being connected to one another.

- IEEE 1801™ Unified Power Format (UPF)

IC Compiler retains the UPF objects, such as level-shifter cells, isolation cells, power switch cells, netlist power pins, ports, nets, and strategy properties that are part of interface logic. When the top-level netlist is linked, the UPF objects retained in the ILM are automatically propagated to the top-level before the top-level power domain is loaded.

- 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 for each scenario.

- Hierarchical signal integrity

IC Compiler can create ILMs with coupling capacitance and signal integrity information for use with top-level 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.

You create an ILM from a block by using the `create_ilm` command. Various command options are available to control specific properties of the generated model.

**Note:**

Only instances at the top level of the physical hierarchy can be modeled as ILMs, but ILMs can occur at any level of logic hierarchy.

IC Compiler can create either compact or noncompact ILMs, which are defined as follows:

**compact ILM**

A compact 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 these paths are included in the compact ILM. This is the default ILM model.

**noncompact ILM**

A noncompact ILM contains all interface logic from each input port and to each output port.

When ILMs are used, the amount of memory usage and runtime improvement depends on design style.

- Designs with registered inputs and outputs will 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.
- Compact ILMs, which are the default ILMs, significantly reduce what is retained in an ILM versus a noncompact ILM.

IC Compiler can create ILMs for the following design configurations:

- Feedthrough nets

Feedthrough nets can be on signal nets or clock nets.

- Don't touch subblocks

The `create_ilm` command automatically handles don't touch subblocks; you do not have to manually remove the `dont_touch` attribute on subblocks before creating an ILM for the block.

- Nested ILMs

A nested ILM is an ILM that is contained within a higher-level ILM. When creating an ILM for a block with nested ILMs, IC Compiler retains only the logic from the lower-level ILM that is involved in the interface logic of the upper-level ILM. For more information about nested ILMs, see “[Creating ILMs for Blocks With Nested ILMs](#)” on page 11-17.

## Milkyway Database Compatibility

ILMs created in IC Compiler are stored in the Milkyway database and are subject to the following compatibility limitations of the Milkyway database between the different versions of the tool:

- ILMs created using IC Compiler versions prior to B-2008.09 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 IC Compiler version B-2008.09 or later versions 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 IC Compiler version B-2008.09 can be used in IC Compiler version C-2009.06 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. The specified cells in the libraries are converted and saved to the disk. This is the recommended method for converting the B-2008.09 version database into a C-2009.06 version database.
  - 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 is an easy method, but it is not the preferred method as an additional runtime penalty occurs for repeated conversions.

Note:

Converting ILMs created in IC Compiler version B-2008.09 into version C-2009.06 is not exactly the same as running the `create_ilm` command in IC Compiler version C-2009.06. 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 C-2009.06 are supported in version B-2008.09 by using the `convert_mw_lib -previous` command.

---

## Benefits of Using ILMs

In addition to improved capacity and reduced optimization times for large designs, ILMs provide these benefits:

- ILMs preserve interface logic by discarding only the logic that is not required for modeling boundary timing. Any subblock in the hierarchy that affects the boundary timing is retained. Therefore, ILMs provide highly accurate timing representations.
- Differences between the timing characteristics of an ILM and its original netlist are easy to debug because the needed interface logic is maintained.
- Required clock and data paths are preserved, and the cell names and net names are identical to the cell names and net names in the CEL view of the original block.

## Creating ILMs

You use the `create_ilm` command to generate an ILM. [Figure 11-2](#) shows the basic steps for creating ILMs in IC Compiler.

*Figure 11-2 Basic Steps for Creating an ILM in IC Compiler*



To create an ILM, follow these steps:

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.
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 `create_generated_clock` command. If you do not specify the clocks, IC Compiler automatically detects them during noncompact ILM creation.

### 3. Create the ILM by using the `create_ilm` command with the appropriate options.

When creating an ILM, IC Compiler

- Performs the following checks on the block:
  - 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 because the ILM will be the same size as the original design.
  - Verifies that all cells and ports of the design have defined locations. If not, the tool does not create an ILM and terminates with an error message.

If you want to disable these checks, set the `ilm_disable_ilm_checks` variable to true. The default for this variable is false.

- Applies the `dont_touch` attribute to all cells of the created ILM and applies the `is_interface_model` attribute to the model.
- Saves the ILM model to the ILM view.

You do not use the `save_mw_cel` command to save the ILM.

Note:

The design in memory after `create_ilm` is the CEL view of the block, not the ILM view.

For information about creating ILMs in a multicorner-multimode design, see [“Multicorner-Multimode Scenarios and ILMs” on page 11-39](#).

---

## Controlling the Logic Included in an ILM

By default, IC Compiler creates a compact ILM that includes the following interface logic:

- Leaf cells and macro cells in the four critical timing paths that lead from input ports to output ports (combinational input-to-output paths)
- Leaf cells and macro cells in the four critical timing paths that lead from input ports to edge-triggered registers
- Leaf cells and macro cells in the four critical timing paths that lead from edge-triggered registers to output ports
- Abstracted clock trees that include the minimum and maximum clock paths, as well as the clock tree synthesis exceptions that are a part of these paths

Note:

For the purposes of ILM generation, generated clocks are treated like clock ports.

- Clock-gating circuitry, if it is driven by external ports
- Logic along the timing path between a master clock and any generated clocks derived from it
- Side-load cells for nets that are connected to the ports of the ILM (the boundary side-load cells) and for nets that are routed and extracted

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 (UPF) objects that are required at the top-level

Note:

By default, latches are treated as combinational logic.

## Changing the Compaction Level

The compaction level controls the amount of logic retained in the ILM. When you compact the interface logic on a path, only the interface logic on the four critical timing paths for that path is retained, rather than retaining all of the interface logic for that path.

You specify the compaction level by using the `-compact` option when you run the `create_ilm` command. The supported compaction levels are

- `-compact all` (the default)

This option performs compaction on all input paths and all output paths and results in the smallest ILM, while still maintaining timing accuracy.

- `-compact output`

This option performs compaction only on the output paths and retains all interface logic on the input paths, resulting in a larger ILM.

- `-compact none`

This option disables compaction and retains all interface logic on both the input paths and the output paths and results in the largest ILM.

If your design does not have complete and correct SDC files, you must use this option because compaction is slack-based for each port.

## Retaining Additional Logic

IC Compiler provides several options that enable you to retain logic in addition to the default interface logic. The following sections describe these options.

### Retaining the Entire Clock Network

By default, IC Compiler retains abstracted clock trees that include the minimum and maximum clock paths, as well as the clock tree synthesis exceptions that are a part of these paths. To keep the entire clock trees, use the `-keep_full_clock_tree` option.

```
icc_shell> create_ilm -keep_full_clock_tree
```

Note:

Because this option causes an ILM to contain many or all of the registers that are in the CEL view of the block, you might see a degradation in capacity and runtime at the top level.

## Retaining All Macro Cells in the Design

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 `-keep_macros` 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.

```
icc_shell> create_ilm -keep_macros
```

## Retaining All Logic in the Design

By default, IC Compiler retains only the interface logic. To retain all the design logic in the ILM, use the `-include_all_logic` option. You should use this option only where you need to retain the entire logic in the ILM, such as for a clock generator block or for a very small block.

```
icc_shell> create_ilm -include_all_logic
```

Note:

Because this option causes an ILM to contain all the logic that is in the CEL view of the block, you might see a degradation in capacity and runtime at the top level.

## Retaining Ports Required for Functional Correctness

You can use the `-must_connect_ports` 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.

```
icc_shell> create_ilm -must_connect_ports [get_ports {in1 in2}]
```

## Retaining Logic Affected By Block-Level Case Analysis Constraints

If you apply case analysis constraints on a block, the disabled logic is removed from the ILM because that logic is usually not needed. However, if the case analysis values on an input or inout port can change when linked to the top-level design, you must retain all interface logic that is associated with this port.

To retain all the interface logic on case-controlled ports, use the `-case_controlled_ports` 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.

```
icc_shell> create_ilm -case_controlled_ports [get_ports {ccin}]
```

After creating an ILM that is case-analysis-independent for the specified ports, you can 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 nets that are connected to the ports of the ILM (the boundary side-load cells) and for nets that are routed and extracted. This usually provides the best tradeoff between model size and accuracy.

You can control which side-load cells are included in the ILM by using the `-include_side_load` option when you run the `create_ilm` command.

The supported values for this option are

- `-include_side_load boundary` (the default)
- `-include_side_load all`

This option includes all side-load cells. Although using this option increases the ILM size, it can improve the timing accuracy of the ILM.

- `-include_side_load none`

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 11-3](#) 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 11-3 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.

You can 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 -compact none -latch_level 1
```

If your design does not have any time borrowing over 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 11-4](#) shows a default ILM model and latch levels. [Figure 11-5](#) shows the results of specifying latch level 1 and latch level 0.

*Figure 11-4 Interface Logic Model and Latch Levels**Figure 11-5 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 `-compact none` option when you run the `create_ilm` 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 a high-fanout port 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 value 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, you can 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]
```

The connectivity from all ignored ports, whether auto-ignored or explicitly ignored, to already-identified interface logic is retained. Minimum and maximum paths and connectivity from these 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 timing exceptions such as the `set_case_analysis`, `set_disable_timing`, or `set_false_path` commands that you apply on the block, because that logic is usually not needed.

If you want to create a context-independent ILM by retaining 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
```

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

If you plan to perform top-level on-route optimization using ILMs, you must store the parasitic data in the ILM. The parasitic data stored in the ILM is automatically used when you run top-level routing, the `extract_rc` command, the `route_opt` command, or the `psynopt -on_route` command.

When you create an ILM model for a routed block, IC Compiler automatically enables the `-keep_parasitics` option. When the `-keep_parasitics` option is enabled, the `create_ilm` command runs the `extract_rc` command in the background and back-annotates the postroute detailed parasitic data of the original placed and routed block onto ILM.

Note:

If the design is not routed, the `create_ilm` command ignores the `-keep_parasitics` option.

If you plan 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, enable the signal integrity options before you run the `create_ilm -include_xtalk` 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

If you plan to use the generated ILM in the top-level signal integrity flow, use the `-include_xtalk` option when you run the `create_ilm` command to generate an ILM with signal integrity information, such as boundary net aggressor data, effective net resistance, total capacitance, and coupling capacitances.

Note:

To generate an ILM with coupling capacitances, the design must be either track assigned or detail routed.

---

## Storing Physical Information for ILMs

Information such as the locations of ILM cells and ports, the net capacitance values, and net delays for nets internal to the model are stored in the ILM. For nets crossing the model boundary, IC Compiler reestimates the wire length and recomputes the boundary net delays when you run the `place_opt` command.

To use the ILM in the top-level design, you must also have information about the placement blockages and route guides. The top-level optimization commands use this information to place the top-level cells, correctly estimate wire lengths for the top-level nets before routing, and route the top level, using any over-the-block resources that are not blocked by the keepouts. This information is stored in the FRAM view, which is created by using the `create_macro_fram` command.

For example, to create a FRAM view for the blk1 block, enter the following command:

```
icc_shell> create_macro_fram -library_name design_lib -cell_name blk1
```

Before creating the FRAM view, you must create the placement and routing blockages for the block design with the following commands:

- The `create_placement_blockage` command for placement blockages

The `create_placement_blockage` command defines only rectangular regions (`-bbox` option). To create a rectilinear region, you must abut two or more placement blockages to create a “composite” blockage that defines the appropriate rectilinear region.

For details, see the man page.

- The `create_routing_blockage` command for routing blockages

The `create_routing_blockage` command defines either rectangular (`-bbox` option) or rectilinear (`-boundary` option) shapes.

For details, see the man page.

Note:

If you do not create a FRAM view for the block or if you fail to change to the block FRAM view, the blockage information is not available to the top level. In this case, IC Compiler automatically creates an all-metal-layer routing blockage for the entire ILM, so that none of the ILM area is available for over-the-block routing. Likewise, none of the ILM area is available for over-the-block placement.

---

## Creating ILMs for Rotated and Mirrored Instances

Even when multiple instances with different orientations of an ILM are instantiated at the top level, you need to create only one ILM. All eight orientations—north, flipped (mirrored) north, south, flipped (mirrored) south, east, flipped (mirrored) east, west, and flipped (mirrored) west—are allowed.

For detailed information, see “[Handling Rotated and Mirrored ILMs in the Top-Level Design](#)” on page 11-30.

Note:

The orientations of ILM instances at the top level must be defined in a floorplanning tool or input as a DEF file or as attributes in a Milkyway top-level design.

---

## 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, IC Compiler 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 11-6](#) shows the ILM for the BOT block.

*Figure 11-6 Interface Logic Model for the BOT Block*



[Figure 11-7](#) shows the CEL view for the MID block, which contains the ILM for the BOT block.

*Figure 11-7 MID Block That Contains the ILM for the BOT Block*



When you run the `create_ilm` command on the MID block, IC Compiler 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 11-8](#) shows the ILM for the MID block. The dotted line indicates the logical hierarchy.

*Figure 11-8 Interface Logic Model for the MID Macro*



---

## Creating ILMs for Multiple Blocks

You can 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 the following section, “[ILM Creation Command Options](#).”

Before you can use the `create_ilm_models` command, CEL views must exist for the blocks that will be turned into ILMs by the command.

---

## Summary of the ILM Creation Command Options

[Table 11-1](#) summarizes the command options supported by the `create_ilm` command. Unless otherwise noted, all options are supported by both the `create_ilm` and `create_ilm_models` commands.

*Table 11-1 ILM Creation Command Options*

| To do this                                                                                                                                                                                                                                                       | Use this                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| Specify the compression strategy that is used to reduce the size of the ILM. The default is <code>all</code> .<br>For more information, see “ <a href="#">Changing the Compaction Level</a> ” on <a href="#">page 11-9</a> .                                     | <code>-compact output   all   none</code> |
| Retain the entire clock tree, rather than an abstracted clock tree.<br>For more information, see “ <a href="#">Retaining the Entire Clock Network</a> ” on <a href="#">page 11-9</a> .                                                                           | <code>-keep_full_clock_tree</code>        |
| Retain macros that are not part of the interface timing paths.<br>This option is supported only by the <code>create_ilm</code> command.<br>For more information, see “ <a href="#">Retaining All Macro Cells in the Design</a> ” on <a href="#">page 11-10</a> . | <code>-keep_macros</code>                 |
| Retain all logic that is in the CEL view of the block.<br>For more information, see “ <a href="#">Retaining All Logic in the Design</a> ” on <a href="#">page 11-10</a> .                                                                                        | <code>-include_all_logic</code>           |

*Table 11-1 ILM Creation Command Options (Continued)*

| To do this                                                                                                                                                                                                                                                                                                                                                            | Use this                             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| <p>Specify the list of ports, such as scan enable or reset ports, that must be connected to already identified logic for the functional correctness of design.</p> <p>This option is supported only by the <code>create_ilm</code> command.</p> <p>For more information, see “<a href="#">Retaining Ports Required for Functional Correctness</a>” on page 11-10.</p> | <code>-must_connect_ports</code>     |
| <p>Retain all logic associated with the specified case-analysis input and inout ports.</p> <p>This option is supported only by the <code>create_ilm</code> command.</p> <p>For more information, see “<a href="#">Retaining Logic Affected By Block-Level Case Analysis Constraints</a>” on page 11-10.</p>                                                           | <code>-case_controlled_ports</code>  |
| <p>Control the side-load cells that are included in the ILM.</p> <p>This option is supported only by the <code>create_ilm</code> command.</p> <p>For more information, see “<a href="#">Controlling Side-Load Cells</a>” on page 11-11.</p>                                                                                                                           | <code>-include_side_load</code>      |
| <p>Control the number of latch levels included in the model.</p> <p>For more information, see “<a href="#">Controlling the Number of Latch Levels</a>” on page 11-12.</p>                                                                                                                                                                                             | <code>-latch_level</code>            |
| <p>Do not automatically exclude the fanout logic from input ports connected to a certain percentage or greater of the total number of registers in the design.</p> <p>This option applies only to noncompact ILMs.</p> <p>For more information, see “<a href="#">Retaining the Fanin and Fanout of Chip-Level Networks</a>” on page 11-14.</p>                        | <code>-no_auto_ignore</code>         |
| <p>Specify the ports to ignore when identifying the interface logic.</p> <p>This option applies only to noncompact ILMs and is supported only by the <code>create_ilm</code> command.</p> <p>For more information, see “<a href="#">Retaining the Fanin and Fanout of Chip-Level Networks</a>” on page 11-14.</p>                                                     | <code>-ignore_ports</code>           |
| <p>Retain the interface logic from disabled timing arcs and pins.</p> <p>This option applies only to noncompact ILMs and is supported only by the <code>create_ilm</code> command.</p> <p>For more information, see “<a href="#">Retaining Logic on Disabled Paths</a>” on page 11-14.</p>                                                                            | <code>-traverse_disabled_arcs</code> |

*Table 11-1 ILM Creation Command Options (Continued)*

| To do this                                                                                                                                                                                                                                                   | Use this                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| Include parasitics in the ILM view.<br>This option is automatically enabled if the block has routed nets and is ignored if the block is not routed.<br>For more information, see “ <a href="#">Storing Parasitic Information in the ILM</a> ” on page 11-15. | <code>-keep_parasitics</code> |
| Generate a signal-integrity-aware ILM.<br>For more information, see “ <a href="#">Storing Signal Integrity Information in the ILM</a> ” on page 11-15.                                                                                                       | <code>-include_xtalk</code>   |
| Generate an ILM for multicorner-multimode scenarios.<br>For more information, see “ <a href="#">Multicorner-Multimode Scenarios and ILMs</a> ” on page 11-39                                                                                                 | <code>-scenarios</code>       |

## Validating ILMs

You can 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 11-2](#) lists the options supported by the `write_interface_timing` command.

*Table 11-2 Options Supported by the write\_interface\_timing Command*

| To do this                                                                                                | Use this                   |
|-----------------------------------------------------------------------------------------------------------|----------------------------|
| Specify the type of the file to which the interface timing information is to be written.                  | <code>file_name</code>     |
| Specify a list of ports that are to be excluded from the timing file. By default, all ports are included. | <code>-ignore_ports</code> |

**Table 11-2 Options Supported by the write\_interface\_timing Command (Continued)**

| To do this                                                                                                                                                                                      | Use this           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Prevent line-splitting.                                                                                                                                                                         | -nosplit           |
| Specify 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 value is 3. | -significant_digit |

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 starting from input ports or ending at output ports. For each critical path, it reports the slack values for following arc types: `min_rise`, `min_fall`, `max_rise`, and `max_fall`
- Type: This section contains maximum or minimum arc values for critical paths starting from input ports or ending at output ports. For each path timing relationship, it reports one of the following possible arc types: `min_rise`, `min_fall`, `max_rise`, and `max_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 the 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 11-3** lists the command options supported by the `compare_interface_timing` command.

**Table 11-3 Options Supported by the compare\_interface\_timing Command**

| To do this                                                                                                      | Use this                         |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------|
| Specify the name of the timing file to be used as the reference in the comparison.                              | <code>ref_timing_file</code>     |
| Specify the name of the timing file to be compared in the comparison.                                           | <code>cmp_timing_file</code>     |
| Specify the name of the output file for which the results of the comparison are to be written.                  | <code>-output</code>             |
| Specify an absolute error tolerance for time data. The default is “0.1” timing unit of the current design unit. | <code>-absolute_tolerance</code> |

*Table 11-3 Options Supported by the compare\_interface\_timing Command (Continued)*

| To do this                                                                                                                                                                                      | Use this           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Prevent line-splitting.                                                                                                                                                                         | -nosplit           |
| Specify 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 value is 3. | -significant_digit |

[Example 11-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 11-2](#) shows an example of the report generated by the compare\_interface\_timing command.

#### *Example 11-1*

```
open_mw_cel my_mcmm_block

set_active_scenarios -all
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_digit 3 ${scenario}.cel.rpt
}

create_ilm -scenarios [all_active_scenarios]

remove_scenario -all
close_mw_cel

open_mw_cel my_mcmm_block.ILM
set_active_scenarios -all
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_digit 3 ${scenario}.ilm.rpt;
    compare_interface_timing ${scenario}.cel.rpt ${scenario}.ilm.rpt \
        -significant_digit 3 -absolute_tolerance 0.1 \
        -output ${scenario}.compare_IF_timing.rpt
}

remove_scenario -all
close_mw_cel
```

***Example 11-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   |

**Reporting Information About ILMs**

The commands listed in [Table 11-4](#) provide information about ILMs.

*Table 11-4 Commands That Report Information About Interface Logic Models*

| To report this                                                                                                                                                                                                                                          | Use this                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Information that the design is an ILM. See “ <a href="#">Reporting Design Information</a> ” on page 11-25.                                                                                                                                              | <code>report_design</code>       |
| Location of the pins of an ILM. See “ <a href="#">Reporting Design Information</a> ” on page 11-25.                                                                                                                                                     | <code>get_location</code>        |
| 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. See “ <a href="#">Reporting Area Information</a> ” on page 11-25. | <code>report_area</code>         |
| Information on ILMs present in the design. You can use this command from the top-level design in which the ILMs are instantiated. See “ <a href="#">Reporting ILMs</a> ” on page 11-27.                                                                 | <code>report_ilm</code>          |
| The objects in the current design that are identified as belonging to interface logic.                                                                                                                                                                  | <code>get_ilm_objects</code>     |
| 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.                                                                                              | <code>get_ilms</code>            |
| Statistics for the original design and the ILM.                                                                                                                                                                                                         | <code>create_ilm -verbose</code> |

For the complete syntax of these commands, see the man pages.

Discrepancies between the original design and its interface logic model can arise because of

- Your choice to include all boundary side loads in the interface logic model which affects the total capacitance on a node and the resultant path timing.
- Propagation of the actual cell interface timing arc instead of the worst-case maximum transition, as shown in [Figure 11-9](#).

*Figure 11-9 Comparison of Timing Propagation Between Netlist and Model*



## Reporting Design Information

The `report_design` command reports information that the design is an ILM if you are at the top of the interface logic model.

The `get_location` command returns the coordinates for pins of an ILM instance. For example, to get the coordinates of the IN1 pin on the ILM instance `ILM_inst`, enter

```
icc_shell> get_location [get_pins ILM_inst/IN1]
```

## Reporting Area Information

When you run the `report_area` command on an ILM, it provides 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. Before running the `report_area` command on an ILM, you must use the `open_mw_cel` command to open the ILM view, as shown in the following example:

```
icc_shell> open_mw_cel A.ILM
icc_shell> report_area
```

[Example 11-3](#) shows the area report for the original design for design A. [Example 11-4](#) shows the area report for the ILM for design A.

*Example 11-3 Area Report on Original Block*

```
*****
Report : area
Design : A
Version: C-2009.06
Date   : Wed May 27 06:48:27 2009
*****
```

Library(s) Used:

slow (File: /remote/testcases7/65365/data/LIBS/slow.db)

|                        |               |
|------------------------|---------------|
| Number of ports:       | 274           |
| Number of nets:        | 1111          |
| Number of cells:       | 134           |
| Number of references:  | 17            |
| Combinational area:    | 277140.500000 |
| Noncombinational area: | 152038.531250 |
| Net Interconnect area: | 162.984695    |
| Total cell area:       | 429177.406250 |
| Total area:            | 429340.406250 |
|                        | 1             |

*Example 11-4 Area Report on ILM*

```
*****
Report : area
Design : A
Version: C-2009.06
Date   : Wed May 27 06:52:42 2009
*****
```

Library(s) Used:

slow (File: /remote/testcases7/65365/data/LIBS/slow.db)  
Design is an Interface Logic Model

Design Information:

|                        |               |
|------------------------|---------------|
| Number of ports:       | 274           |
| Number of nets:        | 1111          |
| Number of cells:       | 134           |
| Number of references:  | 17            |
| Combinational area:    | 277108.281250 |
| Noncombinational area: | 152038.531250 |
| Net Interconnect area: | 162.982513    |

|                  |               |
|------------------|---------------|
| Total cell area: | 429146.812500 |
| Total area:      | 429309.781250 |

#### Model Information:

|                        |               |
|------------------------|---------------|
| Number of ports:       | 274           |
| Number of nets:        | 557           |
| Number of cells:       | 97            |
| Number of references:  | 16            |
| Combinational area:    | 37817.261719  |
| Noncombinational area: | 97321.593750  |
| Net Interconnect area: | 45.728115     |
| Total cell area:       | 135140.203125 |
| Total area:            | 135185.937500 |
| 1                      |               |

---

## Reporting ILMs

The `report_ilm` command reports information on ILMs present in the design. You can use this command from the top-level design in which the ILMs are instantiated. By using the `report_ilm` command, you can print the following details for each ILM:

- The date and time at which the ILMs are created.
- The full path of the library from which the ILMs are loaded.
- The `create_ilm` command options that are used to create an ILM. The options include the explicit options set by you and also the implicit options set or adjusted by the tool.
- Leaf cell count and compression statistics of an ILM.
- 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.

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.

---

## Using ILMs in the Top-Level Design

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.

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-27](#).

2. 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.
3. 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.

For information about creating FRAM views for ILMs, see “[Storing Physical Information for ILMs](#)” on page [11-16](#).

4. Use the `read_sdc` command to read the top-level constraints.

For more information about this step, see “[Applying Top-Level Constraints](#)” on page [11-29](#)

5. Verify that there are no conflicts between the top-level constraints and the constraints applied to blocks before ILM creation by using the `check_physical_design` command.

Keep the following points in mind when using ILMs:

- An ILM is a `dont_touch` cell; therefore optimization is not performed on the cells within an ILM.
- Because an ILM is a `dont_touch` cell, 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 spanning abutted ILMs.
- For nets crossing the ILM boundary, such as the n1 and n3 nets in [Figure 11-10](#), the ILM leaf cell pin locations and the ILM pin locations are used to compute the virtual routes in the preroute flow.
- For nets fully within an ILM, such as the n2 net in [Figure 11-10](#), the capacitances are not reestimated.

*Figure 11-10 Interface Logic Model Handling by IC Compiler*



## 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.

Also incorporated into the link process is automatic propagation of ILM data, such as placement, and UPF constraints, to the top-level design.

## Applying Top-Level Constraints

You apply the top-level constraints 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.

**Note:**

If you are using compact ILMs and set timing exceptions or case analysis constraints on the blocks before ILM creation, you must set the same timing exceptions and case analysis constraints from the top level onto the ILM; otherwise, the ILM might not correctly represent the block-level design. For example, if different case analysis

constraints are applied from the top level than those set on the block level prior to ILM creation, the ILM might not have all the minimum rise, minimum fall, maximum rise, and maximum fall timing paths that correspond to the top-level constraints that affect the ILM.

## Using the `propagate_constraints` Command

The timing and other constraints data are stored in the ILM. The acceptable uses of the `propagate_constraints` command are

- Propagating block-level operating conditions to the current design. To do so, use the `propagate_constraints -operating_conditions` command.
- Propagating power supply information to the current design in a UPF flow. To do so, use the `propagate_constraints -power_supply_data` command.

Note:

As the UPF data from the ILM is automatically propagated to the top level, you do not need to propagate it explicitly.

- Propagating case analysis constraints to the current design in a multicorner-multimode flow. To do so, use 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 in these situations.

Due to limitations of the `propagate_constraints` command, you should apply clocks and constraints from the top level instead of propagating them from the subblocks.

One 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.

---

## Handling Rotated and Mirrored ILMs in the Top-Level Design

The orientation of an ILM block is defined in the floorplan. The floorplan can be specified as a DEF file or as attributes in the Milkyway database. When an ILM block is instantiated in the top level, the physical area that it occupies in the core area depends on the orientation of the block. The default orientation is N (north with 0-degree rotation).

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.

The eight allowed orientations are

- North (N)
- Flipped or mirrored north (FN)
- South (S)
- Flipped or mirrored south (FS)
- East (E)
- Flipped or mirrored east (FE)
- West (W)
- Flipped or mirrored west (FW)

These orientations are shown with their respective port locations in [Figure 11-11](#) through [Figure 11-18](#).

*Figure 11-11 North (N) Orientation of an ILM*



*Figure 11-12 Flipped or Mirrored North (FN) Orientation of an ILM*



*Figure 11-13 South (S) Orientation of an ILM**Figure 11-14 Flipped or Mirrored South (FS) Orientation of an ILM**Figure 11-15 East (E) Orientation of an ILM*

*Figure 11-16 Flipped or Mirrored East (FE) Orientation of an ILM*



*Figure 11-17 West (W) Orientation of an ILM*



*Figure 11-18 Flipped or Mirrored West (FW) Orientation of an ILM*



The lower-left corner of the ILM is the actual location of the block. For example, if the location specified for the ILM block is (0,0), then the lower-left corner of the rotated block is (0,0). Notice how the port locations change with the various orientations.

---

## Running the place\_opt Command on the Top-Level Design

You 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 respects ILM objects, such as leaf cell locations, pin locations, and parasitics or delay values, that have been propagated to the top-level design. If you have changed to the FRAM view for the ILMs, the `place_opt` command recognizes any placement resources that you have defined and can use the ILM area for over-the-block placement.

If you do not specify any placement blockages or routing blockages for an ILM or if you have not changed to the FRAM view for the block, IC Compiler automatically derives a default blockage for the entire ILM block.

If you use automatically derived, default blockages, you still need to define x- and y-coordinates for the ILM block in the top-level DEF file because IC Compiler does not do 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.

You cannot view automatically derived ILM placement blockages and routing blockages in the IC Compiler GUI at the ILM level or at the top level where the ILMs are instantiated. Only user-specified placement blockages and routing blockages are visible in the IC Compiler GUI.

You can create keepout margins around ILM instances or an ILM reference by using the `set_keepout_margin` command. For example, to put a 10-unit margin around the ILM instance `u1_ilm`, enter the following command:

```
icc_shell> set_keepout_margin -type hard -outer {10 10 10 10} u1_ilm
```

To create a keepout margin around every instance of an ILM reference, you also need to use the `get_ilms` command. For example, to put a 10-unit margin around every instance of the `ilm_block` reference, enter the following command:

```
icc_shell> set_keepout_margin -type hard -outer {10 10 10 10} \
[get_ilms -reference ilm_block]
```

For more information about placement, see [Chapter 4, “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. You can use interface logic models (ILMs) to increase the capacity and reduce the runtime for 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

When a clock defined at the top level goes through an ILM, IC Compiler inserts guide buffers before the ILM clock input pin and after the ILM clock output pins. The nets between the input guide buffer and output guide buffers are marked as don't buffer nets.

- 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.

When a clock is defined on an ILM input port or in an ILM, IC Compiler inserts guide buffers after the ILM clock output pins. Clock nets within the ILM up to the guide buffers are marked as don't buffer nets.

- Generated clocks are treated like clock ports. Interface registers driven by a generated clock are retained in the model. 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 ILM.

Note:

As a reminder, [Figure 11-19](#) shows the elements contained in an interface logic model, 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 11-19 Interface Logic Model*

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

## **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 you have specified. For information about creating the FRAM view, see [“Storing Physical Information for ILMs” on page 11-16](#).

**Note:**

If you do not create a FRAM view for the block or if you fail to change to the block FRAM view, the blockage information is not available to the top level. In this case, IC Compiler automatically creates an all-metal-layer routing blockage for the entire ILM, so that none of the ILM area is available for over-the-block routing. Likewise, none of the ILM area is available for over-the-block placement.

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.

---

## Performing On-Route Optimization on the Top-Level Design

You can perform late-stage top-level on-route optimization by running the `route_opt` or `psynopt -on_route` command. First, however, you must route the blocks. After routing the blocks, you must create an ILM and a FRAM view for each block, as described in “[Creating ILMs](#)” on page 11-6. You are now ready to perform on-route optimization on the top-level design by running either the `route_opt` or `psynopt -on_route` command.

For example, assuming block1 is already routed, enter

```
icc_shell> open_mw_cel block1
icc_shell> create_macro_fram -library_name design_lib -cell_name block1
icc_shell> extract_rc
icc_shell> create_ilm
icc_shell> close_mw_cel
icc_shell> open_mw_cel top
icc_shell> change_macro_view -reference block1 -view FRAM
icc_shell> read_sdc top.sdc

## Run the route command or the psynopt -on_route command
icc_shell> route_opt
```

---

## Saving the Floorplan for a Design That Contains ILMs

When you use the `write_def` command to save the floorplan for a top-level design that contains ILMs, the `write_def` command writes the location and orientation of an ILM block to the output Design Exchange Format (DEF) file. No leaf cells beneath an ILM block are output to the DEF file because the ILM itself is treated as a leaf-level cell by the `write_def` command. This capability applies to top-level ILMs, buried ILMs (buried in the logic hierarchy but top-level cells in the physical hierarchy), and nested ILMs (ILMs that contain other ILMs).

---

## Viewing ILMs in the IC Compiler GUI

In the IC Compiler GUI, an ILM 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 ILM pins, select the Pin visibility option.
- To expand the ILM to show the leaf cells and macros within the ILM, type or select a positive integer in the “View level” box, and then click the Settings tab and select ILM in the Child View Name list.
- To reset the display to the default (unexpanded) view, type or select 0 in the “View level” box.

By default, when you change options on the View Settings panel, you must click Apply to update the layout view display.

---

## Hierarchical Signal Integrity Flow With ILMs

ILMs can be used in a hierarchical signal integrity flow. In this flow, the ILMs are shielded at the top level to prevent crosstalk between the ILM nets and top-level nets.

You can use the hierarchical signal integrity flow in combination with the multicorner-multimode capability that is described in [“Multicorner-Multimode Scenarios and ILMs” on page 11-39](#).

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. For more information, see [Chapter 10, “Signal Integrity](#)

The following two scripts suggest how to carry out a signal integrity flow using ILMs:

### **Block Level**

```
open_mw_lib <design>
open_mw_cel <block>
place_opt
clock_opt
set_si_options ...
route_opt
save_mw_cel
create_ilm -include_xtalk
create_macro_fram
```

### **Top Level**

```
open_mw_lib <design>
open_mw_cel <top>
place_opt
clock_opt
set_si_options ...
route_opt
save_mw_cel
```

## **Multicorner-Multimode Scenarios and ILMs**

ILMs are compatible with multicorner-multimode scenarios. You can apply multicorner-multimode constraints to an ILM and use that ILM in a top-level design.

The following requirements apply to using ILMs with multicorner-multimode scenarios:

- For each top-level scenario, an identically named scenario must exist in each of the ILM blocks used in the design. An ILM can have additional scenarios that are not used at the top level.
- In a top-level design without multicorner-multimode scenarios, only ILMs without multicorner-multimode scenarios can be used.
- For each TLUPlus file, an ILM stores the extraction data and the specified temperature (operating condition). At the top level, you cannot use additional TLUPlus files or additional temperature corners for the existing TLUPlus files.
- When you run the `create_ilm` command with `-scenarios scenario_list` option, where `scenario_list` is a list of all the scenarios that are required for the top-level flow, you do not have to activate all the scenarios. Instead the `create_ilm` command activates these scenarios one-by-one for the purpose of creating an ILM.

**Note:**

If you do not specify the `-scenarios` option, all scenarios are considered when creating an ILM.

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.

For more information about multicorner-multimode support in IC Compiler, refer to [Chapter 14, “Using Multicorner-Multimode Technology.”](#)

---

## Creating ILMs for Multicorner-Multimode Usage

To create an ILM for a block with multicorner-multimode scenarios,

1. Open the block-level design.
2. Remove all scenarios.

```
remove_scenario -all
```

3. Create scenarios for the block.

```
create_scenario s1
source ${macro}_s1.tcl
create_scenario s2
source ${macro}_s2.tcl
create_scenario CTS_only
source ${macro}_cts.sdc
set_cts_scenario CTS_only
set_active_scenarios {s1 s2...}
```

4. Perform placement and optimization.

```
place_opt
clock_opt
route_opt
```

5. (Optional) Extract the parasitic data.

```
extract_rc
```

If the design is routed or you use the `-keep_parasitics` option when you run the `create_ilm` command, the `create_ilm` command extracts the parasitic data, so it is not necessary to do this separately.

6. Create an ILM and save it in the ILM view of the Milkyway database.

```
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.

## Using ILMs in Multicorner-Multimode Scenarios

To use an ILM with multicorner-multimode scenarios at the top level,

1. Open the top-level design.
2. Remove all scenarios.

```
remove_scenario -all
```

3. Create scenarios for the top level.

```
create_scenario s1
source ${top}_s1.tcl
create_scenario s2
source ${top}_s2.tcl
create_scenario CTS_only
source ${top}_cts.sdc
set_cts_scenario CTS_only
set_active_scenarios {s1, s2...}
```

The top-level scenarios must match the existing scenarios in the ILM blocks used in the design. All scenarios of the top level must be defined before the next step.

4. Perform optimization.

```
place_opt
clock_opt
route_opt
```

5. Save the top-level design into the Milkyway database.

```
save_mw_cel -as ${top}_routed
```



# 12

## 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 only in the IC Compiler and IC Compiler-PC packages; it is not available in the IC Compiler-XP package. Moreover, Design Compiler Topographical (DC-T) also supports relative placement. For information about using Design Compiler to perform relative placement, see the *Design Compiler User Guide*.

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
- 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 do relative placement by using a set of dedicated commands to specify the relative placement constraints and apply them to a gate-level netlist, check the constraints, remove the constraints, or 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 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 12-1](#).

*Figure 12-1 Relative Placement in a Floorplan*



---

## Benefits of Relative Placement

Along with being technology-independent and having the ability to improve routability, relative placement provides the following benefits:

- Provides a method for maintaining structured placement for legacy or intellectual property (IP) designs
- 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.

- Reduces the placement search space in critical areas of the design, meaning greater predictability of QoR (wire length, timing, power) and congestion
- Allows sizing of relative placement cells while maintaining relative placement.

## Flow for Relative Placement

The relative placement flow is shown in [Figure 12-2](#).

*Figure 12-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 *Chapter 10, “Using Design Compiler Topographical Technology,”* 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 12-9.
  - Add relative placement objects to the groups by using the `add_to_rp_group` command.  
See “[Adding Objects to a Group](#)” on page 12-14.

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 Cells During Optimization](#)” on page 12-36.

4. Read 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 12-42.

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 12-41

## 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 12-41.

---

## Sample Script for a Relative Placement Flow

[Example 12-1](#) is a sample script for running a relative placement flow.

### *Example 12-1 Sample 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
# Apply set_size_only on relative placement cells
set_size_only [rp_group_references -leaf]

# Read floorplan information
read_def top.def

# Perform coarse placement 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 on the design
clock_opt

# Preserve relative placement during routing
set_rp_group_options -route_opt_option fixed_placement \
    [get_rp_groups *]

# Perform routing
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.

---

## 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 need to determine which portions of the design need to be structured because providing relative placement information for cells that would have been placed better by allowing IC Compiler to place the cells 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 13, “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 12-14.

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 12-3](#) shows the positions of columns and rows in a relative placement group.

*Figure 12-3 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.
- It is not necessary to use all positions in the structure. For example, in this figure, 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 12-1](#) describes the attributes that you can set on a relative placement group.

*Table 12-1 Relative Placement Group Attributes*

| To do this                                                                                                                                                                                                                              | Use this option        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| Specify the anchor location.<br>See “ <a href="#">Anchoring Relative Placement Groups</a> ” on page 12-11.                                                                                                                              | -x_offset<br>-y_offset |
| Specify the type of alignment used by the group.<br>You can specify either bottom-left (the default), bottom-right, or bottom-pin. See “ <a href="#">Aligning Leaf Cells Within a Column</a> ” on page 12-16.                           | -alignment             |
| Specify the group alignment pin.<br>See “ <a href="#">Aligning Leaf Cells Within a Column</a> ” on page 12-16.                                                                                                                          | -pin_align_name        |
| Specify the utilization percentage (default is 100 percent).                                                                                                                                                                            | -utilization           |
| 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 12-41.  | -cts_option            |
| Specify the physical optimization 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 12-41. | -psynopt_option        |
| Specify the routing preservation attribute.<br>You can specify <code>fixed_placement</code> or <code>in_place_size_only</code> .<br>See “ <a href="#">Postplacement Optimization of Relative Placement Groups</a> ” on page 12-41.      | -route_opt_option      |
| Ignore this relative placement group.<br>See “ <a href="#">Ignoring Relative Placement Constraints</a> ” on page 12-54.                                                                                                                 | -ignore                |

*Table 12-1 Relative Placement Group Attributes (Continued)*

| To do this                                                                                                                                                                        | Use this option             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| Allow keepouts over tap cells.<br>See “ <a href="#">Adding Keepouts</a> ” on page 12-33.                                                                                          | -allow_keepout_over_tapcell |
| Legalize relative placement groups.<br>You can specify low, medium, or high.<br>See “ <a href="#">Movement Control When Legalizing Relative Placement Groups</a> ” on page 12-35. | -move_effort                |
| Apply compression in the horizontal direction.<br>See “ <a href="#">Applying Compression to Relative Placement Groups</a> ” on page 12-13.                                        | -compress                   |

## 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 12-4](#), enter the following command:

```
icc_shell> create_rp_group misc1 -design block1 \
           -columns 3 -rows 10 -x_offset 100 -y_offset 100
```

*Figure 12-4 Anchored Relative Placement Group*



The script in [Example 12-2](#) defines the locations of 12 relative placement groups that are aligned and anchored vertically at four coordinates, as shown in [Figure 12-5](#). For brevity, not every group is listed in the example.

#### *Example 12-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 12-5 Relative Placement Groups Aligned and Anchored Vertically*



## Applying Compression to Relative Placement Groups

You can apply compression in the horizontal direction to a relative placement group during placement by using the `-compress` option of the `create_rp_group` or the `set_rp_group_options` command. Setting this option enables bit-stack placement that places each row of a relative placement group without any gaps between leaf cells, lower-level hierarchical relative placement groups, or keepouts, as shown in [Figure 12-17 on page 12-29](#). Note that column alignment is not maintained when you use compression.

If you specify both `-utilization` and `-compress` options, the utilization constraints are observed with gaps between leaf elements in a relative placement row. The `-compress` option does not propagate from a parent group to child groups. To disable relative placement with compression, use the `remove_rp_group_options -compress` command.

## Supporting Compression with Mixed Alignment

Relative placement groups with alignment, such as bottom left, bottom right, or pin alignment, and the relative placement group that is created by using `-compress` can be placed on the same top-level groups as shown in [Figure 12-6](#). The individual groups of the top level are aligned with compression only if you specify the `-compress` option. Note that the compression specified at the top level does not propagate to the child groups. The default alignment of the top-level groups is bottom left and the `-compress` option is disabled by default.

*Figure 12-6 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 (created with the `create_rp_group` command). You can add objects either in the relative placement hierarchy browser (for information about the relative placement hierarchy browser, see [“Using the Relative Placement Hierarchy Browser” on page 12-45](#)) or from the command line (using the `add_to_rp_group` command).

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 and row position within the relative placement group. You can also specify how to orient the 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 12-49](#).

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. If you do not specify these options, the default is 1. 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, but you cannot specify an orientation for a relative placement group. If you do not specify a leaf cell orientation, IC Compiler assigns a default orientation, and then, by default, optimizes that orientation for wire length.

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.

The tool chooses the first legal orientation from the list of orientations you provide.

To prevent IC Compiler from automatically optimizing the orientation of cells without user-specified orientation specifications,

- Set the `physopt_rp_enable_orient_opt` variable to false.

By default, this variable is set to true, and IC Compiler optimizes the orientation of cells without user-specified orientations.

## 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

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-right [get_rp_groups *]
```

The script in [Example 12-3](#) defines a relative placement group that is bottom-left aligned. The resulting structure is shown in [Figure 12-7](#).

**Example 12-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 12-7 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 12-4](#) defines a relative placement group that is bottom-right aligned. The resulting structure is shown in [Figure 12-8](#).

**Example 12-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 12-8 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 done by IC Compiler.
- Pin alignment done by IC Compiler takes precedence over the cell orientation optimization done by IC Compiler.

The script in [Example 12-5](#) defines a relative placement group that is aligned by pin A. The resulting structure is shown in [Figure 12-9](#).

### Example 12-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 12-9 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 12-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 12-10](#).

*Example 12-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 12-10 Relative Placement Group Aligned by Pins*




---

## Automatic Orientation of Relative Placement Groups Based on Data Flow

The orientation of relative placement groups is set automatically by the tool according to the data flow to minimize wire length. If the data flow of the relative placement group is from left to right, the first column is placed on the left side and subsequent columns are placed towards the right. This orientation is considered as north (N). If the data flow of the relative placement groups is from right to left, the first column is automatically placed at the right side and subsequent columns are placed towards left: that is, the orientation of the block is flipped. This orientation is considered as flip-north (FN).

In [Figure 12-11](#), U21 and U22, U23, and U24 are four cells in a relative placement group. In case of flip-north orientation, the relative placement group is automatically flipped.

*Figure 12-11 Auto-Orientation of Relative Placement Blocks*

The automatic orientation of relative placement groups is supported for designs with hierarchical relative placement groups. The change in orientation is propagated down to the lowest level in hierarchy.

In case of flip-north orientation, the relative placement constraints, such as alignment, utilization, and so on are preserved according to the specifications that you provide.

[Figure 12-12](#) shows an example in which the utilization constraints and the alignment constraints (align to the right or left edge) are preserved with flip-north orientation.

*Figure 12-12 Preservation of Constraints*

---

## 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 12-23.

- 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 12-25.

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 12-49.

The script in [Example 12-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 12-13.

### *Example 12-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 12-13 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
    [-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 12-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 12-14](#).

### Example 12-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 12-14 Instantiating Groups in a Hierarchical Group*



## 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 12-23. For more information about leaf cell straddling, see also “[Adding Leaf Cells](#)” on page 12-14

[Figure 12-15](#) shows a relative placement group in which cells straddle columns (instance U2) and rows (instance U7).

*Figure 12-15 Hierarchical Relative Placement Group With Straddling*



**Figure 12-16** 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 12-9** shows the commands used in this process.

*Figure 12-16 Straddling With Hierarchical Relative Placement*



***Example 12-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 12-23).

[Figure 12-17](#) 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 12-10](#) shows the commands used to build the compressed structure.

**Figure 12-17 Bottom-Left Alignment Construction and Compression****Example 12-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 accomplish compression in the horizontal direction by using the **-compress** option of the **create\_rp\_group** or **set\_rp\_group\_options** command. See “[Applying Compression to Relative Placement Groups](#)” on page 12-13.

## 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 12-18](#) 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 12-11](#). After ungrouping, the relative placement definition is as shown in [Example 12-12](#).

*Figure 12-18 Instantiating Groups in a Hierarchical Group**Example 12-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 12-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
```

## **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 non-relative-placement cells are handled during legalization  
Non-relative-placement cells can be placed in soft keepouts, but not in space and hard keepouts.
- How the non-relative-placement cells are handled during placement  
Non-relative-placement cells can be placed in space keepouts, but not in hard or soft keepouts. To preserve space for non-relative-placement cells, such as buffers and control flip-flops, inside a relative placement group, choose the space keepout type.  
To fill empty space in rectilinear relative placement groups with non-relative-placement cells, you can create space keepouts to place the non-relative-placement cells in the rectilinear region as shown in [Figure 12-19](#).

*Figure 12-19 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 12-49.

---

## Movement Control When Legalizing Relative Placement Groups

You can control the movement of the relative placement group during legalization by using the `-move_effort` option. 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. The size of the region searched for placement of a relative placement group is progressively reduced as you reduce the effort from high to medium to low.

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_groups_options` command also supports the `-move_effort` option.

For more information about the `-move_effort` option, see the man page.

---

## 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:

- [Preserving Relative Placement Cells During Optimization](#)
- [Performing Relative Placement in a Design Containing Obstructions](#)
- [Performing Relative Placement in a Design Containing Tap Cells](#)
- [Using Move Bounds to Constrain Relative Placement](#)
- [Adding Incremental Relative Placement Groups](#)

---

## Preserving Relative Placement Cells During Optimization

During optimization, relative placement cells might be optimized away, thereby disturbing the relative placement groups. To preserve the attributes, you can specify `fixed_placement` or `size_only`. The `fixed_placement` attribute keeps the relative placement structures fixed. In comparison, the `size_only` attribute prevents relative placement cells from being removed, but it allows sizing during optimization.

For example, to set the `size_only` attribute on all relative placement cells during optimization, enter

```
icc_shell> set_rp_group_options -psynopt_option size_only \
[get_rp_groups *]
```

If relative placement cells are upsized or downsized, the relative placement cell alignment is maintained for placement.

---

## 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 12-20](#) 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 12-20 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 12-21](#) 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 12-21 Shifting Columns to Avoid Tap Cell Array*

If your design contains a single tap cell in a column, rather than a tap cell array, the default placement behavior is to shift individual cells of the relative placement group to avoid the tap cells, as shown in the design on the left in [Figure 12-22](#). To shift the entire column instead of a single cell, set the `rp_shift_column_for_fixed_cells` variable to true. This results in the placement shown in the design on the right in [Figure 12-22](#).

*Figure 12-22 Avoiding Single Tap 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.

---

## 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 4-42.

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 will place and legalize the newly created group anchored by the specified x- and y-coordinates.

---

## 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 two types of relative placement groups, including the macro-only and standard-cell-only relative placement groups. The virtual flat placement stage allows the following relative placement objects: leaf cells, keepouts (hard, soft, and space), hierarchical groups, and relative placement cells occupying multiple column and row positions.

During the design planning flow, you can perform the following relative placement functions:

- Apply compression by using the `-compress` option.
- 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.
- Legalize individual objects in a relative placement group.

For designs contains either macro-only or standard-cell-only relative placement groups, 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` variable.
4. Legalize your design by using the `legalize_placement` command.

5. Mark all relative placement cells with the `is_fixed` variable.
6. Perform physical placement by using the `place_opt` command.

You can skip Steps 4 and 5, depending on your design requirements.

For more information about performing relative placement in the design planning flow, see *Chapter 5, “Performing an Initial Virtual Flat Placement,”* in the *IC Compiler Design Planning User Guide*.

## Postplacement Optimization of Relative Placement Groups

During postplacement optimization, relative placement cells can be modified, moved, or removed, and buffering can occur. 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.

### Preserving Relative Placement Structures

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` keyword with the appropriate option as shown in [Table 12-2](#). To prevent relative placement cells from being removed but to allow sizing during optimization, set the `size_only` keyword with the appropriate option.

These options mark the relative placement cells as `fixed_placement`, `size_only`, or `in_place_size_only` during the affected commands.

*Table 12-2 Options to Preserve Relative Placement Structures*

| Process               | Option                         | Affected commands                                                                             |
|-----------------------|--------------------------------|-----------------------------------------------------------------------------------------------|
| Clock tree synthesis  | <code>-cts_option</code>       | <code>clock_opt</code><br><code>compile_clock_tree</code><br><code>optimize_clock_tree</code> |
| Physical optimization | <code>-psynopt_option</code>   | <code>psynopt</code>                                                                          |
| Routing               | <code>-route_opt_option</code> | <code>route_opt</code><br><code>psynopt -on_route</code>                                      |

For clock tree synthesis and physical optimization, you specify the preservation attribute by using `fixed_placement` or `size_only`. For routing, you specify the preservation attribute by using `fixed_placement` or `in_place_size_only`.

---

## Buffering and Sizing Strategy for Relative Placement Groups

During optimization, buffering that occurs in relative placement groups can increase congestion and degrade QoR. To avoid the situation, IC Compiler provides strategy control of buffering and sizing for relative placement groups.

For designs that contain integrated clock-gating cells and buffers that are relative placement cells, setting the `-cts_option size_only` option restricts the upsizing of the cells before running the clock tree synthesis and optimization or the `clock_opt` step. During the clock tree synthesis and optimization or the `clock_opt` step, to reduce waste space in relative placement groups, you should use the `-cts_option size_only` option to allow sizing only when there is enough space.

During the `psynopt` and `place_opt` steps, cell sizing is allowed for relative placement nets. 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. During the embedded `psynopt` step of the `clock_opt` command, relative placement cells can be sized and moved.

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 *]
```

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 *]
```

---

## 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](#)

---

## 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.

If a failure prevents the group from being placed as a single entity (as defined by the relative placement constraints), the failure is considered a critical failure. If the failure does not prevent placement but causes the relative placement constraints to be violated, the failure is considered noncritical. The generated report contains separate sections for critical and noncritical failures.

Note that the `check_rp_groups` command does not check for the failure: The keepouts are not created correctly in the relative placement group.

You can check all relative placement groups (by specifying the `-all` option) or you can specify which relative placement groups to check. By default, the report is output to the screen. To save the generated report to a file, specify the file name by using the `-output` option.

For example, to check the relative placement constraints for groups `compare17::seg7` and `compare17::rp_group3` and save the output in a file called `rp_failures.log`, run the following command:

```
icc_shell> check_rp_groups "compare17::seg7 compare17::rp_group3" \
-output rp_failures.log
```

The generated report is similar to this:

```
*****
Report : The RP groups, which could not be placed.
Version: 2005.12
Date   : Tue Dec 27 16:32:02 2005
No. of RP groups:1
*****
RP GROUP: compare17::seg7
-----
ERROR: Could not get clean area for placing RP group compare17::seg7.

*****
Report : The RP groups, not meeting all constraints but placed.
Version: 2005.12
Date   : Tue Dec 27 16:32:02 2005
No. of RP groups:1
*****
RP GROUP: compare17::rp_group_3
-----
WARNING: Could not set user specified orientation for cell u[8].
```

You can also check the relative placement constraints in the GUI. To do so, choose 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.

## 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
```

These commands return a list of the x- and y-values of each object specified within the containing relative placement group 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]
```

---

## 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](#)
  - [Moving Relative Placement Groups](#)
  - [Editing and Creating 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 12-23](#), 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 12-23 Relative Placement Hierarchy Browser

The screenshot shows a software interface for managing relative placement groups. On the left, a 'Grid' pane displays a table of components with columns: name, design, rows, and columns. The 'name' column contains items like 'ORCA::Crnt\_Instrn\_reg', 'ORCA::Current\_State\_reg', 'ORCA::Lachd\_Result\_reg', and 'ORCA::Oprnd\_reg'. The 'design' column shows 'ORCA' for all. The 'rows' and 'columns' columns show various values such as 1, 2, 3, 16, etc. A mouse cursor is hovering over the row for 'ORCA::Oprnd\_reg'. On the right, a 'List' pane shows a table with a single column 'full\_name' containing 'ORCA::Oprnd\_A\_reg' and 'ORCA::Oprnd\_B\_reg', both with a value of 0.

| name                    | design      | rows     | columns  |
|-------------------------|-------------|----------|----------|
| ORCA::Crnt_Instrn_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        |

  

| full_name         |
|-------------------|
| ORCA::Oprnd_A_reg |
| ORCA::Oprnd_B_reg |

## 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 will not see the relative placement groups in the layout view but the information in the visual mode panel will be 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. 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 12-24](#). A histogram-like bar graph shows the number of connections for each type.

*Figure 12-24 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

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 12-25](#).

*Figure 12-25 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. Choose Placement > Edit RP Group in the GUI.  
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 radio button to edit an existing relative placement group.  
If you want to create a new relative placement group, click the Create radio button.
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 radio button.  
If you click the Cell radio button, 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 radio button. 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 12-26](#) 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 12-26 Relative Placement Editing Dialog Box**

For more information about using the relative placement editing dialog box, see the IC Compiler online Help.

## Querying Relative Placement Groups

[Table 12-3](#) 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 12-3 Commands for Querying Relative Placement Groups**

| To return collection handles for this                                                                                 | Use this                          |
|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Relative placement groups that match certain criteria                                                                 | <code>get_rp_groups</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> |

*Table 12-3 Commands for Querying Relative Placement Groups (Continued)*

| To return collection handles for this                                                                                                                                                                                                                                                                                   | Use this                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| All or specified relative placement groups that contain included groups                                                                                                                                                                                                                                                 | all_rp_inclusions       |
| All or specified relative placement groups that contain instantiated groups                                                                                                                                                                                                                                             | all_rp_instantiations   |
| All or specified relative placement groups that directly embed leaf cells (added to a group by <code>add_rp_group -leaf</code> ) or instantiated groups (added to a group by <code>add_rp_group -hierarchy -instance</code> ) in all or specified relative placement groups in a specified design or the current design | all_rp_references       |
| Directly embedded included groups (added to a group by <code>add_rp_group -hierarchy</code> ) in all or specified groups                                                                                                                                                                                                | rp_group_inclusions     |
| Directly embedded instantiated groups (added to a group by <code>add_rp_group -hierarchy -instance</code> ) in all or specified groups                                                                                                                                                                                  | rp_group_instantiations |
| Directly embedded leaf cells (added to a group by <code>add_rp_group -leaf</code> ), directly embedded included cells that contain hierarchically instantiated cells (added to the included group by <code>add_rp_group -hierarchy -instance</code> ), or both in all or specified relative placement groups            | rp_group_references     |
| Create a collection of the specified relative placement group keepouts                                                                                                                                                                                                                                                  | get_rp_group_keepouts   |

By default, a maximum of 100 objects is displayed when you use one of these commands at the command prompt. To change this maximum, set the `collection_result_display_limit` variable.

For example, to create a collection of relative placement groups that start with the letter *g* in a design that starts with the letter *r*, enter

```
icc_shell> get_rp_groups r*::g*
{ripple::grp_ripple}
```

To set the utilization to 95 percent for all relative placement groups, enter

```
icc_shell> set_rp_group_options [all_rp_groups] -utilization 0.95
```

---

## Saving Relative Placement Information

The relative placement information is automatically saved in the Milkyway design database when you save the design in Milkyway format (`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

```
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}
```

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 12-4](#).

*Table 12-4 write\_rp\_groups Options*

| To do this                                                                                                                                         | Use this                |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| Write all the relative placement groups within the hierarchy of the relative placement groups. If you omit this option, subgroups are not written. | <code>-hierarchy</code> |
| Write only <code>create_rp_group</code> commands to the script.                                                                                    | <code>-create</code>    |
| Write only <code>add_to_rp_group -leaf</code> commands to the script.                                                                              | <code>-leaf</code>      |
| Write only <code>create_rp_group -keepout</code> commands to the script.                                                                           | <code>-keepout</code>   |

*Table 12-4 write\_rp\_groups Options (Continued)*

| To do this                                                                           | Use this               |
|--------------------------------------------------------------------------------------|------------------------|
| Write only <code>create_rp_group -hierarchy -instance</code> commands to the script. | <code>-instance</code> |
| Write only <code>create_rp_group -hierarchy</code> commands to the script.           | <code>-include</code>  |

## 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. In order 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, either in the relative placement hierarchy browser, in the relative placement editing dialog box, 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 12-45.

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 12-49.

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'
1
```

---

## 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

---

## 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 Attributes of a Relative Placement Group

You can change the attributes of an existing group in either of the following ways:

- Set the attribute values.
- Reset the attributes to their default values (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 12-5](#).

For more information about the relative placement hierarchy browser, see [“Using the Relative Placement Hierarchy Browser” on page 12-45](#).

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 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 12-5](#) describes the relative placement group attributes and the Set RP Options dialog box fields or command options used to change them.

*Table 12-5 Relative Placement Group Attributes*

| Attribute                                                                                                                                                                                                       | Dialog box fields    | Command line options   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------|
| Alignment method<br>See “ <a href="#">Aligning Leaf Cells Within a Column</a> ” on page 12-16.                                                                                                                  | Alignment            | -alignment             |
| Group alignment pin<br>See “ <a href="#">Aligning Leaf Cells Within a Column</a> ” on page 12-16.                                                                                                               | Pin alignment        | -pin_align_name        |
| Anchor location<br>See “ <a href="#">Anchoring Relative Placement Groups</a> ” on page 12-11.                                                                                                                   | X offset<br>Y offset | -x_offset<br>-y_offset |
| Utilization percentage                                                                                                                                                                                          | Utilization          | -utilization           |
| Routing preservation<br>You can specify <code>fixed_placement</code> or <code>in_place_size_only</code> .<br>See “ <a href="#">Postplacement Optimization of Relative Placement Groups</a> ” on page 12-41.     | route_opt<br>Option  | -route_opt_option      |
| 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 12-41. | CTS option           | -cts_option            |

*Table 12-5 Relative Placement Group Attributes (Continued)*

| <b>Attribute</b>                                                                                                                                                                               | <b>Dialog box fields</b>                | <b>Command line options</b>                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------|
| Physical optimization preservation<br>You can specify <code>fixed_placement</code> or <code>size_only</code> .<br>See “Postplacement Optimization of Relative Placement Groups” on page 12-41. | Psynopt option                          | <code>-psynopt_option</code>                |
| Legalizing relative placement groups.<br>You can specify low, medium, or high.<br>See “Movement Control When Legalizing Relative Placement Groups” on page 12-35.                              | <code>move_effort</code>                | <code>-move_effort</code>                   |
| Ignore relative placement constraints<br>See “Ignoring Relative Placement Constraints” on page 12-54.                                                                                          | <code>Ignore placement</code>           | <code>-ignore</code>                        |
| Allow keepouts over tap cells<br>See “Adding Keepouts” on page 12-33.                                                                                                                          | <code>Allow keepout over tapcell</code> | <code>-rp_allow_keepout_over_tapcell</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` 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.

[Table 12-6](#) describes changes you can make with the `remove_rp_group_options` command.

*Table 12-6 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>See “ <a href="#">Anchoring Relative Placement Groups</a> ” on page 12-11. | -x_offset<br>-y_offset |
| Remove the Ignore setting for this relative placement group.<br>See “ <a href="#">Ignoring Relative Placement Constraints</a> ” on page 12-54.                     | -ignore                |

## 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, either in the relative placement hierarchy browser 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 12-45.

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
```

---

## 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 Cells Within a Group

You can change the attributes of relative placement cells within a group, including the alignment, group alignment pin, and orientation.

To set or remove the attributes of one or more relative placement cells,

- Set the values of cell attributes by using the `set_attribute` command.  
You can edit the `rp_alignment`, `rp_pin_align_name`, and `rp_orientation` attributes of relative placement cells.
- Remove cell attributes by using the `remove_attribute` command.  
You can remove the `rp_alignment`, `rp_pin_align_name`, and `rp_orientation` attributes from relative placement cells.

Use the `get_attribute` command to get the `rp_group_name`, `rp_row`, `rp_column`, `rp_num_rows`, `rp_pin_align_name`, and `rp_orientation` attributes.

To display the attributes of relative placement cells,

- Report one or more cell attributes by using the `report_attribute` command.
- List the attributes of all relative placement cells in alphabetical order by using the `list_attributes` command.

The following attributes are listed: `rp_group_name`, `rp_row`, `rp_column`, `rp_num_rows`, `rp_num_columns`, `rp_alignment`, `rp_pin_align_name`, and `rp_orientation`.

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

---

## 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 12-49.

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 will be 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 {0 0 100 100} and annotate the group to the design, enter

```
icc_shell> extract_rp_group -group_name phi1 \
    -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_group` command generates the `create_rp_group` and `add_to_rp_group` commands to define the hierarchical relative placement group. The generated relative placement group will have 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 12-7](#) shows some of the key commands used to perform relative placement.

*Table 12-7 Relative Placement Commands*

| Command                 | Described in section                                                                        |
|-------------------------|---------------------------------------------------------------------------------------------|
| create_rp_group         | <a href="#">See “Creating Relative Placement Groups” on page 12-9.</a>                      |
| add_to_rp_group         | <a href="#">See “Adding Objects to a Group” on page 12-14.</a>                              |
| check_rp_groups         | <a href="#">See “Checking Relative Placement Constraints” on page 12-43.</a>                |
| write_rp_groups         | <a href="#">See “Saving Relative Placement Information” on page 12-53.</a>                  |
| remove_rp_groups        | <a href="#">See “Removing Relative Placement Groups” on page 12-54.</a>                     |
| report_rp_group_options | <a href="#">See “Reporting the Attributes of a Relative Placement Group” on page 12-56.</a> |
| set_rp_group_options    | <a href="#">See “Changing the Attributes of a Relative Placement Group” on page 12-56.</a>  |
| remove_rp_group_options | <a href="#">See “Removing Relative Placement Group Attributes” on page 12-58.</a>           |
| remove_from_rp_group    | <a href="#">See “Removing Objects From a Group” on page 12-59.</a>                          |

*Table 12-7 Relative Placement Commands (Continued)*

| <b>Command</b>   | <b>Described in section</b>                                       |
|------------------|-------------------------------------------------------------------|
| extract_rp_group | See “Extracting a Relative Placement Group” on page 12-61.        |
| order_rp_groups  | See “Ordering Extracted Relative Placement Groups” on page 12-62. |

## 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.

# 13

## 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](#)
- [Handling Level Shifters and Isolation Cells](#)
- [Handling Always-On Logic](#)
- [Sample IC Compiler Script for UPF Flow](#)
- [Voltage-Area-Aware Capabilities](#)
- [Placing and Optimizing the Design](#)
- [Checks and Reporting Commands for Multivoltage Designs](#)
- [Hierarchical UPF Flow](#)
- [Non-UPF Flow For Multivoltage Designs](#)

---

## 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 on 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 details about specifying power intent in the RTL file, see “[Non-UPF Flow For Multivoltage Designs](#)” on [page 13-57](#).

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
- Using a .ddc file
- Writing directly into the Milkyway database
- Writing a Verilog output file and a constraints script file.

Note:

The Verilog file format does not save the power domain information.

## 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 13-8](#).

- 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 [“Non-UPF Flow For Multivoltage Designs” on page 13-57](#)

To save your synthesized design and the power constraints in a file for use in the IC Compiler flow, follow one of the methods mentioned below:

- 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. (See the multivoltage chapter in the *Power Compiler User Guide* for details.) Power domains created in IC Compiler are stored in the Milkyway database.

For further information, see [“Non-UPF Flow For Multivoltage Designs” on page 13-57](#).

---

## 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 directly create the voltage areas 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 further information, see “[Defining and Using Voltage Areas](#)” on page 13-20 and “[Handling Nested Voltage Areas](#)” on page 13-27.

---

## Associating Power Domains and Voltage Areas

There must be an exact one-to-one relationship between logic 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_level_shifters` 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, it is strongly recommended that you run the command as early in the flow as possible.

No command is available that lets you directly insert enable-type level shifters. 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_isolation_cell` 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 further information, see “[Handling Level Shifters and Isolation Cells](#)” on page 13-29.

---

## Basic Library Requirements for Multivoltage Designs

The libraries must conform to the Liberty open library rules. Design Compiler, Automated Chip Synthesis, and IC Compiler support 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. (For further information about target library subsets, see “[Target Library Subsetting](#)” on page 13-7.)

Note that k-factors are not supported for multivoltage designs and are ignored if present in the libraries.

---

## 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.

The Galaxy Design platform tools recognize a design as a multivoltage design and utilize 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 subsetting 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.

[Figure 13-1](#) shows the Galaxy Design platform high-level flow for multivoltage designs. This is a complete RTL-to-sign-off design flow. To understand how to use the individual tools of the design flow, consult the appropriate user guides.

*Figure 13-1 Galaxy Design Platform High-Level Multivoltage Design Flow*



## Target Library Subsetting

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_level_shifters` command as part of the logic synthesis flow in Design Compiler, you do need to run `uniquify` 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 target library subsetting by using either the `check_mv_design -target_library_subset` command or the `check_target_library_subset` command. The command checks for 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.

---

## UPF Flow for Multivoltage Designs

[Figure 13-2](#) shows an overview of the UPF flow for multivoltage designs.

*Figure 13-2 IC Compiler Multivoltage UPF Flow*



The steps involved in the UPF flow are described below:

1. Invoke IC Compiler
2. Use the appropriate target libraries that 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” chapter in the *Library Compiler Modeling Timing, Signal Integrity, and Power in Technology Libraries User Guide*.
3. Read the multivoltage design.
4. 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.

5. Use the `set_operating_condition` command to set the operating condition on the top level of the design hierarchy and to derive the process and temperature conditions for the design. Use the `set_voltage` command to set the voltage values for the power or ground supply nets. If your setup has both `set_operating_condition` and `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, you will encounter a MV-028 error message.

6. Before optimizing your design, use the `derive_pg_connection` command to connect all unconnected power, ground, and tie-off pins to the power and ground supply nets. Use the `-create_net` option to create the missing power nets. To override the existing power connection and use the power intent defined in the UPF file, use the `-reconnect` option.

This 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 about the `derive_pg_connection` command, see the “Power Planning” chapter in the *IC Compiler Design Planning User Guide*.

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.

After completing the implementation and before writing the power and ground netlist to a file, use the `derive_pg_connection` command.

You can use the `check_mv_design -power_nets` command to check for mismatches in the power and ground pin connections.

7. Use the `map_power_switch` command to map the power switch to the technology library cell. Instantiate the power switch cell in the floorplan using the `create_power_switch_array` or `create_power_switch` command to create a power switch.
8. It is recommended that the design being read into IC Compiler already contain special cells such as the retention registers, isolation cells, and level-shifter cells.

Before you run the `place_opt` command, you should run the `check_mv_design -verbose` command to check for any violations in the multivoltage designs. The `-verbose` option gives a detailed report of the violations.

9. After the optimization steps, use the `save_upf` command to write the UPF file updated by IC Compiler.

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 and supply networks using the UPF commands. This section contains the following subsections:

- [Power Domains](#)
- [Hierarchy and Scope](#)
- [Creating Power Domains](#)
- [Power and Ground Supply Network](#)
- [Creating a Power Switch](#)
- [Adding Port State Information to 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 on the concept of power domain see the “Power Intent Specification” chapter in 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 “Power Intent Specification” chapter in 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. Alternately, 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 on scope, see the “Power Intent Specification” chapter in the *Synopsys Low-Power Flow User Guide*.

## 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]
[-scope instance_name] domain_name
```

Use the `-element` 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 `-scope` option to specify the logical hierarchy or the scope at which the power domain is to be defined. `domain_name` is the name of the power domain to be created.

*Figure 13-3 Defining a Power Domain and Scope*



The following example creates the PD1 and PD2 power domains shown in [Figure 13-3](#).

```
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.

## Power and Ground 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 supply_port_name [-domain power_domain_name ]
[-direction in | out]
```

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.

*Figure 13-4 Power Intent Specification Example*



The following example shows creation of the ports shown in [Figure 13-4](#):

To create the supply ports VDD1, VDD2 and VDD3 and GND at the top level of the design hierarchy or power domain PD\_TOP, use the command as follows:

```
create_supply_port VDD1
create_supply_port VDD2
create_supply_port VDD3
create_supply_port GND
```

To create the supply ports VDD1, VDD1g and GND in the power domain PD1, use the `create_supply_port` command as follows:

```
create_supply_port VDD1 -domain PD1
create_supply_port VDD1g -domain PD1
create_supply_port GND -domain PD1
```

To create the supply ports VDD2, GND in the power domain PD2, and VDD3, GND in power domain PD3 respectively, use the `create_supply_port` command as follows:

```
create_supply_port VDD2 -domain PD2
create_supply_port GND -domain PD2
create_supply_port VDD3 -domain PD3
create_supply_port GND -domain PD3
```

Note:

Connectivity is not defined when the supply port is created. To define 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 domain_name [-reuse] supply_net_name
```

The supply net is created in the same scope or logical hierarchy as the specified power domain. 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 command `set_domain_supply_net`.

## Connecting Supply Nets

This 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. The syntax of the `connect_supply_net` command is as follows:

```
connect_supply_net supply_net_name -ports list
```

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 Net 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_name
                     -primary_ground_net supply_net_name 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:

```
set_domain_supply_net -primary_power_net VDD -primary_ground_net GND
```

## Creating a Power Switch

The `create_power_switch` command creates an instance of 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.

For more details regarding various options, see the command man page.

The following simple power switch definition can be used to create the power switch shown in [Figure 13-4](#):

```
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}}
```

---

## Adding Port State Information to 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 _supply_port_name -state {name nom| min nom max | off}
```

A power switch supply port 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.

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 syntax of the `create_pst` command is as follows:

```
create_pst pst_name -supplies list
```

---

## 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 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 an 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, multi-rail 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_net` command.

For more information, see the man pages.

---

## 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*.

You can define voltage areas at any level of a logic hierarchy. Both rectangular and rectilinear voltage areas are allowed. Voltage areas cannot consist of 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 13-27.

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. Care must be taken to align the hierarchies 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.)

The tool derives a default voltage area for placement of cells not assigned to other voltage areas. The default voltage area can contain top-level leaf cells and buffer-type level shifters, as well as the blocks.

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_overlap` variable to false before running placement and legalization.

[Figure 13-5](#) shows a multivoltage design divided into several voltage areas.

*Figure 13-5 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 13-6](#) shows a floorplan similar to [Figure 13-5](#) but with guard bands protecting voltage areas Ra and Rc.

Figure 13-6 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 13-1 on page 13-24](#). For an example that does use the `-power_domain` option, see the script provided in [Example 13-4 on page 13-59](#).

**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 13-25.

After you have defined a voltage area and associated cells, you can add or remove cells from the voltage area by using the `update_voltage_area` command.

Note the following limitations:

- 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.

The script in [Example 13-1](#) shows you how to create voltage areas manually without specifying power domains.

***Example 13-1 Manual Voltage Area Specification***

```
# Block1 is VoltageArea1 and Block2 is VoltageArea2 #
##
create_voltage_area -coordinate {...} -name VoltageArea1
update_voltage_area -name VoltageArea1 Block1
create_voltage_area -coordinate {...} -name VoltageArea2
update_voltage_area -add -name VoltageArea2 Block2
report_voltage_area -all
```

---

## 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. You can use the `get_voltage_area` 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. See the next section, “[Including Guard Bands With Voltage Areas](#).”

---

## 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 three commands:

- `create_voltage_area -guard_band_x x_width -guard_band_y y_width [user input values defining a voltage area]`
- `update_voltage_area -guard_band_x x_width -guard_band_y y_width [user input values specifying voltage area and updating hierarchical cells list]`

[Figure 13-7](#) 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 13-7 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 13-8](#) 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 13-8 Example of Physically Resolved Voltage Areas*



A voltage area with disjoint shapes, in which no boundary is shared, is not allowed. You can change a disjoint voltage, such as VA\_B shown in [Figure 13-9](#), into two voltage areas with unique names, such as VA\_B\_1 AND VA\_B\_2.

*Figure 13-9 Example of a Resolved Disjoint Voltage Area*



## 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.

Once 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.

---

## Handling Level Shifters and Isolation Cells

To properly handle level shifters and isolation cells, you should be aware of the following properties and commands:

- [Level-Shifter and Isolation Cell Requirements](#)
- [Level-Shifter Commands](#)
- [Level-Shifter Threshold \(Automatic and User-Specified\)](#)
- [Inserting Buffer-Type Level Shifters](#)
- [Inserting Isolation Cells and Enable-Type Level Shifters](#)
- [Placing Level Shifters](#)

---

## Level-Shifter and Isolation Cell Requirements

The following level-shifter and isolation cell requirements should be observed:

- Input and output pin voltages are the same for isolation cells.
- 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.
- Level shifters and isolation cells are selected by IC Compiler from the target libraries. Therefore, at least one of the libraries must contain the required cells.
- 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.

---

## Level-Shifter Commands

These commands can be used to manage the level shifters in your design:

- `check_mv_design` with the `-level_shifters` option checks and reports net, cell, and environment violations with respect to level shifters. You can run the command at any point in the flow. (This command is preferred over the `check_level_shifters` command.)
- `insert_level_shifters` – Inserts *only* buffer-type level shifters to accommodate voltage mismatches on nets, according to the level-shifter strategy and threshold settings. This command can be used anywhere in the flow, but it is usually best to run the command as early in the flow as possible (usually prior to logic synthesis).

**Note:**

If the design is synthesized using Design Compiler, *automatic* level-shifter insertion is done as part of the `compile_ultra` or `compile` command process. In this case, you do not need to use the `insert_level_shifter` command unless level-shifter modifications are necessary.

- `set_level_shifter_strategy` – Sets the strategy used for adjusting voltage levels in the design. To use voltage step-up level shifters only, set the strategy rule to `low_to_high`; to use voltage step-down level shifters only, set the strategy rule to `high_to_low`. To use both kinds of level shifters, set the rule to `all`. If you do not want to use the default (`all`), you should set the strategy before level shifters are inserted during `compile` or before using the `insert_level_shifters` command.
- `set_level_shifter_threshold` – Use this command if you do not want the tool automatically to determine the threshold levels. The threshold sets the minimum allowed voltage difference between source and sink, beyond which voltage differences are adjusted by insertion of level shifters. If you do not want to use the default (0 threshold voltage difference and 0 percentage difference), you should set the threshold before level shifters are inserted during `compile` or before using the `insert_level_shifters` command. See “[Level-Shifter Threshold \(Automatic and User-Specified\)](#)” on page 13-31.
- `remove_level_shifters` – Removes all level shifters in a design except those marked with the `dont_touch` attribute. Use this command as needed to correct or redefine the use of level shifters in the design.

---

## Level-Shifter Threshold (Automatic and User-Specified)

A level-shifter threshold strategy must be defined before buffer-type level shifters are inserted (manually or automatically) and checked. Two methods for defining the threshold strategy are available to you:

- The tool’s automatic threshold capability, which uses the default threshold values to determine voltage mismatched nets requiring buffer-type level-shifter insertion. (No user-defined specifications are needed.)
- User-specified threshold conditions for nets with significant voltage mismatches. Threshold conditions are defined by using the `set_level_shifter_threshold` command.

### Automatically Determined Level-Shifter Threshold

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 Level-Shifter Threshold

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 threshold options. 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}$ .

---

## Inserting 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_level_shifters` command to insert these level shifters in the current design. Command options include `-preserve`, `-all_clock_nets`, `-clock_net`, and `-verbose`.

Using this 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. 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, it is recommended that you 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.

In general terms, IC Compiler goes through the following steps to insert buffer-type level shifters into 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_level_shifters` 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 13-10](#) 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 13-10 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).

---

## 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. You 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` argument of the `map_level_shifter_cell` command. This command has no effect on instantiated level-shifter cells that have `dont_touch` attribute set on them. For more details, see the command man page.

---

## 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` or `compile` 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 they can be manually inserted by using the `insert_isolation_cell` command at various points in the flow. Enable-type level shifters cannot be inserted by a user command. They can be instantiated only at the RTL level or inserted automatically during compile to replace already present isolation cells. It is recommended that isolation cells and enable-type level shifters cells be instantiated at the RTL level; otherwise formal verification of the logic is likely to fail.

For isolation cells, the `is_isolation_cell` and `isolation_cell_enable_pin` library attributes should be set on these cells and their enable pins. Similarly, the `is_level_shifter` and the `level_shifter_enable_pin` library attributes must be set on the enable-type level shifter cells and their enable pins. After these cells are instantiated in the netlist, they should be marked 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 Presto Verilog or Presto VHDL. See the appropriate reference manual.)

There are a number of ways in which isolation cells and enable-type level shifters might be connected to the input and output nets of the voltage areas. It is possible to introduce redundant isolation cells accidentally into the RTL description of the design or to fail to specify necessary cells. You can use the `check_isolation_cells` command to check for these conditions.

## 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` 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` argument of the command. If the instantiated isolation cells

have `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 command man page.

---

## 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.)

---

## 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 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 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 on checks and reporting commands see, “[Checks and Reporting Commands for Multivoltage Designs](#)” on page 13-48.

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 using the `set_attribute` command, as shown in the following example:

```
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

```
set_attribute [get_pins U1/U2/A] always_on true
```

By default, the tool assumes the enable pin of special cells such as isolation cells or level-shifter cells as 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 on marking cells and pins as always-on, see the Advanced Low Power Modeling chapter in the *Library Compiler Modeling Timing, Signal Integrity, and Power in Technology Libraries User Guide*.

## 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.

---

## Sample IC Compiler Script for UPF Flow

The following is an example script for power intent specification using the UPF commands.

***Example 13-2 A sample UPF Script for power intent specification***

```
# Use 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} \
    -control_sense high -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 13-3 A Sample IC Compiler Script for the UPF Flow***

```
# Invoke IC Compiler

##open design ddc
read_ddc design.ddc
save_mw_cel -as floorplan
save_upf out.upf
link_physical
## derive pg connections
```

```

derive_pg_connection -create_net/reconnect

## floorplan steps
read_io_constraints design.ios

## 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 \
-net 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_cell HDRSODHVT <name_of_switch>
create_power_swswitch_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 filename.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-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
- Multicorner-Multimode Designs

---

### 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. It is recommended that you ensure 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 preceding constraints that are listed above 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.

---

## 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 given 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) are supported in multivoltage design optimization flows. ILMs 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 detailed information on ILMs, see [Chapter 11, “Using Interface Logic 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_shifter` 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 command `set_si_options` with the appropriate options.

---

## Multicorner-Multimode Designs

Multivoltage designs support multicorner-multimode, concurrent optimization. For information about multicorner-multimode functionality and usage, see [Chapter 14, “Using Multicorner-Multimode Technology”](#).

---

## 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.

Once 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 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 only in the shut-down power domains.
- 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.

It is recommended that you 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 -root [get_ports clk] \
-max_transition 0.5 -reference_per_level {BUF2 INV} -target_skew 0.1
check_mv_design
compile_clock_tree -clock_tree clock_name
check_mv_design
save_mw_cell -as post_cts
```

## Checks and Reporting Commands for Multivoltage Designs

IC Compiler supports commands to check and report multivoltage design-specific details. These are as follows:

- Report the operating conditions and process (P), voltage (V), and temperature (T) values on different blocks.
- Check and report target library subsetting inconsistencies.
- Check and report the power management cells, strategies, and their consistency.
- 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 Checks

The following commands perform multivoltage specific checks. You can use them at various stages of your multivoltage design implementation.

- `check_mv_design`

You 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.

- `check_level_shifters`

You 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`

You 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.

In addition to these multivoltage specific checks, the `check_target_library_subset` command can be useful to identify inconsistent settings among target libraries and the target library subsets and operating conditions.

---

## 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.

- `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_connection`

This command gives you detailed information on the power supply connectivity in your design.

- `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.

For more details, see the command man pages.

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.

For more details, see the command man pages.

---

## 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 13-11](#) shows the IC Compiler hierarchical UPF flow.

*Figure 13-11 IC Compiler Hierarchical UPF Flow*



The hierarchical UPF flow in IC Compiler consists of the following three steps:

1. Full-Chip Design Planning
2. Block-Level Place and Route
3. 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 the DDC format
- An ASCII design database in Verilog along with constraint files such as SDC, UPF and so on.

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 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

Follow these set of guidelines, which are common to both Design Compiler and IC Compiler, to implement your design in IC Compiler. These guidelines are common to both Design Compiler and IC Compiler.

- Align the physical partitions with the power domain boundaries as defined in the logical netlist.
- Specify the UPF constraints in such a way that each power domain is at the same level of hierarchy as the element it contains.
- 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:

- A partition boundary must correspond to a power domain boundary, with the scope of the power domain at the same level of hierarchy as the partition itself.
- 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.

- ILM creation

To ensure that all UPF information is available in the ILM, use the `-compact none` and `-traverse_disabled_arcs` option of the `create_ilm` command when you create the ILM.

- Automatic propagation of the UPF from ILM 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 ILM. However, the constraints are automatically propagated from the ILM. So, do not reapply the UPF constraints or recreate the voltage area for the ILM.

---

## Full-Chip Design Planning

[Figure 13-12](#) 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 on the guidelines, see “[Guidelines For Hierarchical UPF Flow](#)” on page 13-52.

The following are the tasks involved in the full-chip design planning phase:

### Read the DDC File

Read the DDC files by using the `read_ddc` or `import_designs` command, as shown in the following example:

```
icc_shell> import_designs full_chip.ddc -format ddc \
           -top myDesign -cel myDesign
```

### 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
```

Run the `check_mv_design` command to check the PG connections.

### 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}
```

### Create the Power Route

Create the power rings or straps manually before inserting the power switch.

### 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 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 using the `connect_power_switch` command.

*Figure 13-12 Steps Involved In a Full Chip Design Planning*



### 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
```

### 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.

### 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 in the 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> route_global
icc_shell> analyze_fp_routing -finalize plan_groups
```

### Perform Proportional Timing Budgeting

Run 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 UPF constraints in the soft macro.

```
icc_shell> allocate_fp_budgets -file_format_spec {./sdc/m.sdc}
```

### Transform the Plan Groups Into Soft Macros

Run 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_cell -hier
```

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 on the full-chip design planning phase, see “[Full-Chip Design Planning](#)” on page 13-53.

The block-level place and route phase involves the following tasks, as shown in [Figure 13-13](#):

*Figure 13-13 Steps in the Block Level Place and Route Phase*



Before you perform the place and route step, check the UPF constraints inside the ILM, as shown in the following example:

```
icc_shell> save_upf block.upf
icc_shell> report_power_domains
icc_shell> report_pst
icc_shell> report_supply_net -all
icc_shell> report_supply_port -all
```

Connect the power and ground pins after each step by using the `derive_pg_connection -all` command. Also use the `check_mv_design` command to check the UPF consistency.

You then create the ILM and FRAM views by using the `create_ilm` command, as shown in the following example:

```
icc_shell> create_ilm -compact none -traverse_disabled_arcs
icc_shell> create_macro_fram
```

---

## Top-Level Place and Route

The steps involved in the top level place and route phase are shown in [Figure 13-14](#). In this phase, the UPF constraints in the ILM are propagated to the top level. This propagation is performed by the tool automatically during linking.

Use the `derive_pg_connection -all` command to connect the power and ground pins after each step. Use the `check_mv_design` command to check for consistency.

*Figure 13-14 Steps in the Top-Level Place and Route Phase*



---

## Non-UPF Flow For Multivoltage Designs

This section describes the non-UPF flow for multivoltage designs. To invoke IC Compiler in non-UPF mode use the `-non_upf_mode` option of the `icc_shell` command.

---

## Using Power Domains

In the Design Compiler to IC Compiler flow, power domains and power domain objects are created in Design Compiler before compiling the design. You can output the compiled design and power domain data as a .ddc file, or write it directly into the Milkyway database, or write out Verilog and constraint script files. IC Compiler can process all three types of output, automatically transferring the power domain objects into the Milkyway database.

### Power Domain Commands

The principal power domain commands are

- `create_power_domain` – use to create a power domain; arguments include `domain_name` and the options `-power_down`, `-power_down_control`, `-power_down_ack`, and `-object_list` (of hierarchical cells).

- `create_power_net_info` – use to specify the abstract power or ground net objects; arguments include `power_net_name` and the options `-power`, and `-gnd`.
- `connect_power_domain` – use to connect power and ground nets to power domains; arguments include `-object_list` (of power domains), `-primary_power_net`, `-primary_ground_net`, `-backup_power_net`, `-backup_ground_net`, `-internal_power_net`, and `-internal_ground_net`.
- `connect_power_net_info` – use to specify exceptional power net hookups; arguments include `power_net_name` and the options `-object_list` (of leaf cells intended for exceptional power net connections), `-power_pin_name` (of the leaf cells).

Other power domain commands include `remove_power_domain`, `remove_power_net_info`, `report_power_domain`, `report_power_net_info`, `disconnect_power_net_info`. For a detailed discussion on all the above commands and how to use them, see both the man pages and the multivoltage chapter in the *Power Compiler User Guide*.

In a third-party flow, in which the design is not synthesized using Design Compiler, you must create the power domains in IC Compiler. However, you use the same commands as listed previously and in the same way. Refer to the man pages and the multivoltage chapter in the *Power Compiler User Guide*.

## Connecting Power and Ground Nets

The specifications you provide with the `create_power_domain`, `create_power_net_info`, and `connect_power_domain` commands are sufficient to enable the tool to connect the power and ground nets of a power domain. Use the `derive_pg_connection` command to connect the power and ground nets of the power domains automatically. Use this command before you run any of the optimizations. This command has similar behavior in the default and the non-UPF mode. For more details, See “[Connecting Power and Ground Nets](#)” on page 13-19.

---

## Sample IC Compiler Script For Non-UPF Flow

Example 13-4 provides a script with all the steps required in the physical synthesis phase of the multivoltage design flow. This design uses multiple NLDM libraries. The script assumes that two power domains, MV\_BLOCK1 and MV\_BLOCK2, have already been defined for the design.

*Example 13-4 IC Compiler Multivoltage Non-UPF Flow*

```
## Invoke icc_shell
## Create (and open) Milkyway library with tech file
## and reference library names

create_mw_lib MWDL -tech tech.tf \
    -mw_reference_library "$MWRL_stdcell $MWRL_ls" -open

set mw_power_net    VDD
set mw_ground_net   VSS
set mw_power_port   VDD
set mw_ground_port  VSS

set_app_var search_path ".$ ./lib ./src ./db ./scripts $search_path "
set_app_var target_library " \
    max_v108_t125.db \
    max_v132_t125.db \
    max_v70_t125.db \
    max_v85_t125.db \
    max_v95_t125.db \
    slow_ls.db "

set_app_var link_library " * $target_library "

## Read in logic design
read_verilog ./netlist.v

## Optional step, correct unit site names to match techfile
set_app_var mw_site_name_mapping "unit_nsm unit"

## Read in physical pin locations
read_def ./${block_name}.def

link_physical

source -verbose -echo ./${block_name}.SDC
```

***Example 13-4 IC Compiler Multivoltage Non-UPF Flow (Continued)***

```
## Create power net information and power domains
create_power_net_info -power VDD
create_power_net_info -power VDDH
create_power_net_info -power VDDS
create_power_net_info -ground VSS

create_power_domain TOP
connect_power_domain TOP \
    -primary_power_net VDD \
    -primary_ground_net VSS

create_power_domain MV_BLOCK1 \
    -object_list [get_cell -hier* -filter "@ref_name == BLOCK1"] \
    -power_down
connect_power_domain MV_BLOCK1 \
    -primary_power_net VDD \
    -internal_power_net VDDS \
    -primary_ground_net VSS

create_power_domain MV_BLOCK2 \
    -object_list [get_cell -hier* -filter "@ref_name == BLOCK2"] \
    -power_down
connect_power_domain MV_BLOCK2 \
    -primary_power_net VDDH \
    -primary_ground_net VSS

## Create voltage areas using bounding box method
create_voltage_area -power_domain MV_BLOCK1 \
    -coord {387 453 820 820} \
    -guard_band_x 5 \
    -guard_band_y 5

create_voltage_area -power_domain MV_BLOCK2 \
    -coord {387 52 820 340} \
    -guard_band_x 5 \
    -guard_band_y 5
```

***Example 13-4 IC Compiler Multivoltage Non-UPF Flow (Continued)***

```
## Check to make sure all voltage areas have been created
report_voltage_area -all

derive_pg_connection -tie
## Your libraries must contain power/ground pin definitions when using
## the following command
derive_pg_connection -reconnect -verbose

check_mv_design

place_opt

check_legality
check_mv_design -power_nets

report_change_list
change_names -rule verilog -hierarchy
write_verilog icc_placed.v
write_def -output icc_placed.def
write_script -output icc_placed.wscr
save_mw_cel -as icc_placed
exit
```



# 14

## Using Multicorner-Multimode Technology

This chapter describes the IC Compiler support for multicorner-multimode technology.

This chapter discusses the following topics:

- [Basic Multicorner-Multimode Concepts](#)
- [Basic Multicorner-Multimode Flow](#)
- [Setup Considerations](#)
- [Multicorner Library Considerations](#)
- [Using Multicorner-Multimode Commands](#)
- [Multicorner-Multimode Script Example](#)

---

## Basic Multicorner-Multimode Concepts

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

---

### Scenario Definition

A *scenario* is a mode or corner or a combination of both that can be analyzed and optimized.

A *mode* is defined by a set of clocks, supply voltages, timing constraints, and libraries. It can also have annotation data, such as SDF or parasitics files.

A *corner* is defined as a set of libraries characterized for process, voltage, and temperature variations. Corners are not dependent on functional settings; they are meant to capture variations in the manufacturing process, along with expected variations in the voltage and temperature of the environment in which the chip will operate.

You create scenarios by using the `create_scenario` command.

---

### Concurrent Multicorner-Multimode Optimization and Timing Analysis

Concurrent multicorner-multimode optimization works on the worst violations across all scenarios, eliminating the convergence problems observed in sequential approaches. Optimization is performed for DRC, setup and hold, or only setup. Concurrent hold-only optimization for preroute designs (that is, `place_opt` and `psynopt` hold-only optimization) is supported, as well as concurrent preroute and postroute hold fixing when you use the `-effort high` option with the `route_opt` command.

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

Timing analysis can be performed in one of two methods:

- Traditional min and max methodology
- Early-late analysis, such as that in PrimeTime, utilizing the on-chip variation (OCV) switch in the `set_operating_conditions` command.

---

## Basic Multicorner-Multimode Flow

[Figure 14-1](#) shows the basic multicorner-multimode flow.

*Figure 14-1 Basic Multicorner-Multimode Flow*



As shown in [Figure 14-1](#), a scenario definition usually includes commands that specify the TLUPlus libraries, operating conditions, and constraints. However, other commands can be included. For example, for multimode scenarios, you can use the `set_max_leakage_power` command to control power leakage on a per-scenario basis or the `read_sdf` command to set the correct net RC and pin-to-pin delay information in the respective scenarios.

---

## Setup Considerations

Multicorner-multimode scenarios support

- Up to one hundred TLUPlus files (minimum and maximum)
- Minimum and maximum libraries, or multivoltage libraries

IC Compiler uses the nominal process, voltage, and temperature (PVT) values to group the libraries into different sets. Libraries with the same PVT values are grouped into the same set. For each scenario, the PVT of the maximum operating condition is used to select the appropriate set.

To allow for temperature scaling, the TLUPlus files must contain the `GLOBAL_TEMPERATURE`, `CRT1`, and (optionally) `CRT2` variables. The following example is an excerpt from a TLUPlus file:

```
TECHNOLOGY = 90nm_lib
GLOBAL_TEMPERATURE = 105.0
CONDUCTOR metal8 {THICKNESS= 0.8000
    CRT1=4.39e-3 CRT2=4.39e-7
...

```

The TLUPlus file settings, which you specify by using the `set_tlu_plus_files` command, must be made explicitly for each scenario. If a TLUPlus setup is not correct, an error similar to the following is issued:

```
Error: tlu_plus files are not set in this scenario s1.
      RC values will be 0.
```

Also, the design's operating condition must be set for each scenario. If it is not defined, MV-020 and MV-21 warnings similar to the following are issued:

```
icc_shell> set_operating_conditions SLOW_95 -lib 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)
```

---

## Multicorner Library Considerations

To handle libraries appropriately for the multicorner-multimode design flow, you should consider the topics discussed in the following sections:

- [Link Libraries With Equal Nominal PVT Values](#)
  - [Distinct PVT Requirements](#)
  - [Unsupported k-factors](#)
  - [Automatic Detection of Driving Cell Library](#)
  - [Automatic Inference of Operating Conditions for Macro Cells and Pad Cells](#)
  - [Relating the Minimum Library to the Maximum Library](#)
  - [Unique Identification of Libraries Based on File Names](#)
- 

### Link Libraries With Equal Nominal PVT Values

The link library list is a list of all of the libraries that are to be used for linking the design for all scenarios. Because you can use several libraries with any specific scenario, such as a standard cell library and a macro library, IC Compiler automatically groups the libraries in the link library list into sets. The tool also identifies the set of link libraries that must be used with each scenario.

The library grouping is based on their PVT values. Libraries with the same PVT values are grouped into the same set. The tool uses the PVT value of a scenario's maximum operating condition to select the appropriate library set for the scenario.

When the tool cannot find a suitable cell in any of the specified libraries, it reports a warning message as follows:

```
Error: cell TEST_BUFB_En_BUFB/Z (inx4) is not characterized  
for 0.950000V, process 1.000000, temperature -40.000000. (MV-001)
```

When you encounter a MV-001 error in your flow, verify that the operating conditions and library setup are right. If you do not correct this error, optimization is not performed.

## Link Library Example

The following example table shows how the library linking scheme works.

**Table 14-1** shows the libraries in the link library list, their nominal PVT values, and the operating condition (if any) specified in each library. The design has instances of combinational, sequential, and macro cells.

*Table 14-1 Link Libraries With PVT and Operating Conditions*

| Link library (in order) | Nominal PVT | Operating conditions<br>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                                     |

To create a scenario s1 with the cell instances linked to the Combo\_cells\_slow, Macros\_slow, and Sequential\_slow libraries, you run

```
icc_shell> create_scenario s1
icc_shell> set_operating_conditions -max WORST -library
```

Note that providing the `-library` option in the `set_operating_conditions` command merely helps the tool identify the correct PVT for the operating conditions. The PVT of the maximum operating condition is used to find the correct matches in the link library list during linking.

Using this linking scheme, you can link libraries that do not have operating condition definitions. The scheme also provides the flexibility of having multiple library files (for example, one for standard cells, another for macros, and so forth).

### Inconsistent Libraries Warning

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.

---

## Distinct PVT Requirements

If the maximum libraries associated with each corner (scenario) do not have distinct PVT values, the cell instances are linked incorrectly and results in incorrect timing values. This happens because the nominal PVT values, that are used to group the link libraries into sets, group the maximum libraries of different corners into one set. Consequently, the cell instances are linked to the first cell with a matching type in that set (for example, the first AND2\_4), even though the `-library` option is specified for each of the scenario-specific `set_operating_conditions` commands. That is, the `-library` option locates the operating condition and its PVT but not the library to link.

The following two tables and the following script demonstrate the problem:

**Table 14-2** shows the libraries in the link library, listed *in order*, their nominal PVT; and the operating condition that is specified in each library.

*Table 14-2 Link Libraries With PVT and Operating Conditions*

| Link library (in order) | Nominal PVT | Operating conditions<br>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)                       |
| TypHV.db                | 1/1.30/100  | WORST (1/1.30/100)                       |
| Holdtyp.db              | 1/0.85/100  | BEST (1/0.85/100)                        |

**Table 14-3** and the script commands that follow show the operating condition specification for each of the scenarios.

*Table 14-3 Scenarios and Their Operating Conditions*

| Scenarios               |                   |                     |                    |                      |
|-------------------------|-------------------|---------------------|--------------------|----------------------|
|                         | s1                | s2                  | s3                 | s4                   |
| Max Opcond<br>(Library) | WORST<br>(Typ.db) | WORST<br>(TypHV.db) | WORST<br>(Ftyp.db) | WORST<br>(Typ.db)    |
| Min Opcond<br>(Library) | None              | None                | None               | BEST<br>(HoldTyp.db) |

```

create_scenario s1
set_operating_conditions WORST -library Typ.db
create_scenario s2
set_operating_conditions WORST -library TypHV.db
create_scenario s3
set_operating_conditions WORST -library Ftyp.db
create_scenario s4
set_operating_condition \
    -max WORST -max_library Typ.db \
    -min BEST -min_library HoldTyp.db

```

The tool groups the Ftyp.db, and TypHV.db libraries into a set with Ftyp.db as the first library in the set. Therefore, the cell instances in scenario s2 are not linked to the library cells in TypHV.db, as intended. Instead, they are linked to the library cells in the Ftyp.db library (assuming that all the libraries include the library cells required to link the design).

### Ambiguous Libraries Warning

When you use multiple libraries, if any of the libraries with same-name cells 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.

## Unsupported k-factors

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 list.

## Automatic Detection of Driving Cell Library

In multicorner-multimode flow, the operating condition setting is different for different scenarios. To build the timing arc for the driving cell, different technology libraries are used for different scenarios. You can specify the library by using the `-library` option of the `set_driving_cell` command. Specifying the library is optional because the tool can automatically detect the driving cell library.

When you specify the library using the `-library` option of the `set_driving_cell` command, the tool searches for the specified library in the link library set. If the specified library exists it is used. If the specified library does not exist in the link library, the tool issues the UID-993 error message as follows:

Error: Cannot find the specified driving cell in memory. (UID-993)

When you do not use the `-library` option of the `set_driving_cell` command, the tool searches all the libraries for the matching operating conditions. The first library in the link library set, that matches the operating condition is used. If no library in the link library set matches the operating condition, the first library in the link library set, that contains the matching library cell is used. If no library in the link library set contains the matching library cell, the tool issues the UID-993 error message.

---

## Automatic Inference of Operating Conditions for Macro Cells and Pad Cells

Special cells such as macro cells and pad cells usually have associated supply rail information. When the operating condition set on the design does not have rail information or if the technology library does not contain matching cells for the macro cells or pad cells of the design for the PVT values set on the design, IC Compiler generates an MV-001 error message. In such cases, explicitly setting the operating conditions for each instance of the design for the various corners can be tedious.

IC Compiler automatically infers the operating condition for each instance of a macro cell or pad cell that does not have a specified operating condition. The automatic inference is performed when the operating condition on a macro cell or pad cell does not match the operating condition set on the design. For each macro cell or pad cell instance, IC Compiler finds the set of library cells with the same name. Within this set, it groups the library cells in the following order of priority:

1. The PVT values of the library cell match the PVT values of the design.
2. The voltage and temperature values of the library cell match the voltage and temperature values of the design.
3. The process and voltage values of the library cell match the process and voltage values of the design.
4. The voltage value of the library cell matches the voltage value of the design.
5. The voltage value of the library cell does not match the voltage value of the design.

After the library cells are grouped, IC Compiler inspects each group in the order mentioned above. The inference is terminated in the following situations:

- None of the groups contain exactly one cell.
- Even though a group contains exactly one cell, one or more groups of higher priority contain more than one cell.

When IC Compiler finds a group that contains exactly one cell and no group with higher priority contains more than one cell, it uses the PVT values of that cell as the operating condition of the associated macro cell or the pad cell.

The following table shows how IC Compiler infers the operating condition when there are a different number of library cells in the various groups.

*Table 14-4 Operating Condition Inference for Pad Cells and Macro Cells*

| <b>Matching library cell group priority</b> | <b>Number of library cells in the matching library cell groups</b> |                         |                  |                     |                  |
|---------------------------------------------|--------------------------------------------------------------------|-------------------------|------------------|---------------------|------------------|
|                                             | <b>Example 1</b>                                                   | <b>Example 2</b>        | <b>Example 3</b> | <b>Example 4</b>    | <b>Example 5</b> |
| PVT                                         | 1                                                                  | 0                       | 2                | 0                   | 0                |
| Voltage and temperature                     | 2                                                                  | 1                       | 1                | 0                   | 0                |
| Process and voltage                         | 5                                                                  | 3                       | 3                | 1                   | 0                |
| Voltage                                     | 3                                                                  | 2                       | 3                | 2                   | 0                |
| Does not match voltage                      | 0                                                                  | 1                       | 2                | 0                   | 5                |
| Inferred operating condition                | PVT                                                                | Voltage and temperature | No inference     | Process and voltage | No inference     |

When the automatic inference of operating conditions is successful, the tool prints the MV-751 information message.

The automatic inference of operating conditions is supported in both IEEE 1801™ (UPF) and non-UPF modes. You can disable the automatic inference of operating conditions by explicitly setting the operating conditions.

### **Inferring Operating Conditions for Pad Cells With Driving Voltage**

Inferring operating conditions for pad cells with driving voltage is similar to inferring operating conditions for regular pad cells. However, there are two differences in the process:

- Library cells whose pad pin voltage is different from the driving voltage of the pad cell instance are ignored while categorizing the library cells into various priority groups
- The inferred operating condition is spread to the top-level port that drives the pad cell instance.

---

## Relating the Minimum Library to the Maximum Library

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 only one minimum library. As shown in the example in [Table 14-5](#), 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 14-5 Supported Min-Max Library Configuration*

| Scenarios   |                           |
|-------------|---------------------------|
| s1          | s2                        |
| Max library | <code>Slow.db</code>      |
| Min library | <code>Fast_0yr.db</code>  |
|             | <code>Fast_10yr.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 14-6](#), 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 14-6 Unsupported Multiple Minimum Library Configuration*

| Scenarios   |                           |
|-------------|---------------------------|
| s1          | s2                        |
| Max library | <code>Slow.db</code>      |
| Min library | <code>Fast_0yr.db</code>  |
|             | <code>Fast_10yr.db</code> |

***Example 14-1 Unsupported Multiple Minimum Library Configuration Script***

```

create_scenario S1
set_min_library -min Fast_0yr.db Slow.db
...
create_scenario S2
set_min_library -min Fast_10yr.db Slow.db
...

```

In the [Example 14-1](#), 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'.
```

**Unique Identification of Libraries Based on File Names**

Two libraries with the same name can be uniquely identified if their file names, which precede the library names (colon-separated), are unique. For example, the library ABC.db:stdcell (where ABC.db is the library file name and stdcell is the library name) is identifiable with respect to the library DEF.db:stdcell.

However, two libraries that have the same file name and library name but reside in different directories are not uniquely distinguishable. The following two libraries are not uniquely distinguishable:

```

/remote/snps/testcase/LIB/fast/ABC.db
/remote/snps/testcase/LIB/slow/ABC.db

```

**Using Multicorner-Multimode Commands**

The command groups used in multicorner-multimode flows are discussed in the following sections:

- [Scenario Management](#)
- [Multicorner-Multimode Optimization](#)
- [Using Scenario Reduction](#)
- [Preroute Hold Fixing](#)
- [Using the Clock Tree Synthesis Scenario](#)
- [Using Interface Logic Models With Multicorner-Multimode Scenarios](#)

- [Reporting Commands for Multicorner-Multimode](#)
- 

## Scenario Management

A scenario is a grouping of constraints and is specific to an IC Compiler session. You can create scenarios either before or after reading the design. In an IC Compiler session, if you create scenarios prior to reading the design, all the scenario definitions are applied to the design being read. Similarly, when you save the design, the tool not only saves all the design data and the scenarios that were read in, but also saves all the scenarios that were defined in the session unless you remove the scenarios before writing out the design.

Note:

Although scenario definitions are specific to a session, data such as the TLUplus files, the operating conditions, and the timing derating factors that you specify on the current scenario are design-specific and are stored on the design.

You use the following commands to create and manage scenarios:

- `create_scenario`
- `current_scenario`
- `all_scenarios`
- `set_active_scenarios`
- `all_active_scenarios`
- `set_scenario_options`
- `remove_scenario`
- `set_tlu_plus_files`
- `write_parasitics`
- `save_mw_cel -scenario`

### **`create_scenario`**

Use this command to create a new scenario in `icc_shell`. When the first scenario is created, 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
```

### **current\_scenario**

Use this command to specify the name of the current scenario. You use this command in combination with many `icc_shell` commands. Without arguments, the command returns the name of the current scenario.

Note that the `current_scenario` command merely specifies the focus scenario and that when you define more than one scenario, the tool performs concurrent analysis and optimization across all scenarios, independent of the current scenario setting. The following example highlights usage:

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

### **all\_scenarios**

Use this command to display the scenarios currently defined in the `icc_shell`:

```
icc_shell> all_scenarios
s1 s2
```

### **set\_active\_scenarios**

Use this command to specify which scenarios the tool should include for analysis and optimization. Scenarios that you consider not relevant in a given optimization context can be ignored, which allows memory recovery and runtime reduction.

### **all\_active\_scenarios**

Use this command to display the currently active scenarios.

### **set\_scenario\_options**

Use this command to set the options for the specified scenario. You can specify a list of scenarios using the `-scenarios` option to apply the options to the specified scenarios. If you do not specify any scenario, the options are applied only to the current scenario.

Use the `-leakage_power` option to enable or disable the leakage power optimization. The leakage power optimization is enabled by default, on the scenarios. Set the `-leakage_power` option to `false` to disable the leakage power optimization. The default value of the `-leakage_power` option is `true`. The following example shows how to enable leakage power optimization on specific scenarios.

```
icc_shell> set_scenario_options -leakage_power true \
-scenarios scenario_list
```

Use the `-dynamic_power` option to enable or disable the dynamic power optimization. The dynamic power optimization is enabled by default, on the scenarios. When you enable the dynamic power optimization, you must also set the `-setup` option to `true`. The default value of the `-dynamic_power` option is `true`.

Use the `-setup` option to enable or disable the setup or maximum delay optimization for the specified scenarios. The default value of the `-setup` option is `true`, so maximum delay optimization is enabled, by default. The following example shows how to disable maximum delay optimization on specific scenarios.

```
icc_shell> set_scenario_options -setup false -scenarios scenario_list
```

Use the `-hold` option to enable or disable the hold or minimum delay optimization for the specified scenarios. When you set the `-hold` option to `false`, the tool ignores the hold or the minimum delay violations in the specified scenarios. The default value of the `-hold` option is `true`.

Set the `-leakage_only` option to `true` to optimize the current scenario only for leakage power. Set the `-hold_only` option to `true` to fix all the hold delays in the current scenario. Restricting the optimization to one specific cost yields you faster results. The `-hold_only` and the `-leakage_only` options are mutually exclusive. IC Compiler issues an error message if you use both the options.

When you set the `-leakage_only` option to `true`, the tool considers only the leakage constraints and ignores all other constraints such as the maximum and minimum delay and design rule checks. To restrict the current scenario to leakage power optimization, use this command as follows:

```
icc_shell> set_scenario_options -leakage_only true
```

To fix the hold delays in the current scenario, set the `-hold_only` option to `true`. When you set this option, the tool ignores the setup delay, design rule checks, and so on during the optimization process. Because all other constraints are ignored, the hold-fixing process for the current scenario completes faster. With the `-hold_only` option set to `true`, the tool honors the leakage constraints set on the scenario only if the leakage consideration does not adversely affect the hold delay and the effect on the setup delay is not a concern. To fix the hold delays on the current scenario, use this command as follows:

```
icc_shell> set_scenario_options -hold_only true
```

The `set_scenario_option` command supports the `-reset_all` option. When this option is set to `true`, the values of the various options are reset to their default values. The following example shows the use of the `-reset_all` option to reset the values of all options on all the scenarios.

```
icc_shell> set_scenario_options -reset_all true \
           -scenarios [all_scenarios]
```

**remove\_scenario**

You use this command to remove the specified scenarios from memory. To remove all scenarios use the `-all` option.

Because scenarios are specific to an IC Compiler session, if the scenarios that are defined in the session are not to be applied to the design being read, use the `remove_scenario -all` command before reading the design. Similarly, if the scenarios defined in the session do not need to be saved along with the design data, you can use this command before writing the design.

**set\_tlu\_plus\_files**

Use this command to set the TLUPlus files in the scenario specified by the `current_scenario` command. Each scenario must have a set of TLUPlus files specified, otherwise, IC Compiler issues the following error message:

```
Error: tlu_plus files are not set in this
scenario <name>. RC values will be 0.
```

**write\_parasitics**

Use this command to write out parasitics for the current scenario:

```
icc_shell> write_parasitics -format sbpf -output s1.sbpf
icc_shell> write_parasitics -format spef -output s1.spef
```

**save\_mw\_cel -scenario**

Use this command to save a design and its scenarios in Milkyway format.

```
icc_shell> save_mw_cel -scenario s1 -as cel_s1
Information: Saved design named cel_s1. (UIG-5)
```

You can save multiple scenarios:

```
icc_shell> save_mw_cel -scenario {s1 s2} -as cel_s1_s2
Information: Saved design named cel_s1_s2. (UIG-5)
```

If you do not specify a scenario, all scenarios are saved.

At present, there is no comparable `open_mw_cel -scenario` command. The design is read in with whatever scenarios were previously saved.

---

## Multicorner-Multimode Optimization

[Table 14-7](#) shows supported multicorner-multimode flows:

*Table 14-7 Supported Multicorner-Multimode Flows*

| Functionality | Preroute placement optimization | Postroute optimization |
|---------------|---------------------------------|------------------------|
| Multimode     | Yes                             | Yes                    |
| Multicorner   | Yes                             | Yes                    |

The `place_opt` and `psynopt` commands are fully supported in both multimode and multicorner flows.

The `route_opt` and `psynopt -on_route` commands are fully supported in both multimode and multicorner flows.

All features of multivoltage designs and related multivoltage commands are supported in both multicorner and multimode flows.

Signal integrity analysis and optimization are supported in both multicorner and multimode flows. Leakage power optimization is supported only in multimode flows.

The various `route_xxx` commands are supported. However, timing-driven options are supported only for the `route_opt` command.

The `clock_opt` command is not currently supported. You must perform clock tree synthesis sequentially on a per-scenario basis.

## Scaling Resistance and Capacitance

### Preroute Estimation

Use the `set_delay_estimation_options` command to set the scaling factors for resistance and capacitance for the current scenario. To set the scaling factors for a newly created scenario, use this command soon after you create the scenario.

Use the `report_delay_estimation_options` command to see the scaling factors set for the current scenario.

## Postroute Extraction

Use the `set_extraction_options` command to set the resistance, capacitance, and coupling capacitance scaling values for the current scenario. The following options 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`

Use the `report_extraction_options` command to check the values set for the current scenario. Use the `extract_rc` command to see the effect of the scaling on the design's parasitics.

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

## Filtering Coupling Capacitances

The tool supports coupling capacitance filtering across scenarios. After you have defined each scenario along with its TLUPlus files and operating conditions, run the following commands:

```
set_si_options -delta_delay true  
route_opt  
extract_rc -coupling_cap  
report_timing -scenario [all_scenarios]
```

With signal integrity options set, the `route_opt` command takes into account coupling capacitance effects across the nets. In multicorner-multimode flows, the tool's extraction engine generates the parasitics per corner from the TLUPlus and operating conditions pair values. To model the coupling capacitance effects during extraction, you must use the `-coupling_cap` option of the `extract_rc` 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 DRC 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; it is a dominated scenario.

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.

You can control the effort level of scenario reduction with the `mcm_m_high_capacity_effort_level` variable. The value that you can specify for this variable ranges from 0 (the default) to 10. IC Compiler considers all active scenarios in the reduction effort when you use the default value. As you increase the effort level, the scenario reduction method becomes more aggressive, adjusting its criteria to allow more scenarios to be removed from the dominant scenario set. This can lead to further memory and runtime reductions, but it can also imply that fewer violations are fixed during optimization.

There are two ways to accomplish scenario reduction:

- Using the `get_dominant_scenarios` command
- Automatic scenario reduction during core command execution

These techniques are discussed in detail in the following sections.

## Using the `get_dominant_scenarios` Command

Before performing optimization, you can explicitly use the `get_dominant_scenarios` command to select a single or a few scenarios to be active during optimization. You can specify the list of scenarios using the `-scenarios` option of the command to restrict the set of scenarios to be considered for the reduction. This list can include both active and inactive scenarios. The command identifies the dominant set from the specified list of scenarios.

To make the set of dominant scenarios the active set of scenarios, run the `set_active_scenarios [get_dominant_scenarios]` command. All subsequent commands use this subset of active scenarios until you rerun the `set_active_scenarios [get_dominant_scenarios]` command. Note that the list of dominant scenarios can change when you rerun this command.

In the adaptive multicorner-multimode flow, IC Compiler also runs the `get_dominant_scenarios` command internally during the optimization process. This can be very time consuming, especially for huge designs that have a large number of scenarios. To improve turnaround time without adversely affecting QoR, you can run the `get_dominant_scenarios` command in distributed mode, which runs the command in parallel across several machines.

To run the `get_dominant_scenarios` command in distributed mode, follow these steps:

1. Use the `set_mcmm_job_options` command to specify the compute resources, load sharing, and working directories that are required for executing the distributed analysis.
2. Use the specific options of the `get_dominant_scenarios` command to run the command in distributed mode.

Note:

In distributed mode, the `get_dominant_scenarios` command does not support designs that contain ILM blocks and designs that are not yet placed.

### Distributed-Mode-Specific Options of the `get_dominant_scenarios` Command

To support running in the distributed mode, the `get_dominant_scenarios` command supports the following additional options:

- `-distributed`

Use this option when you require the command to perform the analysis in the distributed mode. To use the command in distributed mode, you must have already created the setup using the `set_mcmm_job_options` or the `set_host_options` command.

- `-setup_distributed`

Creates all the necessary directories, data files, and scripts required to run the distributed analysis.

- `-run_distributed`

This option is useful when you have already created a setup. To run the `get_dominant_scenarios` command in a separate session, you must use the various options of the `set_mcmm_job_options` command.

- `-process_distributed`

After a failed run, if you have to rerun the analysis separately, this option is useful.

The `get_dominant_scenarios` command supports the `-scenario` option. This option is not specific to the distributed mode. You use this option to specify the list of scenarios to be analyzed. By default, all active scenarios are analyzed.

### Automatic Scenario Reduction During Core Command Execution

If you set the variable `mcmm_enable_high_capacity_flow` to true (default is false), the `place_opt`, `clock_opt`, and `route_opt` commands automatically determine the set of dominant scenarios at particular points in their flow and activate these scenarios. During the execution of basic commands, the last set of dominant scenarios is active.

The set of active scenarios after running a core command might be a subset of the scenarios that were active immediately before running the command. The core commands generate a message at the end of the command that lists both sets of scenarios. If necessary, you can reset the list of active scenarios by using the `set_active_scenarios` command.

---

## Preroute Hold Fixing

Concurrent, preroute hold fixing is fully supported across all scenarios in multicorner-multimode designs. Hold fixing is done in the standard way, using the `set_fix_hold` and `set_fix_hold_options` commands. In the `place_opt` flow, both setup and hold optimizations are carried out concurrently when you run the `place_opt` command. The `route_opt` flow requires that you use the `-effort high` option with the `route_opt` command to obtain concurrent setup and hold optimizations.

---

## Using the Clock Tree Synthesis Scenario

To perform clock tree synthesis in a multicorner-multimode design, you must define a scenario that is used specifically for clock tree synthesis. You might name this scenario CTS. In the clock tree synthesis scenario, you select a set of clocks that need to be synthesized and put the constraints for these clocks into a single constraints file, which is then used to run clock tree synthesis or clock tree optimization.

To identify this scenario as the clock tree synthesis scenario, use the `set_cts_scenario` command. For example, `set_cts_scenario CTS`. Then you use the `set_active_scenarios` command to list the scenarios you want to activate for optimization, *but not necessarily including the clock tree synthesis scenario*.

When you run clock tree synthesis (`clock_opt` command), only the scenario identified as the clock tree synthesis scenario is active. That is, IC Compiler first deactivates all scenarios except the clock tree synthesis scenario. After clock tree synthesis, design information (such as ideal clock latencies, propagated clocks, and so on) is automatically updated in the design scenarios, so that subsequent optimizations (such as `route_opt`) can be performed on all the active scenarios.

To return the clock tree synthesis scenario, use the `get_cts_scenario` command.

---

## Using Interface Logic Models With Multicorner-Multimode Scenarios

The multicorner-multimode feature is enabled by default when you create an ILM. You can use the `-scenario` option of the `create_ilm` command to create ILM for your multicorner-multimode design. You can apply multicorner-multimode constraints to a block, perform physical synthesis, and create an ILM for the block. The ILM created can be used in the top-level design.

The following are the requirements when you use ILMs in a multicorner-multimode flow:

- For each top-level scenario, an identically named scenario must be defined in each of the ILM blocks used in the design. An ILM can have additional scenarios that are not used at the top level as long as those scenarios do not have any additional TLUPlus file settings. In other words, the ILM can have additional modes, but not additional parasitic corners (TLUPlus files).
- In a top-level design without multicorner-multimode scenarios, only ILMs without multicorner-multimode scenarios can be used.

For detailed information on using ILMs, including script examples, see [Chapter 11, “Using Interface Logic Models.”](#)

---

## Reporting Commands for Multicorner-Multimode

This section describes commands that you can use for reporting multicorner-multimode designs.

### report\_scenario\_options

The `report_scenario_options` command reports the options set by the `set_scenario_options` command. You can specify a list of scenarios, active or inactive, to be reported using the `-scenarios` option. When you do not specify any scenario, the scenario options of only the current scenario are reported. This command does not report scenarios that are specified as `hold_only` and `leakage_only` scenarios. The following example shows a report generated by the `report_scenario_options` command:

```
*****
Report : scenario_options
Design : test
Scenario(s): scenario1 scenario2 CTS_only
Version: C-2009.06
Date   : Fri May 22 11:36:40 2009
*****

Scenario: scenario1 is active.
leakage_only  : false
hold_only     : false
setup         : true
hold          : true
leakage_power : true
dynamic_power : true

Scenario: scenario2 is active.
leakage_only  : false
hold_only     : false
setup         : true
hold          : true
leakage_power : true
dynamic_power : true

Scenario: CTS_only is active.
leakage_only  : false
hold_only     : false
setup         : true
hold          : true
leakage_power : true
dynamic_power : true
```

## report\_scenarios

The `report_scenarios` command reports the scenario setup information for multicorner-multimode designs. This command reports all the defined scenarios, the clock tree synthesis scenario, and the leakage-only scenario in the design. The scenario-specific information includes the technology library used, the operating condition, and the TLUPlus files.

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
```

## Reporting Commands That Support the -scenario Option

Some reporting commands in IC Compiler support the `-scenario` option to report scenario-specific information. You can specify a list of scenarios to the `-scenario` option and the tool reports scenario details for the specified scenarios.

The following reporting commands support the `-scenario` option:

- `report_qor`
- `report_clock`
- `report_constraint`
- `report_extraction_options`
- `report_path_group`
- `report_timing`
- `report_timing_derate`
- `report_tlu_plus_files`

## Commands That Report the Current Scenario

The following reporting commands report scenario-specific details for the current scenario. The header section of the report contains the name of the current scenario. No additional options are required to report the scenario-specific details of the current scenario.

- `report_annotated_check`
- `report_annotated_delay`
- `report_annotated_transition`
- `report_attribute`
- `report_case_analysis`
- `report_clock_gating_check`
- `report_clock_timing`
- `report_clock_tree`
- `report_clock_tree_power`
- `report_crpr`
- `report_delay_calculation`
- `report_delay_estimation_options`
- `report_disable_timing`
- `report_ideal_network`
- `report_internal_loads`

- report\_latency\_adjustment\_options
- report\_net
- report\_noise
- report\_power
- report\_power\_calculation
- report\_signal\_em
- report\_timing\_derate
- report\_timing\_requirements
- report\_transitive\_fanin
- report\_transitive\_fanout

## Reporting Examples

This section contains sample reports for some of the multicorner-multimode reporting commands.

### **report\_qor**

This command reports the QoR for each scenario.

```
*****
Report : qor
Design : TEST
Scenario(s): scenario1
Version: C-2009.06
Date   : Fri May 22 12:32:02 2009
*****  
  
Scenario 'scenario1'
Timing Path Group 'CLKIN_GROUP'
-----
Levels of Logic:      15.00
Critical Path Length: 1.80
Critical Path Slack: -0.24
Critical Path Clk Period: 2.91
Total Negative Slack: -0.70
No. of Violating Paths: 6.00
Worst Hold Violations: -0.33
Total Hold Violations: -405.56
No. of Hold Violations: 4709.00
-----
```

```
Scenario 'scenario1'
Timing Path Group 'ENABLE'
-----
Levels of Logic:          13.00
Critical Path Length:    1.72
Critical Path Slack:     0.25
Critical Path Clk Period: 2.91
Total Negative Slack:    0.00
No. of Violating Paths:  0.00
Worst Hold Violation:   -0.32
Total Hold Violation:   -44.59
No. of Hold Violations: 371.00
-----

Cell Count
-----
Hierarchical Cell Count: 1122
Hierarchical Port Count: 28646
Leaf Cell Count:         155202
Buf/Inv Cell Count:      26163
CT Buf/Inv Cell Count:   11
-----

Area
-----
Combinational Area: 300028.403042
Noncombinational Area:
                         688285.650848
Net Area:             0.000000
Net XLength :        129049.90
Net YLength :        149876.58
-----
Cell Area:           988314.053890
Design Area:         988314.053890
Net Length:          278926.47

Design Rules
-----
Total Number of Nets: 191378
Nets With Violations: 2
-----

Hostname: testmachine

Compile CPU Statistics
-----
Resource Sharing:       0.00
Logic Optimization:    0.00
Mapping Optimization:  736.34
-----
Overall Compile Time:  772.18
```

### **report\_timing -scenario [all\_scenarios]**

This command reports timing results for the active scenarios in the design. You can specify a list of scenarios with the `-scenario` option. When the `-scenario` option is not specified only the current scenario is reported.

```
*****
Report : timing
    -path full
    -delay max
    -physical
    -input_pins
    -nets
    -max_paths 1
    -transition_time
    -crosstalk_delta
    -capacitance
Design : TEST1
Scenario(s): scenario1
Version: C-2009.06
Date   : Fri May 22 12:36:28 2009
*****
* Some/all delay information is back-annotated.
# A fanout number of 1000 was used for high fanout net computations.

Startpoint: TEST_BUFBEn
            (input port clocked by clk)
Endpoint:  TEST1/TEST2_SYN/latch_3
            (non-sequential rising-edge timing check clocked by clk)
Scenario: scenario1
Path Group: CLKIN_GROUP
Path Type: max

Attributes:
  d - dont_touch
  u - dont_use
  mo - map_only
  so - size_only
  i - ideal_net or ideal_network

Point          Incr      Path      Lib:OC
-----
clock clk (rise edge)        0.00      0.00
clock network delay (propagated) 0.00      0.00
input external delay        450.00    450.00 f
TEST_BUFBEn (in)           0.00      450.00 f
stdcell_typ:WORST          9.75     459.75 r
TEST_BUFBEn_BUFB1/Z (inx4)   9.75     459.75 r
stdcell_typ:WORST          10.21    469.96 f
U468/Z (inx10)             10.21    469.96 f
stdcell_typ:WORST          8.74     478.70 r
TEST_BUFBEn_BUFB/Z (inx11)  8.74     478.70 r
stdcell_typ:WORST          8.74     478.70 r
```

|                                         |        |         |   |
|-----------------------------------------|--------|---------|---|
| U293/Z (inx11)                          | 9.30   | 488.00  | f |
| stdcell_typ:WORST                       |        |         |   |
| TEST1/TEST2_SYN/U74963/Z (nr2x4)        | 12.78  | 500.78  | r |
| stdcell_typ:WORST                       |        |         |   |
| U31662/Z (inx4)                         | 10.58  | 511.37  | f |
| stdcell_typ:WORST                       |        |         |   |
| TEST1/TEST2_SYN/U75093/Z (aoi21x6)      | 18.98  | 530.34  | r |
| stdcell_typ:WORST                       |        |         |   |
| U42969/Z (nd2x6)                        | 14.16  | 544.51  | f |
| stdcell_typ:WORST                       |        |         |   |
| TEST1/TEST2_SYN/U53046/Z (inx8)         | 13.35  | 557.86  | r |
| stdcell_typ:WORST                       |        |         |   |
| U2765/Z (inx8)                          | 11.48  | 569.33  | f |
| stdcell_typ:WORST                       |        |         |   |
| U32442/Z (inx6)                         | 7.61   | 576.94  | r |
| stdcell_typ:WORST                       |        |         |   |
| U33615/Z (nd2x3)                        | 18.14  | 595.09  | f |
| stdcell_typ:WORST                       |        |         |   |
| U32269/Z (nd2x6)                        | 8.74   | 603.82  | r |
| stdcell_typ:WORST                       |        |         |   |
| TEST1/TEST2_SYN/clk_gate/EN (cklan2x1)  | 0.00   | 603.82  | r |
| stdcell_typ:WORST                       |        |         |   |
| -----                                   |        |         |   |
| data arrival time                       |        | 603.82  |   |
| clock clk (rise edge)                   | 650.00 | 650.00  |   |
| clock network delay (propagated)        | 0.00   | 650.00  |   |
| TEST1/TEST2_SYN/clk_gate/CLK (cklan2x1) |        |         |   |
|                                         | 0.00   | 650.00  | r |
| clock uncertainty                       | -0.15  | 2.76    | r |
| clock gating setup time                 | -56.25 | 593.75  |   |
| data required time                      |        | 593.75  |   |
| -----                                   |        |         |   |
| data required time                      |        | 593.75  |   |
| data arrival time                       |        | -603.82 |   |
| -----                                   |        |         |   |
| slack (VIOLATED)                        |        | -10.07  |   |

### report\_constraint

This command reports the constraints of each scenario along with the multi-scenario costs. The `-all_violators` and `-verbose` options of this command are not available in multicorner-multimode flows. Therefore, only the current scenario is reported.

```
*****
Report : constraint
Design : TEST1
Scenario(s): s1 s2
Version: C-2009.06
Date : Fri May 22 12:32:08 2009
*****
```

| Group (max_delay/setup) | Cost   | Weight | Weighted |          |
|-------------------------|--------|--------|----------|----------|
|                         |        |        | Cost     | Scenario |
| CLKIN_GROUP             | 10.07  | 1.00   | 10.07    | s1       |
| ENABLE                  | 372.89 | 1.00   | 372.89   | s1       |
| CLKIN_HCLK_GROUP        | 199.73 | 1.00   | 199.73   | s1       |
| CROSS_CLK_DOMAIN        | 467.99 | 1.00   | 467.99   | s1       |
| ATCLK                   | 171.16 | 1.00   | 171.16   | s1       |
| FREECLKIN               | 0.00   | 1.00   | 0.00     | s1       |
| CLKIN_GROUP             | 90.60  | 1.00   | 90.60    | s2       |
| ENABLE                  | 474.97 | 1.00   | 474.97   | s2       |
| CLKIN_HCLK_GROUP        | 166.88 | 1.00   | 166.88   | s2       |
| CROSS_CLK_DOMAIN        | 326.46 | 1.00   | 326.46   | s2       |
| ATCLK                   | 0.00   | 1.00   | 0.00     | s2       |
| FREECLKIN               | 0.00   | 1.00   | 0.00     | s2       |
| max_delay/setup         |        |        | 4404.52  |          |

| Group (critical_range) | Total Slack | Neg Endpoints | Critical  |                     |
|------------------------|-------------|---------------|-----------|---------------------|
|                        |             |               | Cost      | Scenario            |
| CLKIN_GROUP            | 0.70        | 1             | 0.24      | s1                  |
| ENABLE                 | 0.00        | 0             | 0.00      | s1                  |
| CLKIN_HCLK_GROUP       | 0.00        | 0             | 0.00      | s1                  |
| CROSS_CLK_DOMAIN       | 0.00        | 0             | 0.00      | s1                  |
| ATCLK                  | 0.00        | 0             | 0.00      | s1                  |
| FREECLKIN              | 0.00        | 0             | 0.00      | s1                  |
| CLKIN_GROUP            | 2.26        | 1             | 0.43      | s2                  |
| ENABLE                 | 0.00        | 0             | 0.00      | s2                  |
| CLKIN_HCLK_GROUP       | 0.00        | 0             | 0.00      | s2                  |
| CROSS_CLK_DOMAIN       | 0.00        | 0             | 0.00      | s2                  |
| ATCLK                  | 0.00        | 0             | 0.00      | s2                  |
| FREECLKIN              | 0.00        | 0             | 0.00      | s2                  |
| critical_range         |             |               | 1.03      |                     |
| Constraint             |             |               |           | Multi-Scenario Cost |
| multiport_net          |             |               | 0.00      | (MET)               |
| max_transition         |             |               | 45.28     | (VIOLATED)          |
| max_fanout             |             |               | 150.00    | (VIOLATED)          |
| max_capacitance        |             |               | 0.00      | (MET)               |
| max_delay/setup        |             |               | 4404.52   | (VIOLATED)          |
| critical_range         |             |               | 1.03      | (VIOLATED)          |
| max_area               |             |               | 714233.56 | (VIOLATED)          |

### **report\_tlu\_plus\_files**

This command reports the TLUPPlus files associations; it shows each minimum and maximum TLUPPlus and layer map file per scenario:

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

icc_shell> report_tlu_plus_files
Max TLU+ file: /snps/testcase/s1max.tlupplus
Min TLU+ file: /snps/testcase/s1min.tlupplus
Tech2ITF mapping file: /snps/testcase/tlupplus_map.txt
```

## **Multicorner-Multimode Script Example**

The following script shows the multicorner-multimode scenario capabilities in design placement, clock tree synthesis, and routing.

```
#.....path settings.....
set_app_var search_path ". $DESIGN_ROOT $lib_path/dbs \
$lib_path/mwlabs/macros/LM"
set_app_var target_library "stdcell.setup.ftyp.db \
stdcell.setup.typ.db stdcell.setup.typhv.db"
set_app_var link_library [concat * $target_library \
setup.ftyp.130v.100c.db setup.typhv.130v.100c.db \
setup.typ.130v.100c.db]
set_min_library stdcell.setup.typ.db -min_version \
stdcell.hold.typ.db

#.....Milkyway setup.....
#.....load design.....
create_scenario s1
set_operating_conditions -library $lib_path/dbs \
/stdcell.setup.typ.db:stdcell_typ WORST
set_tlu_plus_files -max_tluplus design.tlup \
-tech2itf_map layermap.txt
read_sdc s1.sdc

create_scenario s2
set_operating_conditions -library $lib_path/dbs \
/stdcell.setup.ftyp.db:stdcell_ftyp WORST
set_tlu_plus_files -max_tluplus design.tlup \
-tech2itf_map layermap.txt
read_sdc s2.sdc

.....
create_scenario cts
```

```
set_operating_conditions -library $lib_path/dbs \
    /stdcell.setup.ftyp.db:stdcell_ftyp WORST
set_tlu_plus_files -max_tluplus design.tlup \
    -tech2itf_map layermap.txt
read_sdc scts.sdc

set_cts_scenario cts
set_active_scenarios {s1 s2 ... }

place_opt
clock_opt
route_opt

report_qor
report_constraints
report_timing -scenario [all_scenarios]
```

# 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 re-running logic synthesis for the whole design.

This chapter describes the IC Compiler ECO flow in the following sections:

- [ECO Flow Overview](#)
- [ECO Recommended Flows](#)
- [ECO Flows and Hierarchical Designs](#)
- [ECO Flows and Multivoltage/UPF Designs](#)
- [ECO Limitations](#)
- [Removing Tie Cells](#)
- [Unconstrained ECO Flow](#)
- [Freeze Silicon ECO Flow](#)

## 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 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.
- Use the hierarchical engineering change order (HECO) file only when using a PrimeTime–IC Compiler flow. For details, see *IC Compiler ECO Flow Application Note*.

[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*



## ECO Flows and Hierarchical Designs

IC Compiler ECO flows support hierarchical design methodologies. However, you should note that while internal logics and ports on hierarchical blocks may be changed, deleting and creating of hierarchical blocks or ILMs themselves is not supported; the logical and physical hierarchy relationship must be maintained.

## ECO Flows and Multivoltage/UPF Designs

IC Compiler ECO flows fully support multivoltage and UPF designs. For any netlist changes implemented via `eco_netlist`, the associated multivoltage and UPF constraints will be updated accordingly. If a netlist object is unchanged during ECO, its associated multivoltage/UPF constraint data will be kept unchanged as well. If a netlist object is changed, the ECO process will update its relationship with multivoltage and UPF constraints accordingly. These constraints can be verified by using the `check_mv_design` command.

Currently, multivoltage ECO flows do not support multivoltage-specific cells, such as, level shifters.

---

## ECO Limitations

When placing spare cells, you must set the attribute `is_spare_cell` 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-13.

The `eco_netlist` command, used to read in the Verilog ECO netlist, does not support the following operations:

- Bus manipulation
- Clock tree synthesis (CTS)
- Scan chains

For `eco_netlist` usage details, see “[Creating ECO Changes and Updating the Design](#)” on page 15-6.

In addition to the `eco_netlist` method of ECO implementation, you can use Tcl commands to change your netlist. Note the following Tcl limitation:

For Tcl usage details, see “[Updating With Tcl Commands](#)” on page 15-8.

---

## Removing Tie Cells

Use the `remove_tie_cells` command if you want to remove any tie cells, which are preexisting in the design or inserted by the tool. The command replaces the original tie cell connections with 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 will do nothing. Tie cells are leaf cell instances. |

---

To reconnect a leaf pin and a hierarchical pin to tie-off, the tie net to be created or reused by `remove_tie_cells` is 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 to a hierarchical port, the tie net to be created by `remove_tie_cells` is an indirect tie net. A tie net named 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-3 Tie-Off Connection During remove\_tie\_cells*



## 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 next 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. From 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 execute 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.

Both the command line and the GUI method provide the following options:

- `eco_netlist -by_verilog_file verilog_filename`  
Use this option to specify your Verilog ECO file.
- `eco_netlist -compare_pg`  
Use this option to perform ECO changes on PG ports and nets.
- `eco_netlist -physical`  
Use this option to perform ECO changes on physical-only cells.
- `eco_netlist -freeze_silicon`  
Use this option to perform ECO changes in the freeze silicon mode.
- `eco_netlist -write_changes write_changes_file_name`  
Use this option to write the ECO changes that the command does to an output file.

For command details, see the `eco_netlist` man page.

## Power and Ground (PG) Support

If your netlist has PG ports and nets and you execute `eco_netlist -compare_pg`, 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 PG ports and nets and you execute the `eco_netlist` command without the `-compare_pg` option, the tool performs only the logical ECO. The golden Verilog file's PG data has no effect on the existing PG 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 execute 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**

Execute 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.

## **Updating With Tcl Commands**

IC Compiler provides the following Tcl commands that help you change your netlist. Three of these commands are available from the GUI: `insert_buffer`, `remove_buffer`, and `size_cell`. For command details, see the man pages.

#### **Note:**

To make netlist changes with hierarchical engineering change order (HECO) commands instead of Tcl commands, see SolvNet article 019642, “Mapping HECO Commands to IC Compiler Tcl Commands.”

### **Port Operations**

You can use Tcl commands to perform the following port operations:

- Add a new port or hierarchical port

`create_ports`: Creates ports in the current design or its subdesign

- Remove a port or hierarchical port

`remove_port`: Removes ports from the current design or its subdesign

- Change the local name of a port

`set_name`: Changes the port name local to the parent hierarchical module; it does not change the hierarchical path information

## Net Operations

You can use Tcl commands to perform the following net operations:

- Add a new flat or hierarchical net

`create_net`: Creates nets in the current design or its subdesign

- Remove a flat or hierarchical net

`remove_net`: Removes nets from the current design or its subdesign

- Rename a flat or hierarchical net

`change_names`: Renames nets in the current design or its subdesign

- Change the local name of a net

`set_name`: Changes the net name local to the parent hierarchical module; it does not change the hierarchical path information

## Connection Operations

You can use Tcl commands to perform the following connection operations:

- Connect a flat or hierarchical net with a port or hierarchical port instance

`connect_net`: Connects a specified net to specified pins or ports

- Disconnect a port or hierarchical port instance from a flat or hierarchical net

`disconnect_net`: Disconnects a specified net from specified pins or ports

## Instance Operations

You can use Tcl commands to perform the following instance operations:

- `create_cell`: Add a new flat or hierarchical cell instance

- `insert_buffer`: Add a new buffer

- `remove_cell`: Remove a flat or hierarchical cell instance

- `remove_buffer`: Remove a buffer

- `size_cell`: Resize a flat cell instance

- `set_name`: Changes the cell name local to the parent hierarchical module; it does not change the hierarchical path information

## Example

The following example uses Tcl commands to size cell “block1/U2” from reference “BUFX2” to “BUFX8” and insert a buffer with reference “BUFFX16”:

```
size_cell block1/U2 class/BUFX8
insert_buffer {block1/U2/Z} class/BUFFX16
```

---

## Updating Placement

In the unconstrained ECO flow, you need to legalize your ECO changes when you have performed the functional ECO by using the `eco_netlist` command.

To update placement, execute `legalize_placement -eco -incr`. The `-eco` option tells the tool to derive locations for newly added cells. The `-incr` option tells the tool to move as few cells as possible because most of the cells have already been placed and legalized.

### Example

```
.....
open_mw_lib MDBLIB
open_mw_cel top
eco_netlist -by_verilog_file eco.v
legalize_placement -eco -incr
```

---

## 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_eco` command to do the following operations:

- Perform the routing for broken nets, newly added nets, deleted nets, obsolete nets, and ripped-up unused sections of changed wires
- Attempt to preserve the critical routes and to fix the DRC violations
- Go through global routing, track assignment, and detail routing

The `route_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 `-auto`, `-search_repair_loop`, `-utilize_dangling_wires`, `-scope`, and `-reroute` options.

### Example

```
icc_shell> route_eco -auto -search_repair_loop 5 -utilize_dangling_wires\
           -scope local -reroute modified_nets_first_then_others
```

---

## 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. After each call of the `eco_netlist` command, run the `place_freeze_silicon` command (freeze ECO flow only) in order 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

The freeze silicon ECO flow consists of the following steps:

- [Inserting Spare Cells](#)
  - [Creating ECO Changes and Updating the Design](#)
  - [Finalizing the Freeze Silicon Flow](#)
  - [Updating Routing](#)
- 

### 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-12.

- 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 Using `insert\_spare\_cells`](#)” on page 15-16.

These methods are described in the following sections:

- [Inserting Spare Cells Using a Verilog Netlist](#)
- [Inserting Spare Cells Using `insert\_spare\_cells`](#)

## 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-14.

After you add your spare cells into the Verilog netlist and import the netlist into IC Compiler, the tool will distribute 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-4](#).

*Figure 15-4 Spare Cells Inserted in a Submodule*



In [Figure 15-4](#),

- 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 will not be 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 may place them in one tight location.
- Set the spare cells to the `soft-fixed` attribute once 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
```

If you do not apply this attribute, the `spread_spare_cells` command will 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 will place 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 will 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. It is highly recommended that you run the incremental legalization, using the following syntax:

```
legalize_placement -incr
```

## 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 Place 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 -incr
set_dont_touch [get_cells *spares*] true
set_attribute [get_cells *spares*] is_soft_fixed true
clock_opt
route_opt
...
```

[Example 15-2](#) shows how to manually place 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 Using `insert_spare_cells`

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, execute `insert_spare_cells -skip_legal` to skip legalized placement checking on the design. However, the command will still try to find a legal location for each spare cell even if the design has illegal placement.

When you insert spare cells in a given hierarchy by using the `-hier_cell` option, the spare cells will be 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 reference libraries, run the `insert_spare_cells` command with the `-num_cells` option. For example, if you want to insert two AND2 and three BUF3, execute `insert_spare_cells -num_cells {AND2 2 BUF3 3}`. Each one will be with legal placement if there is enough space. New spare cells from the same library will be spread as evenly as possible. This is the same as if you specify different library reference 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 reference. If you enable the `-num_cells` option, you do not need to specify the `-num_instances` and `-lib_cell` options.

For more details, see the command man pages.

[Example 15-3](#) shows how to use the `insert_spare_cells` command.

### *Example 15-3 Example of Running `insert_spare_cell`*

```
...
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. Tcl commands are not supported in the freeze silicon ECO flow.

Use the `eco_netlist` command to import your ECO netlist into IC Compiler. You can also import your ECO netlist with the GUI. From the GUI, choose ECO > ECO Netlist. The ECO by Verilog dialog box appears. The default cell is the current cell. IC Compiler also provides several Tcl commands that help you change your netlist.

For more information, see “[Updating With a Verilog Netlist](#)” on page 15-7 and “[Updating With Tcl Commands](#)” on page 15-8.

---

## Finalizing the Freeze Silicon Flow

For the freeze silicon flow, you can run `eco_netlist` multiple times to meet the design need. However, you have to run `place_freeze_silicon` after each call of `eco_netlist`. Otherwise, the spare cell book will be confused as multiple ECOs overlay with each other.

---

## 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_eco` command to do the following operations:

- Perform the routing for broken nets, newly added nets, deleted nets, obsolete nets, and ripped-up unused sections of changed wires
- Attempt to preserve the critical routes and fix the DRC violations
- Go through global routing, track assignment, and detail routing

For more information, see “[Updating Routing](#)” on page 15-10.



# 16

## Sign-Off Driven Design Closure

---

This chapter describes how to reduce timing violations during final sign-off by using IC Compiler sign-off driven design closure.

In general, the implementation engine (IC Compiler) and the sign-off engine (Star-RCXT and PrimeTime) are well correlated with each other. However, small variations can occur because

- PrimeTime and Star-RCXT, as sign-off tools, are more accurate.
- PrimeTime has reduced signal integrity pessimism.
- IC Compiler may have implementation margins.
- The implementation engine (IC Compiler) may have fewer corners.

These differences can cause timing violations during final sign-off. To reduce violations, you should use IC Compiler sign-off driven design closure. In this flow, IC Compiler automatically runs the sign-off tools (PrimeTime and Star-RCXT) 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 sign-off driven design closure in the following sections:

- [Sign-Off Driven Design Closure Overview](#)
- [Key Features](#)
- [Sign-Off Driven Design Closure Methodology](#)

- [Usage Guidelines](#)
- [Troubleshooting and Problem Solving](#)

---

## Sign-Off Driven Design Closure Overview

The starting point for IC Compiler sign-off driven design closure is a completely routed database from IC Compiler. This flow uses two key commands:

- `signoff_opt` that runs analysis and optimization and is the basis of the automatic flow. For details, see “[Automatic IC Compiler Sign-Off Driven Design Closure](#)” on page 16-5.
- `run_signoff` that runs analysis and is the basis of the manual flow. For details, see “[Manual IC Compiler Sign-Off Driven Design Closure](#)” on page 16-7.

During the analysis process, IC Compiler automatically runs Star-RCXT to perform a complete parasitic extraction on the database and stores the results as an SBPF (Synopsys Binary Parasitic Format) file which is transparent to the user. 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.

Running IC Compiler sign-off 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-10.

---

## Key Features

IC Compiler sign-off driven design closure supports the following key features:

- Multicorner-Multimode (MCMM)

Sign-off driven design closure supports multicorner-multimode technology (MCMM). When you use sign-off with this technology, IC Compiler runs PrimeTime distributed multi-scenario analysis (DMSA) and multiple Star-RCXT 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 sign-off multicorner-multimode technology, follow the guidelines in “[Multicorner-Multimode Guidelines](#)” on page 16-15.

- Unified Power Format (UPF) support

IC Compiler sign-off driven design closure supports designs with UPF constraints automatically. IC Compiler will automatically pass UPF constraints to PrimeTime for analysis when you execute either `run_signoff` or `signoff_opt`. The `signoff_opt` flow with UPF constraints is supported for both multicorner-multimode (MCMM) and best

case/worst case (BCWC) 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

IC Compiler sign-off driven design closure can use either Zroute or the classic router for ECO route. To invoke Zroute during `signoff_opt`, execute `set_route_mode_options -zroute true`.

- Bottleneck analysis support

IC Compiler sign-off 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 sign-off driven design closure supports the PrimeTime path-based analysis feature. To enable this feature, execute `run_signoff -path_based_analysis` or `signoff_opt -path_based_analysis`.

- Advanced on-chip variation modeling (AOCVM) and on-chip variation (OCV) support

On-chip variation (OCV) is supported in `signoff_opt`. 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
```

For AOCVM support details, see “[General Guidelines](#)” on page 16-11.

- Customized PrimeTime and Star-RCXT settings

When you use IC Compiler sign-off driven design closure, IC Compiler runs PrimeTime and Star-RCXT automatically using each tool’s default settings. If you want to customize these settings, use the methods described in “[PrimeTime and Star-RCXT Customizing Options](#)” on page 16-18.

- PrimeTime and Star-RCXT correlations

To check the environment variables, Tcl commands, SDC commands in both IC Compiler and PrimeTime, and the extraction settings in both IC Compiler and Star-RCXT for a routed design, execute `run_signoff` with the `-correlation` option.

For more information, see “[PrimeTime and Star-RCXT Correlations](#)” on page 16-22.

---

## Sign-Off Driven Design Closure Methodology

This section describes the IC Compiler sign-off driven design closure methodology which consists of the following topics:

- [Automatic IC Compiler Sign-Off Driven Design Closure](#)
- [Manual IC Compiler Sign-Off Driven Design Closure](#)

---

### Automatic IC Compiler Sign-Off 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. Set up the PrimeTime and Star-RCXT tools.

Use the `set_primestime_options` and `set_starrcxt_options` commands to specify global options. You can also use the GUI by choosing Signoff > Optimize. The Signoff Optimize dialog box appears. You can verify your options by using the `report_primestime_options` and `report_starrcxt_options` commands. For details, see “[PrimeTime and Star-RCXT Version Requirements](#)” on page 16-10 and “[General Guidelines](#)” on page 16-11.

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_host` command. You can verify your host options by using the `report_distributed_host` command.
- 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-15.

3. Execute `signoff_opt`.

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_constraints` 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 Sign-Off Driven Design Closure](#)” on page 16-7.

[Example 16-1](#) shows a sample script.

*Example 16-1 Using signoff\_opt*

```
open_mw_cel post_route_opt

set_primate_time_options
set_starrcxt_options

report_primate_time_options
report_starrcxt_options
signoff_opt

report_timing
report_constraints -all_violators

run_signoff -signoff_analysis false

save_mw_cel -as signoff
```

[Example 16-2](#) shows a sample script that uses multiple scenarios.

*Example 16-2 Using signoff\_opt With Multiple Scenarios*

```
set pt_dir /tools/primetime/C-2009.06/amd64/syn/bin
set star_dir /tools/star_rcxt/C-2009.06/amd64_star-rcxt/bin

# global settings
set_primate_time_options -exec_dir $pt_dir
set_starrcxt_options -exec_dir $star_dir

report_primate_time_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_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
signoff_opt

```

## Manual IC Compiler Sign-Off Driven Design Closure

Manual IC Compiler sign-off 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, do the following steps:

1. Set up the PrimeTime and Star-RCXT tools.

Use the `set_primestime_options` and the `set_starrcxt_options` commands to specify global options. You can also use the GUI by choosing Signoff > Analysis. The Run Signoff dialog box appears. You can verify your options by using the `report_primestime_options` and `report_starrcxt_options` commands. For details, see “[PrimeTime and Star-RCXT Version Requirements](#)” on page 16-10 and “[General Guidelines](#)” on page 16-11.

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_host` command. You can verify your host options by using the `report_distributed_host` command.
- 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-15](#).

3. Execute `run_signoff`.

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_constraints` 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 sign-off 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-24](#).

6. Run incremental legalization and incremental routing. This will legalize any newly added cells to legal locations and do ECO routing.

7. Run incremental analysis.

Use the `run_signoff -incremental` command. From 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 a sample script for executing `run_signoff`.

*Example 16-3 Using run\_signoff*

```
set pt_dir /tools/primetime/C-2009.06/amd64/syn/bin
set star_dir /tools/star_rcxt/C-2009.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_primestime_options -exec_dir $pt_dir -sdc_file $SDC
report_starrcxt_option
report_primestime_options
run_signoff
report_qor
report_timing
size_cell ...
insert_buffer ...
legalize_placement -eco
route_eco -auto
run_signoff -incremental
report_qor
```

```
report_timing
```

**Example 16-4** shows a sample script for a design that uses multiple scenarios.

**Example 16-4 Using run\_signoff With Multiple Scenarios**

```
set pt_dir /tools/primetime/C-2009.06/amd64/syn/bin
set star_dir /tools/star_rcxt/C-2009.06/amd64_star-rcxt/bin

open_mw_cel post_route_opt

# global settings
set_primestime_options -exec_dir $pt_dir
set_starrcxt_options -exec_dir $star_dir
    $map_file

report_primestime_options
report_starrcxt_options

add_distributed_hosts -target primetime -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_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_constraints -all_violators

get_alternative_lib_cells
size_cell
insert_buffer
```

```
legalize_placement -eco  
route_eco -auto  
  
run_signoff -incremental  
report_timing  
  
report_qor  
  
run_signoff -signoff_analysis false  
  
save_mw_cel -as final
```

---

## Usage Guidelines

Before running IC Compiler sign-off driven design closure, you need to be familiar with the following usage guidelines:

- [PrimeTime and Star-RCXT Version Requirements](#)
- [Entry Requirements for IC Compiler Sign-Off Driven Design Closure](#)
- [General Guidelines](#)
- [Scenario Differences Between IC Compiler and PrimeTime](#)
- [Multicorner-Multimode Guidelines](#)
- [PrimeTime and Star-RCXT Customizing Options](#)
- [PrimeTime and Star-RCXT Correlations](#)
- [Rail Voltage Information Update](#)

These guidelines are described in the next sections.

---

## PrimeTime and Star-RCXT Version Requirements

For best results, use the following sign-off tools when running IC Compiler sign-off driven design closure:

- PrimeTime version C-2009.06 or later

Default options of PrimeTime and the PrimeTime SI default filters are used in the sign-off driven design closure flow. If you want to use non-default settings, see “[PrimeTime and Star-RCXT Customizing Options](#)” on page 16-18.

- Star-RCXT version C-2009.06 or later

Default options of Star-RCXT are used in the sign-off driven design closure flow. These include MODE 200, accept Star-RCXT run directory, operating temperature – ON, topological reduction – ON, and writing subnode information – ON. If you want to use non-default options, see “[PrimeTime and Star-RCXT Customizing Options](#)” on [page 16-18](#).

---

## Entry Requirements for IC Compiler Sign-Off Driven Design Closure

When you use IC Compiler sign-off 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 will 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 will issue an error message and exit 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 will issue an error message and exit the `signoff_opt` command, unless you specify the `-ignore_design_readiness` option.
- The number of logic DRC violations should be less than 0.1 percent of the total nets or less than 1000 nets. Otherwise, the tool will issue a warning message.
- The number of violating paths should be less than 1000; otherwise, the tool will generate a warning.
- Violating endpoints should be less than 1000; otherwise, the tool will generate a warning.

You might not get the best QoR if your design does not meet the above requirements when you execute `signoff_opt`. To prevent the tool from exiting with an error message, execute `signoff_opt -ignore_design_readiness`.

---

## General Guidelines

General IC Compiler sign-off driven design closure guidelines are as follows:

1. Sign-off driven design closure requires additional memory because `signoff_opt` 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 will 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 will need additional memory. For details, see “[Multicorner-Multimode Guidelines](#)” on page 16-15.

2. To improve QoR, you can enable the tool to fix static noise by executing `set_si_options -static_noise TRUE`. When you use this command, the following commands will be based on PrimeTime after `run_signoff` and `signoff_opt`:
  - `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, execute `run_signoff -path_based_analysis` or `signoff_opt -path_based_analysis`.
4. To achieve better correlation with the stand-alone sign-off tools, set Star-RCXT REDUCTION to YES. For the best QoR, IC Compiler, by default, sets Star-RCXT REDUCTION to TOPO when you execute `signoff_opt`.
5. After you run `signoff_opt`, you need to re-insert the filler cells. Any filler cells that overlap with new or changed cells are automatically removed during `signoff_opt`. Generally, it is best to run `signoff_opt` before chip finishing. But, if there is a significant timing impact during the chip finishing process, you need to run `signoff_opt` after chip finishing.
6. When using metal fill, you should execute `signoff_opt` after metal fill if the metal fill has significant timing impact; otherwise, you can execute `signoff_opt` before metal fill. When metal fill is done before `signoff_opt`, use the following guidelines:
  - a. Metal fill must be done in the FILL view, not in the CEL view. To do this, use the `-out design_name.FILL` option of the `insert_metal_filler` command:

```
insert_metal_filler ... -out design_name.FILL
```

- b. Metal fill must be made floating. Notice that the FILL view only supports floating metal filling. To do this, use the `-tie_to_net` option of `insert_metal_filler` as follows:

```
insert_metal_filler ... -tie_to_net none
```

- c. Exit `signoff_opt` after ECO routing. To do this, run `signoff_opt` with `-only_psyn` as follows:

```
signoff_opt -only_psyn
```

- d. Remove overlap between signal routes and fill metals. To do this, manually update metal fill by using `trim_fill_eco` as follows:

```
trim_fill_eco -input design_name.FILL -output design_name.FILL
```

- e. Repeat Step (c) and (d) as needed.

When you use this flow, you lose the capability to run the incremental Star-RCXT and incremental PrimeTime features of `signoff_opt` because in each iteration, full extraction and full timing analysis will be performed.

7. To exit the PrimeTime timing engine and return to the IC Compiler timing engine, execute `run_signoff -signoff_analysis false`.

8. By default, the tool always runs incremental extraction and incremental PrimeTime analysis if possible. If you want to force full extraction, use the `-full_extract` option. If you want 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 `-full_extract`. When you use `-full_analysis` without `-full_extract`, the tool runs Star-RCXT with incremental extraction and creates a full netlist output. A warning is issued for runtime increases.

9. The `signoff_opt` command supports the IC Compiler ILM flow. However, the Star-RCXT and PrimeTime SI runs will be flat. If you are running `signoff_opt` on a hierarchical design in which its top level has ILM blocks, you will get runtime benefit and memory reduction from the IC Compiler side, not from the Star-RCXT or PrimeTime SI side.

10. If you execute `run_signoff` prior to `signoff_opt`, you can use `signoff_opt -skip_initial_analysis` 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 nothing is changed between `run_signoff` and `signoff_opt`. Note that you will still need to run Star-RCXT to create the netlist output (but no actual extraction is needed).

11. IC Compiler sign-off driven design closure supports the advanced on-chip variation modeling (AOCVM) feature in PrimeTime. You enable AOCVM by using the `-aocvm` option with `run_signoff` or `signoff_opt`. You must use a saved session or the `-specific_file` option when running IC Compiler sign-off driven design closure with AOCVM. See “[PrimeTime and Star-RCXT Customizing Options](#)” on page 16-18.

Use `report_aocvm` to report AOCVM related information. For timing reports, use `report_timing -aocvm` after `run_signoff`. Note that this is PrimeTime syntax. The `report_timing` command from IC Compiler does not have the `-aocvm` option.

12. You cannot change the timing constraints after you execute the `run_signoff` command.

To change timing constraints, exit `run_signoff` by using `run_signoff -signoff_analysis false`, as shown below:

```
run_signoff  
report_timing  
run_signoff -signoff_analysis false  
set_false_path  
...
```

---

## Scenario Differences Between IC Compiler and PrimeTime

When creating scripts for IC Compiler sign-off 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_scenario` 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 `set_active_scenario` instead.
- Each PrimeTime process reads only one corner for `read_parasitics`.
- IC Compiler invokes multi-corner `read_parasitics`.

After you execute the IC Compiler `current_scenario` command, most reporting commands and the `read_parasitic` command are only applied 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 execute the PrimeTime `current_scenario` command, all commands are applied to the specified current scenario. Even optimization commands, such as `size_cell`, will only change the given scenarios. The PrimeTime `current_scenario` command supports the following options:

- `current_scenario -all`
- `current_scenario {Func Test}`

After you execute the IC Compiler `run_signoff` command, the `current_scenario` behavior will be changed to update both IC Compiler and PrimeTime.

- `current_scenario -all`

No change will occur to the current scenario in IC Compiler.

Command focus is changed to include all scenarios in PrimeTime distributed multi-scenario analysis.

- `current_scenario Func`

Executing `current_scenario Func` changes the current scenario to Func in IC Compiler.

Executing `current_scenario Func` changes the command focus to Func in PrimeTime distributed multi-scenario analysis.

---

## Multicorner-Multimode Guidelines

Use the following guidelines when running IC Compiler sign-off driven design closure with multicorner-multimode technology:

1. Using IC Compiler sign-off driven design closure in multicorner-multimode requires additional memory space. Use the Unix `top` command to determine the memory size. 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 \text{ is } \geq 4$$

This requirement only considers the IC Compiler process. PrimeTime and Star-RCXT 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. Not enough memory will cause excessive memory swap and increase 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 will fail. The following example uses the “-b y” option.

```
add_distributed_hosts -farm grd \
-setup_path ... -num_of_hosts 8 \
-options {-cwd -P bnrmal -b y -l arch=glinux,cputype=amd64}
```

These options instruct 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 sign-off driven design closure uses a distributed processing environment. To set up this environment, you need to understand that, by default, IC Compiler sign-off driven design closure uses the remote shell (`rsh`) program to invoke Star-RCXT and PrimeTime processes. To use the C-shell (`csh`), create a `runcmd` file as follows:

```
#!/bin/csh -f
$argv &
```

Then specify the `runcmd` file with `add_distributed_hosts` as follows:

```
add_distributed_hosts -submission_script runcmd ...
```

To use the secure shell protocol (`ssh`), use the `-enable_ssh` option as follows:

```
add_distributed_hosts -enable_ssh
```

Note that the secure shell protocol (`ssh`) must be configured without using an explicit user name and password. This is a PrimeTime distributed multi-scenario analysis limitation.

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 sign-off driven design closure starts running PrimeTime distributed processes as soon as a single host becomes available. Other hosts will start PrimeTime processes as soon they become available.

For example, if you define 15 hosts by using the following command:

```
add_distributed_hosts -farm lsf -num_of_hosts 15
```

IC Compiler will start your PrimeTime analysis as soon as the first host becomes available from LSF. Additional PrimeTime processes will 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 sign-off 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 execute 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 automatically calls `get_dominant_scenario` 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)
```

8. After you run the initial analysis (`run_signoff`),

- Determine the dominant scenario by using `get_dominant_scenario`.
- To manually reduce the number of scenarios, specify the active scenarios by using `set_active_scenario`.

9. IC Compiler does not support the PrimeTime `current_session` command. Use `set_active_scenario` instead.

10. All active scenarios in IC Compiler, that is, those specified by `set_active_scenario`, will be analyzed in PrimeTime distributed multi-scenario analysis. Inactive scenarios in IC Compiler will not be 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 Star-RCXT.

11. 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_tlup max.tlup -min_tlup min.tlup
set_min_library -min fast.db slow.db
set_operating_conditions -analysis_type bcwc
```

You need to replace this scenario with two scenarios when running IC Compiler sign-off driven design closure with multicorner-multimode technology:

- Scenario worst case (WC)

```
set_tlu_plus_file -max_tlup max.tlup
# Use slow.db as the link_library
set_operating_conditions -analysis_type on_chip_variation
```

- Scenario best case (BC)

```
set_tlu_plus_file -max_tlup min.tlup
# Use fast.db as the link_library
set_operating_conditions -analysis_type on_chip_variation
```

12. After you execute `run_signoff`, you cannot activate a scenario that was inactive before you executed `run_signoff`. If you try to do so, IC Compiler will issue a PSYN-432 warning message.

13. IC Compiler disables `create_scenario` and `remove_scenario` after you execute `run_signoff` or `signoff_opt`. To enable these commands, quit the sign-off mode by executing the following command:

```
run_signoff -signoff_analysis false
```

## PrimeTime and Star-RCXT Customizing Options

When you use IC Compiler sign-off driven design closure, IC Compiler runs PrimeTime and Star-RCXT automatically 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_primetetime_options` command
- `set_starrcxt_options -option_file`
- `set_starrcxt_options -mode`

These methods are described in the following paragraphs.

### Saved Sessions

To create a saved session in PrimeTime, use the `save_session` command in PrimeTime and specify this saved session file name by using the `-max_image` option or the `-min_image` option of the `set_primetetime_options` command, as shown in [Example 16-5](#). If you want to verify your option settings, use the `report_primetetime_options` command, as shown in [Example 16-6](#).

You must add the following command at the beginning of the PrimeTime script in order to generate a PrimeTime saved session for `signoff_opt`:

```
set_program_options -enable_eco
```

Without this command, IC Compiler cannot use the saved session for incremental analysis.

Starting with version A-2007.12-SP4, `signoff_opt` will check if the specified PrimeTime saved session has ECO enabled. If ECO is not enabled, IC Compiler will generate a PSYN-441 warning and behave as if `-only_psyn` is specified.

To use a saved session of Star-RCXT, specify the run directory name in the `set_starrcxt_options`, as shown in [Example 16-5](#). If you want to verify your option settings, use the `report_starrcxt_options` command, as shown in [Example 16-6](#).

*Example 16-5 Specified Saved PrimeTime and Star-RCXT Runs*

```
set SDC pt.sdc
set pt_dir /tools/primetime/C-2009.06/amd64/syn/bin
set star_dir /tools/star_rcxt/C-2009.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_primetetime_options -exec_dir $pt_dir -sdc_file $SDC \
                        -max_image pt_max \
                        -min_image pt_min
report_starrcxt_option
report_primetetime_options
```

*Example 16-6 Report Saved Sessions*

```
icc_shell> report_starrcxt_option
```

```
*****
Report : StarRCXT_options
Design : RISC_CORE
Version:
Date   :
*****

StarRCXT exec dir: /tools/star_rcxt/2009.06/C-2009.06/amd64_star-rcxt/bin
StarRCXT max nxtgrd file: /libraries/tcbn90g/tsmcn90_7lm.nxtgrd
StarRCXT min nxtgrd file: /libraries/tcbn90g/tsmcn90_7lm.nxtgrd
StarRCXT map file: /libraries/tcbn90g/tcbn90_7lm.map
StarRCXT max image: star_max
StarRCXT min image: star_min

icc_shell> report_primestime_options*
*****
Report : PrimeTime_options
Design : RISC_CORE
Version:
Date   :
*****
PrimeTime exec dir: / tools/primetime/C-2009.06/amd64/syn/bin
PrimeTime SDC file: /home/signoff/risc_core/pt.sdc
PrimeTime max image: pt_max
PrimeTime min image: pt_min
```

### **Executing set\_primestime\_options –common\_file**

When you use `set_primestime_options -common_file`, one file is used for all PrimeTime runs (BC/WC, 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 (PBA) variables
- All report variables
- All timing variables except `timing_save_pin_arrival_and_slack`
- All signal integrity (SI) 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`

## **Executing set\_primestime\_options –specific\_file**

When you use `set_primestime_options -specific_file`, you can have up to two files {`max_file` `min_file`} in best-case/worst-case (BC/WC) mode. The second file is used for the PrimeTime minimum corner in BC/WC analysis. If only one file is specified, the same file will be used for both corners. This file is sourced into PrimeTime after the netlist loads. You can have one specific file per corner when using multicorner-multimode technology in the IC Compiler sign-off driven design closure flow.

Only these 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`

## **Executing set\_starrcxt\_options –option\_file**

To customize Star-RCXT options, use `set_starrcxt_options -option_file`. This is the file you create that contains a subset of the Star-RCXT command file.

Note:

The commands listed below are reserved and will be 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

### **Executing set\_starrcxt\_options -mode**

You can specify a Star-RCXT mode by executing `set_starrcxt_options -mode`. The valid values are 100, 150, 200, and 400. The default value 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 `set_starrcxt_options -option_file`.

---

## **PrimeTime and Star-RCXT Correlations**

Execute `run_signoff` with the `-correlation` option to check if there are any variables that may impact the signoff correlation, including

- The environment variables, Tcl commands, SDC commands in both IC Compiler and PrimeTime
- The extraction settings in both IC Compiler and Star-RCXT for correlation

Here is the syntax:

```
run_signoff -correlation {setup spef_out}
```

- `setup`: When enabled, the command checks the following correlation settings:
  - Clock gating

- Delay calculation model
- Library consistency between IC Compiler and PrimeTime
- Operating conditions
- SDC files (only partial)
- Setup consistency between IC Compiler and Star-RCXT
- Timing and SI variables
- TLUPlus and .nxtgrd files

When finished, the command will generate a correlation report and an IC Compiler Tcl file for each scenario to correct the settings which may have correlation issues.

- `spef_out`: For each corner, generate two parasitic files in the SPEF format, one from IC Compiler and one from Star-RCXT. A sample script will also be generated to run the myBingo utility to compare the SPEF files and to check the parasitics correlation between IC Compiler and Star-RCXT. Examine the sample script and modify it to match the design technology.

When analysis is finished, execute `run_signoff -signoff_analysis false` to exit from the sign-off mode and source the script file generated to correct the reported correlation setting issues. You should complete the correlation-setting correction before signoff driven design closure flow.

### Multicorner-Multimode (MCMM) Support

If the design being analyzed is a multicorner-multimode (MCMM) design, executing `run_signoff -correlation` generates all the related reports and script files for each scenario.

When the correlation on a multicorner-multimode design is complete, a correlation report directory will be created, called `correlation_report.<time_stamp>`, in which all the correlation reports reside in the following structure:



---

## Rail Voltage Information Update

During the sign-off 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 PrimePower or PrimeRail.

To update rail voltage information for cells that are newly inserted to the netlist without actually invoking PrimePower or PrimeRail, execute `signoff_opt -update_rail_voltage`. The option is supported in both UPF and non-UPF flows.

Because `signoff_opt` does not support PrimePower and PrimeRail directly, you need to use either 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 will be 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 executing `run_signoff -check_only`. In this case you do not actually invoke Star-RCXT and PrimeTime.
2. If IC Compiler sign-off driven design closure is producing poor QoR, your design may not be meeting the entry requirements. For detailed requirements, see “[Entry Requirements for IC Compiler Sign-Off Driven Design Closure](#)” on page 16-11.
3. If your IC Compiler sign-off driven design closure runs are excessively slow, you may not have enough memory. For memory requirements, see “[Usage Guidelines](#)” on page 16-10 and “[Multicorner-Multimode Guidelines](#)” on page 16-15.
4. If you are getting warnings about not being able to load the PrimeTime or Star-RCXT tools, you may not be using the correct Star-RCXT or PrimeTime versions or platforms.
5. If you are having library consistency problems, do the following step:
  - Use `get_libs *` or `write_link_library` before `signoff_opt` to ensure library consistency between IC Compiler and PrimeTime.

6. After you save the Milkyway CEL view and reload it, you may have inconsistencies in your timing reports among IC Compiler, PrimeTime, and Star-RCXT. If this happens, execute `run_signoff` again. The timing in IC Compiler is different from the timing in PrimeTime and Star-RCXT, shown by the previous `run_signoff` session, until you run `run_signoff` 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 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 the online Help.

This appendix contains the following sections:

- [Viewing a Design](#)
- [Visualizing the Physical Design](#)
- [Analyzing the Physical Design](#)
- [Examining Routing and Verification Errors](#)
- [Editing the Physical Layout](#)
- [Analyzing Timing Paths](#)

---

## 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-24](#).

- 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-74](#).

- 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 Design and Path Schematics” on page A-76](#) and [“Viewing the Fanout or Fanin Schematic” on page 7-112](#).

- 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-111](#).

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

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 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:

- [Selecting a Mouse Tool](#)
- [Previewing Objects in a Layout View](#)
- [Selecting Objects](#)
- [Highlighting Objects](#)
- [Viewing Object Information](#)
- [Magnifying and Traversing the Design](#)
- [Viewing and Editing Object Properties](#)
- [Exploring the Design Hierarchy](#)
- [Selecting and Viewing Timing Paths](#)
- [Viewing Reports](#)
- [Searching for Objects by Name](#)
- [Saving an Image of a Window or View](#)

For details about drawing rulers, see “[Drawing Rulers](#)” on page [A-26](#).

---

## 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                                                                               | Do this mouse 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. |

**Table A-1 Mouse Tools**

| To perform this task                                                                                | Do this mouse 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.  |
| 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-64](#).

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 IC Compiler online 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.

You can control the location where the InfoTip appears. 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.

*Figure A-3 Selection Tool Options on Mouse Tool Options Toolbar*



You can select objects by doing any of the following:

- To select an object, click the object.

To select additional objects, press the Control key and click the other objects. To remove objects from the selection, press the Shift key and click the objects.

- To select all objects in a rectangular area, select the Smart option or the Rectangle option, and drag the pointer diagonally to define a rectangular box around the objects. By default, the region must completely encompass all the objects you need to select.
- If you want to select objects that are only partially inside the region, select the rectangle intersect Enable option.
- If you select the Rectangle option, you can define the region by either dragging the pointer or by clicking two diagonally opposite corners. This allows you to click one corner, and then use the zoom and pan tools to magnify or traverse a large area of the design before clicking the other corner of the region.
- To select objects in a line, select the Line option, and click or drag the pointer to define a straight line over at least one edge of each object you need to select.

You can set the Selection tool to automatically add to or remove objects from the current selection, instead of replacing them, by selecting Add or Remove in the Selection list.

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](#).

---

## Highlighting Objects

You can interactively highlight objects in the active layout or schematic view by using the Highlight tool. In a layout view, you can set options to highlight the object's net connections and to display information about the 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, yellow by default, and cross-highlights the object in all other open layout and schematic views.

To enable the Highlight tool in the active view,

1. Click the  button on the Mouse Tools toolbar (or choose View > Mouse Tools > Highlight Tool).

When you enable the Highlight tool in a layout view, the Highlight Tool options appear on the Mouse Tool Options toolbar.

2. (Optional) Set options on the Mouse Tool Options toolbar as needed.

- 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.

You can use the Highlight toolbar and the Highlight menu to change the highlight color, to add or remove highlighting on selected objects or timing paths.

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](#).

You can use highlighting to identify design objects or physical constraints in the active layout view. You can highlight individual objects or objects within a region. You can also toggle (add or remove) highlighting on objects. If you select the “Include nets of chosen objects” option on the Highlight Tool Options panel, flylines appear in the highlight color to show the net connections for the highlighted objects.

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*



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 in the active layout view 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** tool bar, 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.
  - 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, Control-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.

You can select or deselect options on the Highlight Tool Options panel at any time when the Highlight tool is active. If you need to close the panel, move the pointer over the raised bars on one edge of the panel, then right-click and choose Close. The panel is closed automatically when you change to a different mouse tool.

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-67.

---

## 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.

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](#).

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 (white by default), and the information for the object appears on the Query panel. You can select and copy text on the panel, but you cannot edit it.

Note:

Query highlighting has thinner lines than selection highlighting.

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.

In a layout view, you can display information about a selected object by pressing the F1 key. The object information appears on the Query panel. If multiple objects are selected, the information for the next object in the selection list appears on the Query panel each time you press F1.

You can also display information about a visible cell, port, or pin in the active layout view by selecting it. When you select an object, the object’s name, the x- and y-coordinates for the origin of the object’s placement bounding box, and the width and height for a cell) appear in the status bar.

For more details about the Query tool, see the IC Compiler online 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-6](#), 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-6 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-7](#), 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-7 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 online 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.

---

## Viewing and Editing Object Properties

You can use the Properties dialog box to view property values for selected designs, design objects, or timing paths. The Properties dialog box lists object properties in a table with two columns for property names and property values and a row for each property. The properties you can view include object names, attribute values, and certain timing and placement values. The list of properties differs depending on the type of object you select.

Some object properties are attributes that you can edit by changing the value (if one is already assigned), applying a value (if one is not already assigned), or removing the attributes. A bold border in the value column indicates an editable property value.

To display object properties,

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. 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.

For some object types, you can control which types of properties appear in the table by selecting an option in the “Attribute group” list. By default, all the properties for an object appear in the table.

- For cells, you can display basic, placement, timing, user, or all properties.
- For other objects, you can display basic, user, or all properties.

You can also display the properties displayed by InfoTips in a layout view.

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.

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 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 appears empty.

For more information about using the Properties dialog box, see IC Compiler online Help.

---

## Exploring the Design Hierarchy

Use the hierarchy browser to examine the design hierarchy and to display information about the hierarchical cells and logic blocks in the design. You can select hierarchical cells, leaf cells, or other objects you want to examine in a layout view or schematic view, or with other analysis tools.

If you are not familiar with a design, you can explore the hierarchy to understand its structure and gather information about the design objects (cells, ports, pins, and nets) in a cell or block. You can also use the hierarchy browser to

- Highlight cells or blocks (and their leaf cells) with different colors in both the hierarchy browser and the layout view
- Perform floorplan tasks such as creating plan groups and importing black box cells
- Display design schematics of hierarchical cells

To open the hierarchy browser, do one of the following:

- In the layout window, choose Partition > New Hierarchy Browser View.
- In the main window, choose Hierarchy > New Hierarchy Browser View.

The view window consists of two panes, with an instance tree on the left and an object table on the right. The instance name of the top-level design appears at the top of the instance tree. You can use the split bars between the panes to increase or decrease the relative widths of the instance tree and the object table.

The hierarchy browser indicates cell types (standard cells, macros, ILMs, and so forth) by displaying icons beside the cell names. If you highlight cell hierarchies with colors, the hierarchy browser displays the cell colors on the icons.

You can explore the complete hierarchical structure of the design and observe how many hierarchical blocks are present. To explore the design hierarchy, you can

- Click the expansion button (plus sign) next to an instance name to expand the instance tree, showing the names of the subblocks at the next level in the hierarchy
- Select an instance in the instance tree to display leaf cell information in the object table  
Shift-click or Control-click instance names to select combinations of instances. The cell information includes cell instance names, cell types, and cell reference names.

- 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 filter the cell names in the object table by cell type: hierarchical, hard or soft macro, plan group, black box, or ILM.

Note:

Although you can view and filter the names of objects inside a soft macro, you cannot select the objects or perform any operations on them.

You can use the arrow keys to navigate the instance tree or the object table and to expand or collapse levels in the instance tree. You can also sort, resize, and filter the columns in the object table.

For more information about the hierarchy browser, see IC Compiler online Help.

---

## 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.

---

## 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.

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.

---

## 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 online 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 quickly 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 ILM Blocks](#)
  - [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 “Using the Overview Panel” topic in IC Compiler online 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 Escape 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 enable 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 “Changing Cell Orientations” in the IC Compiler Online Help.

---

## Examining ILM Blocks

An ILM is a structural model of a circuit that is modeled as a smaller circuit representing the interface logic of the block. In an ILM block, the gate-level netlist for the block is modeled by another gate-level netlist that contains only the interface logic of the block. ILMs contain cells whose timing affects or is affected by the external environment of a block.

If your design contains ILMs, you should visually check the ILM blocks for correct site locations when you validate the preplacement floorplan. You should also visually check for ILM blocks in highly congested areas when you examine the congestion map.

You can expand ILM blocks to display the objects (cells, ports, pins, nets, and so forth) inside the blocks. When ILM blocks are expanded, you can use layout window analysis and editing tools to analyze and modify the placement of cells within the blocks.

To expand ILM blocks,

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 ILM expanding cell type option is selected.
5. Click Apply.

To collapse (close) ILM blocks,

1. Set 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 deselect the ILM expanding cell type option.
2. Click Apply.

You can control the visibility and selection of objects within ILM blocks by using the same View Settings panel options you use for other objects in the layout window.

---

## 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.

---

## 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 view or object (for cells, ports, pins, or nets) display options

[Figure A-8](#) 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-8 View Settings Panel for Objects in Layout Views*



[Figure A-9](#) 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-9 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 on using the View Settings panel, see the IC Compiler online 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, Control, or Alt), or a combination of these keys as shown below.

#### **Basic strokes made without pressing Shift, Control, or Alt**



#### **Basic strokes made while pressing Control**



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](#)
  - [Exploring 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-10](#), 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-10 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 IC Compiler online 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.

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 net connections are displayed, the connections are also highlighted, and they remain highlighted when the object is no longer selected.

For more information, see IC Compiler online Help.

## Using Visual Modes

Visual modes are analysis tools you can use to highlight specific design or timing information with colors in the active layout view. When you enable a visual mode, the GUI dims the visible objects in the layout view by default 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

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, choose View > Visual Mode.
- To display 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 enable some visual modes during a session, you must load the data before you can view the color overlay in the layout view.

To use a visual mode,

- Click the current visual mode tool on the Analysis toolbar, or click the Visual Mode Menu button (▼) to list the other visual modes (see [Figure A-11](#)).

*Figure A-11 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 highlight specific floorplan, placement, or routing results with colors in the active layout view. When you enable a map mode, the GUI dims the visible objects in the layout view by default 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 routing)
- Power density (leakage, internal, switching, dynamic, or total)
- Preroute power network analysis (electromigration, voltage drop, or resistance)
- Cell placement (cell density or pin density)
- Critical areas (shorts and opens)
- Postroute power rail analysis from PrimeRail (electromigration, voltage drop, or resistivity)
- Chemical mechanical polishing (thickness variations or hotspots)

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, choose View > 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.

To use a map mode,

- Click the current map mode tool on the Analysis toolbar, or click the Map Mode Menu button (▼) to list the other map modes (see [Figure A-12](#)).

*Figure A-12 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.

---

## 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-40.

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](#)

## 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-13](#), 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-13 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-105](#).

## 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 in order 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 IC Compiler online Help.

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](#)

### Expanding or Collapsing Fanout Levels

The Expand Browser toolbar, shown in [Figure A-14](#), 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-14 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-15](#), lets you find a clock tree object in the clock tree fanout browser by selecting the object in another view.

*Figure A-15 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-16](#), to control whether the tool uses maximum or minimum timing values to calculate the timing data.

**Figure A-16 Clock Tree Timing Modes Toolbar**

## Highlighting the Critical Paths

You can use the Critical Path toolbar, shown in [Figure A-17](#), to highlight the longest and shortest clock tree fanout paths in the active clock tree fanout browser or clock tree schematic.

**Figure A-17 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.
- A clock tree schematic displays selected clock paths or design logic in a flat, single-sheet schematic that can include cells, ports, pins, and nets.  
You can generate a clock tree schematic to display an entire clock path or the fanin or fanout logic for selected clock tree objects.

- A clock graph view represents clock tree fanout and fanin in a time-based display that facilitates clock tree latency and skew analysis.

You can examine clock skew, bottlenecks, insertion delays, and the intrinsic path delays caused by the insertion of integrated clock gating (ICG) cells in a clock tree.

For more information, see [“Analyzing Clock Trees in the GUI” on page 7-105](#).

---

## Exploring 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).

You can use the relative placement hierarchy view to examine the structures of relative placement groups and gather placement information about each group. You can also select the names of instances (leaf cells or embedded groups) that you want to examine in graphic views (such as the layout view) or with other analysis tools.

To open a relative placement hierarchy view,

- Choose Placement > New RP Hierarchy View.

For more information about using the relative placement hierarchy view, see [“Working With Relative Placement Groups in the GUI” on page 12-45](#) and the IC Compiler online 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

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 IC Compiler online Help.

---

## 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 file

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 cells. You can examine detail routing errors, layout versus schematic (LVS) verification errors, DRC errors, signoff DRC errors, rail analysis errors from PrimeRail, and third-party DRC errors. For more information about using these rule checking processes, see “[Verifying the Routed Design](#)” on [page 8-39](#).

The error browser loads detail routing errors from memory and other types of errors from the appropriate error cells. 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 or close the error browser,

- Choose Verification > Error Browser or Rail > Error Browser.

The Error Browser dialog box appears. You can set error browser options by choosing commands on the Options menu at the top of the error browser. To display the Options menu, click the menu button (▼). If you need help using the error browser, click the Help button.

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.

The error browser loads detail routing errors by default. If you want to examine other types of errors, you must load the error data from the appropriate error cells:

To load error data in the error browser,

1. Click the Reload button to open the Local Error Cell dialog box.
2. 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.
3. For each option you select except Detail Route, type the error cell file name in the text box, or click the browse button and select the file in the Choose Cell dialog box.
4. Click OK.

The Error Browser dialog box contains three error panes: an error hierarchy tree on top, an error list in the middle, and an error detail pane on the bottom. You can sort the items in the error hierarchy tree or the error list by clicking in a column heading.

- 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 above the error hierarchy tree 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 cell, 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-54.

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 Control-click or drag the pointer to select multiple errors.

5. Examine the errors on 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 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-54.

- 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-11.
  - 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-55.
  - 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-56.
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 cells with unsaved status changes when you save the top-level design. You can manually save individual error cells with unsaved status changes by using the Save Error Views dialog box.

For more details, see IC Compiler online Help.

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.

For more information about examining errors with the error browser, see the following sections:

- [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 Information in a File](#)

---

## 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, specific types of errors, or errors on specific layers.

To filter selected errors.

1. Select the errors you want to filter.

You can either hide the selected errors or hide all the other errors.

2. Click the Filter button to open the Filter Error List dialog box.
3. Select a filter operation option: Show or Hide.
4. Click OK.

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 by layer or error type,

1. Click the Filter button to open the Filter Error List dialog box.
2. Select a filter operation option: Show or Hide.
3. Select the criteria option: Layers or Error Types.
4. Select the options for the layers or error types that you want to show or hide.
5. Click OK.

You can repeat this procedure to filter the remaining errors in the error list.

To remove the filters, you can

- Click the Clear Filter button in the Error Browser window.
- Click the filter button to open the Filter Error List dialog box, and click Clear Filters.

---

## 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 on the Mouse Tools toolbar, or choose View > Mouse Tools > Selection Tool.

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, Control-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 Control 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,

- Select the Detail Route error type in the error hierarchy tree.
- Select one or more errors in the error list.
- 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 cell 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 Information in a File

When you examine errors in the error browser, you can save the error list information in a text file, and you can choose whether to exclude or include hidden errors.

To save the error list information in a file,

1. 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.
2. Navigate to the directory where you want to save the file, and type the file name in the “File name” box.
3. Click Save.

---

## 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
- Stretch, split, and reshape objects
- Orient, rotate, align, distribute, spread, and expand selected objects

In addition, you can use commands on the Floorplan menu to create physical objects such as bounds and plan groups.

You can use route editing tools to

- Route individual nets
- Create net and user shapes, vias and via arrays, port terminals, text objects, and custom wires
- Route physical buses and multiple nets

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 and the Advanced Edit toolbar or by choosing commands on the Edit menu. [Figure A-18](#) shows the Edit toolbar as it appears when you select one or more objects in the layout view.

[Figure A-19](#) shows the Advanced Edit toolbar. The toolbars group related editing functions together in lists that open when you click the  button.

*Figure A-18 Edit Toolbar When Objects Are Selected*



The Advanced Edit toolbar provides access to the Advanced Route tool and the commands for creating, modifying, and removing physical buses.

*Figure A-19 Advanced Edit Toolbar*



For information about editing physical design objects and constraints, see the following sections:

- [Working in the Editing Environment](#)
- [Editing Objects Interactively](#)
- [Selecting Objects by Name](#)
- [Selecting Only the Highlighted Objects](#)
- [Moving, Resizing, Modifying, and Removing Objects](#)
- [Routing Nets and Physical Busses](#)
- [Aligning and Distributing Objects](#)
- [Creating Floorplan Objects](#)

## 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 control grid snapping, set editing constraints, and define and edit object groups. [Table A-2](#) explains the global operations that you can use with any editing tool or command.

*Table A-2 Global Editing Operations*

| To perform this operation                                                | Do this                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reverse the previous edit change                                         | Click  , or choose Edit > Undo. Alternatively, you can use the <code>undo</code> command.                                                                                                                                  |
| Reapply the subsequent edit change                                       | Click  , or choose Edit > Redo. Alternatively, you can use the <code>redo</code> command.                                                                                                                                  |
| Enable or disable grid snapping                                          | Click  or choose Edit > Snapping.                                                                                                                                                                                          |
| Lock or unlock (fix or unfix) selected objects to prevent or allow edits | Click a lock tool (  or  <p>Appendix A: Using GUI Tools<br/>Editing the Physical Layout</p> |

*Table A-2 Global Editing Operations (Continued)*

| To perform this operation                                            | Do this                                                                                                                                                                                   |
|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Create edit group that contains the objects in the current selection | Select the objects, and then click the  button on the Edit toolbar or choose Edit > Create Edit Group. |
| View or edit object attribute values for selected objects.           | Click the  button, right-click and choose Properties, or choose Edit > Properties.                       |

**Note:**

For details about using the Properties dialog box, see “[Viewing and Editing Object Properties](#)” on page [A-17](#).

For information about the physical design editing environment, see the following sections:

- [Fixing and Unfixing Objects for Edits](#)
- [Changing the Way Objects Snap to a Grid](#)
- [Editing Groups of Objects](#)
- [Reversing and Reapplying Edit Changes](#)

## 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

IC Compiler automatically snaps objects to the grids associated with them. By default, when you create or edit objects interactively in the layout view by using an editing tool or command, IC Compiler first modifies them as you specify and then snaps them to the nearest associated snap grid. You can enable or disable snapping for all editing operations, 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.

To change the ways objects are snapped,

1. Display the Snap Settings dialog box if it is not already open by choosing Edit > Snap Settings.
2. Enable or disable snapping for all object types by clicking the “Enable snapping” option.

A check mark appears on the option when snapping is enabled.

3. Enable or disable snapping for individual object types by clicking the option to the left of the object type name.

A check mark appears on the option when snapping is enabled.

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

5. (Optional) Click Done to close the Snap Settings dialog box.

## 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 edit groups, see IC Compiler online help.

## 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-20](#) 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-20 Undo Toolbar*



- To reverse the most recent editing operation, click the button on the Undo toolbar, press **Ctrl+Z**, or choose **Edit > Undo**.
- To reapply the most recently reversed editing operation, click the button on the Undo toolbar, press **Ctrl+Y**, or choose **Edit > Redo**.

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.

## 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 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.

[Table A-4](#) shows the buttons that you can use to perform actions with the active editing tool.

*Table A-3 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-4](#) shows the standard key bindings for the interactive editing tools.

*Table A-4 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 interactive 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. If multiple objects occupy the same location, you can cycle through the objects, forward or backward, by pressing F1 or Shift-F1. Click to select the object you need when its name appears in the InfoTip. For details, see “[Previewing Objects in a Layout View](#)” on page A-6.

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.

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.

The Create Route tool, Advanced Route tool, Stretch Wire tool, and Window Stretch tool support nondefault routing rules by default. You can disable nondefault routing rule compliance in a tool and use the rules defined in the technology file.

The Advanced Route tool also provides interactive DRC support. For more information, see the Help pages for the tools. You can set options to enable or disable interactive DRC and adjust the interactive DRC rules.

When you activate the Create Route tool or the Advanced 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.

## Selecting 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.

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-21 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 IC Compiler online Help.

Alternatively, you can select objects by specifying a name pattern or defining a regular expression in the Select By Name dialog box. For more information, see “[Searching for Objects by Name](#)” on page A-21.

---

## 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

---

## 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-5** explains the editing tools you can use to modify the physical design.

*Table A-5 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.  |
| Stretch wires while maintaining connectivity by 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 maintaining connectivity by 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.                                   |
| 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.                                   |
| 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.                                |
| Reshape objects by cutting or adding an area                                                    | 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. |
| 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.                                                        |

For more information about using these editing tools, see IC Compiler online Help.

---

## Routing Nets and Physical Busses

**Table A-6** explains how you can use interactive editing tools to create route objects and route nets and buses in the physical design.

*Table A-6 Interactive Route Editing Tools*

| To perform this operation                                                                               | Use this tool                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Route single nets by adhering to nondefault routing 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.                          |
| 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 the pointer 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 the pointer 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 the pointer to draw the terminal. You can set options as needed on the Mouse Tool Options toolbar.                                                          |
| 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.                                                         |
| Route physical buses or multiple nets by adhering to nondefault routing rules and interactive DRC rules | Click  or choose Edit > Advanced > 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. |

---

For more information about these tools, see “[Routing Nets and Buses in the GUI](#)” on [page 8-50](#) and the IC Compiler online Help.

## Aligning and Distributing Objects

[Table A-7](#) explains how you can align, expand, orient, distribute, spread, rotate, and flip design objects.

*Table A-7 Editing Commands for Design Objects*

| To perform this operation                              | Do this                                                                                                                                              |
|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Align selected objects to one side or a center         | Select an align tool ( or choose Edit > Align > <i>alignment_type</i> . Alternatively, you can use the <code>align_objects</code> command.           |
| Expand selected objects to objects on one or all sides | Click an expansion tool ( or choose Edit > Expand > <i>expansion_direction</i> . Alternatively, you can use the <code>expand_objects</code> command. |
| Orient selected objects to north                       | Click an orientation tool () or choose Edit > Orientation > <i>orientation</i> .                                                                     |
| Distribute selected objects from a side                | Click a distribution tool ( or choose Edit > Distribute > <i>side</i> . Alternatively, you can use the <code>distribute_objects</code> command.      |
| Spread selected objects horizontally or vertically     | Click a spread tool ( or choose Edit > Spread > <i>direction</i> .                                                                                   |
| Rotate selected objects 90 or 180 degrees              | Click a rotation tool ( 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 choose Edit > Rotate > <i>axis</i> . Alternatively, you can use the <code>flip_objects</code> command.                        |

For more information about these editing commands, see IC Compiler online Help.

---

## Creating Floorplan Objects

You can use the GUI or `icc_shell` commands to create floorplan objects in the physical design.

**Table A-8** lists the floorplan objects you can create and the menu commands and the `icc_shell` commands you can use to create them.

*Table A-8 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 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 floorplan objects, see IC Compiler online 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 Design and Path 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 default values 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 IC Compiler online 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-110.

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 Design and Path 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, see the IC Compiler online 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.



# Index

---

## A

abbreviations in scripts 2-39  
add\_clock\_drivers command 7-83  
add\_end\_cap command 9-34  
add\_tap\_cell\_array command 9-3  
adjust\_premesh\_connection command 7-81  
Advanced Route tool 8-56, A-69  
alias command 2-40  
align\_objects command A-70  
aligning objects A-70  
alignment tools A-70  
all\_active\_scenarios command 14-14  
all\_rp\_groups command 12-51  
all\_rp\_hierarchicals command 12-51  
all\_rp\_inclusions command 12-52  
all\_rp\_instantiations command 12-52  
all\_rp\_references command 12-52  
all\_scenarios command 14-14  
always-on  
    power wells, multivoltage designs 13-28  
synthesis  
    exclusive move bounds 13-28  
    multivoltage designs 13-46  
ambiguous commands 2-38  
AMD64 platform 1-2  
Analysis toolbar A-37

analysis tools, layout  
    flylines A-37, A-38  
    map modes A-37, A-42  
    net connectivity A-37, A-39  
    visual modes A-37, A-40  
analyze\_subcircuit command 7-89  
Application Preferences dialog box 2-30  
area utilization 4-25  
attributes  
    connected\_to\_iso\_cell 13-28  
    direct\_power\_rail\_tie 13-43  
    dont\_touch 13-31, 13-33, 13-34  
    ignore, removing 12-54  
    is\_isolation\_cell 13-30, 13-36, 13-37  
    is\_level\_shifter 13-30, 13-36, 13-37  
    isolation\_cell\_enable\_pin 13-30, 13-36  
    level\_shifter\_enable\_pin 13-30, 13-36  
    relative placement, writing to disk 12-53  
    size\_only 13-34, 13-35, 13-36

## B

balance\_inter\_clock\_delay command 7-75  
blockages  
    creating placement blockages 4-5  
blockages, creating placement blockages A-71  
boundary cell, clock tree synthesis 7-34  
bounds, creating objects A-71

Browsers toolbar 7-108, A-45

buffer trees

    creating 4-14

    removing 4-14

    reporting 4-14

buffering high-fanout nets 4-14

buffer-type level shifters

    inserting 13-33

    insertion threshold 13-31

    placing 13-37

bus naming style, specifying 3-10

## C

Calibre interface 8-49

capacitance, net capacitance histogram A-74

capture window or view image A-23

cell orientations A-70

    displaying or hiding A-28

cell placement statistics 8-39

Cells List toolbar 2-32

change\_names command 3-38

check\_clock\_tree command 7-63

check\_isolation\_cells command 13-36, 13-48

check\_level\_shifters command 13-45

check\_mv\_design command 13-8, 13-30,  
    13-48

check\_physical\_design command 3-31

check\_routeability command 8-2

check\_timing command 3-34

check\_tlu\_plus\_files command 3-33

chemical mechanical polishing thickness  
    displaying maps 9-46

    loading data 9-45

chip finishing

    adding end caps 9-34

    adding tap cell arrays 9-3

    chemical mechanical polishing thickness  
        displaying maps 9-46

        loading data 9-45

displaying critical area heat maps 9-28

filling empty tracks with metal fill 9-38

filling notches and gaps 9-44

inserting pad fillers 9-37

inserting redundant vias 9-30

inserting standard cell fillers 9-31

inserting tap cells 9-4

inserting well fillers 9-35

performing wire spreading 9-29

reporting critical areas 9-27

Clear Rulers A-3

clear rulers A-26

clock

    convergent 7-4

    overlapping 7-4

clock arrival histograms 7-110

clock mesh

    adding mesh drivers 7-83

    analysis 7-89

    building premesh trees 7-83

    compiling premesh trees 7-86

    definition 7-77

    flow 7-79, 7-93

    prerequisites 7-78

    removing 7-83

    routing mesh nets 7-85

    routing premesh trees 7-88

    specifying 7-81

    splitting clock nets 7-81

    structure 7-77

clock network element tables, path inspector  
    window A-79

clock tree

    design rule constraints priority 7-27

    exception, float pins 7-48

    removing 7-50

    reporting 7-103

    verifying 7-63

    viewing 7-105

clock tree arrival time histogram, displaying  
    7-110

clock tree clustering, on-chip-variation-aware  
    7-35

clock tree design rule constraint  
    maximum capacitance 7-26  
    maximum fanout 7-26  
    maximum transition time 7-26

clock tree exceptions  
    defining 7-9  
    don't buffer net 7-18  
    don't size cell 7-18  
    don't touch subtree 7-17, 7-50  
    exclude pin 7-7, 7-13  
    float pin 7-14  
    nonstop pin 7-13  
    preserve hierarchy 7-19  
    priority 7-12  
    removing 7-12  
    reporting 7-12  
    size-only cells 7-19  
    stop pin 7-7, 7-17

clock tree fanout browser A-46

clock tree hierarchy browser  
    defined 7-109  
    displaying 7-110

clock tree optimization  
    ECO routing 7-75  
    optimization capabilities 7-73  
        postroute, default 7-74  
        preroute, default 7-74  
        selecting 7-74  
    postroute 7-74  
    preroute 7-74  
    timing analysis, router for 7-73  
    voltage area support 13-43

clock tree reference  
    defined 7-4  
    resetting 7-21  
    specifying 7-20

clock tree sinks  
    default 7-8  
    defining 7-7, 7-17  
    optimizing 7-67

clock tree synthesis  
    boundary cell, defined 7-34  
    design rule constraints, viewing 7-27  
    don't touch subtree  
        defined 7-17, 7-50  
        logic-level balancing 7-37  
    exclude pin  
        defined 7-7, 7-13  
        implicit 7-8  
    float pin  
        defined 7-14  
        examples 7-48  
        modeling hard macros 7-48  
    ILM, logic-level balancing 7-37  
    logic-level balancing  
        defined 7-36  
        don't touch subtree 7-37  
        enabling 7-37  
        hard macro 7-38  
        ILM 7-37  
    maximum capacitance 7-26  
    maximum fanout 7-26  
    maximum level count, setting 7-29  
    maximum transition time 7-26  
    minimum insertion delay, defined 7-28  
    multicorner-multimode 7-62  
    nonstop pin  
        defined 7-13  
        implicit 7-8  
    prerequisites  
        design 7-3  
        library 7-4  
    skew, defined 7-28  
    stop pin  
        defined 7-7, 7-17  
        implicit 7-7  
    timing goals 7-28  
    voltage area support 13-43

clock tree synthesis options  
    defining 7-22  
    reporting 7-25  
    resetting 7-25

clock tree synthesis scenario, multicorner-multimode 14-21  
clock\_opt command 7-64, 13-42, 14-20  
close\_mw\_lib command 3-21  
closing the GUI 2-7  
collection\_result\_display\_limit variable 12-52  
command  
    abbreviation in scripts 2-39  
    console, main window 2-22  
    displaying options 2-5  
    execution at startup 2-3  
    history 2-26  
    listing for session 2-26  
    listing in GUI 2-27  
    menu, choosing task mode in layout window 2-29  
    output, redirecting 2-41  
    saving session transcript 2-25  
command line 2-3  
    copying commands to command line 2-5  
    entering commands 2-4, 2-38  
icc\_shell 2-4  
shell 2-4, 2-38  
X-term window 2-4, 2-38  
command scripts, Tcl (tool command language) 2-8  
commands  
    add\_clock\_drivers 7-83  
    add\_end\_cap 9-34  
    add\_tap\_cell\_array 9-3  
    adjust\_premesh\_connection 7-81  
    alias 2-40  
    align\_objects A-70  
    all\_active\_scenarios 14-14  
    all\_rp\_groups 12-51  
    all\_rp\_hierarchicals 12-51  
    all\_rp\_inclusions 12-52  
    all\_rp\_instantiations 12-52  
    all\_rp\_references 12-52  
    all\_scenarios 14-14  
    ambiguous 2-38  
    analyze\_subcircuit 7-89  
    balance\_inter\_clock\_delay 7-75  
    change\_names 3-38  
    check\_clock\_tree 7-63  
    check\_isolation\_cells 13-36, 13-48  
    check\_level\_shifters 13-45  
    check\_mv\_design 13-8, 13-30, 13-48  
    check\_physical\_design 3-31  
    check\_routeability 8-2  
    check\_timing 3-34  
    check\_tlu\_plus\_file 3-33  
    choosing in menus 2-5  
    clock\_opt 7-64, 13-42, 14-20  
    close\_mw\_lib 3-21  
    commit\_skew\_group 7-118  
    compare\_delay\_calculation 3-37  
    compile 13-5, 13-31, 13-36  
    compile\_clock\_tree 7-71  
    compile\_premesh\_tree 7-83, 7-86  
    compile\_ultra 13-5, 13-31, 13-36  
    connect\_power\_domain 13-58  
    connect\_power\_net\_info 13-58  
    connect\_supply\_command 13-16  
    convert\_fill\_polygons 9-38  
    convert\_wire\_ends 8-39  
    copy\_floorplan 3-29  
    copy\_mw\_cel 3-26  
    copy\_object A-68  
    copying session log 2-24  
    create\_auto\_shield 8-36  
    create\_bounds 4-8, A-71  
    create\_bounds, exclusive 13-28  
    create\_buffer\_tree 4-14  
    create\_clock\_mesh 7-81  
    create\_ilm 11-6, 11-24, 13-45  
    create\_macro\_fram 11-16  
    create\_mw\_lib 3-10  
    create\_physical\_bus 8-52, 8-54  
    create\_physical\_buses\_from\_patterns 8-53  
    create\_pin\_guide A-71  
    create\_placement 13-37  
    create\_placement\_blockage A-71  
    create\_plan\_groups command A-71

create\_power\_domain 13-3, 13-13, 13-57, 13-58  
create\_power\_net\_info 13-58  
create\_route\_guide 8-3, A-71  
create\_routing\_blockage 8-5  
create\_scenario 14-2, 14-13  
create\_track A-71  
create\_voltage\_area 13-4, 13-20, 13-23, 13-25, A-71  
current\_mw\_cel 2-32  
current\_scenario 14-14  
define\_routing\_rule 7-30, 8-7  
derive\_pg\_connection 13-58  
disconnect\_power\_net\_info 13-58  
distribute\_objects A-70  
expand\_objects A-70  
extract\_rc 4-20, 8-59, 11-15, 14-18  
extract\_rp\_group 12-61  
flatten\_clock\_gating 7-80  
flip\_objects A-70  
Follow Selection A-15  
get\_always\_on\_logic 13-47  
get\_bounds 4-9  
get\_cts\_scenario 7-62, 14-21  
get\_ilm\_objects 11-24  
get\_ilms 11-24  
get\_license 2-47  
get\_magnet\_cells 4-12  
get\_placement\_blockages 4-5, 4-6  
get\_route\_guides 8-5  
get\_routing\_blockages 8-6  
get\_selection 2-23  
get\_voltage\_area 13-24  
Go Back in Zoom and Pan History A-15  
Go Forward in Zoom and Pan History A-15  
gui\_show\_form 2-12  
gui\_show\_man\_page 2-11  
gui\_start 2-7  
gui\_start command 2-3  
gui\_stop 2-8  
help 2-11  
history 2-26, 2-40  
history view 2-26  
icc\_shell 2-4  
insert\_isolation\_cell 13-5, 13-36  
insert\_level\_shifters 13-5, 13-30, 13-33  
insert\_metal\_filler 9-39  
insert\_ng\_filler 9-44  
insert\_pad\_filler 9-37  
insert\_redundant\_vias 9-30  
insert\_stdcell\_filler 9-32, 13-44  
insert\_tap\_cells\_by\_rules 9-5  
insert\_well\_filler 9-35  
interrupting 2-6  
keyboard shortcuts in GUI 2-14  
legalize\_placement 13-37  
license\_users 2-46  
magnet\_placement 4-12  
map\_isolation\_cell 13-36  
map\_level\_shifter\_cell 13-35  
move\_object A-68  
Named Zoom and Pan Settings A-15  
Open Design 2-30  
optimize\_clock\_tree 7-73  
optimize\_pre\_cts\_power 7-55  
optimize\_wire\_via 8-36  
order\_rp\_groups 12-62  
Pan to Selection A-13  
place\_opt 4-15, 11-34, 13-4, 13-6, 13-37, 13-42, 14-2, 14-17, 14-20, 14-21  
process\_particle\_probability\_file 9-27  
propagate\_constraints 13-45  
psynopt 4-19, 13-4, 13-43, 14-2, 14-17  
psynopt, on\_route option 14-17  
read\_cmp\_thickness 9-45  
read\_def 3-28  
read\_drc\_error\_file 8-49  
read\_floorplan 3-29  
read\_parasitics 3-33  
read\_sdc 3-34  
read\_sdf 3-33  
read\_verilog 3-27  
recalling 2-40  
redirect 2-41

redo A-59  
refine\_placement 4-43  
remove\_all\_spacing\_rules 4-10  
remove\_annotations 3-33  
remove\_bounds 4-9  
remove\_buffer\_tree 4-14  
remove\_clock\_tree 7-50  
remove\_clock\_tree\_exceptions  
  -dont\_buffer\_nets 7-18  
  -dont\_size\_cells 7-18  
  -dont\_touch\_subtrees 7-17  
  -exclude\_pins 7-13  
  -float\_pins 7-16  
  -non\_stop\_pins 7-13  
  -preserve\_hierarchy 7-20  
  -stop\_pins 7-17  
remove\_clock\_tree\_exceptions -  
  size\_only\_cells 7-19  
remove\_filler\_withViolation 9-34  
remove\_from\_rp\_group 12-59  
remove\_ideal\_network 3-34  
remove\_keepout\_margin 4-5  
remove\_level\_shifters 13-31  
remove\_license 2-48  
remove\_net\_routing\_layer\_constraints 4-22  
remove\_objects A-68  
remove\_placement\_blockage 4-6  
remove\_power\_domain 13-58  
remove\_power\_net\_info 13-58  
remove\_preferred\_routing\_direction 8-7  
remove\_route\_by\_type 8-12  
remove\_route\_guides 8-5, 8-6  
remove\_routing\_blockage 8-6  
remove\_rp\_group\_options 12-54  
remove\_rp\_groups 12-54  
remove\_sdc 3-34  
remove\_skew\_group 7-119  
remove\_stdcell\_filler  
  -pad 9-38  
  -stdcell 9-34  
  -tap 9-6  
remove\_target\_library\_subset 13-8  
remove\_voltage\_area 13-29  
remove\_well\_filler 9-37  
report\_all\_spacing\_rules 4-10  
report\_area 11-24  
report\_bounds 4-9  
report\_buffer\_tree 4-14  
report\_cell 13-49  
report\_clock\_timing 7-105  
report\_clock\_tree 7-103  
report\_constraint 7-124, 14-29  
report\_critical\_area 9-27  
report\_delay\_calculation 4-30  
report\_design 8-39, 11-24  
report\_error\_coordinates 8-2, 8-49  
report\_extraction\_options 14-18  
report\_keepout\_margin 4-5  
report\_net\_routing\_layer\_constraints 4-22  
report\_noise\_calculation 10-14  
report\_operating\_conditions 13-50  
report\_physical\_signoff 8-42  
report\_placement\_blockages 4-6  
report\_placement\_utilization 4-25  
report\_power 4-31  
report\_power\_domain 13-58  
report\_power\_guide 13-29  
report\_power\_net\_info 13-58  
report\_preferred\_direction 8-6  
report\_qor 14-26  
report\_route\_opt\_strategy 8-24  
report\_route\_options 8-12  
report\_routing\_rules 7-30  
report\_scan\_chain 5-12  
report\_signal\_em 10-20  
report\_target\_library\_subset 13-8, 13-50  
report\_threshold\_voltage\_group 6-6  
report\_timing 4-28, 7-124  
report\_timing -scenario 14-28  
report\_timing\_derate 3-36  
report\_tlu\_plus\_files 3-33, 14-31  
report\_units 3-20, 10-18, 10-20  
report\_voltage\_area 13-29, 13-49  
reset\_clock\_tree\_references 7-21

reset\_design 3-34  
reset\_timing\_derate 3-36  
resize\_object A-68  
reusing 2-26  
rotate\_objects A-70  
route\_detail 8-35  
route\_global 8-32  
route\_group 8-20  
route\_htree 7-88  
route\_mesh\_net 7-85  
route\_opt 13-42, 14-2, 14-17, 14-20, 14-21  
route\_search\_repair 8-36  
route\_spreadwires 9-29  
route\_track 8-35  
route\_zrt\_eco 8-37  
rp\_group\_inclusions 12-52  
rp\_group\_instantiations 12-52  
rp\_group\_references 12-52  
Save Design 2-30  
save\_mw\_cel 3-38  
save\_mw\_cel -scenario 14-16  
saving transcript of session commands 2-27  
set\_active\_scenarios 14-14, 14-19  
set\_ahfs\_options 4-14  
set\_attribute 13-39  
set\_clock\_tree\_exceptions  
  -dont\_buffer\_nets 7-18  
  -dont\_size\_cells 7-18  
  -dont\_touch\_subtrees 7-17  
  -exclude\_pins 7-13  
  float pin options 7-14, 7-48  
  -non\_stop\_pins 7-13  
  -preserve\_hierarchy 7-19  
  -size\_only\_cells 7-19  
  -stop\_pins 7-17  
set\_clock\_tree\_references 7-20  
set\_congestion\_options 4-7  
set\_cts\_scenario 7-62, 14-21  
set\_delay\_calculation 3-37  
set\_delay\_estimation\_options 4-23, 4-24  
set\_distributed\_route 8-17  
set\_extraction\_options 8-60, 9-38, 14-18  
set\_fix\_hold 14-21  
set\_fix\_hold\_options 14-21  
set\_gui\_stroke\_bindings A-37  
set\_gui\_stroke\_preferences A-37  
set\_ignored\_layers 8-9  
set\_inter\_clock\_delay\_options 7-59  
set\_keepout\_margin 4-4, 11-34  
set\_left\_right\_filler rule 9-31  
set\_level\_shifter\_strategy 13-31, 13-33  
set\_level\_shifter\_threshold 13-31, 13-32, 13-33  
set\_lib\_cell\_spacing\_label 4-9, 4-10  
set\_max\_leakage\_power 14-4  
set\_min\_library 3-3, 3-35, 14-11  
set\_mw\_lib\_reference 3-22  
set\_mw\_technology\_file 3-21  
set\_net\_aggressors 8-11  
set\_net\_routing\_layer\_constraints 4-22  
set\_operating\_conditions 3-35, 13-34, 13-45, 14-2, 14-6, 14-7  
set\_optimize\_dft\_options 5-10  
set\_physical\_signoff 8-41  
set\_physical\_signoff\_options 9-42  
set\_power\_guide 13-29  
set\_power\_net\_to\_voltage\_area 13-44  
set\_preferred\_routing\_direction 8-6  
set\_route\_opt\_strategy 8-23  
set\_route\_options 8-12  
set\_route\_type 8-12  
set\_rp\_group\_options 12-56  
set\_scope 13-12  
set\_si\_options 3-38, 13-46, 14-18  
set\_skew\_group 7-117  
set\_spacing\_label\_rule 4-9, 4-10  
set\_target\_library\_subset 13-5, 13-7  
set\_timing\_derate 3-36  
set\_tlu\_plus\_files 3-32, 3-33, 9-38, 9-39, 14-4, 14-16  
signoff\_drc 8-40  
signoff\_metal\_fill 9-42  
split\_clock\_gates 7-56  
split\_clock\_net 7-81

split\_objects A-68  
stretch\_wire A-68  
stroke A-35  
stroke activated commands A-35  
terminating 2-6  
undo A-59  
uniquify\_fp\_mw\_cel 3-27  
unset\_power\_guide 13-29  
update\_bounds 4-9  
update\_clock\_latency 7-76  
update\_voltage\_area 13-24, 13-25  
verify\_drc 8-45  
verify\_route 8-48  
window\_stretch A-68  
write\_def 3-39  
write\_interface\_timing 11-21  
write\_mw\_lib\_files 3-22  
write\_parasitics 3-39, 8-59, 14-16  
write\_rp\_groups 12-53  
write\_sdc 3-39  
write\_stream 3-39  
Zoom Fit All A-13  
Zoom Follows Selection A-13  
Zoom In 2x A-13  
Zoom Out 2x A-13  
Zoom to Selection A-13  
commit\_skew\_group command 7-118  
compare\_delay\_calculation command 3-37  
compile command 13-5, 13-31, 13-36  
compile\_clock\_tree command 7-71  
compile\_premesh\_tree command 7-83, 7-86  
compile\_ultra command 13-5, 13-31, 13-36  
compression, relative placement 12-28  
concurrent analysis and optimization,  
multicorner-multimode 14-2  
congestion options 4-7  
connect\_power\_domain command 13-58  
connect\_power\_net\_info command 13-58  
connected\_to\_iso\_cell attribute 13-28  
Connectivity Settings panel A-39  
console  
command line 2-23  
entering commands 2-23  
history view 2-26  
log view 2-24  
main window 2-22  
saving log messages 2-24  
searching the transcript 2-24  
window 2-23  
constraints  
reading 3-34  
report 7-124  
saving 3-39  
timing 3-33  
convergent clock path, defined 7-4  
convert\_fill\_polygons command 9-38  
convert\_wire\_ends command 8-39  
Copy tool A-68  
copy\_floorplan command 3-29  
copy\_mw\_cel command 3-26  
copy\_object command A-68  
copying  
commands 2-5  
objects A-68  
session log 2-24  
coupling capacitance  
extracting 8-59  
filtering, multicorner-multimode 14-18  
scaling 8-60  
create object tools A-71  
Create Route tool 8-50  
Create Via tool A-69  
create\_auto\_shield command 8-36  
create\_bounds command 4-8, A-71  
exclusive 13-28  
create\_buffer\_tree command 4-14  
create\_clock\_mesh command 7-81  
create\_ilm command 11-6, 11-24, 13-45  
create\_macro\_fram command 11-16  
create\_mw\_lib command 3-10  
create\_physical\_bus command 8-52, 8-54

create\_physical\_buses\_from\_patterns  
    command 8-53

create\_pin\_guide command A-71

create\_placement command 13-37

create\_placement\_blockage command A-71

create\_plan\_groups command A-71

create\_power\_domain command 13-3, 13-57, 13-58

create\_power\_net\_info command 13-58

create\_route\_guide command 8-3, A-71

create\_routing\_blockage command 8-5

create\_scenario command 14-2, 14-13

create\_track command A-71

create\_voltage\_area command 13-4, 13-20, 13-23, 13-25, A-71

creating objects A-71

critical area

- displaying heat maps 9-28
- encrypting and decrypting the particle probability function 9-27
- reporting 9-27

crosstalk

- analysis
  - delta delay visual mode 10-13
  - noise reports 10-13
  - preparation 10-9
  - static noise visual mode 10-13
  - timing report 10-12
- defined 10-3
- net lists, path inspector window A-79
- optimization
  - about 10-7
  - postroute 10-8
  - signoff optimization 10-14
- prevention
  - clock shielding 10-6
  - clock tree synthesis 10-6
  - placement 10-5
  - track assignment 10-7
- reduction engines 10-6
- timing impacts 10-12

crosstalk prevention, net aggressors 8-11

cts\_do\_characterization variable 7-102

cts\_enable\_rc\_constraints variable 7-43

cts\_fix\_clock\_tree\_sinks variable 7-67

cts\_move\_clock\_gate variable 7-67

cts\_rc\_relax\_factor variable 7-43

cts\_traverse\_dont\_touch\_subtrees variable 7-17

cts\_use\_debug\_mode variable 7-102

cts\_use\_lib\_max\_fanout variable 7-27

cts\_use\_sdc\_max\_fanout variable 7-27

current design, setting 2-32

current\_mw\_cel command 2-32

current\_scenario command 14-14

Custom Wire tool A-69

## D

database, Milkyway

- about 3-2
- saving a design 3-38

datapath, physical, defined 12-1

DEF file

- reading 3-28
- writing 3-39

define\_routing\_rule command 7-30, 8-7

delay calculation algorithm

- Arnoldi 3-37
- clock Arnoldi 3-37
- Elmore 3-37
- postroute
  - default 3-37
  - setting 3-37

Delete toiol A-68

deleting objects A-68

densely-packed objects A-6

derating factors for timing library 3-36

derive\_pg\_connection command 13-58

design for manufacturing (DFM)

- chemical mechanical polishing thickness

- displaying maps 9-46
- loading data 9-45
- critical area heat map displaying 9-28
- critical area reporting 9-27
- metal density filling 9-38
- via doubling 9-30
- wire spreading 9-29
- design overlays, layout view A-30
- design rules, routing
  - metal density 9-38
  - notch and gap filling 9-44
- design task mode, layout window 2-29
- designs
  - opening 2-30
  - saving 2-30
  - schematics A-77
- detail routing 8-35
- dialog boxes
  - finding 2-12
- direct\_power\_rail\_tie attribute 13-43
- disconnect\_power\_net\_info command 13-58
- DISPLAY environment variable
  - checking before startup 2-2
  - overriding 2-3
- displaying command options 2-5
- distribute\_objects command A-70
- distributed routing 8-16
- distributing objects A-70
- distribution commands A-70
- dont\_touch attribute 13-31, 13-33, 13-34
- draw rulers A-26
- E**
  - ECO routing
    - during clock tree optimization 7-75
    - running 8-37
  - Edit Snapping Settings panel A-61
  - Edit tool
    - moving objects A-68
  - resizing objects A-68
  - Edit toolbar A-58
  - editing object properties A-17
  - edits
    - redo A-63
    - undo A-63
  - electromigration
    - loading net switching information for analysis 10-18
    - performing signal analysis 10-20
    - signal analysis repair file 10-22
  - emulation metal fill extraction 9-38
  - enable-type level shifters
    - inserting 13-36
    - placing 13-37
  - end cap
    - adding 9-34
    - defined 9-34
  - endpoint slack histogram
    - histogram views A-74
    - Timing Views toolbar A-74
  - environment variable, DISPLAY 2-2
  - environment variables
    - SNPS\_MAX\_QUEUEUTTIME 2-47
    - SNPS\_MAX\_WAITTIME 2-47
    - SNPSLMD\_QUEUE 2-47
  - error browser, viewing routing and verification errors A-50
  - estimating via resistance 4-24
  - exceptions for clock tree synthesis
    - don't buffer net 7-18
    - don't size cell 7-18
    - don't touch subtree 7-17, 7-50
    - exclude pins 7-7, 7-13
    - float pin 7-14, 7-48
    - nonstop pins 7-13
    - preserve hierarchy 7-19
    - size-only cells 7-19
    - stop pins 7-7, 7-17
  - exclusive move bounds, always-on synthesis 13-28

executing  
     command at startup 2-3  
     script at startup 2-3  
 exiting IC Compiler 2-10  
 Expand Browser toolbar 7-108, A-47  
 expand\_objects command A-70  
 expanding  
     objects A-70  
 expansion commands A-70  
 exporting  
     GDSII 3-39  
     Oasis 3-39  
     parasitic data 3-39  
 extract\_rc command 4-20, 8-59, 11-15, 14-18  
 extract\_rp\_group command 12-61  
 extraction  
     postroute 8-59  
     real and emulation metal fill 9-38

**F**

File toolbar 2-30  
 files, bytecode-compiled 2-45  
 FILL view 9-44  
 fill, metal 9-38, 9-39, 9-41  
 filler cell  
     inserting pad fillers 9-37  
     inserting standard cell fillers 9-31  
     inserting well fillers 9-35  
     removing pad fillers 9-38  
     removing standard cell fillers 9-34  
     removing standard cell fillers that have  
         routing design rule violations 9-34  
     removing tap cells 9-6  
     removing well fillers 9-37  
 fix objects A-60  
 fix objects for edit A-59  
 flatten\_clock\_gating command 7-80  
 flip\_objects command A-70  
 flipping object commands A-70

float pin  
     defined 7-48  
     setting 7-48  
 floorplan file, reading 3-29  
 Flyline Settings panel A-38  
 flylines  
     Analysis toolbar A-37  
     displaying A-38  
     Flyline Settings panel A-38  
 Follow Selection command A-15  
 following selected objects in graphic views  
     A-15  
 functional ECO methods, using 15-2

**G**

GDSII format 3-39  
 generated clocks  
     as clock tree roots 7-5  
 get\_always\_on\_logic command 13-47  
 get\_bounds command 4-9  
 get\_cts\_scenario command 7-62, 14-21  
 get\_ilm\_objects command 11-24  
 get\_ilms command 11-24  
 get\_license command 2-47  
 get\_magnet\_cells command 4-12  
 get\_placement\_blockages command 4-5, 4-6  
 get\_route\_guides command 8-5  
 get\_routing\_blockages command 8-6  
 get\_selection command 2-23  
 get\_voltage\_area command 13-24  
 global routing  
     defined 8-32  
     running 8-32  
     voltage area support 13-44  
 global skew, defined 7-28  
 Go Back in Zoom and Pan History command  
     A-15  
 Go Forward in Zoom and Pan History  
     command A-15

Graphical User Interface (GUI) 1-4  
grid snapping A-59  
grids  
  displaying or hiding A-26  
  litho grid A-26  
  user grid A-26  
groups  
  creating plan groups A-71  
  relative placement, defined 12-9  
guard bands, voltage area 13-25  
GUI 1-4  
  closing 2-7  
  displaying on named terminal 2-3  
  help starting 2-3  
  hiding 2-7  
  opening 2-7  
  starting while executing command 2-3  
  starting while executing script 2-3  
GUI preferences  
  saving 2-30  
  setting 2-30  
GUI windows 2-17  
  menu bar 2-18  
  status bar 2-19  
  toolbars 2-19  
  view windows 2-20  
gui\_show\_form command 2-12  
gui\_show\_man\_page command 2-11  
gui\_start command 2-3, 2-7  
gui\_stop command 2-8  
guides  
  creating pin guides A-71  
  creating route guides A-71

searching for text in 2-15

Hercules  
  design rule checking  
    distributed 8-43  
    signoff\_drc command 8-40  
    verify\_drc 8-45  
  environment, setting up 8-40  
  layer mapping file 8-42  
Hercules metal fill 9-41  
hiding the GUI 2-7  
hierarchy browser  
  exploring design hierarchy A-18  
  logic hierarchy view A-18  
high-fanout nets, buffering 4-14  
high-fanout synthesis  
  during place\_opt 4-14  
  standalone 4-14  
  using compile\_clock\_tree 7-72  
  voltage area support 13-42  
high-level design flow, multivoltage designs  
  13-6  
Highlight tool A-8  
Highlight toolbar A-9  
highlighting  
  critical path A-11  
  selected objects A-11  
  timing paths A-11  
histograms A-74  
  clock arrival histograms 7-110  
  endpoint slack histogram A-74  
  net capacitance histogram A-74  
  path slack histogram A-74  
history  
  command log 2-26  
  view 2-26  
history command 2-40  
hotkeys report, displaying 2-14

## H

help command 2-11  
Help system 2-11  
  accessing 2-15  
  choosing browser 2-16  
  configuring Web browser for 2-16

I

IC Compiler 2-3

exiting 2-10  
  Help 2-11  
  icc\_shell commands 2-4  
  starting 2-2, 2-3  
**IC Compiler Help** 2-11  
**IC Compiler packages**  
  **IC Compiler** 1-2  
  **IC Compiler-DP** 1-2  
  **IC Compiler-PC** 1-2  
  **IC Compiler-XP** 1-2  
**icc\_shell command** 2-3  
  displaying options 2-5  
  listing startup options 2-3  
  starting IC Compiler 2-2  
  using 2-4, 2-38  
**icc\_shell command-line interface** 1-4  
**icc\_shell> prompt** 2-3, 2-4  
**ignore attribute**, removing 12-54  
**ILM (interface logic model)** 11-1  
**ilm\_disable\_ilm\_checks** variable 11-7  
**image**  
  capturing window or view A-23  
**importing**, Verilog 3-27  
**incremental placement** 4-19  
**information**  
  displaying for objects in graphic views A-11  
  displaying InfoTips in layout views A-6  
**InfoTips** A-6  
**insert\_isolation\_cell** command 13-5, 13-36  
**insert\_level\_shifters** command 13-5, 13-30,  
  13-33  
**insert\_metal\_filler** command 9-39  
**insert\_ng\_filler** command 9-44  
**insert\_pad\_filler** command 9-37  
**insert\_redundant\_vias** command 9-30  
**insert\_stdcell\_filler** command 9-32, 13-44  
**insert\_tap\_cells\_by\_rules** command 9-5  
**insert\_well\_filler** command 9-35  
**inserting enable-type level shifters,**  
  multivoltage designs 13-36  
**inserting isolation cells, multivoltage designs**  
  13-36  
**insertion threshold, buffer-type level shifters**  
  13-31  
**inspecting timing paths** A-78  
**interactive clock tree synthesis** 7-121  
**interactive clock tree synthesis window,**  
  displaying 7-108  
**intercell spacing rules**, defining 4-9, 4-10  
**interclock delay balancing**  
  **clock group**, specifying 7-59  
  **running** 7-75  
  **timing analysis, router for** 7-75  
**interclock skew, balancing** 7-58  
**interface logic model** 11-34  
  area information, reporting 11-25  
  benefits for using 11-5  
  **clock\_opt** command 11-35  
  defined 11-1  
  design information  
    differences depending on current design  
      11-25  
    reporting 11-25  
  examining in GUI A-29  
  fanin and fanout of chip-level networks,  
    controlling 11-14  
  flow for creating 11-6  
  **ILM view** 11-17, 11-28  
  information about, reporting 11-24  
  instantiating and using at the top level 11-28  
  logic included in, controlling 11-8  
  logic-level balancing in clock tree synthesis  
    7-37  
  mirrored 11-17  
  multicorner-multimode flows 14-22  
  number of latch levels, controlling 11-12  
  on-route capability 11-37  
  overview 11-2  
  propagation of information to the top-level  
    design 11-29  
  reporting information 11-24  
  rotated 11-17

rotated and mirrored models, handling 11-30  
**route\_opt** command 11-36  
 side-load cells  
   controlling 11-11  
 signal integrity 11-38  
 storing parasitic delay information 11-15  
 viewing in GUI 11-38  
 voltage area support 13-44  
**interfaces**  
   GUI 1-4  
   icc\_shell 1-4  
**interrupting commands** 2-6  
**is\_isolation\_cell** attribute 13-30, 13-36, 13-37  
**is\_level\_shifter** attribute 13-30, 13-36, 13-37  
**isave** window or view mage A-23  
**isolation cells**  
   and level shifters, multivoltage designs 13-4  
   handling in multivoltage designs 13-29  
   inserting 13-36  
   requirements, multivoltage designs 13-30  
**isolation\_cell\_enable\_pin** attribute 13-30, 13-36

## K

**keepout margins**  
   cell-specific, setting 4-4  
**keyboard shortcuts** 2-14  
**k-factors**  
   multivoltage designs 13-5  
   unsupported in multicorner-multimode 14-8

## L

**layer constraints**  
   defining 4-22  
**layout editing** 8-50, 8-51, 8-52, 8-53, 8-56, 12-49  
**layout editing tools** 8-50, 8-56, A-58  
   Create Custom Wire tool 8-57  
**layout tools, analysis** A-37  
**layout view** A-2, A-24  
   refreshing A-16  
   save screenshot of A-23  
**layout window** 2-28  
**legalize\_placement** command 13-37  
**level shifter commands, multivoltage designs** 13-30  
**level shifters**  
   and isolation cells, multivoltage designs 13-4  
   handling in multivoltage designs 13-29  
   placing 13-37  
   requirements, multivoltage designs 13-30  
   threshold, multivoltage designs 13-31  
**level\_shifter\_enable\_pin** attribute 13-30, 13-36  
**library data, preparing** 1-6  
**library requirements,**  
   multivoltage designs 13-5  
**license queuing**  
   enabling 2-47  
   environment variables 2-47  
     SNPS\_MAX\_QUEUETIME 2-47  
     SNPS\_MAX\_WAITTIME 2-47  
     SNPSLMD\_QUEUE 2-47  
**license\_users** command 2-46  
**licenses**  
   checking out 2-47  
   enabling queuing 2-47  
   listing 2-46  
   releasing 2-48  
   using 2-46  
   working with 2-46  
**licenses, getting or releasing in GUI** 2-48  
**Linux platforms** 1-2  
**Linux shell** 2-3  
**listing commands** 2-27  
**listing startup options** 2-3  
**litho grid, displaying or hiding** A-26  
**locking objects for edit** A-59  
**log view** 2-24  
**logic hierarchy view** A-18

logic libraries 1-6  
low-effort flow 1-7  
lwindow  
  save image of A-23

## M

macros  
  voltage area 13-28  
magnet placement 4-12  
magnet\_placement command 4-12  
main library, defined 3-3  
main window 2-3, 2-21  
man page viewer 2-13  
map file for TLUPlus 3-32  
Map Mode panel 9-28, 9-46, A-42  
map modes  
  Analysis toolbar A-37  
  displaying A-42  
  Map Mode panel A-42  
map\_isolation\_cell command 13-36  
map\_level\_shifter\_cell command 13-35  
maximum net length optimization, voltage area  
  support 13-43  
maximum timing information 3-3, 3-35  
mcmm\_enable\_high\_capacity\_flow variable  
  14-20  
mcmm\_high\_capacity\_effort\_level variable  
  14-19  
menu bar 2-18  
menu commands  
  choosing 2-5  
  finding 2-12  
menu task mode, layout window 2-29  
menus  
  choosing task mode in layout window 2-29  
  keyboard shortcuts 2-14  
metal density filling  
  inserting 9-38  
metal fill 9-38, 9-39, 9-41

metal fill extraction, real and emulation 9-38  
methodology 1-5  
Milkyway database  
  about 3-2  
  saving a design 3-38  
Milkyway design  
  copying 3-26  
Milkyway design library  
  changing settings 3-21  
  closing 3-21  
  creating 3-10  
  defined 3-9  
  reporting  
    Milkyway reference libraries 3-4, 3-20  
    units 3-20, 10-18, 10-20  
Milkyway format, saving in 1-7  
Milkyway reference library  
  changing 3-22  
  defined 3-9  
  specifying 3-10  
minimum insertion delay, defined 7-28  
minimum timing information 3-3, 3-35  
model, interface logic, defined 11-1  
Mouse Tool Options toolbar A-5, A-7, A-64  
mouse tools  
  Advanced Route tool A-69  
  Copy tool A-68  
  Create Via tool A-69  
  Custom Wire tool A-69  
  Delete tool A-68  
  Edit tool (move objects) A-68  
  Edit tool (resize objects) A-68  
  Highlight tool A-8  
  Mouse Tools toolbar A-4  
  Pan tool A-3  
  Query tool A-3, A-11  
  Route tool A-69  
  Ruler tool A-3, A-26  
  Selection Tool A-3  
  Selection tool A-7  
  Split tool A-68

Stretch Wire tool A-68  
Window Stretch tool A-68  
Zoom In tool A-3  
Zoom Out tool A-3  
Mouse Tools toolbar A-4  
move bound  
  adding cells to 4-9  
  creating 4-8  
  defined 4-8  
  deleting 4-9  
  exclusive 4-8  
  hard 4-8  
  removing cells from 4-9  
  reporting 4-9  
  soft 4-8  
move\_object command A-68  
moving and stretching objects A-68  
moving objects A-68  
multicorner-multimode  
  all\_active\_scenarios command 14-14  
  all\_scenarios command 14-14  
  basic concepts 14-2  
  basic flow 14-3  
  clock tree synthesis 7-62  
  clock tree synthesis scenario 14-21  
  commands 14-12  
  concurrent analysis and optimization 14-2  
  create\_scenario command 14-2, 14-13  
  current\_scenario command 14-14  
  k-factors, unsupported 14-8  
  multicorner library setup 14-5  
  optimization 14-17  
    CC filtering 14-18  
    RC scaling 14-17  
  preroute hold fixing 14-21  
  report\_constraint command 14-29  
  report\_qor command 14-26  
  report\_timing -scenario command 14-28  
  report\_tlu\_plus\_files command 14-31  
  save\_mw\_cel command  
    -scenario 14-16  
scenario definition 14-2  
scenario management, commands 14-13  
scenario reduction 14-18  
script example 14-31  
set\_active\_scenarios command 14-14  
set\_max\_leakage\_power command 14-4  
set\_min\_library command 14-11  
set\_tlu\_plus\_files command 14-4, 14-16  
setup considerations 14-4  
using interface logic models (ILMs) 14-22  
voltage area support 13-46  
write\_parasitics command 14-16  
multiple instances, support for 3-27  
multivoltage designs  
  always-on power wells 13-28  
  always-on synthesis 13-46  
  creating voltage areas 13-23  
  handling isolation cells 13-29  
  handling level shifters 13-29  
  high-level design flow 13-6  
  identifying characteristics 13-6  
  inserting enable-type level shifters 13-36  
  inserting isolation cells 13-36  
  isolation cell requirements 13-30  
  isolation cells 13-29  
  k-factors 13-5  
  level shifter commands 13-30  
  level shifter placement 13-37  
  level shifter requirements 13-30  
  level shifter threshold 13-31  
  level shifters 13-29  
  level shifters and isolation cells 13-4  
  library requirements 13-5  
  nested voltage areas 13-27  
  optimization script 13-59  
  physical synthesis 13-6  
  placing and optimizing 13-46  
  power domains 13-2  
  power domains and voltage areas 13-4  
  power domains, using 13-57  
  reporting 13-48  
  target library subsetting 13-7

using voltage areas 13-20  
 voltage areas 13-4

## N

Named Zoom and Pan Settings command A-15  
 nested voltage areas, multivoltage designs 13-27  
 net aggressors 8-11  
 net capacitance histogram histogram views A-74  
 Timing Views toolbar A-74  
 net connectivity Analysis toolbar A-37  
 Connectivity Settings panel A-39  
 displaying A-39  
 net layer constraints, specifying 8-9  
 net shielding 8-36  
 net switching information, loading 10-18  
 NLDM (nonlinear delay model) libraries 13-58  
 nondefault routing rules, setting 8-7  
 nonlinear delay model libraries 13-58  
 notch and gap filling 9-44

## O

Oasis format 3-39  
 object alignment tools A-70  
 object distribution commands A-70  
 object expansion commands A-70  
 object flipping commands A-70  
 object information InfoTips A-6  
 Query tool A-11  
 object properties A-17  
 object rotation commands A-70  
 object snapping options for layout editing A-61  
 object splitting tools A-68  
 object spreading commands A-70

objects  
 create object tools A-71  
 fix or unfix for editing A-60  
 select by name A-21  
 selecting in graphic views A-7  
 on-chip-variation, clock tree clustering 7-35  
 online Help 2-11  
 accessing 2-15  
 choosing browser 2-16  
 configuring Web browser for 2-16  
 searching for text in 2-15  
 Open Design command 2-30  
 opening designs 2-30  
 opening the GUI 2-3, 2-7  
 operating condition analysis modes 3-35  
 best-case and worst-case 3-35  
 on-chip variation 3-35  
 optimization  
 multicorner-multimode 14-17  
 optimization script, multivoltage designs 13-59  
 optimize\_clock\_tree command 7-73  
 optimize\_pre\_cts\_power command 7-55  
 optimize\_wire\_via command 8-36  
 order\_rp\_groups command 12-62  
 orientations A-70  
 orientations, displaying or hiding for cells A-28  
 orienting cells A-70  
 overlapping clock path, defined 7-4  
 overlapping objects A-6  
 overlays, layout view A-30  
 overriding DISPLAY value 2-3  
 over-the-block resources, placement and routing 11-16, 11-34  
 overview of interface logic models 11-2  
 Overview panel A-25

## P

packages, IC Compiler 1-2  
 pad filler

inserting 9-37  
removing 9-38

Pan to Selection command A-13

Pan tool A-3

panels

- Connectivity Settings panel A-39
- Edit Snapping Settings panel A-61
- Flyline Settings A-38
- Map Mode panel A-42
- Overview panel A-25
- Query panel A-11
- timing analysis driver A-72
- View Settings panel, layout views A-31
- View Settings panel, schematic views A-78
- Visual Mode panel A-40

path data element table, path inspector window A-79

path inspector

- panels A-78
- path schematic A-80
- viewing path profiles A-76

path inspector windows A-78

path profile views

- timing analysis A-76
- Timing Views toolbar A-74

path profiles

- in path inspector A-78
- path inspector window A-79

path schematics A-76

- in path inspector A-78

path slack histogram

- histogram views A-74
- Timing Views toolbar A-74

path specifications for TLUPlus 3-32

path summaries, path inspector window A-79

paths

- select A-19

physical bus

- creating
- automatic 8-52
- manual 8-51

modifying 8-53  
routing 8-56

physical bus, modifying 8-53

physical bus, routing 8-56

physical data

- copying 3-29
- validating 3-31

physical datapath, defined 12-1

physical optimization, voltage area support 13-43

physical signoff options

- reporting 8-42
- setting 8-41

physical synthesis

- creating voltage areas 13-20
- multivoltage designs 13-6
- placing and optimizing designs 13-46
- voltage-area-aware capabilities 13-42

physopt\_check\_site\_overlap variable 13-21

physopt\_enable\_via\_res\_support variable 4-24

physopt\_rp\_enable\_orient\_opt variable 12-16

pin guides

- creating objects A-71

place\_opt command 4-15, 11-34, 13-4, 13-6, 13-37, 13-42, 14-2, 14-17, 14-20, 14-21

placement

- incremental 4-19
- magnet 4-12
- refining 4-42
- statistics 8-39

placement and optimization 1-6

- customizing 4-15
- multivoltage 13-46
- physical synthesis 13-46

placement area utilization 4-25

placement blockages

- creating 4-5
- creating objects A-71

plan groups

- creating objects A-71

platforms 1-2  
postroute extraction 8-59  
power and ground net associations, voltage area support 13-44  
power domains  
  definition 13-2  
  multivoltage designs 13-2, 13-57  
  voltage areas 13-4  
power statistics 4-31  
preferences  
  saving 2-30  
  setting 2-30  
preferred routing direction  
  reporting 8-6  
  setting 8-6  
prerequisites, routing 8-2  
preroute hold fixing, multicorner-multimode 14-21  
preroute RC estimation 4-20  
preroute scaling factors, setting 4-23, 4-24  
prerouting special nets 8-20  
preview selection A-6  
previewing commands in dialog boxes 2-27  
process scaling factors 8-61  
process\_particle\_probability\_file command 9-27  
propagate\_constraints command 13-45  
properties, viewing and editing for selected object A-17  
psynopt command 4-19, 13-4, 13-43, 14-2, 14-17  
  on\_route option 14-17

## Q

Query panel A-11  
Query tool A-3, A-11  
querying objects A-11  
queuing licenses 2-47  
quick flow 1-7

quitting IC Compiler 2-10

## R

RC calculations, preparing 3-31  
RC estimation 4-20  
  coefficients, specifying 4-23  
  scaling factors, setting 4-23  
  via resistance 4-24  
RC scaling, multicorner-multimode 14-17  
read\_cmp\_thickness command 9-45  
read\_def command 3-28  
read\_drc\_error\_file command 8-49  
read\_floorplan command 3-29  
read\_parasitics command 3-33  
read\_sdc command 3-34  
read\_sdf command 3-33  
read\_verilog command 3-27  
reading  
  DEF file 3-28  
  Verilog 3-27  
real metal fill extraction 9-38  
reapply edits A-59  
reapplying edits in layout view A-63  
recalling commands 2-40  
redirect command 2-41  
redirect operator ( > ) 2-41  
redirect operator ( >> ) 2-41  
redirecting command output 2-41  
redo command A-59  
redo edits A-63  
redrawing the active view A-16  
reference control file  
  writing 3-22  
reference, clock tree  
  specifying 7-20  
refine\_placement command 4-43  
refreshing the active view A-16  
relative coordinates A-6

relative placement  
    aligning by pins 12-16  
    anchoring at a specified location 12-11  
    cell placement using bounds 12-39  
    changing specific items within a group 12-60  
    commands 12-63  
    compression 12-28  
    considerations for using 12-8  
    flow 12-5  
    group  
        adding items to 12-14  
        adding or removing items from in GUI A-49  
        creating 12-9  
        defined 12-9  
        extracting 12-61  
        ordering extracted 12-62  
        renaming 12-59  
    hierarchical group  
        adding 12-22  
        exploring in GUI A-49  
        for instantiation 12-25  
        included, defined 12-22  
        instantiated, defined 12-22  
        syntax to include 12-23  
        syntax to instantiate 12-25  
hierarchy view A-49  
in a design containing obstructions 12-36, 12-37  
in virtual flat placement 12-40  
incremental relative placement 12-39  
keepout  
    adding 12-33  
    adding or removing in GUI A-49  
leaf cell  
    adding or removing in GUI A-49  
    specifying orientation 12-16  
    syntax to add to group 12-15  
limitations 12-64  
methodology 12-6  
modifying a group 12-56  
modifying information 12-55  
orientation optimization  
    defined 12-16  
    directing 12-16  
positions for data 12-9  
preserving during optimization 12-36  
relative placement information, ignoring 12-54  
removing 12-54  
removing items from a group 12-59  
required inputs 12-8  
sample script 12-7  
straddling 12-26  
ungrouping 12-30  
uniquifying 12-32  
voltage area support 13-45  
writing information to script file 12-53  
relative placement groups  
    exploring in GUI A-49  
    relative placement hierarchy view A-49  
    removing in GUI A-49  
    removing items from in GUI A-49  
relative placement hierarchy view A-49  
remove\_all\_spacing\_rules command 4-10  
remove\_annotations command 3-33  
remove\_bounds command 4-9  
remove\_buffer\_tree command 4-14  
remove\_clock\_tree command 7-50  
remove\_clock\_tree\_exceptions command  
    -dont\_buffer\_nets 7-18  
    -dont\_size\_cells 7-18  
    -dont\_touch\_subtrees 7-17  
    -exclude\_pins 7-13  
    -float\_pins 7-16  
    -non\_stop\_pins 7-13  
    -preserve\_hierarchy 7-20  
    -size\_only\_cells 7-19  
    -stop\_pins 7-17  
remove\_filler\_withViolation command 9-34  
remove\_from\_rp\_group command 12-59  
remove\_ideal\_network command 3-34  
remove\_keepout\_margin command 4-5  
remove\_level\_shifters command 13-31

remove\_license command 2-48  
remove\_net\_routing\_layer\_constraints command 4-22  
remove\_objects command A-68  
remove\_placement\_blockage command 4-6  
remove\_power\_domain command 13-58  
remove\_power\_net\_info command 13-58  
remove\_preferred\_routing\_direction command 8-7  
remove\_route\_by\_type command 8-12  
remove\_route\_guides command 8-5, 8-6  
remove\_routing\_blockage command 8-6  
remove\_rp\_group\_options command 12-54  
remove\_rp\_groups command 12-54  
remove\_sdc command 3-34  
remove\_skew\_group command 7-119  
remove\_stdcell\_filler command  
    -pad 9-38  
    -stdcell 9-34  
    -tap 9-6  
remove\_target\_library\_subset command 13-8  
remove\_voltage\_area command 13-29  
remove\_well\_filler command 9-37  
removing objects A-68  
report views A-20  
report, clock tree  
    generating 7-103  
    types 7-103  
report\_all\_spacing\_rules command 4-10  
report\_area command 11-24  
report\_bounds command 4-9  
report\_buffer\_tree command 4-14  
report\_cell command 13-49  
report\_clock\_timing command 7-105  
report\_clock\_tree command 7-103  
report\_constraint command 7-124, 14-29  
report\_critical\_area command 9-27  
report\_delay\_calculation command 4-30  
report\_design command 8-39, 11-24  
report\_error\_coordinates command 8-2, 8-49  
report\_extraction\_options command 14-18  
report\_keepout\_margin command 4-5  
report\_milkyway\_version 3-20  
report\_net\_routing\_layer\_constraints command 4-22  
report\_noise\_calculation command 10-14  
report\_operating\_conditions command 13-50  
report\_physical\_signoff command 8-42  
report\_placement\_blockages command 4-6  
report\_placement\_utilization command 4-25  
report\_power command 4-31  
report\_power\_domain command 13-58  
report\_power\_guide command 13-29  
report\_power\_net\_info command 13-58  
report\_preferred\_direction command 8-6  
report\_qor command 14-26  
report\_route\_opt\_strategy command 8-24  
report\_route\_options command 8-12  
report\_routing\_rules command 7-30  
report\_scan\_chain command 5-12  
report\_signal\_em command 10-20  
report\_target\_library\_subset command 13-8, 13-50  
report\_threshold\_voltage\_group command 6-6  
report\_timing command 4-28, 7-124  
report\_timing -scenario command 14-28  
report\_timing\_derate command 3-36  
report\_tlu\_plus\_files command 3-33, 14-31  
report\_units command 3-20, 10-18, 10-20  
report\_voltage\_area command 13-29, 13-49  
reporting  
    cell placement statistics 8-39  
    multivoltage designs 13-48  
    routing and optimization strategy 8-24  
    routing options 8-12  
    routing statistics 8-39  
    threshold voltage 6-6  
reports

saving A-20  
viewing A-20  
**reset\_clock\_tree\_references** command 7-21  
**reset\_design** command 3-34  
**reset\_timing\_derate** command 3-36  
**resize\_object** command A-68  
resizing objects A-68  
reusing commands 2-26  
reverse edits A-59  
reversing edits in layout view A-63  
rotate object commands A-70  
**rotate\_objects** command A-70  
rotating objects A-70  
routability, checking 8-2  
route guide  
  creating 8-3  
  creating objects A-71  
  finding 8-5  
  removing 8-5, 8-6  
Route tool A-69  
**route\_detail** command 8-35  
**route\_global** command 8-32  
**route\_group** command 8-20  
**route\_htree** command 7-88  
**route\_mesh\_net** command 7-85  
**route\_opt** command 13-42, 14-2, 14-17,  
  14-20, 14-21  
**route\_search\_repair** command 8-36  
**route\_spreadwires** command 9-29  
**route\_track** command 8-35  
**route\_zrt\_eco** command 8-37  
routing  
  detail 8-35  
  ECO 8-37  
  global 8-32  
interactive  
  multiple nets 8-56  
  physical bus 8-56  
  single net 8-50  
postroute extraction 8-59  
prerequisites 8-2  
running individual steps 8-32  
special nets 8-20  
track assignment 8-35  
verifying 8-39  
routing and optimization strategy  
  reporting 8-24  
  setting 8-23  
routing blockage  
  creating 8-5  
  finding 8-6  
  removing 8-6  
routing direction, setting preferred 8-6  
routing layers, clock tree  
  default 7-33  
  setting 7-33  
routing options, setting 8-12  
routing rule  
  clock tree  
    default 7-30  
    nondefault 7-30  
  defining 7-30  
  nondefault, defined 7-30  
  reporting 7-30  
routing rules (nondefault), setting 8-7  
routing statistics 8-39  
routing tracks, creating objects A-71  
routing type  
  removing 8-12  
  setting 8-12  
**rp\_group\_inclusions** command 12-52  
**rp\_group\_instantiations** command 12-52  
**rp\_group\_references** command 12-52  
Ruler tool A-3, A-26

## S

Save Design 2-30  
**save\_mw\_cel** command 3-38  
**save\_mw\_cel -scenario** command 14-16

saving  
design using Milkyway 3-38  
designs 1-7, 2-30  
log messages 2-24  
preferences 2-30  
reports A-20  
transcript of session commands 2-24, 2-27

SBPF  
reading 3-33  
writing 3-39

scaling factors  
process 8-61

scaling factors, preroute, setting 4-23, 4-24

scan chains  
partitioning  
default 5-9  
horizontal 5-9  
vertical 5-10  
reporting 5-12  
viewing 5-12

SCANDEF file, defined 5-4

scenario definition  
clock tree synthesis 7-62  
multicorner-multimode 14-2

scenario reduction, multicorner-multimode  
14-18

Schematic View panel, path inspector window  
A-80

schematic views  
design schematics A-77  
path schematics A-76  
refreshing A-16  
symbol view A-77

Schematics toolbar A-77

screenshot of layout view A-23

scripts 2-8  
command abbreviations in 2-39  
executing at startup 2-3

SDC  
reading 3-34  
writing 3-39

SDF files, reading 3-33

search and repair, filling notches and gaps  
during 9-44

search\_path variable 3-32

searching the transcript 2-24

select by name dialog box A-21

select timing paths A-19

selected objects, following in graphic views  
A-15

selecting objects in graphic views A-7

selection preview A-6

Selection Tool A-3

Selection tool A-7

session log 2-24

set\_active\_scenarios command 14-14, 14-19

set\_ahfs\_options command 4-14

set\_attribute command 13-39

set\_clock\_tree\_exceptions command  
-dont\_buffer\_nets 7-18  
-dont\_size\_cells 7-18  
-dont\_touch\_subtrees 7-17  
-exclude\_pins 7-13  
float pin options 7-14, 7-48  
-non\_stop\_pins 7-13  
-preserve\_hierarchy 7-19  
-size\_only\_cells 7-19  
-stop\_pins 7-17

set\_clock\_tree\_options command  
-layer\_list 7-33  
-max\_buffer\_levels 7-29  
-max\_capacitance 7-26  
-max\_fanout 7-26  
-max\_transition 7-26  
-routing\_rule 7-30  
-target\_early\_delay 7-28  
-target\_skew 7-28  
-use\_default\_routing\_for\_sinks 7-30

set\_clock\_tree\_references command 7-20

set\_congestion\_options command 4-7

set\_cts\_scenario command 7-62, 14-21

set\_delay\_calculation command 3-37  
set\_delay\_estimation\_options command 4-23, 4-24  
set\_distributed\_route command 8-17  
set\_extraction\_options command 8-60, 9-38, 14-18  
set\_fix\_hold command 14-21  
set\_fix\_hold\_options command 14-21  
set\_gui\_stroke\_bindings command A-37  
set\_gui\_stroke\_preferences command A-37  
set\_ignored\_layers command 8-9  
set\_inter\_clock\_delay\_options command 7-59  
set\_keepout\_margin command 4-4, 11-34  
set\_left\_right\_filler\_rule command 9-31  
set\_level\_shifter\_strategy command 13-31, 13-33  
set\_level\_shifter\_threshold command 13-31, 13-32, 13-33  
set\_lib\_cell\_spacing\_label command 4-9, 4-10  
set\_max\_leakage\_power command 14-4  
set\_min\_library command 3-3, 3-35, 14-11  
set\_mw\_lib\_reference command 3-22  
set\_mw\_technology\_file command 3-21  
set\_net\_aggressors command 8-11  
set\_net\_routing\_layer\_constraints command 4-22  
set\_operating\_conditions command 3-35, 13-34, 13-45  
set\_operating\_conditions command 14-2, 14-6, 14-7  
set\_optimize\_dft\_options command 5-10  
set\_physical\_signoff command 8-41  
set\_physical\_signoff\_options command 9-42  
set\_power\_guide command 13-29  
set\_power\_net\_to\_voltage\_area command 13-44  
set\_preferred\_routing\_direction command 8-6  
set\_route\_opt\_strategy command 8-23  
set\_route\_options command 8-12  
set\_route\_type command 8-12  
set\_rp\_group\_options command 12-56  
set\_si\_options command 3-38, 13-46, 14-18  
set\_skew\_group command 7-117  
set\_spacing\_label\_rule command 4-9, 4-10  
set\_target\_library\_subset command 13-5, 13-7  
set\_timing\_derate command 3-36  
set\_tlu\_plus\_files command 3-32, 3-33, 9-38, 9-39, 14-4, 14-16  
setting preferences 2-30  
setting routing types 8-12  
setting the current design 2-32  
shell command line  
  copying commands to command line 2-5  
  entering commands 2-4, 2-38  
shell commands 2-4  
shell interface 1-4  
shielding nets 8-36  
shortcut keys 2-14  
signal electromigration  
  analysis repair file 10-22  
  performing analysis 10-20  
signal integrity  
  defined 10-1, 10-3  
  options  
    commands affected 10-4  
    setting 10-4  
signal integrity flow  
  ILMs 11-38  
  voltage area support 13-46  
signoff\_drc command 8-40  
signoff\_metal\_fill command 9-42  
single net, routing 8-50  
size\_only attribute 13-34, 13-35, 13-36  
skew  
  balancing between clocks 7-58  
  global 7-28  
skew group  
  definition 7-116

guidelines 7-116  
snapping options for layout editing A-61  
snapping, enable or disable A-59  
sparc64 platform 1-2  
special nets, prerouting 8-20  
SPEF (Standard Parasitic Exchange Format)  
  files  
  reading 3-33  
  writing 3-39  
Split tool A-68  
split\_clock\_gates command 7-56  
split\_clock\_net command 7-81  
split\_objects command A-68  
spreading object commands A-70  
standard cell filler  
  inserting 9-31  
  removing 9-34  
  removing fillers that have routing rule  
    violations 9-34  
  rules, defining 9-31  
standard cell row, adding end caps 9-34  
standard-cell filler cell insertion, voltage area  
  support 13-44  
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-13  
  violations 10-13  
  visual mode 10-13  
status bar 2-19, A-6  
Status panel, path inspector window A-79  
straddling, in relative placement, defined 12-26  
Stretch Wire tool A-68  
stretch\_wire command A-68  
stretching and moving objects A-68  
stretching wires A-68  
stroke activated commands A-35  
stroke commands A-35  
supported platforms 1-2  
Suse platforms 1-2  
symbol views A-77

## T

Tab panel, path inspector window A-79  
tap cell  
  inserting 9-4  
  removing 9-6  
tap cell array  
  adding 9-3  
target library subsetting, multivoltage designs  
  13-7  
target\_library variable 13-8  
task mode, layout window menus 2-29  
Tcl (tool command language)  
  scripts 2-8  
  used by IC Compiler 1-4  
TclPro  
  bytecode-compiled files 2-45  
  limitations 2-45  
  procomp 2-45  
technology (.tf) file  
  changing 3-21  
  defined 3-9  
  metal density rules 9-38  
  specifying 3-10  
  writing 3-22  
technology files  
  editing 3-21  
terminating commands 2-6  
threshold voltage 6-6  
tie cell insertion 4-11  
timing analysis  
  histograms A-74

- path inspector windows A-78
  - preparing 3-31
  - timing analysis driver A-72
  - timing analysis window A-71
  - Timing Views toolbar A-74
- timing analysis driver A-72
- timing constraints
  - removing 3-34
  - setting 3-34
- timing goals, clock tree 7-28
- timing information
  - maximum 3-3, 3-35
  - minimum 3-3, 3-35
- timing libraries 1-6
  - derating factors 3-36
- timing paths
  - analyzing A-71
  - endpoint slack histogram A-74
  - path slack histogram A-74
  - selecting A-19
  - timing analysis driver A-72
  - viewing in path inspector A-78
- timing report 4-28, 7-124
  - crosstalk analysis 10-12
- Timing Views toolbar A-74
- TLUPlus
  - map file 3-32
  - models 3-32
  - reporting files 3-33
  - specifying paths 3-32
  - validating files 3-33
- toggle snapping A-59
- tool command language (Tcl)
  - scripts 2-8
  - used by IC Compiler 1-4
- tool command language (Tcl) mode 1-4
- toolbars 2-19
  - Analysis toolbar A-37
  - Browsers 7-108, A-45
  - Cells List 2-32
  - console 2-23
- Edit toolbar A-58
- Expand Browser 7-108, A-47
- File toolbar 2-30
- Highlight toolbar A-9
- Mouse Tool options toolbar A-5, A-7, A-64
- Mouse Tools toolbar A-4
- Schematics A-77
- Timing Views A-74
- Undo A-63
- View Zoom/Pan toolbar A-13
- Zoom and Pan History toolbar A-15
- tools A-69
  - Copy tool A-68
  - Create Via tool A-69
  - creating objects A-71
  - Delete tool A-68
  - Edit tool (move objects) A-68
  - Edit tool (resize objects) A-68
  - Highlight tool A-8
  - layout editing A-58
  - left mouse button tools A-4
  - Pan tool A-3
  - Query tool A-3, A-11
  - Route tool A-69
  - Ruler tool A-3, A-26
  - Selection Tool A-3
  - Selection tool A-7
  - Split tool A-68
  - Stretch Wire A-68
  - Window Stretch tool A-68
  - Zoom In tool A-3
  - Zoom Out tool A-3
- top-level windows 2-17
- track assignment 8-35
- transcript of session commands, saving 2-24

## U

- undo command A-59
- undo edits A-63
- Undo toolbar A-63

unfix objects A-60  
unfix objects for edit A-59  
Unified Power Format (UPF) 13-8  
uniquify\_fp\_mw\_cel command 3-27  
units  
  default 3-3  
  saving with design 3-38  
  saving with SDC 3-39  
UNIX  
  DISPLAY environment variable 2-2  
  shell 2-3  
UNIX operator  
  append ( >> ) 2-41  
  redirect ( > ) 2-41  
unlocking objects for edit A-59  
unset\_power\_guide command 13-29  
update\_bounds command 4-9  
update\_clock\_latency command 7-76  
update\_voltage\_area command 13-24, 13-25  
user grid, displaying or hiding A-26  
user interfaces 1-4  
using aliases 2-40  
utilization 4-25

V

variables  
  collection\_result\_display\_limit 12-52  
  cts\_do\_characterization 7-102  
  cts\_dont\_touch\_subtrees 7-17  
  cts\_enable\_rc\_constraints 7-43  
  cts\_fix\_clock\_tree\_sinks 7-67  
  cts\_move\_clock\_gate 7-67  
  cts\_rc\_relax\_factor 7-43  
  cts\_use\_debug\_mode 7-102  
  cts\_use\_lib\_max\_fanout 7-27  
  cts\_use\_sdc\_max\_fanout 7-27  
DISPLAY 2-2  
ilm\_disable\_ilm\_checks 11-7  
mcmm\_enable\_high\_capacity\_flow 14-20

mcmm\_high\_capacity\_effort\_level 14-19  
physopt\_check\_site\_overlap 13-21  
physopt\_enable\_via\_res\_support 4-24  
physopt\_rp\_enable\_orient\_opt 12-16  
search\_path 3-32  
SNPS\_MAX\_QUEUETIME 2-47  
SNPS\_MAX\_WAITTIME 2-47  
SNPSLMD\_QUEUE 2-47  
target\_library 13-8

verify\_drc command 8-45  
verify\_route command 8-48  
Verilog  
  reading 3-27  
  writing 3-38  
via resistance  
  estimating 4-24  
  scaling 4-24  
vias  
  inserting redundant 9-30  
View Settings panel  
  design overlays on layout view A-30  
  layer properties in layout view A-33  
  object properties in layout view A-31  
  object properties in schematic view A-78  
  save or load settings A-35  
  using A-31  
view window  
  save image of A-23  
view windows 2-20  
View Zoom/Pan toolbar A-13  
view, FILL 9-44  
viewing  
  man pages 2-13  
  object properties A-17  
  reports A-20  
  scan chains 5-12  
views  
  clock tree fanout browser A-46  
  design schematics A-77  
  histograms A-74  
  layout A-2, A-24

- path inspector window A-78  
path profiles A-76  
path schematics A-76  
symbol A-77  
virtual hierarchy routing, voltage area support 13-42  
Visual Mode panel A-40  
visual modes  
    Analysis toolbar A-37  
    delta delay 10-13  
    displaying A-40  
    static noise 10-13  
    Visual Mode panel A-40  
voltage area aware capabilities  
    maximum net length optimization 13-43  
    virtual hierarchy routing 13-42  
voltage areas  
    creating 13-20, 13-23  
    creating for multivoltage designs 13-23  
    creating objects A-71  
    guard bands, using 13-25  
    macro cells 13-28  
    multivoltage designs 13-4, 13-20  
    power domains 13-4  
    power domains, associating 13-23  
    removing 13-29  
    reporting 13-29  
    updating 13-24  
voltage-area-aware capabilities 13-42  
    automatic high-fanout synthesis 13-42  
    clock tree synthesis and optimization 13-43  
    global routing 13-44  
    maximum net length optimization 13-43  
    multicorner-multivoltage 13-46  
    physical optimization 13-43  
    power and ground nets, associating 13-44  
    signal integrity flow 13-46  
    standard-cell filler cell insertion 13-44  
    using interface logic models 13-44  
    using relative placement 13-45  
    virtual hierarchy routing 13-42  
    voltage-area-based optimization 13-43  
voltage-area-based optimization 13-43
- W**
- well filler  
    inserting 9-35  
    removing 9-37  
Window Stretch tool A-68  
window\_stretch command A-68  
windows  
    layout 2-28  
    main 2-3, 2-21  
    menu bar 2-18  
    status bar 2-19  
    timing analysis A-71  
    toolbars 2-19  
    top-level 2-17  
    view windows 2-20  
    working environment 2-17  
wire spreading 9-29  
wires  
    creating with layout editor 8-57  
    stretching A-68  
working environment 2-17  
write\_def command 3-39  
write\_interface\_timing 11-21  
write\_mw\_lib\_files command 3-22  
write\_parasitics command 3-39, 8-59, 14-16  
write\_rp\_groups command 12-53  
write\_sdc command 3-39  
write\_stream command 3-39  
writing  
    DEF file 3-39  
    Verilog 3-38
- Y**
- yield, optimizing  
    displaying critical area heat maps 9-28  
    performing wire spreading 9-29  
    reporting critical areas 9-27

# Z

Zoom and Pan History toolbar A-15  
Zoom Fit All command A-13  
Zoom Follows Selection command A-13

Zoom In 2x command A-13  
Zoom In tool A-3  
Zoom Out 2x command A-13  
Zoom Out tool A-3  
Zoom to Selection command A-13