

Product Version 5.0.13 December 2003  $\ensuremath{\mathbb{C}}$  1999-2003 Cadence Design Systems, Inc. All rights reserved. Printed in the United States of America.

Cadence Design Systems, Inc., 555 River Oaks Parkway, San Jose, CA 95134, USA

**Trademarks:** Trademarks and service marks of Cadence Design Systems, Inc. (Cadence) contained in this document are attributed to Cadence with the appropriate symbol. For queries regarding Cadence's trademarks, contact the corporate legal department at the address shown above or call 1-800-862-4522.

All other trademarks are the property of their respective holders.

**Restricted Print Permission:** This publication is protected by copyright and any unauthorized use of this publication may violate copyright, trademark, and other laws. Except as specified in this permission statement, this publication may not be copied, reproduced, modified, published, uploaded, posted, transmitted, or distributed in any way, without prior written permission from Cadence. This statement grants you permission to print one (1) hard copy of this publication subject to the following conditions:

- 1. The publication may be used solely for personal, informational, and noncommercial purposes;
- 2. The publication may not be modified in any way;
- 3. Any copy of the publication or portion thereof must include all original copyright, trademark, and other proprietary notices and this permission statement; and
- 4. Cadence reserves the right to revoke this authorization at any time, and any such use shall be discontinued immediately upon written notice from Cadence.

**Disclaimer:** Information in this publication is subject to change without notice and does not represent a commitment on the part of Cadence. The information contained herein is the proprietary and confidential information of Cadence or its licensors, and is supplied subject to, and may be used only by Cadence's customer in accordance with, a written agreement between Cadence and its customer. Except as may be explicitly set forth in such agreement, Cadence does not make, and expressly disclaims, any representations or warranties as to the completeness, accuracy or usefulness of the information contained in this document. Cadence does not warrant that use of such information will not infringe any third party rights, nor does Cadence assume any liability for damages or costs of any kind that may result from use of such information.

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

# Contents

| Preface                             | 23 |
|-------------------------------------|----|
| About This Manual                   | 23 |
| <u> 2 Dther Information Sources</u> | 23 |
| Documentation Conventions           | 25 |
| Text Command Syntax                 | 25 |
| <u>Using Menus</u>                  | 25 |
| <u>Using Forms</u>                  | 26 |

## 1 BuildGates Synthesis Command

| 3 | uildGates Synthesis Commands  | . 27 |
|---|-------------------------------|------|
|   | ac_shell                      | . 33 |
|   | add netconn                   | . 36 |
|   | alias                         | . 37 |
|   | all_children                  | . 38 |
|   | all parents                   | . 40 |
|   | bg shell                      | . 41 |
|   | bgx_shell                     | . 44 |
|   | check_netlist                 | . 47 |
|   | check option                  | . 49 |
|   | create instance               | . 52 |
|   | create_module                 | . 53 |
|   | create_net                    | . 54 |
|   | create_port                   | . 56 |
|   | delete attribute              | . 57 |
|   | delete aware component        | . 58 |
|   | delete_netconn                | . 59 |
|   | delete object                 | . 60 |
|   | delete unconnected ports      | . 61 |
|   | do blast busses               | . 62 |
|   | do build generic              | . 65 |
|   | do change module architecture |      |

| <u>do change name</u>                 |
|---------------------------------------|
| do cleanup netlist                    |
| <u>do copy module</u>                 |
| do create hierarchy                   |
| do delete buffer                      |
| do dissolve hierarchy                 |
| do extract critical                   |
| do extract fanin                      |
| do extract fanout                     |
| do extract non critical               |
| do fix hold                           |
| do insert buffer                      |
| <u>do_optimize</u>                    |
| <u>do pipeline check</u>              |
| do pipeline retime                    |
| <u>do pop module</u>                  |
| do push module                        |
| <u>do rebind</u>                      |
| do remove design                      |
| <u>do rename</u>                      |
| do uniquely instantiate               |
| do xform buffer                       |
| do xform buffer tree                  |
| do xform clone                        |
| do xform fast optimize                |
| do xform fix design rule violations   |
| do xform fix hold                     |
| do xform fix multiport nets           |
| do xform footprint                    |
| do xform ipo                          |
| do xform insert repeaters             |
| do xform map                          |
| do xform optimize generic             |
| do xform optimize slack               |
| do xform pre placement optimize slack |
| do xform prevent crosstalk 146        |

| do xform prevent wire self heat 148 |
|-------------------------------------|
| do xform propagate constants 149    |
| do xform reclaim area               |
| do xform remove redundancy 152      |
| do xform resize                     |
| do xform restructure                |
| do xform run repair file            |
| do xform structure                  |
| do xform unmap                      |
| <u>dump_adb</u>                     |
| eval bottom up                      |
| <u>find</u>                         |
| <u>get area</u>                     |
| get attribute                       |
| get build id                        |
| get buswidth                        |
| get cell area                       |
| get crosstalk threshold             |
| get crosstalk tolerance             |
| get current instance                |
| get current module                  |
| get equivalent cells                |
| get global                          |
| get hdl file                        |
| get hdl hierarchy                   |
| get hdl top level                   |
| get hdl type                        |
| <u>get info</u>                     |
| get message count                   |
| get message verbosity               |
| <u>get names</u>                    |
| <u>get net</u>                      |
| get parent instances                |
| get state of design                 |
| get tempfilename                    |
| get version                         |

| <u>help</u>                      |
|----------------------------------|
| <u>highlight</u>                 |
| issue message                    |
| <u>limit</u>                     |
| <u>quit</u>                      |
| <u>read adb</u>                  |
| <u>read_edif</u>                 |
| <u>read symbol</u>               |
| read symbol update               |
| read_verilog216                  |
| <u>read_vhdl</u>                 |
| <u>record macro</u>              |
| report area                      |
| report aware library             |
| report crosstalk violations      |
| report design rule violations    |
| <u>report_fsm</u>                |
| report globals                   |
| report hierarchy                 |
| report path group options        |
| report resources                 |
| report_skewed_clock_pins245      |
| report vhdl library              |
| report wire self heat violation  |
| reset crosstalk threshold        |
| reset_dont_modify                |
| reset failsafe                   |
| <u>reset_global</u>              |
| reset register type              |
| reset vhdl library               |
| reset_wire_self_heat_prevention  |
| set_attribute                    |
| set aware component property 261 |
| set_aware_library                |
| set cell property                |
| set current instance             |

| set current module     |
|------------------------|
| set dissolve hierarchy |
| set dont modify        |
| <u>set_failsafe</u>    |
| <u>set global</u>      |
| <u>set logic0</u> 273  |
| <u>set_logic1</u>      |
| set message count      |
| set message verbosity  |
| set_path_group_options |
| set port property      |
| set register type      |
| set table style        |
| set unconnected        |
| set vhdl library       |
| <u>unalias</u>         |
| <u>write adb</u>       |
| <u>write edif</u>      |
| write globals          |
| write verilog          |
| <u>write vhdl</u>      |

## 2 CTPKS Commands.

| CIPKS Commands               | 298 |
|------------------------------|-----|
| do build clock tree          | 300 |
| do build physical tree       | 305 |
| do xform optimize clock tree | 308 |
| get clock tree constraints   | 317 |
| get clock tree objects       | 318 |
| report clock tree            | 320 |
| report_clock_tree_violations | 327 |
| reset clock tree constraints | 329 |
| set clock tree constraints   | 330 |
| <u>define_structure</u>      | 333 |
| <u>Attributes</u>            | 336 |

## 3 Distributed Synthesis Commands

| ) | stributed Synthesis Commands | 340 |
|---|------------------------------|-----|
|   | check batch                  | 342 |
|   | check dist                   | 344 |
|   | check host                   | 345 |
|   | get host info                | 346 |
|   | get job info                 | 349 |
|   | get_weight_batch_option      | 355 |
|   | <u>kill job</u>              | 356 |
|   | remove host                  |     |
|   | remove_job                   | 359 |
|   | report job                   |     |
|   | reset dist bits              | 361 |
|   | reset dist rlimit            |     |
|   | reset dist point             |     |
|   | reset dist weight            |     |
|   | set dist bits                |     |
|   | set dist point               |     |
|   | set dist rlimit              |     |
|   | set host config              |     |
|   | set host list                |     |
|   | set dist weight              |     |
|   | set_weight_batch_option      | 374 |

## <u>4</u>

| Low Power Synthesis (LPS) Commands |
|------------------------------------|
| <u>check_cg_logic</u> 37           |
| do remove cg dummy hierarchy       |
| do_xform_insert_sleep_mode38       |
| do xform optimize clock gate       |
| do xform optimize power            |
| get_clock_gating_options           |
| get clock tree power               |
| <u>get dynamic peak power</u>      |

| get dynamic power                                    |
|------------------------------------------------------|
| get gating instance list                             |
| get list of cg instances                             |
| get power                                            |
| get power display unit 402                           |
| get power optimization options 403                   |
| get sleep mode instance list 404                     |
| get sleep mode options                               |
| <u>read saif</u>                                     |
| <u>read_tcf</u>                                      |
| read tcf update                                      |
| <u>read vcd</u>                                      |
| report clock gating                                  |
| report power                                         |
| report slew for power analysis 431                   |
| report to stats                                      |
| reset slew for power analysis 437                    |
| reset switching activity                             |
| set clock gating options                             |
| set power display unit                               |
| set power optimization options                       |
| set sleep mode options                               |
| set slew for power analysis 459                      |
| set switching activity                               |
| write clock gating attribute 463                     |
| <u>write_psf</u>                                     |
| write sleep mode attribute 466                       |
| <u>write_tcf</u>                                     |
| Low Power for Existing BuildGates Synthesis Commands |

# <u>5</u>

| PKS Commands                             | 474 |
|------------------------------------------|-----|
| add physical connection                  | 479 |
| <u>check_design</u>                      | 481 |
| check libraries and design compatibility | 482 |

| check_library                     |
|-----------------------------------|
| create blockage                   |
| create layer usages table 488     |
| create physical cluster           |
| create physical instance          |
| create physical net               |
| create physical pin               |
| create placement area             |
| do extract lef model              |
| do extract route parasitics       |
| <u>do groute</u>                  |
| do initialize floorplan           |
| do insert filler cells            |
| <u>do place</u>                   |
| <u>do pull</u>                    |
| <u>do_push</u>                    |
| do refine place                   |
| do remove filler cells            |
| do remove route                   |
| do reset floorplan                |
| <u>do route</u>                   |
| <u>do_wroute</u>                  |
| <u>do wroute eco</u>              |
| do xform tcorr eco                |
| generate supply rails on rows 554 |
| <u>get cluster</u>                |
| get cluster contents              |
| get cluster names                 |
| get cluster physical info         |
| get current cluster               |
| get current congestion            |
| get current utilization           |
| get ground net                    |
| get library layer_offset          |
| get logic 0 net                   |
| get logic 1 net                   |

| get min porosity for over block routing |
|-----------------------------------------|
| get min wire length                     |
| get physical info                       |
| get pin location                        |
| get power net                           |
| get route availability                  |
| get special netpins                     |
| get steiner capacitance                 |
| get steiner channel width 577           |
| get steiner length                      |
| get steiner resistance                  |
| modify physical cluster                 |
| <u>pks_shell</u>                        |
| <u>prune_routes</u>                     |
| read cap table                          |
| read cap table update                   |
| read_change_file                        |
| <u>read_def</u>                         |
| <u>read_gns</u>                         |
| read layer usages                       |
| <u>read lef</u>                         |
| read lef update                         |
| <u>read_pdef</u>                        |
| <u>read wdb</u>                         |
| remove blockage                         |
| remove physical cluster                 |
| remove physical connection              |
| remove_physical_instance                |
| remove physical net                     |
| remove physical pin                     |
| remove_placement_area                   |
| remove supply rails on rows 610         |
| report block halo                       |
| report blockage                         |
| report cluster                          |
| report floorplan parameters             |

| report grow parameters                      |
|---------------------------------------------|
| report net distribution                     |
| report net rc                               |
| report_overlap                              |
| report physical library                     |
| report placement area                       |
| report preroute parameters                  |
| report supply rails on rows                 |
| report unplaced                             |
| reset dont move                             |
| reset net physical attribute                |
| set block halo                              |
| set block rc rule                           |
| set current cluster                         |
| set default core site                       |
| set dont move                               |
| set floorplan parameters                    |
| set ground net                              |
| set grow anchors                            |
| set grow parameters                         |
| set layer usages table 644                  |
| set lef_multiplier                          |
| set library layer offset 648                |
| set logic 0 net                             |
| <u>set logic 1_net</u>                      |
| set min porosity for over block routing 651 |
| set min RC multipliers                      |
| set min wire length 654                     |
| set net physical attribute                  |
| set physical info                           |
| set physical instance                       |
| set pin location                            |
| set pin status                              |
| set power_net                               |
| set power stripe spec                       |
| set preroute parameters                     |

| set route availability        |
|-------------------------------|
| set special netpin            |
| set steiner channel width 673 |
| set_steiner_mode              |
| set supply rails on rows      |
| vbg pks display ilist         |
| vbg_pks_group_delete          |
| vbg pks group display         |
| <u>write def</u>              |
| <u>write_gns</u>              |
| write gns lib                 |
| write layer usages            |
| <u>write_pdef</u>             |
| write wdb                     |

## <u>6</u> Te

| <u>e</u> | est Synthesis Commands             | 690 |
|----------|------------------------------------|-----|
|          | check dft rules                    | 692 |
|          | display_scan_chains                | 695 |
|          | do remove scan order data          | 697 |
|          | do xform connect scan              | 698 |
|          | do xform fix dft_violations        | 704 |
|          | do xform insert shadow dft         | 706 |
|          | do xform insert testpoint          | 712 |
|          | get_dft_config_mode                | 716 |
|          | get scan chain info                |     |
|          | read scan order file               | 720 |
|          | remove dft assertions              | 722 |
|          | report dft assertions              | 726 |
|          | report dft registers               |     |
|          | reset dft compatible clock domains | 731 |
|          | reset dft fix violations           | 732 |
|          | reset dft internal clock domain    |     |
|          | reset_dft_transparent              | 734 |
|          | reset dont scan                    | 736 |

| reset dont touch scan            |
|----------------------------------|
| reset must scan                  |
| reset scan data                  |
| reset_test_mode_setup            |
| set dft clock waveform           |
| set dft compatible clock domains |
| set dft compatible chains        |
| set dft fix violations           |
| set dft internal clock domain    |
| set dft lockup element           |
| set dft transparent              |
| set dont scan                    |
| set dont touch scan              |
| set lssd aux clock               |
| set Issd scan clock a            |
| set Issd scan clock b            |
| set max scan chain length        |
| set must scan                    |
| set number of scan chains        |
| set scan chain                   |
| set scan chain segment           |
| set scan data                    |
| set scan equivalent              |
| set scan mode                    |
| set scan style                   |
| set test mode setup              |
| set test scan clock              |
| write atpg info                  |
| write scan order file            |

# 7

| Common Timing Engine (CTE) Commands | 788 |
|-------------------------------------|-----|
| Path Exception Priorities           | 797 |
| Bidirectional Pin Defaults          | 799 |
| Command Descriptions                | 802 |

| <u>check_timing</u>               |
|-----------------------------------|
| create mp constraint arc          |
| create mp delay arc               |
| create mp drive type              |
| create mp load type               |
| create mp model                   |
| create mp path type               |
| create mp port                    |
| do analyze crosstalk              |
| do cppr analysis                  |
| do derive context                 |
| do extract model                  |
| do signalstorm                    |
| do time budget                    |
| do xform timing correction        |
| get capacitance unit              |
| get cell drive                    |
| get cell pin load                 |
| <u>get_clock</u>                  |
| get clock propagation             |
| get clock source                  |
| get constant for timing           |
| get dcl calculation mode          |
| get dcl functional mode           |
| get dcl functional mode array 863 |
| get dcl level                     |
| get derived clock                 |
| <u>get drive pin</u>              |
| get fanin                         |
| <u>get fanout</u>                 |
| get flow compatible mode          |
| get load pin                      |
| get module worst slack            |
| get operating conditions          |
| get operating parameter           |
| get operating voltage             |

| get propagated clock        |
|-----------------------------|
| get scale delays            |
| <u>get slack</u>            |
| get slew thresholds         |
| get tech info               |
| get time borrow limit       |
| <u>get time unit</u>        |
| get timing                  |
| get top timing module       |
| <u>libcompile</u>           |
| load dcl rule               |
| <u>read alf</u>             |
| <u>read_ctlf</u>            |
| read dc script              |
| read dotlib                 |
| <u>read irdrop</u>          |
| read library update         |
| <u>read_ola</u>             |
| read sdf                    |
| <u>read_spef</u>            |
| <u>read_spf</u>             |
| <u>read_stamp</u>           |
| <u>read_tlf</u>             |
| remove assertions           |
| report analysis coverage    |
| report annotated check      |
| report_annotations          |
| report cell instance        |
| report cell instance timing |
| report clocks               |
| report fanin                |
| report fanout               |
| report functional mode      |
| report inactive arcs        |
| report library              |

| <u>report_net</u>                | . 975 |
|----------------------------------|-------|
| report path exceptions           |       |
| report path groups               |       |
| report path group timing         |       |
| report poles residues            |       |
| report ports                     |       |
| report_timing                    |       |
| reset capacitance limit          |       |
| reset capacitance unit           |       |
| reset clock gating check         |       |
| reset clock info change          |       |
| reset clock insertion delay      | 1020  |
| reset_clock_root                 |       |
| reset clock uncertainty          |       |
| reset constant for timing        |       |
| reset_dcl_calculation_mode       |       |
| reset dcl functional mode        |       |
| reset dcl level                  |       |
| reset_default_slew_time          | 1031  |
| reset disable cell timing        |       |
| reset disable clock gating check |       |
| reset disable timing             | 1035  |
| reset drive cell                 |       |
| reset drive resistance           |       |
| reset_external_delay             |       |
| reset fanout load                | 1043  |
| reset fanout load limit          |       |
| reset feedback loop snipped arcs | 1045  |
| reset functional mode            |       |
| reset generated clock            | 1047  |
| reset_ideal_net                  |       |
| reset input delay                |       |
| reset num external sinks         |       |
| reset_num_external_sources       |       |
| reset operating condition        | 1053  |
| reset operating parameter        | 1055  |

| reset operating voltage 1056    |
|---------------------------------|
| reset path exception            |
| reset path group                |
| reset port capacitance          |
| reset port capacitance limit    |
| reset port wire load            |
| reset propagated clock          |
| reset scale delays              |
| reset slew limit                |
| reset slew thresholds           |
| reset slew time                 |
| reset slew time limit           |
| reset tech info                 |
| reset time borrow limit         |
| reset time unit                 |
| reset wire capacitance          |
| reset wire load                 |
| reset wire load mode            |
| reset wire load selection table |
| reset wire resistance           |
| save mp model                   |
| set annotated check 1094        |
| set annotated delay 1096        |
| set capacitance limit           |
| set capacitance unit            |
| set case analysis 1104          |
| set cell pin load 1106          |
| <u>set_clock</u>                |
| set clock arrival time          |
| set clock gating check 1112     |
| set_clock_info_change           |
| set clock insertion delay 1120  |
| set clock propagation           |
| set clock_required_time         |
| <u>set clock root</u>           |
| set clock transition            |

| set_clock_uncertainty          | 1130 |
|--------------------------------|------|
| set constant for timing        | 1134 |
| set cycle addition             |      |
| set_data_arrival_time          | 1143 |
| set data required time         |      |
| set dcl calculation mode       |      |
| set dcl_functional_mode_       | 1146 |
| set dcl level                  |      |
| set default slew time          |      |
| set disable cell timing        | 1149 |
| set disable clock gating check |      |
| set disable timing             |      |
| set drive_cell                 | 1156 |
| set drive resistance           |      |
| set external delay             |      |
| set false path                 |      |
| set fanout load limit          |      |
| set flow compatible mode       |      |
| set functional mode            |      |
| set generated clock            | 1184 |
| set ideal net                  |      |
| set input delay                | 1193 |
| set max_delay                  |      |
| set min delay                  |      |
| set mp area                    |      |
| set mp global parameter        | 1199 |
| set mp max fanout limit        |      |
| set mp min fanout limit        | 1202 |
| set mp port drive              |      |
| set mp port load               | 1205 |
| set mp_port_max_capacitance    | 1207 |
| set mp port max transition     | 1209 |
| set mp port min capacitance    | 1211 |
| set mp port min transition     | 1213 |
| set mp_technology              | 1215 |
| set num external sinks         | 1217 |

| set num_external_sources         |     |
|----------------------------------|-----|
| set operating conditions         | 219 |
| set operating parameter          |     |
| set operating voltage            | 228 |
| set path_delay_constraint12      | 230 |
| set path group                   |     |
| set port capacitance             | 238 |
| set port capacitance limit       |     |
| set port wire load               |     |
| set propagated clock             | 244 |
| set scale delays                 | 246 |
| set slew limit                   | 248 |
| set slew thresholds              | 249 |
| set slew time                    |     |
| set slew time limit              | 253 |
| set tech info                    |     |
| set time borrow limit            | 263 |
| set time unit                    |     |
| set top timing module            | 267 |
| set wire capacitance             | 269 |
| set wire load                    | 271 |
| set wire load mode               | 274 |
| set wire load selection table 12 |     |
| set wire resistance              | 276 |
| unload dcl rule                  | 277 |
| write assertions                 | 278 |
| write constraints                | 280 |
| write gcf assertions             | 282 |
| write library assertions         | 284 |
| <u>write rspf</u>                | 285 |
| <u>write_sdc</u>                 | 286 |
| <u>write sdf</u>                 | 288 |
| <u>write spf</u>                 | 295 |
| write timing windows             | 296 |

# <u>1</u>

| Temporary Commands 129                         | 8  |
|------------------------------------------------|----|
| Timing Analysis on page 1310Datapath Synthesis | 9  |
| <u>write datapath pdef</u> 130                 | 0  |
| Turning on the Prototype DP GUI 130            | )1 |
| <u>Optimization</u>                            | 12 |
| <u>get cell area</u>                           | 13 |
| <u>get_cell_pin_load</u> 130                   | )4 |
| <u>set cell area</u>                           | )5 |
| <u>set cell pin load</u>                       | 6  |
| <u>PKS</u> 130                                 | )7 |
| <u>generate lut from routes</u> 130            | 8  |
| report steiner route                           | 19 |
| Timing Analysis                                | 0  |
| <u>convert delays to assertions</u> 131        | 1  |
| <u>get cell area</u>                           | 2  |
| <u>set_cell_area</u>                           | 3  |
| write design timing                            | 4  |
| write timing windows clock arrival             | 6  |
| <u>write_timing_windows_fast_mode</u> 131      | 7  |
| write timing windows slack info                | 8  |
|                                                |    |
| Index                                          | 20 |

# Preface

This preface contains the following sections:

- About This Manual on page 23
- <u>Other Information Sources</u> on page 23
- <u>Documentation Conventions</u> on page 25

## **About This Manual**

This manual is a complete alphabetical collection of BuildGates synthesis commands. BuildGates synthesis can be run both in command line mode and in graphical user interface (GUI) mode.

## **Other Information Sources**

For more information about related products, you can consult the sources listed here. The documents you have vary depending on your product licenses.

- AmbitWare Component Reference
- BuildGates Synthesis User Guide
- CeltIC User Guide
- Common Timing Engine (CTE) User Guide
- Constraint Translation for BuildGates Synthesis and Cadence PKS
- Datapath for BuildGates Synthesis and Cadence PKS
- Delay Calculation Algorithm Guide
- Design for Test Using BuildGates Synthesis and Cadence PKS
- Distributed Processing for BuildGates Synthesis
- Glossary for BuildGates Synthesis and Cadence PKS
- GUI Guide for BuildGates Synthesis and Cadence PKS

- HDL Modeling for BuildGates Synthesis
- Low Power for BuildGates Synthesis and Cadence PKS
- Low Power Synthesis Tutorial
- Migration Guide for BuildGates Synthesis and Cadence PKS
- Modeling Generation for Verilog 2001 and the Verilog Datapath Extension
- PKS User Guide
- Synthesis Place-and-Route Flow Guide
- Verilog Datapath Extension Reference
- VHDL Datapath Package Reference
- Known Problems and Solutions in BuildGates Synthesis
- Know Problems and Solutions in Cadence PKS
- What's New in Cadence PKS
- What's New in BuildGates Synthesis

BuildGates synthesis is often used with other Cadence<sup>®</sup> tools during various design flows. The following documents provide information about these tools and flows. Availability of these documents depends on the product licenses your site has purchased.

- Cadence Timing Library Format Reference
- Cadence Pearl Timing Analyzer User Guide
- Cadence General Constraint Format Reference

The following books are helpful references, but are not included with the CD-ROM documentation:

- IEEE 1364 Verilog HDL LRM
- TCL Reference, Tcl and the Tk Toolkit, John K. Ousterhout, Addison-Wesley Publishing Company

## **Documentation Conventions**

#### **Text Command Syntax**

The list below describes the syntax conventions used for the BuildGates Synthesis text interface commands.

| literal  | Nonitalic words indicate keywords that you must enter literally.<br>These keywords represent command or option names.                                                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| argument | Words in italics indicate user-defined arguments or information for which you must substitute a name or a value.                                                                                                                                                                                |
| I        | Vertical bars (OR-bars) separate possible choices for a single argument.                                                                                                                                                                                                                        |
| [ ]      | Brackets denote optional arguments. When used with OR-bars, they enclose a list of choices from which you can choose one.                                                                                                                                                                       |
| { }      | Braces are used to indicate that a choice is required from the list<br>of arguments separated by OR-bars. You must choose one from<br>the list.                                                                                                                                                 |
|          | { argument1   argument2   argument3 }                                                                                                                                                                                                                                                           |
|          | Three dots () indicate that you can repeat the previous argument. If the three dots are used with brackets (that is, [argument]), you can specify zero or more arguments. If the three dots are used without brackets (argument), you must specify at least one argument, but can specify more. |
| #        | The pound sign precedes comments in command files.                                                                                                                                                                                                                                              |

#### **Using Menus**

GUI commands can take one of three forms.

| CommandName | A command name with no dots or arrow executes immediately.           |
|-------------|----------------------------------------------------------------------|
| CommandName | A command name with three dots displays a form for choosing options. |

| CommandName -> | A command name with a right arrow displays an additional menu with more commands. Multiple layers of menus and commands are presented in what are called command sequences, for example: $File - Import - LEF$ . In this example, you go to the File menu, then the Import submenu, and, finally, the LEF command. |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Using Forms    |                                                                                                                                                                                                                                                                                                                    |
|                | A menu button that contains only three dots provides browsing capability. When you select the browse button, a list of choices appears.                                                                                                                                                                            |
| Ok             | The Ok button executes the command and closes the form.                                                                                                                                                                                                                                                            |
| Cancel         | The Cancel button cancels the command and closes the form.                                                                                                                                                                                                                                                         |
| Defaults       | The <i>Defaults</i> button displays default values for options on the form.                                                                                                                                                                                                                                        |
| Apply          | The <i>Apply</i> button executes the command but does not close the form.                                                                                                                                                                                                                                          |

# 1

# **BuildGates Synthesis Commands**

This chapter describes the commands and global variables used with BuildGates<sup>®</sup> Synthesis.

- <u>ac\_shell</u> on page 33
- <u>add\_netconn</u> on page 36
- alias on page 37
- <u>all children</u> on page 38
- <u>all parents</u> on page 40
- bg shell on page 41
- bgx shell on page 44
- <u>check netlist</u> on page 47
- <u>check\_option</u> on page 49
- <u>create instance</u> on page 52
- <u>create module</u> on page 53
- <u>create\_net</u> on page 54
- <u>create port</u> on page 56
- <u>delete attribute</u> on page 57
- <u>delete\_aware\_component</u> on page 58
- <u>delete\_netconn</u> on page 59
- <u>delete object</u> on page 60
- <u>delete\_unconnected\_ports</u> on page 61
- <u>do blast busses</u> on page 62
- <u>do build generic</u> on page 65

- <u>do change module architecture</u> on page 70
- <u>do change name</u> on page 72
- <u>do cleanup netlist</u> on page 77
- <u>do\_copy\_module</u> on page 78
- <u>do create hierarchy</u> on page 80
- <u>do delete buffer</u> on page 82
- <u>do\_dissolve\_hierarchy</u> on page 83
- <u>do extract critical</u> on page 85
- <u>do extract fanin</u> on page 88
- <u>do\_extract\_fanout</u> on page 90
- <u>do extract non critical</u> on page 92
- <u>do fix hold</u> on page 93
- <u>do insert buffer</u> on page 95
- <u>do optimize</u> on page 97
- <u>do pipeline check</u> on page 112
- <u>do pipeline retime</u> on page 113
- <u>do pop module</u> on page 114
- <u>do push module</u> on page 115
- <u>do\_rebind</u> on page 116
- <u>do remove design</u> on page 119
- <u>do rename</u> on page 120
- <u>do\_uniquely\_instantiate</u> on page 122
- <u>do xform buffer</u> on page 124
- <u>do xform buffer tree</u> on page 126
- <u>do\_xform\_clone</u> on page 128
- <u>do xform fast optimize</u> on page 130
- <u>do xform fix design rule violations</u> on page 132

- <u>do\_xform\_fix\_hold</u> on page 134
- <u>do xform fix multiport nets</u> on page 136
- <u>do xform footprint</u> on page 137
- <u>do\_xform\_ipo</u> on page 138
- <u>do xform insert repeaters</u> on page 139
- <u>do xform map</u> on page 141
- <u>do\_xform\_optimize\_generic</u> on page 143
- <u>do xform optimize slack</u> on page 144
- <u>do xform pre placement optimize slack</u> on page 145
- <u>do\_xform\_prevent\_crosstalk</u> on page 146
- <u>do xform prevent wire self heat</u> on page 148
- <u>do xform propagate constants</u> on page 149
- <u>do xform reclaim area</u> on page 150
- <u>do xform remove redundancy</u> on page 152
- <u>do xform resize</u> on page 153
- <u>do\_xform\_restructure</u> on page 155
- <u>do xform run repair file</u> on page 156
- <u>do xform structure</u> on page 161
- <u>do\_xform\_unmap</u> on page 163
- <u>dump\_adb</u> on page 165
- <u>eval bottom up</u> on page 166
- find on page 169
- <u>get area</u> on page 176
- <u>get attribute</u> on page 178
- get build id on page 179
- get buswidth on page 180
- get cell area on page 181

- <u>get\_crosstalk\_threshold</u> on page 182
- <u>get\_crosstalk\_tolerance</u> on page 183
- get current instance on page 184
- <u>get\_current\_module</u> on page 185
- <u>get\_equivalent\_cells</u> on page 186
- <u>get global</u> on page 187
- get hdl file on page 188
- <u>get hdl hierarchy</u> on page 189
- get hdl top level on page 191
- <u>get hdl type</u> on page 192
- <u>get info</u> on page 193
- <u>get message count</u> on page 195
- <u>get\_message\_verbosity</u> on page 196
- get names on page 197
- <u>get net</u> on page 198
- <u>get\_parent\_instances</u> on page 200
- get state of design on page 201
- <u>get\_tempfilename</u> on page 203
- get version on page 204
- <u>help</u> on page 205
- <u>highlight</u> on page 206
- <u>issue message</u> on page 207
- limit on page 208
- <u>quit</u> on page 210
- read\_adb on page 211
- <u>read\_edif</u> on page 213
- <u>read\_symbol</u> on page 214

- <u>read\_symbol\_update</u> on page 215
- <u>read\_verilog</u> on page 216
- <u>read vhdl</u> on page 219
- <u>record\_macro</u> on page 222
- report area on page 223
- <u>report aware library</u> on page 226
- <u>report\_crosstalk\_violations</u> on page 227
- report design rule violations on page 229
- report fsm on page 231
- <u>report\_globals</u> on page 234
- <u>report hierarchy</u> on page 236
- <u>report path group options</u> on page 238
- <u>report\_resources</u> on page 240
- <u>report skewed clock pins</u> on page 245
- report vhdl library on page 246
- <u>report\_wire\_self\_heat\_violation</u> on page 247
- <u>reset crosstalk threshold</u> on page 249
- reset dont modify on page 250
- <u>reset\_failsafe</u> on page 252
- reset global on page 253
- <u>reset register type</u> on page 254
- <u>reset\_vhdl\_library</u> on page 255
- <u>reset wire self heat prevention</u> on page 256
- <u>set attribute</u> on page 257
- set\_aware\_component\_property on page 261
- <u>set aware library</u> on page 262
- <u>set cell property</u> on page 263

- <u>set current instance</u> on page 265
- <u>set current module</u> on page 266
- <u>set dont modify</u> on page 268
- <u>set\_dissolve\_hierarchy</u> on page 267
- set failsafe on page 271
- <u>set global</u> on page 272
- <u>set logic0</u> on page 273
- <u>set logic1</u> on page 274
- <u>set message count</u> on page 275
- <u>set message verbosity</u> on page 276
- <u>set path group options</u> on page 277
- <u>set port property</u> on page 279
- <u>set\_register\_type</u> on page 280
- <u>set table style</u> on page 282
- <u>set unconnected</u> on page 286
- <u>set\_vhdl\_library</u> on page 287
- <u>unalias</u> on page 289
- <u>write adb</u> on page 290
- <u>write\_edif</u> on page 292
- <u>write globals</u> on page 293
- <u>write verilog</u> on page 294
- <u>write\_vhdl</u> on page 296

#### ac\_shell

```
ac_shell [-64] [[-f] filename] [-cmdfile command_filename]
    [-logfile log_filename] [-cdsdocd {on | off}] [-queue] [-expire] [-version]
    [-help] [-continue] [-no_init] [-set var=value ...] [-which] [-gui]
    [-display machine:0] [-geometry intxint+int+int] [-fullscreen] [-large]
    [-limit] [-colormap_colormap_file] [-unique]
```

Starts the BuildGates Synthesis tool. For more detail on starting ac\_shell, refer to <u>Before</u> <u>You Begin</u> in the BuildGates Synthesis User Guide.

#### **Options and Arguments**

| -64                        |                                                                                                                                                                                                                                                                                                                                          |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Starts a 64-bit ac_shell session instead of the default. <i>Default</i> : 32 bit                                                                                                                                                                                                                                                         |
| -cdsdocd {on   off}        | Enables or disables the use of browser-based documentation for ac_shell help. When set to on, the full documentation set is available from the <i>Help</i> button in the GUI. When set to off, only the syntax is displayed in the command line. <i>Default</i> : on when running in GUI mode and off when running in command line mode. |
| -cmdfile <i>command_fi</i> | <i>lename</i><br>Specifies the name of the command file.<br><i>Default</i> : ac_shell.cmd                                                                                                                                                                                                                                                |
| -colormap                  | Specifies the color map file.                                                                                                                                                                                                                                                                                                            |
| -continue                  | Does not exit after an error in Tcl script file.                                                                                                                                                                                                                                                                                         |
| -display machine:0         | Specifies the system display to use.                                                                                                                                                                                                                                                                                                     |
| -expire                    | Displays the expiration date of the license.                                                                                                                                                                                                                                                                                             |
| -f filename                | Displays name of Tcl script file to source at startup. You can use $filename$ without specifying the $-f$ .                                                                                                                                                                                                                              |

| -fullscreen              |                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Allows using the entire screen for the ac_shell.                                                                                                                                                                                                                                                                                                                  |
| -geometry intxin         | <pre>ht+int+int Sets the initial size and position of the GUI main screen window. Where width and height are in pixels. And xoff and yoff are the number of pixels from the corner; a negative value is measured from the bottom or right corners, and a positive value is measured from the top or left corners. No spaces are allowed between the values.</pre> |
|                          | For example: -geometry 800x400+10-30 means create a window 800 by 400 pixels with its left edge offset 10 pixels from the left edge of the screen and its bottom edge offset 30 pixels from the bottom of the screen                                                                                                                                              |
|                          | Valid only in GUI mode.                                                                                                                                                                                                                                                                                                                                           |
| -gui                     | Invokes graphical user interface (GUI) mode                                                                                                                                                                                                                                                                                                                       |
| -help                    | Prints usage message for this command.                                                                                                                                                                                                                                                                                                                            |
| -large                   | Increases the memory limit above 2GB for the process running ac_shell if the memory is available.                                                                                                                                                                                                                                                                 |
| -limit                   | Prints the current datasize limit and memory allocation limit for the machine on which the software will run.                                                                                                                                                                                                                                                     |
| -logfile <i>log_fi</i> . | <i>lename</i><br>Displays the name of the log file.<br><i>Default</i> : ac_shell.log                                                                                                                                                                                                                                                                              |
| -no_init                 | Disables the sourcing of ~/.ambit/.acshrc                                                                                                                                                                                                                                                                                                                         |
| -queue                   | Waits for a license if none is available.                                                                                                                                                                                                                                                                                                                         |

| -set var=value | Initializes a Tcl variable.                                              |
|----------------|--------------------------------------------------------------------------|
| -unique        | Instructs the tool to create unique names for all command and log files. |
| -version       | Displays the version of this ac_shell.                                   |
| -which         | Displays the full path name of the ac_shell executable.                  |

#### Example

The following command starts the BuildGates Synthesis graphical user interface and saves the session log in  $cpu_design.log$ :

> ac\_shell -gui -logfile cpu\_design.log

#### **Related Information**

check option

#### add\_netconn

add\_netconn net\_id pin\_id\_list

Adds new net connections to the given net\_id in the current module. Place connections in the same module as the specified net.

This command does not delete the connection between the pin and the net if one already exists. It will create a generic buffer between the existing net and the new net.

To delete a net connection, use <u>delete netconn</u>.



Use caution when using the add\_netconn command. This command changes the connectivity of the netlist, which can change the functionality of the netlist. You may create timing loops, multiport nets, and short circuits, and connect multiple outputs to the same net. Use the <a href="https://www.change.check\_timing">check\_timing</a> and <a href="https://www.check.com">check\_timing</a> and <a href="https://www.check.com">and</a> and</a> and</a> and</a> and <a href="https://www.check.com">and</a> and</a> and</

#### **Options and Arguments**

| net_id      | Specifies the id of the net where you want to add connections. |
|-------------|----------------------------------------------------------------|
| pin_id_list | Specifies the id list of the pin you want to add to the net.   |

#### Example

The following command adds CLK pin connections of all the instances with the name out1\_reg\_\* to net1:

> add\_netconn [find -net net1] [find -pins out1\_reg\*/CLK]

#### **Related Information**

<u>create\_instance</u>

<u>create\_net</u>

<u>create port</u>

December 2003

## alias

alias command\_name name

Creates a simple alias for command names. It does not support aliasing a command with options to a new name. It only performs a simple renaming of a previously defined command.

A more general mechanism for renaming or repackaging commands is the built-in Tcl proc command.

### **Options and Arguments**

| command_name | Displays the alias name.                  |
|--------------|-------------------------------------------|
| name         | Displays the name of an existing command. |

### **Database Impact**

There is no effect on the database

## Example

This command creates the wv alias for the write\_verilog command:

> alias wv write\_verilog

### **Related Information**

<u>unalias</u>

## all\_children

all\_children [-instances] [-hierarchical] [module\_id | module\_name]

Returns a Tcl list of object identifiers representing the child modules that are instantiated in the specified parent module. Use this routine recursively to traverse through the netlist in a top-down fashion, as shown in the example below.

**Note:** The list returned by the all\_children command excludes black box children unless you use the -instances option.

### **Options and Arguments**

| -instances                      |                                                                                                                                                                            |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 | Returns a Tcl list of object identifiers representing the instance_ids of the instantiated child modules in the specified parent module, including the black box children. |
| -hierarchical                   |                                                                                                                                                                            |
|                                 | Returns the module_ids (or the instance_ids if the -instances option is specified) of all the modules instantiated in the specified module and its submodules.             |
| <pre>module_id   module_n</pre> | ame                                                                                                                                                                        |
|                                 | Specifies the object identifier or name associated with a module.<br>If neither is specified, the command returns the children of the<br>current module.                   |

### Examples

The following command gets the names of children of module a:

```
> get_names [all_children [find -module a]]
b c
```

■ The following command writes a netlist for all children of module a:

```
foreach i [all_children [find -module a]] {
    set_current_module $i
    write_ver $i.ver
  }
```

The following command traverses the hierarchy using attributes:

```
proc traverse_hier {mod} {
    set_current_module $mod
```

```
foreach i [all_children] {
    traverse_hier $i
    }
if {[get_attribute [find -module $mod] MY_ATTR] == ""} {
    set_attribute [find -module $mod] MY_ATTR "visited"
    # do action
    }
```

## **Related Information**

<u>all parents</u>

<u>find</u>

## all\_parents

all\_parents [module\_id | module\_name]

Returns a Tcl list of object identifiers of modules that instantiate the specified module, similar to the all\_children command. This routine is used to do a bottom-up traversal of the netlist hierarchy.

## **Options and Arguments**

module\_id | module\_name

Specifies the object identifier or name associated with a module. If neither is specified, the command returns the parents of the current module.

## **Related Information**

<u>all\_children</u>

<u>find</u>

## bg\_shell

```
bg_shell [-64] [[-f] filename] [-cmdfile command_filename]
    [-logfile log_filename] [-cdsdocd {on | off}] [-queue] [-expire] [-version]
    [-help] [-continue] [-no_init] [-set var=value ...] [-which] [-gui]
    [-display machine:0] [-geometry intxint+int+int] [-fullscreen] [-large]
    [-limit] [-colormap_colormap_file]
```

Starts the BuildGates Synthesis tool. For more detail on starting bg\_shell, refer to <u>Before</u> <u>You Begin</u> in the *BuildGates Synthesis User Guide*.

### **Options and Arguments**

| -64                        |                                                                                                                                                                                                                                                                                                                                          |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Starts a 64-bit ac_shell session instead of the default. <i>Default</i> : 32 bit                                                                                                                                                                                                                                                         |
| -cdsdocd {on   off}        | Enables or disables the use of browser-based documentation for bg_shell help. When set to on, the full documentation set is available from the <i>Help</i> button in the GUI. When set to off, only the syntax is displayed in the command line. <i>Default</i> : on when running in GUI mode and off when running in command line mode. |
| -cmdfile <i>command_fi</i> | <i>lename</i><br>Specifies the name of the command file.<br><i>Default</i> : bg_shell.cmd                                                                                                                                                                                                                                                |
| -colormap                  | Specifies the color map file.                                                                                                                                                                                                                                                                                                            |
| -continue                  | Does not exit after an error in Tcl script file.                                                                                                                                                                                                                                                                                         |
| -display machine:0         | Specifies the system display to use.                                                                                                                                                                                                                                                                                                     |
| -expire                    | Displays the expiration date of the license.                                                                                                                                                                                                                                                                                             |
| -f filename                | Displays the name of the Tcl script file to source at startup. You can use <i>filename</i> without specifying the -f.                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                                                                                                                                                          |

| -fullscreen              |                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Allows using the entire screen for the bg_shell.                                                                                                                                                                                                                                                                                                                 |
| -geometry intxint        | <pre>s+int+int Sets the initial size and position of the GUI main screen window. Where width and height are in pixels. And xoff and yoff are the number of pixels from the corner; a negative value is measured from the bottom or right corners, and a positive value is measured from the top or left corners. No spaces are allowed between the values.</pre> |
|                          | For example: -geometry 800x400+10-30 means create a window 800 by 400 pixels with its left edge offset 10 pixels from the left edge of the screen and its bottom edge offset 30 pixels from the bottom of the screen                                                                                                                                             |
|                          | Valid only in GUI mode.                                                                                                                                                                                                                                                                                                                                          |
| -gui                     | Invokes the graphical user interface (GUI) mode.                                                                                                                                                                                                                                                                                                                 |
| -help                    | Prints the usage message for this command.                                                                                                                                                                                                                                                                                                                       |
| -large                   | Increases the memory limit above 2GB for the process running bg_shell if the memory is available.                                                                                                                                                                                                                                                                |
| -limit                   | Prints the current datasize limit and memory allocation limit for the machine on which the software will run.                                                                                                                                                                                                                                                    |
| -logfile <i>log_file</i> | Displays the name of the log file.<br>Default: bg_shell.log                                                                                                                                                                                                                                                                                                      |
| -no_init                 | Disables the sourcing of ~/.ambit/.acshrc                                                                                                                                                                                                                                                                                                                        |
| -queue                   | Waits for a license if none is available.                                                                                                                                                                                                                                                                                                                        |

| -set var=value | Initializes a Tcl variable.                             |
|----------------|---------------------------------------------------------|
| -version       | Displays the version of this bg_shell.                  |
| -which         | Displays the full path name of the bg_shell executable. |

## Example

The following command starts the BuildGates Synthesis graphical user interface and saves the session log in cpu\_design.log:

> bg\_shell -gui -logfile cpu\_design.log

### **Related Information**

<u>check\_option</u>

# bgx\_shell

```
bgx_shell [-64] [[-f] filename] [-cmdfile command_filename]
    [-logfile log_filename] [-cdsdocd {on | off}] [-queue] [-expire] [-version]
    [-help] [-continue] [-no_init] [-set var=value ...] [-which] [-gui]
    [-display machine:0] [-geometry intxint+int+int] [-fullscreen] [-large]
    [-limit] [-colormap colormap_file]
```

Starts the BuildGates Extreme Synthesis tool. For more detail on starting bgx\_shell, refer to Before You Begin in the BuildGates Synthesis User Guide.

### **Options and Arguments**

| -64                        |                                                                                                                                                                                                                                                                                                                                           |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Starts a 64-bit bgx_shell session instead of the default. <i>Default</i> : 32 bit                                                                                                                                                                                                                                                         |
| -cdsdocd {on   off}        | Enables or disables the use of browser-based documentation for bgx_shell help. When set to on, the full documentation set is available from the <i>Help</i> button in the GUI. When set to off, only the syntax is displayed in the command line. <i>Default</i> : on when running in GUI mode and off when running in command line mode. |
| -cmdfile <i>command_fi</i> | <i>lename</i><br>Specifies the name of the command file.<br><i>Default</i> : bgx_shell.cmd                                                                                                                                                                                                                                                |
| -colormap                  | Specifies the color map file.                                                                                                                                                                                                                                                                                                             |
| -continue                  | Does not exit after an error in Tcl script file.                                                                                                                                                                                                                                                                                          |
| -display machine:0         | Specifies the system display to use.                                                                                                                                                                                                                                                                                                      |
| -expire                    | Displays the expiration date of the license.                                                                                                                                                                                                                                                                                              |
| -f filename                | Displays the name of the Tcl script file to source at startup. You can use <i>filename</i> without specifying the -f.                                                                                                                                                                                                                     |
|                            |                                                                                                                                                                                                                                                                                                                                           |

| -fullscree | מי         |                                                                                                                                                                                                                                                                                                                                                                      |
|------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rurrber ee |            | Allows using the entire screen for the bgx_shell.                                                                                                                                                                                                                                                                                                                    |
| -geometry  | intxint+i. | nt+int<br>Sets the initial size and position of the GUI main screen window.<br>Where width and height are in pixels. And xoff and yoff<br>are the number of pixels from the corner; a negative value is<br>measured from the bottom or right corners, and a positive value<br>is measured from the top or left corners. No spaces are allowed<br>between the values. |
|            |            | For example: $-geometry \ 800x400+10-30$ means create a window 800 by 400 pixels with its left edge offset 10 pixels from the left edge of the screen and its bottom edge offset 30 pixels from the bottom of the screen                                                                                                                                             |
|            |            | Valid only in GUI mode.                                                                                                                                                                                                                                                                                                                                              |
| -gui       |            | Invokes the graphical user interface (GUI) mode                                                                                                                                                                                                                                                                                                                      |
| -help      |            | Prints the usage message for this command.                                                                                                                                                                                                                                                                                                                           |
| -large     |            | Increases the memory limit above 2GB for the process running bgx_shell if the memory is available.                                                                                                                                                                                                                                                                   |
| -limit     |            | Prints the current datasize limit and memory allocation limit for the machine on which the software will run.                                                                                                                                                                                                                                                        |
| -logfile I | log_filena | me<br>Displays the name of log file.<br>Default: bgx_shell.log                                                                                                                                                                                                                                                                                                       |
| -no_init   |            | Disables the sourcing of ~/.ambit/.acshrc                                                                                                                                                                                                                                                                                                                            |
| -queue     |            | Waits for a license if none is available.                                                                                                                                                                                                                                                                                                                            |

| -set var=value | Initializes a Tcl variable.                              |
|----------------|----------------------------------------------------------|
| -version       | Displays the version of this bgx_shell.                  |
| -which         | Displays the full path name of the bgx_shell executable. |

## Example

The following command starts the BuildGates Extreme Synthesis graphical user interface and saves the session log in cpu\_design.log:

> bgx\_shell -gui -logfile cpu\_design.log

### **Related Information**

<u>check\_option</u>

## check\_netlist

```
check_netlist [-module module] [-blocklevel] [-verbose] [-ignore_loops]
    [file_name]
```

Performs a number of checks on the structural connectivity of the netlist, including recursively defined modules, combinational feedback, undriven nets and pins, multiple driven nets and pins, and undriven ports.

This command can be applied to generic and mapped modules.

**Note:** The following applies to warning messages which may be printed out when using this command:

- A **multiple** driven net is a net that has multiple drivers. For example, two AND gates drive the same net which causes signal contention.
- A **potential multiple** driven net is a net that is driven by more than one bidirectional pin or port. It is allowable at any time for there to be only one driver while the rest of the bidirectional pins or ports are sinks. Otherwise, this causes signal contention, as in multiple nets above. Bidirectional pins can be created when an instance is a black box, therefore BuildGates Synthesis cannot determine the true direction of pins.

## **Options and Arguments**

| -blocklevel           | Checks the current module only, not the hierarchy.                                                                                              |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| file_name             | Displays optional file name for the output.                                                                                                     |
| -ignore_loops         | Does not report combinational loops.                                                                                                            |
| -module <i>module</i> | Checks a specific module. By default, check_netlist checks the current module.                                                                  |
| -verbose              | Prints detailed information for each violation check and also the summary. Also reports floating inputs or nets in RTL and gate level netlists. |

### Example

The following shows sample output for the check\_netlist command:

```
> check_netlist
The number of recursively defined modules (at least):0
The number of combinational feedbacks(at least):0
The total number of undriven nets/pins:0
The total number of multiple driven nets:0
The total number of potential multiple driven nets:1
The total number of undriven ports:0
```

# check\_option

```
check_option [-hide | -show {-datapath | -power | -64 | -large | -PKS | -no_PKS |
-gui | -visual}]
[[-]datapath] [[-]power] [[-]64] [[-]large] [[-]PKS] [[-]no_PKS] [[-]gui]
[[-]visual]
```

Determines which command line options the current ac\_shell executable has been invoked. It returns all enabled options when the command is invoked without any arguments. Options which enable a feature are printed in capitalized letters. When invoking the ac\_shell, all options invoking features can be entered in any upper and / or lower case combination.

The invokable options (datapath, power, 64, large, PKS, no\_PKS, gui, and visual) may be specified with or without the preceding dash to return different types of values. The option without a dash will return a 1 or 0 to indicate ac\_shell is running with or without the option enabled, respectively. The option with a dash will return the name of the enabled option or the empty set ("") if the option is not enabled. See examples below for clarification.

### **Options and Arguments**

| -64       | If the current session was executed with ac_shell -64,<br>the check_option command:<br>Returns 1 If the 64 option is specified.<br>Returns the word -64 if the -64 option is specified.                                                   |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -datapath | If the current session was executed with ac_shell -datapath<br>(the Datapath feature), the check_option command:<br>Returns 1 If the datapath option is specified.<br>Returns the word -Datapath if the -datapath option is<br>specified. |
| -gui      | If the current session was executed with ac_shell -gui<br>(the graphical user interface), the check_option command:<br>Returns 1 If the gui option is specified.<br>Returns the word -gui if the -gui option is specified.                |
| -hide     | Temporarily disables an option that was invoked when ac_shell was started.                                                                                                                                                                |

| -large  |                                                                                                                                                                                                                                      |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | If the current session was executed with ac_shell -large,<br>the check_option command:<br>Returns 1 If the large option is specified.                                                                                                |
|         | Returns the word -large if the -large option is specified.                                                                                                                                                                           |
| -no_PKS | If the current session was executed with ac_shell -no_pks<br>(or without the -pks option), the check_option command:<br>Returns 1 If the no_pks option is specified.<br>Returns the word -no_PKS if the -no_pks option is specified. |
| -PKS    |                                                                                                                                                                                                                                      |
|         | If the current session was executed with ac_shell -pks<br>(the PKS license), the check_option command:<br>Returns 1 If the pks option is specified.<br>Returns the word -PKS if the -pks option is specified.                        |
| -power  |                                                                                                                                                                                                                                      |
|         | If the current session was executed with ac_shell -power<br>(the Low Power feature), the check_option command:<br>Returns 1 If the power option is specified.<br>Returns the word -Power if the -power option is specified.          |
| -show   |                                                                                                                                                                                                                                      |
|         | Re-enables an option that was previously disabled with the -hide option.                                                                                                                                                             |
| visual  |                                                                                                                                                                                                                                      |
|         | This option provides the same functionality as the -gui option<br>and is used only for backward compatibility with previous<br>releases.                                                                                             |
|         | If the current session was executed with ac_shell -visual<br>(the graphical user interface), the check_option command:<br>Returns 1 If the visual option is specified.                                                               |
|         | Returns the word -visual if the -visual option is specified.                                                                                                                                                                         |

### Examples

■ The following example shows the output of the check\_option command for a session invoked with the PKS and GUI options:

```
> check_option [datapath | large | pks | power | gui]
0 0 1 0 1
```

■ The following example shows the output for a session invoked with the PKS option:

```
> check_option -power -pks -large
-PKS
```

■ The following example shows the commands and output for an ac\_shell session started with the -gui and the -large options. This example demonstrates the disabling (-hide) and re-enabling (-show) of the -large option:

```
> check_option -gui -large
-gui -large
> check_option -hide -large
> check_option -gui -large
-gui
> check_option -show -large
> check_option -gui -large
-gui -large
```

## create\_instance

create\_instance [mod\_name\_or\_id | cell\_name\_or\_id] instance\_name

Creates a new instance in the current module that refers to the specified module or cell, and returns the ID number of the new object.



Use caution when using the create\_instance command. Do not use this command without a very good reason: in most cases, there is no check for functionality.

### **Options and Arguments**

| instance_name  | Specifies the name of the instance you want to create.                                                                             |
|----------------|------------------------------------------------------------------------------------------------------------------------------------|
| mod_name_or_id | <pre>cell_name_or_id Specifies either the name or the id of the module or the technology cell for the instantiation created.</pre> |

### Example

The following command creates an instance named i1 that refers to the module named modl in the current module:

> create\_instance mod1 i1

### **Related Information**

<u>add\_netconn</u>

<u>create module</u>

<u>create net</u>

<u>create\_port</u>

<u>find</u>

## create\_module

create\_module module\_name

Creates an empty module with the given name, and returns the ID number of the new object. The created module is linked to all the black boxes in the netlist with the same name. This command also creates the corresponding ports.



Use caution when using the create\_module command. Do not use this command without a very good reason: in most cases, there is no check for functionality.

### **Options and Arguments**

module\_name

Specifies the name of the module you want to create.

### Example

The following command creates a module named mod1:

> create\_module mod1

### **Related Information**

<u>do copy module</u>

<u>do\_rebind</u>

### create\_net

create\_net -vector -begin begin -end end net\_name

Creates a scalar or vector net in the current view with the given name, and returns the ID number of the new object.

Caution

Use caution when using the create\_net command. Do not use this command without a very good reason: in most cases, there is no check for functionality.

### **Options and Arguments**

| -begin <i>begin</i> |                                                                                                                          |
|---------------------|--------------------------------------------------------------------------------------------------------------------------|
|                     | Specifies the begin bit number of the vector net, which is ignored if the -vector option is not specified.<br>Default: 0 |
| -end <i>end</i>     |                                                                                                                          |
|                     | Specifies the end bit number of the vector net, which is ignored if the -vector option is not specified.                 |
| net_name            |                                                                                                                          |
|                     | Specifies the name of the net you want to create.                                                                        |
| -vector             |                                                                                                                          |
|                     | Specifies that the net is a vector.                                                                                      |
|                     | <i>Default</i> : scalar                                                                                                  |

### Examples

- The following command creates a scalar net named aNet:
  - > create\_net aNet
- The following command creates a vector net named bNet[0:7]:
  - > create\_net -vector -begin 0 -end 7 bNet

### **Related Information**

### add\_netconn

December 2003

### create\_instance

<u>create port</u>

### create\_port

Creates a port with the given name and direction for the current module, and returns the ID number of the new object. This automatically updates all the instances referring to the current module.

# Caution

Use caution when using the create\_port command because it can cause simulation failures. In many cases, there is not a check for functionality. Always verify the generated names.

### **Options and Arguments**

| -begin <i>begin</i> | Specifies the begin bit number of the vector net, which is ignored if the -vector option is not specified. <i>Default</i> : 0 |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------|
| -direction {input   | output   bidir}<br>Specifies the direction of the port you want to create.<br><i>Default</i> : bidir                          |
| -end <i>end</i>     | Specifies the end bit number of the vector net, which is ignored if the -vector option is not specified. <i>Default</i> : 0   |
| port_name           | Specifies the name of the port you want to create.                                                                            |
| -vector             | Specifies that the port is a vector.<br><i>Default</i> : scalar                                                               |

### **Related Information**

<u>add netconn</u>

### <u>create\_instance</u>

December 2003

## delete\_attribute

delete\_attribute object\_id attribute\_name

Removes the specified attribute\_name from the specified object\_id.

### **Options and Arguments**

| attribute_name | Displays the name of the attribute to delete. Refer to the set_attribute command's <u>set_attribute</u> on page 257 for a list of tool-defined attributes. |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| object_id      | Displays the object identifier of the module, instance, cellref, net, port, or pin from which to delete the specified <i>attribute_name</i> .              |

### Example

The following command clears the attribute net\_node in the object \$net:

> delete\_attribute \$net net\_node

### **Related Information**

get\_attribute

<u>set\_attribute</u>

### delete\_aware\_component

delete\_aware\_component [-library library\_name] { -all | component\_name }

Deletes the specified aware component or all aware components from the specified library.

### **Options and Arguments**

| -all                    | Specifies that all components in the specified library are deleted.<br>If you use this option and no library is specified, all the<br>components in all aware libraries are deleted. |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| component_name          | Displays the name of the aware component.                                                                                                                                            |
| -library <i>libname</i> | Selects the aware library specified by <i>lib name</i> . If no library or no <i>component name</i> is specified, the first component found in all aware libraries is deleted.        |

### Example

The following command deletes the component AWMYCOMP1 from the library AWMYLIB:

> delete\_aware\_component -library AWMYLIB AWMYCOMP1

### **Related Information**

report aware library

set\_aware\_component\_property

<u>set aware library</u>

## delete\_netconn

delete\_netconn list\_of\_pin\_ids

Deletes any net connections created with the add\_netconn command.

### **Options and Arguments**

list\_of\_pin\_ids

Specifies the pin ids you want to delete from the net.

### **Related Information**

add netconn

<u>delete\_object</u>

## delete\_object

```
delete_object {list_of_object_ids}
```

Deletes any design object. The object type is known to the object, therefore it is unnecessary to specify the type of object.

Be careful when deleting individual objects. To remove all the design objects from the database use the do\_remove\_design command.

Removes the specified design object from the database.

### **Options and Arguments**

{list\_of\_object\_ids}

Provides the list of object identifiers of the objects to be removed.

### **Related Information**

do remove design

### Example

The following command creates a new module, new\_mod, by copying the contents of mod\_a into new\_mod. The object ID of the new module is returned and used to delete the newly created module:

> set id [do\_copy\_module mod\_a new\_mod]
28993

> delete\_object \$id

## delete\_unconnected\_ports

delete\_unconnected\_ports [-preserve\_busses] [-verbose]

Deletes the unconnected input and output ports in the netlist.

### **Options and Arguments**

-preserve\_busses

Recognizes the ports belonging to the busses not deleted so these port busses are preserved.

-verbose

Prints detailed information for each port detailed from the netlist.

## do\_blast\_busses

do\_blast\_busses [-nets] [-ports] [-complex\_ports] [-current\_module]

Removes bus objects in the hierarchy or in the current module. When converted to scalars, the hdl\_array\_generator and hdl\_record\_generator globals are used to name the scalars for array and record busses. The buscomp\_generator global is used to name the scalars of all other busses.

To remove all the bus nets from the top level and the lower levels of the design use the following command:

do\_blast\_busses -nets

Converts pin, port, and net bus objects in the current module or in the hierarchy to scalars. If instances of the module exist they are modified to connect each bit of the previously bussed port separately.

**Note:** The term blast (see argument descriptions) refers to the process of converting pins, ports, and net bus objects in the current module.

### **Options and Arguments**

| -complex_ports  | Blasts complex bus ports, such as array ports and record ports,<br>using the scalar names specified by the<br>hdl_array_generator and hdl_record_generator<br>global commands, respectively. |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <b>TIP</b> : This command argument is useful for generating netlist ports that are easily recognized by formal verification tools.                                                           |
| -current_module | Blasts bus objects only in the current module.                                                                                                                                               |
| -nets           | Blasts bus nets as well as bus pins on the instance.                                                                                                                                         |
| -ports          | Blasts bus ports and complex ports as well as bus pins on the instance.                                                                                                                      |

### Examples

The following example shows two modules, a and b. <u>"Before do blast busses:</u>" contains bus objects before the do\_blast\_busses command is run. In <u>"After do blast busses:</u>" all the bus objects have been removed by the do\_blast\_busses command and converted to scalars:

Before do\_blast\_busses:

```
module a(out);
      output [1:0] out;
      b bl(out);
endmodule
module b(out);
      output [1:0] out;
endmodule
After do blast busses:
module a(\out[1], \out[0]);
      output \out[1] ;
      output \out[0] ;
      b bl(.\out[1] (\out[1] ), .\out[0] (\out[0] ));
endmodule
module b(\out[1] , \out[0] );
      output \out[1] ;
      output \out[0] ;
endmodule
```

Using the hdl\_array\_generator and hdl\_record generator with do\_blast\_busses:

```
package p is
  type arr is array (1 downto 0) of bit_vector(2 downto 0);
  type rec is
    record
    field1 : integer range 0 to 3;
    field2 : arr;
    end record;
end;
use work.p.all;
entity e is
    port(p_rec : in rec;
        __rec : out rec);
end;
architecture a of e is
```

```
begin
  q_rec <= p_rec;</pre>
end;
set_global hdl_array_generator %s\[%d\]
set global hdl record generator %s\[%s\]
do_build_generic
do_blast_busses
entity e is
   port (
_rec[field1][1]\: in std_logic;
_rec[field1][0]\: in std_logic;
_rec[field2][1][2]\: in std_logic;
_rec[field2][1][1]\: in std_logic;
_rec[field2][1][0]\: in std_logic;
_rec[field2][0][2]\: in std_logic;
_rec[field2][0][1]\: in std_logic;
_rec[field2][0][0]\: in std_logic;
      \q_rec[field1][1]\: out std_logic;
      \q_rec[field1][0]\: out std_logic;
      \q_rec[field2][1][2]\: out std_logic;
      \q_rec[field2][1][1]\: out std_logic;
      \q_rec[field2][1][0]\: out std_logic;
      \q_rec[field2][0][2]\: out std_logic;
      \q_rec[field2][0][1]\: out std_logic;
      \q_rec[field2][0][0]\: out std_logic
   );
end entity e;
```

## **Related Information**

```
do remove design
do_rename
```

set global buscomp generator

set global hdl array generator

set global hdl record generator

# do\_build\_generic

```
do_build_generic [-all] [-module name] [-extract_fsm] [-group_all_processes]
    [-group_named_processes] [-group_process list_of_processes]
    [-group_all_subprograms] [-group_subprograms list_of_subprograms]
    [-parameters | -generics tcl_list] [-sleep_mode]
```

Transforms the design read in by the commands read\_vhdl and read\_verilog into a hierarchical, gate-level netlist consisting of technology-independent logic gates, using components from the Ambit Synthesis Technology Library (ATL) and Extended ATL (XATL). The command performs constant propagation, loop unrolling, lifetime analysis, register inferencing, and logic mapping.

You must run do\_build\_generic after specifying the source Verilog or VHDL files for the initial design database and before calling do\_optimize. You must run do\_build\_generic on a netlist even if it is already mapped to the target library. After running do\_build\_generic, any instance of a target library cell in the source description will remain mapped to that cell in the design database.

This command must be executed before any optimization commands can be applied. The generated netlist can then be written as a Verilog netlist (using the write\_verilog command), a VHDL netlist (write\_vhdl), and an AMBIT database (write\_adb). These netlists can be loaded later for optimization and analysis using the read\_verilog, read\_vhdl, and read\_adb commands, respectively.

The options associated with this command allow for customization and control of logical partitions grouped by various processes. When a <code>-group</code> switch is specified, the do\_build\_generic command creates a separate level of hierarchy for the logic generated for each of the specified RTL procedural constructs (process, named process, process listed in <code>list\_of\_processes</code>, subprogram, or subprogram listed in <code>list\_of\_subprograms</code>, respectively) in the design. For VHDL designs, a process is a VHDL process statement, and a subprogram is a VHDL function or procedure. For Verilog designs, a process is a Verilog initial or always block, and a subprogram is a Verilog task or function.

**Note:** Grouping processes or subprograms may result in sub-optimal designs because the logic optimizations performed during the do\_optimize command are applied to each hierarchy separately and are not applied across hierarchy boundaries.

The do\_build\_generic options also allow the user to generate netlists for selected modules in the design hierarchy. The netlist created by this command uses technology-independent logic gates using components from the ATL.

*Default*: This command treats all procedural blocks (initial and always blocks in Verilog and processes in VHDL) as part of the module in which they appear without any hierarchy. When the grouping is done, a new level of hierarchy is created that only contains the logic represented by the selected blocks.



Use the  $\underline{find}$  command to find all instances of a particular module. For example, the following command returns the names of all instance in module  $level2_mod$ .

find -of\_cell\_type level2\_mod

### **Options and Arguments**

-all Builds a generic netlist for all modules in the design hierarchy. If there are multiple top-level modules in the design hierarchy, the -all or -module option must be specified. If -all is specified, the first module returned by [find -top \*] is selected as the top of the design hierarchy and as the default top timing module. -extract\_fsm Extracts fsm for registers marked with the state vector directive. Generates a finite state machine (FSM) to implement each variable identified by the state vector synthesis directive. See "Optimizing and Structuring Finite State Machines" in the HDL Modeling for BuildGates Synthesis user guide for additional information. -generic {{ <generic1> <value1> } ... { <genericN> <valueN> }} Builds a netlist using the generic values specified in the Tcl list. The generic values must be integers. The term "generic" conforms to VHDL nomenclature. In Verilog the term "parameter" is used instead of the VHDL "generic". Generics or parameters can be selectively modified. Therefore, those that are not modified with the -generic option will retain their default value (the value specified in the module). -group all processes Creates a new level of hierarchy by grouping the logic from all the processes. -group\_all\_subprograms Creates a new level of hierarchy by grouping the logic from all of the subprograms.

| -group_named_process                                                                                                                                                                                               | Creates a new level of hierarchy by grouping the logic from all the named processes.                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -group_process list_                                                                                                                                                                                               | of_processes<br>Creates a new level of hierarchy by grouping the logic from all the<br>named processes specified by the list_of_processes.                                                                                                                                                                                                |
| -group_subprograms 1                                                                                                                                                                                               | List_of_subprograms<br>Creates a new level of hierarchy by grouping the logic from the<br>subprograms (functions and tasks in Verilog).                                                                                                                                                                                                   |
| -module <i>name</i>                                                                                                                                                                                                | Builds a generic netlist for the named module and all sub-<br>modules in the hierarchy. Selects the named module as the top<br>of the design hierarchy and as the default top timing module. The<br>commands get_hdl_hierarchy and get_hdl_top_level<br>can be used prior to do_build_generic to identify the<br>modules in the database. |
| -parameters {{ <gene< td=""><td>Provides a list of parameter names and values to use for the indicated generics. Each item of the Tcl list is a name-value pair. For example: {{WIDTH 4} {HEIGHT 7}}.</td></gene<> | Provides a list of parameter names and values to use for the indicated generics. Each item of the Tcl list is a name-value pair. For example: {{WIDTH 4} {HEIGHT 7}}.                                                                                                                                                                     |
| -sleep_mode                                                                                                                                                                                                        | Explores areas of the design where power could be saved by using the sleep mode technique and inserts sleep-mode logic for commitment during gate level power optimization.                                                                                                                                                               |

## Examples

- The following sequence of commands reads a Verilog file, design.v, performs highlevel optimizations and resource allocation, and then reports the hierarchy.
  - > read\_verilog design.v
  - > do\_build\_generic
  - > report\_hierarchy
- The following commands build a generic netlist for all modules:

```
> do_build_generic
```

or:

```
> do_build_generic -all
```

#### or:

```
> do_build_generic -module des_top
```



Two parameters are specified in the following module:

```
module m(q, d1, d2);
parameter w1 = 4, w2 = 8;
output [w1+w2-1:0] q;
input [w1-1:0] d1;
input [w2-1:0] d2;
assign q = d1 * d2;
```

endmodule

The following command specifies a new value for the w2 parameter:

> do\_build\_generic -module m -generic { {w2 4} }

The w1 parameter in this case will retain its original value of 4.

■ The following command builds a generic netlist for unit1, blk11, and blk12, as shown in the Figure 1-1 on page 68:

> do\_build\_generic -module unit1

### Figure 1-1 Building a Generic Netlist



■ The following command elaborates the design for a module named FOO which has three parameters: WIDTH, HEIGHT, and LENGTH by providing specific values for the parameters:

> do\_build\_generic -design FOO parameters { {WIDTH 4} {HEIGHT 2} }

If parameter LENGTH is not specified in the command line, the default value is used.

### **Related Information**

do dissolve hierarchy

<u>do remove design</u>

<u>get\_hdl\_hierarchy</u>

<u>get hdl top level</u>

<u>read\_symbol</u>

read\_verilog

<u>read\_vhdl</u>

write assertions

<u>write\_verilog</u>

<u>write\_vhdl</u>

## do\_change\_module\_architecture

```
do_change_module_architecture [-hierarchical]
    [-adder_architecture {rpl | ripple | fcla | cla | csel | csum}]
    [-multiplexer_architecture {encoded | decoded}]
    [-multiplier_architecture {booth | non_booth}] {list_of_modules}
```

Changes the architecture of the adder, multiplexer, and multiplier elements in the relevant Ambitware module. The Ambitware module is resynthesized with the specified architecture values and the old module is replaced by the new one. If the -hierarchical option is specified, the command applies to all the Ambitware sub-modules found in the specified module. If the list of modules is specified, the command is applied to all the modules successively.

Either the -adder\_architecture or -multiplier\_architecture option must be specified. Specifying both options is allowed.

This command applies only to modules built using Datapath synthesis.

License Requirement: BuildGates Extreme Synthesis, or BuildGates Physically Knowledgeable Synthesis (PKS) Synthesis

### **Options and Arguments**

| -adder_architecture  | Specifies the final adder architecture. The valid values are rpl, ripple, fcla, cla, csel, and csum.         |
|----------------------|--------------------------------------------------------------------------------------------------------------|
| -hierarchical        | Applies the command recursively to all the relevant Ambitware sub-modules in the specified module.           |
| -multiplexer_archite | cture<br>Specifies the multiplexer architecture. The valid values are<br>decoded and encoded.                |
| -multiplier_architec | ture<br><b>Specifies the multiplier encoding scheme. The valid values are</b><br>booth <b>and</b> non_booth. |

### Examples

- The following command changes the architecture of adder AWDP\_ADD\_0 to cla:
  - > do\_change\_module -adder\_architecture cla [find -module AWDP\_ADD\_0]

■ The following command changes the architecture of all adder elements in the module *filter* to cla. The -hierarchical option is required because *filter* is not a datapath module:

> do\_change\_module -hierarchical -adder\_architecture cla [find -module filter]

■ The following command changes the architecture of all adder elements in the module *filter* and its sub-modules to cla:

> do\_change\_module -hierarchical -adder\_architecture cla [find -module filter]

■ The following command changes the architecture of all adder elements in the module *filter1*, *filter2*, and their sub-modules to cla:

> do\_change\_module -hierarchical -adder\_architecture cla [find -module filter1
filter2]

## do\_change\_name

do\_change\_name {object\_id new\_name} | {-use\_rules [-verbose] [-log filename]}

Renames objects within the design database. The execution of this command will change the name of one object only. An error will result if you attempt to change to a name that already exists in the corresponding name space.

Upon execution of the command, an attribute is created on the renamed object whose value is the name being replaced. Use get\_info or get\_attribute to retrieve the name. The name of the attribute created reflects the type of object being renamed.

**Note:** The do\_change\_name command handles logical netlist changes only. It does not make any updates to the physical aspects of the design.

There are two modes of operation, single-object name change and rule-based name change:

■ Single object:

do\_change\_name object\_id new\_name

Rules based:

do\_change\_name -use\_rules [-verbose] [-log file]

- □ Uses conversion rules specified by the set\_global dcn\_\* variables.
- □ Process all objects hierarchically from current module down.

Default: no conversion

The following is the order for rule processing:

1. Remove reserved word:

Prefix the reserved words with AMBIT\_ so they don't appear in netlist.

2. Replace first restricted character:

If the *first* character of the name is a restricted character, then it is replaced with the replacement character.

3. Replace last restricted character:

If the *last* character of the name is a restricted character, then it is replaced with the replacement character.

- 4. Replace characters:
  - Pass 1: Any character in the name that is restricted is replaced with the replacement character.
  - □ Pass 2: Any character in the name that is *not* in the allowed list of characters is replaced by the replacement character.
- 5. Add prefix:

The prefix is added if present.

6. Check length and chop back middle if required:

The name length is checked. If it is too long, characters are removed from middle until the name is the correct length.

7. Check for name collisions and change name, if required:

New names are checked for collisions with existing names. If there is a collision a new unique name is created.

The following are set\_global variable conversion rules. See the <u>Common Variables</u> chapter of the *Global Variable Reference for BuildGates Synthesis and Cadence PKS* for additional details.

| Global Variable            | Comments                                            |  |
|----------------------------|-----------------------------------------------------|--|
| Net:                       |                                                     |  |
| dcn_net_allow_conversion   | Set if conversion allowed<br>Default: no conversion |  |
| dcn_net_max_length         | Max name length                                     |  |
| dcn_net_allowed            | String of allowed characters                        |  |
| dcn_net_first_restricted   | String of first restricted characters               |  |
| dcn_net_last_restricted    | String of last restricted characters                |  |
| dcn_net_map                | List of old net name and new net name               |  |
| dcn_net_remove_chars       | String of characters to remove                      |  |
| dcn_net_replacement_char - | Single replacement character                        |  |
| dcn_net_reserved_words     | String of reserved words to change                  |  |
| dcn_net_restricted         | String of all restricted characters                 |  |
| dcn_net_prefix             | Prefix to add to name                               |  |

December 2003

# Command Reference for BuildGates Synthesis and Cadence PKS BuildGates Synthesis Commands

| Global Variable           | Comments                                            |
|---------------------------|-----------------------------------------------------|
| Bus:                      |                                                     |
| dcn_bus_allow_conversion  | Set if conversion allowed<br>Default: no conversion |
| dcn_bus_map               | List of old bus name and new bus name               |
| dcn_bus_max_length        | Max name length                                     |
| dcn_bus_allowed           | String of allowed characters                        |
| dcn_bus_restricted        | String of all restricted characters                 |
| dcn_bus_first_restricted  | String of first restricted characters               |
| dcn_bus_last_restricted   | String of last restricted characters                |
| dcn_bus_replacement_char  | Single replacement character                        |
| dcn_bus_remove_chars      | String of characters to remove                      |
| dcn_bus_reserved_words    | String of reserved words to change                  |
| dcn_bus_prefix            | Prefix to add to name                               |
| Instance:                 |                                                     |
| dcn_inst_allow_conversion | Set if conversion allowed<br>Default: no conversion |
| dcn_inst_max_length       | Max name length                                     |
| dcn_inst_allowed          | String of allowed characters                        |
| dcn_inst_restricted       | String of all restricted characters                 |
| dcn_inst_first_restricted | String of first restricted characters               |
| dcn_inst_last_restricted  | String of last restricted characters                |
| dcn_inst_replacement_char | Single replacement character                        |
| dcn_inst_remove_chars     | String of characters to remove                      |
| dcn_inst_reserved_words   | String of reserved words to change                  |
| dcn_inst_prefix           | Prefix to add to name                               |
| dcn_inst_map              | List of old instance name and new instance name     |

# Command Reference for BuildGates Synthesis and Cadence PKS BuildGates Synthesis Commands

| Global Variable             | Comments                                            |
|-----------------------------|-----------------------------------------------------|
| Module:                     |                                                     |
| dcn_module_allow_conversion | Set if conversion allowed<br>Default: no conversion |
| dcn_module_max_length       | Max name length                                     |
| dcn_module_allowed          | String of allowed characters                        |
| dcn_module_map              | List of old module name and new module name         |
| dcn_module_restricted       | String of all restricted characters                 |
| dcn_module_first_restricted | String of first restricted characters               |
| dcn_module_last_restricted  | String of last restricted characters                |
| dcn_module_replacement_char | Single replacement character                        |
| dcn_module_remove_chars     | String of characters to remove                      |
| dcn_module_reserved_words   | String of reserved words to change                  |
| dcn_module_prefix           | Prefix to add to name                               |
| Port:                       |                                                     |
| dcn_port_allow_conversion   | Set if conversion allowed<br>Default: no conversion |
| dcn_port_max_length         | Max name length                                     |
| dcn_port_allowed            | String of allowed characters                        |
| dcn_port_restricted         | String of all restricted characters                 |
| dcn_port_first_restricted   | String of first restricted characters               |
| dcn_port_last_restricted    | String of last restricted characters                |
| dcn_port_map                | List of old port name and new port name             |
| dcn_port_replacement_char   | Single replacement character                        |
| dcn_port_remove_chars       | String of characters to remove                      |
| dcn_port_reserved_words     | String of reserved words to change                  |
| dcn_port_prefix             | Prefix to add to name                               |

# **Options and Arguments**

| -log filename | Writes the conversion progress messages to the specified file only valid for -use_rules option.             |
|---------------|-------------------------------------------------------------------------------------------------------------|
| new_name      | Determines the replacement name for the specified object.                                                   |
| object_id     | Determines the object identifier of the specified object.                                                   |
| -use_rules    | Enables rules-based renaming ability controlled by the set_global command's dcn_* variables.                |
| -verbose      | Prints conversion progress messages in the console (old name to new name) only valid for -use_rules option. |

# Example

The following commands change all occurrences of oldname1 to newname1 and so on:

> do\_change\_name [find -instance instance\_name] new\_name

- > get\_info [find -instance new\_name]
- > dcn\_net\_map [list [list oldname1 newname1] [list oldname2 newname2]]

## **Related Information**

<u>set global</u>

# do\_cleanup\_netlist

do\_cleanup\_netlist [-hierarchical] [-mapped] [-remove\_buffer\_and\_inverter\_pair]

Removes all dangling or unconnected instances in the netlist without regard to timing. This command was designed for cleaning up generic netlists prior to timing optimization.

**Note:** The do\_cleanup\_netlist command does not remove hierarchical self-loops (loops that do not connect to any output).

## **Options and Arguments**

| -hierarchical        | Performs a hierarchical cleanup of the netlist.                                                                                                                                                                                                                                                                                                                       |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -mapped              | Removes unreachable instances from a mapped netlist during the cleanup.                                                                                                                                                                                                                                                                                               |
| -remove_buffer_and_: | Inverter_pair<br>Removes all dangling or unconnected instances <i>and</i> all<br>connected buffers and inverter pairs from a mapped netlist.<br><i>Default</i> : This is the default behavior for a generic netlist.<br><b>Note</b> : Because this command is not timing driven, this option will<br>also strip out any buffer and inverter pairs added for timing or |

## Example

The following command removes floating instances (and any other instances that are not in hierarchical self-loops) in a netlist:

> do\_cleanup\_netlist -hierarchical

# do\_copy\_module

do\_copy\_module module name

Creates a single new module by copying the contents of an existing module to the new module. You can only create one at a time. This command does not descend into the hierarchy of the design. That is, if the module contains instances of other hierarchical objects, those objects and their contents are not copied to the new module. It only works at the level from which it was called.

An example of this is to use the command to cache a module before making changes to the netlist. The effect of the change on the quality of the new netlist can be tested using the get\_area or get\_module\_worst\_slack commands. This command can also be used to perform a uniquify\_module function.

# **Options and Arguments**

module

Specifies the name of the source module.

name

Specifies the name of the new module. The name must be unique.

## Examples

■ The following example demonstrates the creation of a new module, new\_module1, by copying the contents of the source module, a, to the new module:

```
> do_copy_module a new_module1
72705
```

The *object\_id* of the new module is returned and the command can be used as follows:

```
> set_current_module [do_copy_module a new_module2]
72977
```

# **Optimization Loop**

■ The following example shows how to use do\_copy\_module in an optimization loop:

```
proc xform {} {
   set orig_slack [get_module_worst_slack]
   do_copy_module top temp_module
```

```
# do some transforms here with the goal of improving timing
    do_optimize -flatten on -effort high
    set new_slack [get_module_worst_slack]
    if { $new_slack > [expr $orig_slack + 0.001] } {
    # Commit this change if the new slack is better by > 1 ps
        delete_object [find -module temp_module]
    } else {
    # Abort this change since the slack is not significantly better.
        delete_object [find -module top]
        do_rename temp_module top
}
```

#### **Related Information**

<u>do rebind</u>

# do\_create\_hierarchy

```
do_create_hierarchy [-module name] [-instance name] [-no_feedthrough]
      [-dont_preserve_busses] instance_list
```

Creates a new level of hierarchy by placing a list of instances in a new module. The ports of the new module are derived automatically through the connections between the instances that are in the new module and the instances that are outside the new module.

The command do\_create\_hierarchy introduces a new module in the database and alters the existing hierarchy. By default, this command preserves the net and port busses in the newly created hierarchy.

#### **Options and Arguments**

| -dont_preserve_busse  | S                                                                                                                                                                |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | Does not preserve the busses in the new hierarchy.                                                                                                               |
| -instance <i>name</i> | Specifies name of the instance created in the parent module.<br>The default name is generated using instance_generator.                                          |
| instance_list         | Specifies the list of instances that make up the new module.                                                                                                     |
| -module <i>name</i>   | Specifies the name for the new module. The default name is automatically generated using the string set by the attribute.                                        |
| -no_feedthrough       | Does not allow feedthrough wires to be created in the new hierarchy. This prevents the formation of feedthrough ports to model external uses of an input signal. |

## Attributes

set global instance generator

## Example

The following command creates the new module pcimod by placing all instances whose name starts with pci.

> do\_create\_hierarchy -module pcimod [find -inst pci\*]

December 2003

# **Related Information**

do dissolve hierarchy

<u>set global</u>

# do\_delete\_buffer

Deletes the specified buffers or inverters. The search for objects is carried out in the current module. If the object name has a hierarchy in it (for example cnt99/inst1), then the search is carried out at the appropriate hierarchy level.

**Note:** Use the do\_delete\_buffer command only on placed designs, either routed or unrouted. Do not use it on designs that are not yet placed.

# **Arguments and Options**

| -buf_inv_pairs       | When specified with -from_pin, do_delete_buffer removes all buffers and inverter pairs in the buffer tree, starting from the specified pins. This option preserves polarity.                                                                                   |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -from_pin list_of_pi | Ins<br>Deletes all buffers in a buffer tree, starting from the specified<br>pins.                                                                                                                                                                              |
| -inverters           | If specified, do_delete_buffer deletes only inverters. If not specified, do_delete_buffer deletes only buffers.<br>Note: The do_delete_buffer command does not ensure that polarity is preserved. You must make sure that you are deleting inverters in pairs. |
|                      | inverter_names_or_ids                                                                                                                                                                                                                                          |

Specifies the list of buffers or inverters to be removed.

# do\_dissolve\_hierarchy

```
do_dissolve_hierarchy [-hierarchical] [-view name] [ {instance_list |
    module_list}]
```

Dissolves hierarchical instances of modules by flattening the hierarchy of the instance. Each instance specified in the instance\_list is expanded into its parent module. The parent module now contains all the logic for the sub-modules. The hierarchical components inside the modules referenced by the instances are now components in the current module. The new names of the cells in the parent module are derived by appending a number to the original instance. Once dissolved, an instance no longer exists in the design and constraints can not be placed on it.

The netlist changes as the hierarchical components inside the modules referenced by the instances are now components in the current module. *Default*: Dissolves the current module into its parent.

## **Options and Arguments**

| -hierarchical | All hierarchical components of the instances are recursively expanded to flatten the current module. The current module now only has instances of the library cells and instances of the modules marked by the set_dont_modify command. If the instance list and the hierarchical option are not specified, then all instances of the current module are expanded in their respective parent modules. |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| instance_list | Specifies list of all instances to be dissolved.                                                                                                                                                                                                                                                                                                                                                      |
| module_list   | Specifies list of all modules to be dissolved.                                                                                                                                                                                                                                                                                                                                                        |
| -view name    | Specifies list of all names to be dissolved.                                                                                                                                                                                                                                                                                                                                                          |

## Attributes

## <u>set global hierarchy divider</u>

# Example

The following figures show the hierarchical design before and after using this command:

> do\_dissolve\_hierarchy [find -instance unit2].

# Figure 1-2 Before do\_dissolve\_hierarchy



# Figure 1-3 After do\_dissolve\_hierarchy



## **Related Information**

do create hierarchy

<u>do uniquely instantiate</u>

<u>set current module</u>

set dont modify

# do\_extract\_critical

do\_extract\_critical [-critical\_ratio float] [-critical\_offset float]
 [-fanin\_depth integer] [-fanout\_depth integer] [-hierarchical]

Extracts a section of the current module based on the worst slack. The critical\_ratio option allows you to specify a wider extraction region based on a fraction of the worst slack. For example, a critical\_ratio of 0 causes only the critical path to be extracted. A critical ratio value of 0.5 means that all components on paths having slack up to 0.5 times the worst (most negative critical) slack are also extracted. Likewise, the critical\_offset option allows you to specify a wider extraction region based on a specific relative amount from the worst slack. For example, a critical\_offset value of 1.5 means that all nets whose slack falls between the worst slack and the worst slack number minus1.5 time units are extracted including the two nets defining this region. The extracted module can be manipulated or written in the same way as any other design module.

When the -hierarchical option is used, the do\_extract\_critical command extracts the critical path of a design and writes it to a separate new module at each level of the hierarchy, starting with the current module. Thus, all of the hierarchical components on the critical path are extracted from the current module and the hierarchy of the components is maintained. In the absence of this option, extraction is done for the current level of hierarchy. It is not done for sub-levels.

The do\_extract\_\* commands extract sections of the current module and write them to a separate visible module in the design hierarchy. The extracted section of the module is determined by the particular do\_extract\_\* command used. These commands only work on the current module (identified by the set\_current\_module command). Paths between modules are not extracted. To extract a path that exceeds a module boundary, you must execute a do\_dissolve\_hierarchy command to group the desired logic within a single module boundary, then execute the particular do\_extract\_\* command.

In all cases, when using the extraction commands, the extracted module contains more inputs and outputs than expected. This is necessary to capture the arrival and required constraints of the extracted piece of logic in the context of the original module. For example, a net that exists in the middle of a critical path that also fans out to non-critical logic will appear as an output of the extracted module.

A new module and an instance of that module is created by extracting the critical section of the netlist. The hierarchy is changed. You must run the do\_dissolve\_hierarchy command to restore the original hierarchy

#### **Options and Arguments**

| -critical_offset flo  | Dat<br>Indicates the range of slack as a relative amount of the worst<br>slack in the module for which the gates would be extracted.<br>Default: 0, indicating the critical path only.         |  |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| -critical_ratio floa  | at                                                                                                                                                                                             |  |
|                       | Indicates the range of slack as a fraction of the worst slack in the module for which the gates would be extracted. <i>Default</i> : 0, indicating the critical path only.                     |  |
| -fanin_depth integer  |                                                                                                                                                                                                |  |
|                       | Specifies the number of levels of fanin logic to extract. <i>Default</i> : 0                                                                                                                   |  |
| -fanout_depth integer |                                                                                                                                                                                                |  |
|                       | Specifies the number of levels of fanout logic to extract. <i>Default</i> : 0                                                                                                                  |  |
| -hierarchical         |                                                                                                                                                                                                |  |
|                       | Extracts the critical path through the hierarchy starting with the current module and placing the portion extracted from a particular module in its own module at each level of the hierarchy. |  |

#### Example

The following example extracts the path with the worst slack (in the current module), gets the name of the module, and prints a hierarchy report showing where the critical module falls in the hierarchy.

```
> set extracted_mod [do_extract_critical]
73473
> get_name $extracted_mod
top_critical_0_critical_0
```

```
> report_hierarchy
|-top(g)
| |-top_critical_0(g)
| | |-top_critical_0_critical_0(g)
```

# **Related Information**

- do dissolve hierarchy
- <u>do\_extract\_fanin</u>
- <u>do\_extract\_fanout</u>
- do extract non critical

# do\_extract\_fanin

```
do_extract_fanin [-level integer] [-threshold float] [-early] [-module module]
        [-tristate] [-sequential] list_of_object_id
```

Extracts a section of the netlist defined by the fanin-cone of the specified list of object identifiers. All the logic associated with the list of object ids is placed in one extracted module.

**Note:** For more information about extraction commands, see <u>do extract critical</u> on page 85 and <u>do extract fanout</u> on page 90.

A new module and an instance of the module is created by extracting a section of the netlist specified by the fanin-cone. An extra level of hierarchy is added to the design.

#### **Options and Arguments**

| -early                  | Specifies early slack when used with the threshold option. <i>Default</i> : late. This option is also known as hold.                                                                                                                                                                                                                    |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -level integer          | Specifies a maximum number of logic levels to extract. <i>Default</i> : Extracts all the logic in the fanin cone.                                                                                                                                                                                                                       |
| list_of_object_id       | Specifies a list of the nets, pins, or ports from which to start the extraction.                                                                                                                                                                                                                                                        |
| -module <i>module</i>   | Works on the specified module, not the current module.                                                                                                                                                                                                                                                                                  |
| -sequential             | Extracts sequential element into the new module. If not specified,<br>the extraction will not include sequential elements. The value<br>returned is the object id of the module created. If no module is<br>created a null string is returned.                                                                                          |
| -threshold <i>float</i> | Extracts only the logic having a slack of the value specified by $float$ or a worse slack value. The threshold option is an optional qualifier that limits the fanin cone based on slack, not on logic levels. For example, setting a threshold of -2 and a level of 4 extracts all gates within 4-levels of logic of the inputs to the |

|           | given objects that have slack of -2 or worse. The more negative the number for slack, the worse it is.                                                                                                                                                                    |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -tristate |                                                                                                                                                                                                                                                                           |
|           | Extracts a 3-level cone from any bit of the output bus. Cones of logic will include tristate cells and the respective fanin based on the other options specified. Without the -tristate option, command stops extraction on the logic cone when a tristate cell is found. |

# Example

The following command extracts a three-level cone from any bit of the output bus out:

> do\_extract\_fanin -level 3 [find -output -port out\*]

## **Related Information**

do dissolve hierarchy

<u>do extract fanin</u>

<u>do\_extract\_fanout</u>

do extract non critical

# do\_extract\_fanout

```
do_extract_fanout [-level integer] [-threshold float] [-early] [-module module]
        [-tristate] [-sequential] list_of_object_id
```

Extracts a section of the design determined by the fanout cone of the specified list of object identifiers. All the logic associated with the list of object ids is placed in one extracted module.

A new module and an instance of the module is created from the extracted section of the netlist, specified by the fanout cone. A level of hierarchy is added to the design.

**Note:** For more information on the extraction commands see the <u>do extract critical</u> on page 85 and <u>do extract fanin</u> on page 88.

#### **Options and Arguments**

| -early                  | Specifies early slack when used with the threshold option. <i>Default</i> : late. This option is also known as hold.                                                                                                                                                                                                                     |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -level integer          | Specifies a maximum number of logic levels to extract. <i>Default</i> : Extracts all the logic in the fanout cone.                                                                                                                                                                                                                       |
| list_of_object_id       | Specifies a list of the nets, pins, or ports from which to start the extraction.                                                                                                                                                                                                                                                         |
| -module <i>module</i>   | Works on the specified module, not the current module.                                                                                                                                                                                                                                                                                   |
| -sequential             | Extracts sequential element into the new module. If not specified,<br>the extraction will not include sequential elements. The value<br>returned is the object id of the module created. If no module is<br>created a null string is returned.                                                                                           |
| -threshold <i>float</i> | Extracts only the logic having a slack of the value specified by $float$ or a worse slack value. The threshold option is an optional qualifier that limits the fanout cone based on slack, not on logic levels. For example, setting a threshold of -2 and a level of 4 extracts all gates within 4-levels of logic of the inputs to the |

|           | given objects that have slack of -2 or worse. The more negative the number for slack, the worse it is.                                                                                                                                                                        |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -tristate |                                                                                                                                                                                                                                                                               |
|           | Extracts a 3-level cone from any bit of the input bus. Cones of logic will include tristate cells and the respective fanout based on the other options specified. Without the -tristate option, the command stops extraction on the logic cone when a tristate cell is found. |

# Example

The following command extracts a three-level cone from any bit of the input bus in:

> do\_extract\_fanout -level 3 [find -input -port in\*]

# **Related Information**

do dissolve hierarchy

<u>do extract fanin</u>

<u>do\_extract\_fanout</u>

do extract non critical

# do\_extract\_non\_critical

do\_extract\_non\_critical [-critical\_ratio float] [-critical\_offset float]

Extracts the section of the netlist that is not on the critical path. Specifying the -critical\_ratio and -critical\_offset options widens the region of the critical path to be excluded from extraction. This command is rarely used.

A new module and an instance of the module is created by extracting the non critical section of the netlist. A level of hierarchy is added to the design.

See the command do extract critical on page 85 for more general information.

# **Options and Arguments**

-critical\_offset float

Indicates the range of slack as a relative amount of the worst slack in the module for which gates would be excluded from extraction. *Default*: 0, indicating the critical path only.

-critical\_ratio float

Indicates the range of slack as a fraction of the worst slack in the module for which gates would be excluded from extraction. *Default*: 0, indicating the critical path only.

## **Related Information**

do dissolve hierarchy

<u>do\_extract\_fanin</u>

<u>do extract fanout</u>

<u>do extract non critical</u>

# do\_fix\_hold

```
do_fix_hold [-footprint] [-resize] [-buffer] [-dont_modify_children]
    [-no_design_rule] [-minimize] [-max_area float] [-dont_legalize]
    [-critical_ratio float] [-critical_offset float]
```

Attempts to fix hold times without trying to fix setup times. Allows the worsening of any setup slack to fix hold, but it tries to choose moves that minimize the impact on negative setups. If you do not specify the <code>-dont\_legalize</code> option, <code>do\_fix\_hold</code> also legalizes the placement of the design.

*Default*: If the *-resize* or *-buffer* options are not specified, the command use both options to get the best possible results.

**Note:** The do\_fix\_hold command does not consider regions when moving cells during optimization, so it is possible for some cells to get moved outside their region. In general, cells within a region are moved only when there is a good reason, such as improving timing or routability. If your design requires that cells not be moved outside of their regions, consider using the set\_dont\_move command to mark the instances fixed after initial placement.

# **Options and Arguments**

-buffer

Allows buffers to be used to fix hold violations.

```
-critical_offset float
```

Adds the -critical\_offset number to the value of the worst slack. Similar to the -critical\_ratio option below.

-critical\_ratio float

Indicates the range of slack for paths to be considered critical during hold fixing. Specify the argument float as a fraction (a number from 0 to 1, inclusive) of the worst slack. This option allows a range of worst slack to be considered critical. This should only be used on negative slack. The critical range considered is defined as follows:

```
worst_slack * (1 - critical_ratio) +
critical_offset
Default: 0
```

**Note:** This option ignores path groups. It works on the worst slack of the overall design.

| -dont_legalize       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Prevents placement legalization of the design.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| -dont_modify_childre |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Applies the optimization transform only to the portion of the design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children).                                                                                                                                                                                                                            |
| -footprint           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Substitutes cells with higher (lower) drive capability for the cells with lower (higher) drive, if both cells have the same footprints (in addition to the same functionality). This assures that there are no changes in the placement or routing of the cells. This is also referred to as in-place swapping of cells. This option is useful when operating on a netlist that has been already placed and no significant changes can be made to the netlist. This option implies -resize option. |
| -max_area float      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Prevents timing optimization from increasing area beyond the specified value.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -minimize            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Prevents negative setup from worsening and does not allow any positive setup to become negative, but allows positive setup to become less positive.                                                                                                                                                                                                                                                                                                                                                |
| -no_design_rule      | Tells optimization to completely ignore all design rules.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| -resize              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Replaces a cell with an equivalent cell with a different drive when<br>the new cell contributes toward meeting the goal of the<br>transformation. This only occurs if the library has a choice of<br>cells with the same functionality, but on different drives                                                                                                                                                                                                                                    |

# do\_insert\_buffer

```
do_insert_buffer list_of_nets
    [-fix_hold] [-fraction fraction_value] [-from_sink sink_pin_name]
    [-location {xloc yloc}][-macro macro_name]
    [-tolerance tolerance_value]
```

Attempts to insert one buffer in each net in the specified list and returns a list containing the object IDs of the inserted buffers. If no buffer was inserted, it returns an empty list.

**Note:** You must specify the net name as the first argument. You can specify all other arguments in arbitrary order.

If you do not specify any options, PKS inserts a buffer to improve design rule violations and late slack as much as possible. If you do not specify any options, and no improvement is possible, no buffer will be inserted.

#### **Arguments and Options**

| -fix_hold                    | Instructs PKS to try to fix hold violations on the net.                                                                                                                                                                              |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              | <b>Note</b> : This option only has an effect when used alone or with the -macro option.                                                                                                                                              |
| -fraction fraction_va        | lue                                                                                                                                                                                                                                  |
|                              | Specifies target wire length of the resulting net driven by the original driver, as a fraction of the original wire length. If used with the -from_sink option, the fraction is measured from the target sink instead of the driver. |
|                              | <b>Note</b> : This definition different than the -value option of the reduceNetC command in do_xform_run_repair_file.                                                                                                                |
| -from_sink <i>sink_pin</i> _ | _name<br>Specifies a particular sink pin which must be driven by the new<br>buffer.                                                                                                                                                  |
|                              | <b>Note</b> : This option has no effect unless you use it with the - fraction option.                                                                                                                                                |
| list_of_nets                 | Specifies the nets where buffers should be inserted. You may specify each net by name or object ID.                                                                                                                                  |

| -location $\{x loc y loc$ | c }                                                                                                                                                                                                           |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | Specifies that PKS needs to place a buffer at the point on the route or Steiner tree that is closest to the specified location.                                                                               |
|                           | <b>Note</b> : The location values must be in the same units used in the DEF file.                                                                                                                             |
| -macro <i>macro_name</i>  | Specifies the name of the buffer master cell to use; if not specified, the best master cell (in terms of timing, based on design rule violations and late slack) will be inserted.                            |
| -tolerance tolerance      | e_value                                                                                                                                                                                                       |
|                           | Specifies a tolerance limit for buffer location as a fraction of the original net wire length. PKS inserts a buffer if a location is found within the tolerance limit, otherwise it leaves the net unchanged. |
|                           | Calculation of the wire length variance is based on the amount<br>by which the wire length of each new net exceeds the<br><i>fraction_value</i> specified with the -fraction option.                          |
|                           | For example: if the <i>fraction_value</i> is 0.4, then ideally, the fraction of the wire length before the buffer is 0.4 and the fraction after the buffer is 0.6.                                            |
|                           | If the new nets have fractions 0.35 and 0.7, the relevant value is 0.1, because 0.7 exceeds 0.6 by 0.1.                                                                                                       |
|                           | If the new nets have fractions 0.45 and 0.7, the relevant value is 0.15, because in addition to the 0.1 mentioned above, 0.45 exceeds 0.4 by 0.05.                                                            |
|                           | <b>Note</b> : The -tolerance option is only meaningful when used with the -fraction option.                                                                                                                   |

# do\_optimize

```
do_optimize
   [-start_with {mapping | placement | clock_tree_insertion}]
   [{-stop_before | -stop_after} {mapping | placement | clock_tree_insertion}]
   [-power [no_gatelevel_opt | low | medium | high]] (requires BGX license)
   [-dont_uniquify] [-checkpoint]
```

#### Options that affect generic netlist optimization:

```
[-auto_dissolve_generic integer]
[-flatten {off | auto | on}]
[-priority {area | time}]
[-minimize {multiple_output | single_pass}]
[-phase_assignment]
[-dont_structure]
[-dont_remove_redundancy]
[-force]
```

#### Options affect generic and mapped netlist optimization:

```
[-distributed]
[-no_partition]
[-dont_propagate_constants]
```

#### Options that affect mapped netlist optimization:

```
[-auto_dissolve_mapped integer]
[-scan_file]
[-preserve_scan_configuration]
[-time_budget]
[-remap_for_timing]
[-reclaim_maximum_area]
[-stop_for_power_simulation]
```

#### Options that affect mapped and placed netlist optimization:

```
[-effort {none | low | medium | high}]
[-incremental]
[-dont_reclaim_area]
[-max area float]
{[-critical_ratio ratio] [-critical_offset float]} | [-all_end_points]
[-target slack float]
[-no_design_rule | -design_rule_only | -dont_fix_design_rules]
[-design_rules_have_been_fixed]
[-dont downsize]
[-dont_buffer]
[-dont_clone]
[-dont resize]
[-dont swap pins]
[-dont_restructure]
[-restructure aware]
[-scan_reorder] (requires PKS license)
[-skip scan configuration]
```

```
Options that affect placed netlist optimization (all require PKS license):
```

```
[-insert_clock_tree]
[-skew_clock]
[-prevent_crosstalk]
[-crosstalk_threshold]
[-crosstalk_tolerance]
[-prevent_wire_self_heat]
[-congestion_effort {none | low | medium}
[-dont_legalize | -legalize_only]
```

#### **Options for** do\_optimize -ipo

```
[-change limit int]
[-change file file]
[-checkpoint]
[-max area float]
{[-critical_ratio ratio] [-critical_offset float]} | [-all_end_points]
[-target slack float]
[-no_design_rule | -design_rule_only | -dont_fix_design_rules]
[-dont downsize]
[-dont_resize]
[-dont_buffer}
[-prevent_crosstalk] (requires PKS license)
[-crosstalk_threshold] (requires PKS license)
[-crosstalk tolerance] (requires PKS license)
[-prevent wire self heat] (requires PKS license)
[-dont legalize] (requires PKS license)
[-legalize_only] (requires PKS license)
```

Performs optimization on the current module as specified with the command <u>set current module</u>. Depending on the state of the design, optimization will include some or all of the following: uniquification, constant propagation, structuring, redundancy removal, technology mapping, timing-driven optimization, buffering of multiport nets, and design-rule fixing.

Child modules which are not marked with the dont\_modify attribute are always included in the optimization process.

If the default do\_optimize flow is used, all child modules are simultaneously optimized along with the parent module (current\_module).

If the <code>-time\_budget</code> option is used, some level of optimization is done on the non-uniquified child modules prior to uniquification and optimization of the parent module. With the <code>-time\_budget</code> option, the initial timing optimization of the non-unique child modules uses time budgeting to derive the constraints for each child module. After each child module has undergone this initial optimization, uniquification is performed and the parent module and all child modules are simultaneously optimized as in the default flow. The use of the <code>-time\_budget</code> option may improve the run time and quality of results obtained. The designs

most likely to benefit from this option are those with a fair amount of module reuse or large design databases.

**Note:** During optimization, all early timing constraints as well as all clock constraints are ignored. The following globals are temporarily set:

- timing\_disable\_pulsewidth\_checks on
- timing\_disable\_clockperiod\_checks on
- latch\_time\_borrow\_mode budget

The clock network is implicitly considered dont\_modify.

**Note:** The do\_optimize command does not consider regions when moving cells during optimization, so it is possible for some cells to get moved outside their region. In general, cells within a region are moved only when there is a good reason, such as improving timing or routability. If your design requires that cells not be moved outside of their regions, consider using the set\_dont\_move command to mark the instances fixed after initial placement.

## **Options and Arguments**

-all\_end\_points

Works only on the worst endpoint, and gives up if it cannot improve that endpoint. This argument tells optimization to skip such an endpoint and continue working on the next endpoint until all endpoints that do not meet the target slack have been maximally optimized for timing.

#### -auto\_dissolve\_generic [integer]

Works on *generic* netlists to decide whether to dissolve the instance of the module into the parent module instance. If the number of instances in the module is lower than the specified limit, the module is dissolved.

*Default*: If no value is specified, infinite is used and no action is taken.

#### -auto\_dissolve\_mapped [integer]

Works on *mapped* netlists to decide whether to dissolve the instance of the module into the parent module instance. This option works from the bottom up; child instances are analyzed before their parent instances. If the number of module instances is lower than the specified limit, the module is dissolved. *Default*: If no value is specified, infinite is used and no action is taken.

#### -change\_file filename

Works only with IPO. Changes made to the netlist are written out to the file specified. The program must have write privileges to the directory where the file is to be created. The *filename* can be the full path name to a file. If not, the file is opened in the current directory.

Each line contains information about a specific change in the following format:

change old\_cell new\_cell hierchical\_instance\_name

where *change* is ADD or DELETE or RESIZE;

 $old\_cell$  is the name of the cell bound to this instance initially. If it is a new instance, then it is printed as '-'.

*new\_cell* is the name of the cell bounded to this instance after optimization is completed.

#### -change\_limit integer

Works only with IPO. Indicates the maximum number of changes allowed in the netlist with regards to the number of instances added, deleted, and resized when doing IPO. Connectivity changes (that is, when connection to instances are added, deleted, etc) are not counted. Changes to a particular instance are counted once, for example, if an instance is first created, and then resized in the optimization process, it will be counted as one change in the netlist.

#### -checkpoint

Creates a checkpoint of the design in checkpoint.adb file after each major step. The timing optimization step may create intermediate checkpoints as there are several important changes taking place. The number of times checkpoints are done depends on the effort level and other options used. All other steps create a checkpoint at the end of that step.

There is only one checkpoint.adb file created. If a previous file exists, either from previous session or from previous steps in the current session, it is overwritten with the new adb format information.

| <pre>-congestion_effort {</pre> | none   low   medium  high}<br>Specifies the amount of effort PKS should put into congestion<br>analysis<br>Default: medium):                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 | high<br>Currently the same as medium. Reserved for future<br>enhancements to congestion analysis.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                 | low<br>Congestion analysis is done only at placement-setup time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                 | medium<br>Congestion analysis is done at placement setup as well as in<br>every physical break operation.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                 | <b>none</b><br>No congestion analysis is done.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| -critical_offset flo            | Adds the -critical_offset number to the value of the worst slack. Similar to the -critical_ratio option below.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                 | Note: Do not use this option if you have specified path groups.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -critical_ratio floa            | Indicates the range of slack for paths to be considered critical<br>toward the end of optimization for area reclamation and timing-<br>driven buffer insertion, cloning, and resizing. Specify the<br>argument <i>float</i> as a fraction (a number from 0 to 1, inclusive)<br>of the worst slack. This option allows a range of worst slack to be<br>considered critical. This should only be used on negative slack.<br>The critical range considered is defined as follows:<br>worst_slack * (1 - critical_ratio) +<br>critical_offset |
|                                 | Default: 0 <b>Note:</b> Do not use this option if you have specified path groups.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**Note:** Do not use this option if you have specified path groups. Use the -all\_end\_points and -target\_slack options instead.

| -crosstalk_threshold | I num<br>Specifies a new threshold against which crosstalk prevention is<br>performed. Use this with the -prevent_crosstalk option.<br>Default: MAXFLOAT                                                                                                  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -crosstalk_tolerance | Specifies a number, which together with the calculated or<br>specified threshold, defines a range within which crosstalk<br>violations will be tolerated and need not be fixed. Thus, the<br>crosstalk violation at a net is calculated as the following: |
|                      | violation = worst net transition time - (threshold + tolerance)                                                                                                                                                                                           |
|                      | where a positive number indicates a violation. Use this with the -prevent_crosstalk option.<br>Default: 0                                                                                                                                                 |
| -design_rules_have_b | been_fixed<br>Use this option if design rules violations on the netlist have<br>already been fixed.                                                                                                                                                       |
|                      | When starting with an unplaced design, the default behavior of optimization is to ignore design rules until later in the process. With this option, however, optimization honors design rules from the start.                                             |
|                      | When starting with a placed design, the default behavior is to fix design rule violations before optimizing timing. With this option, however, timing is optimized first, and then any design rule violations are fixed.                                  |
| -design_rule_only    | Performs only design rule fixing and placement legalization.                                                                                                                                                                                              |
| -distributed         | Performs the optimization in distributed mode. This option cannot be applied in conjunction with -time_budget.                                                                                                                                            |
| -dont_buffer         | Prevents the use of buffers during optimization.                                                                                                                                                                                                          |
| -dont_clone          | Prevents the tool from cloning instances during optimization.                                                                                                                                                                                             |

# Command Reference for BuildGates Synthesis and Cadence PKS BuildGates Synthesis Commands

| -dont_downsize       |                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Prevents downsizing of cells. Usually used to prevent area reclaim from downsizing drivers before routing.                                                                                                                                                                                                                                                                        |
| -dont_fix_design_rul | es<br>Flow skips all design rule fixing steps.                                                                                                                                                                                                                                                                                                                                    |
| -dont_legalize       | Prevents placement legalization of the design.                                                                                                                                                                                                                                                                                                                                    |
| -dont_propagate_cons | tants<br>Prevents propagation of constants during optimization.                                                                                                                                                                                                                                                                                                                   |
| -dont_reclaim_area   | Prevents the downsizing and removal of buffers and the decloning of instances to reduce area. By default, area reclamation is done when slack fixing ceases to find improvement. This option is useful when you want prevent area reclamation in parts of the design that are not timing critical. This option cannot be used with the <code>-reclaim_maximum_area</code> option. |
| -dont_remove_redunda | Prevents removal of redundancies during generic optimization.                                                                                                                                                                                                                                                                                                                     |
| -dont_resize         | Prevents resizing during optimization.                                                                                                                                                                                                                                                                                                                                            |
| -dont_restructure    | Prevents restructuring routine from being called for timing optimization.                                                                                                                                                                                                                                                                                                         |
| -dont_structure      | Prevents structuring during generic optimization.                                                                                                                                                                                                                                                                                                                                 |
| -dont_swap_pins      | Prevents the swapping of pins during optimization.                                                                                                                                                                                                                                                                                                                                |
| -dont_uniquify       | Prevents the design from being uniquified. By default do_optimize will uniquify the design. This might be useful to save run time on structuring multiple instantiated modules.                                                                                                                                                                                                   |

| -effort {none   low | <pre>  medium   high} Controls the CPU time spent during the timing optimization step. Default: medium</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | high<br>Further improvements by applying various time- consuming<br>algorithms.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                     | <b>Low</b><br>Operation is done quickly to meet requirements through easy<br>optimization steps.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                     | medium<br>Extra time is spent searching for alternate mappings and<br>structures to meet all the constraints.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                     | <b>none</b><br>No slack optimization is done for path groups that do not have an<br>effort level previously set by the <u>set path group options</u><br>command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| -flatten [on   off  | auto]<br>Controls the operations employed for optimization of logic<br>equations. If flatten option is set to on, the logic equations are<br>flattened into a sum of products form before applying<br>optimization. This generally helps in creating faster and optimal<br>implementation of the logic, even though it may take up extra<br>area (gates). For some circuits, this option may result in<br>excessive run time or memory usage. If flatten option is set to<br>auto, only certain flattening operations are performed; some of<br>the time consuming steps are skipped. The flattening step may<br>be disabled entirely by setting the option to off.<br><i>Default</i> : off. |
| -force              | Restarts optimization with all generic optimizations. In essence,<br>the design is unplaced and unmapped and then reoptimized<br>from scratch.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -incremental        | Indicates that the design is already well-optimized and that design rule violations have been fixed. In addition, optimization occurs at the highest slew depth, unless the global auto_slew_prop_selection is set to false.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| -insert_clock_tree   | Enables automatic clock tree insertion. After automatic clock tree insertion, the tool automatically switches the clock_mode to propagated. All clock tree constraints must be properly set before you run optimization. See <u>do build clock tree</u> for more details.                                  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -legalize_only       | Legalizes the placement of the design and performs additional timing optimizations.                                                                                                                                                                                                                        |
|                      | Starts with do_place -eco and then runs buffer, resize, pinswap, and design rule fixing optimizations to try to recover from any slack and design rule violations that might have occurred from placement legalization, and then runs do_place -eco again. The command has an implied -incremental option. |
| -max_area float      | Prevents timing optimization from increasing area beyond the specified value.                                                                                                                                                                                                                              |
| -minimize {multiple_ | <pre>output   single_pass}<br/>Controls what two-level logic minimization strategy is used when<br/>sum-of-products (SoP) logic is extracted (see the<br/><u>hdl_extract_sum_of_products_logic</u> global variable) or<br/>a netlist is flattened (see -flatten option).</pre>                             |
|                      | multiple_output indicates that equations for all outputs of module will be minimized all together, increasing the chance of product terms of equation being shared among different outputs.                                                                                                                |
|                      | single_pass forces BuildGates Synthesis to perform minimization in one pass, rather than iteratively, to reduce optimization effort for fast run time.                                                                                                                                                     |
| -no_design_rule      | Tells optimization to completely ignore all design rules.                                                                                                                                                                                                                                                  |
| -no_partition        | Prevents automatic partitioning of the design into smaller<br>modules for optimization, irrespective of the size of the module.<br>Each module boundary should be retained as the partition to                                                                                                             |

|                   | optimize. Specifying the -no_partition option generally provides better quality of results than omitting it (although runtime may increase).                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -phase_assignment | Allows BuildGates Synthesis to invert the phase of outputs,<br>perform minimization on both ON-set and OFF-set of the<br>equation, and pick the simpler implementation of logic when PLA<br>is extracted, or when a netlist is flattened to a two-level form. It<br>can apply to either single_output or multiple_output<br>strategy, depending on the setting of option -minimize. When<br>OFF-set of equation is much bigger than ON-set, phase<br>assignment optimization could be very expensive in terms of run<br>time. |
| -power            | Performs all types of power transformations to simultaneously optimize power, delay, and area. This command honors power constraints set with <u>set power optimization options</u> .                                                                                                                                                                                                                                                                                                                                         |
|                   | If you have sleep-mode logic inserted from running the<br><u>do_build_generic</u> -sleep_mode command, do_optimize<br>-power will first commit/decommit the logic based on potential<br>power savings. The -power argument will also commit/<br>decommit clock-gating logic as well as perform the physical<br>knowledgeable decloning, cloning, and root gating if PKS is<br>involved.                                                                                                                                       |
|                   | The effort level you include with the -power argument specifies<br>the scope of the gate-level power optimization that you want. In<br>general, the higher the level, the better the power results, but the<br>longer the run time for the optimization.<br><i>Default</i> : medium                                                                                                                                                                                                                                           |
|                   | Value: Specify one of the following four effort levels:                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                   | high<br>Performs gate-level power optimizations at the highest level. It<br>does more iterations than the low and medium effort levels to<br>minimize the power consumption.                                                                                                                                                                                                                                                                                                                                                  |
|                   | low<br>Performs gate-level transformations, such as resizing, pin                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

swapping, and restructuring, to minimize power consumption while trying to meet timing.

#### medium

Performs the same gate-level transformations as the low effort level, but does more iterations to simultaneously optimize the power and timing. This level is recommend for a non-optimized circuit.

#### no\_gatelevel\_opt

No gate-level optimization is performed.

The following globals might affect the -power transformation:

power clock gate decommit in do opt power clock gate insert in do opt power clone declone in do opt power gatelevel opt in do opt power no sleepmode in resource sharing power opt no tcf power root gate in do opt

-preserve\_scan\_chain\_configuration

Preserves existing pre-placement configuration of scan chains.

-prevent\_crosstalk

Prevents crosstalk problems heuristically by fixing the design such that no net in the design has a transition time longer than a given threshold.

Performed after the design is placed and design rules have been fixed. Options to do\_xform\_prevent\_crosstalk are available to do\_optimize through the following globals when -prevent\_crosstalk is specified: crosstalk\_threshold (*Default*: MAXFLOAT) and crosstalk\_tolerance (*Default*: 0).

-prevent\_wire\_self\_heat

Performs wire-self-heat prevention after a design is placed and the design rules are fixed.

-priority {area | time}

Sets area or timing minimization to be the highest priority of the technology independent optimization step. If you have a loosely

|                        | constrained or unconstrained design, then the priority should be<br>set to area.<br><i>Default</i> : time                                                                                                                                                                                                                                                                                          |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -reclaim_maximum_are   | Specifies that the optimization engine performs area reclamation<br>transforms, allowing any slack to worsen up to the worst negative<br>slack in the design.<br><i>Default</i> :, Area reclamation is only done if slack does not worsen<br>or if it remains positive.                                                                                                                            |
| -remap_for_timing      | Performs timing-driven remapping of the design. After the initial technology mapping is done, the do_optimize command may do remapping of the cells for timing optimization. If this option is not used then do_optimize command will not remap the design.                                                                                                                                        |
| -restructure_aware     | Enables the standard optimization engine to perform combinational logic restructuring on AmbitWare (ACL) modules. Without this option, restructuring can only be achieved through component swapping by the Datapath engine.                                                                                                                                                                       |
| -scan_file <i>file</i> | Declares a file name to be given to the scan report file. This option is used when test synthesis is enabled.<br>Default: top_module.scan                                                                                                                                                                                                                                                          |
| -scan_reorder          | Reorders mapped scan chains during or after placement.                                                                                                                                                                                                                                                                                                                                             |
| -skew_clock            | Inserts buffers on the leaves of the clock tree (when working with<br>a clock-tree inserted design). The clock must be in propagated<br>mode.<br>Default: do_optimize does not modify the clock network.<br>The buffers will be inserted next to the receiving sequential<br>element (flop, latch, RAM, and so forth) in order to improve the<br>worst late slack of any path group in the design. |
|                        | worst late slack of any path group in the design.<br>For more control over which buffers are used, you can set the<br><u>do optimize skew clock buffer list</u> and                                                                                                                                                                                                                                |

| <u>do</u> _ | <u>optimize</u> | _skew_ | <u>clock</u> | <u>ignore</u> | <u>dont</u> | <u>utilize</u> |
|-------------|-----------------|--------|--------------|---------------|-------------|----------------|
| glol        | oals.           |        |              |               |             |                |

-skip\_scan\_configuration

Skips the scan chain connection pass which is implicitly run by  $do_optimize$  if TDRC data is present. This option is to be used on scan-mapped structural netlists only. Avoid using this option with mixed RTL/structural databases. This option allows for preconditioning of the netlist using  $do_optimize$ , while avoiding reconfiguration of the scan chains due to the presence of TDRC data. The goal is to preserve the scan chain architecture.

- -start\_with {mapping | placement | clock\_tree\_insertion} Resumes optimizing where the do\_optimize -stop\_before state\_change command stopped optimizing, or it skips any optimizations prior to the specified state change.
- -stop\_after {mapping | placement | clock\_tree\_insertion} Stops optimization after the specified state change. A do\_optimize -stop\_after state-change can be resumed with just the do\_optimize command.
- -stop\_before {mapping | placement | clock\_tree\_insertion} Stops optimization before the specified state change.

-stop\_for\_power\_simulation

Stops the optimization in a LPS flow at for an appropriate state suitable for performing the simulation for generating TCF. You should dump the netlist after this state and perform simulation and read back the TCF and continue timing and power optimization.

-target\_slack float

Specifies the worst slack allowed for any path in the group. Optimization proceeds until the worst path has a slack equal to or greater than the target slack. *Default*: 0.0

You can specify negative slack to compensate for overconstraining and to cut down on runtime. You can specify a positive value to cause the tool to optimize to a positive slack number.

-time\_budget Uses time budgeting to derive constraints and optimize modules in the design hierarchy; performs a multi-pass optimization, first optimizing in a bottom-up fashion using the time budgeted constraints and then following with a hierarchical compile (default compile) from the root (top-level) module.

### **Global Variables**

Set the following variables using the <u>set\_global</u> command:

do optimize skew clock buffer list

do optimize skew clock ignore dont utilize

map\_inversion\_through\_register

slew propagation mode

<u>target technology</u>

time budget stop before uniquification

<u>time budget min size</u>

### Examples

- The following example shows a series of do\_optimize commands in BuildGates Synthesis:
  - > # optimize the generic netlist
  - > do\_optimize -stop\_before mapping
  - > # the next step is equivalent to "do\_xform\_map -hier"
  - > do\_optimize -start\_with mapping -stop\_after mapping

> # optimize the mapped netlist

> do\_optimize

```
The following example is a series of do_optimize commands in PKS:
# optimize the generic netlist
do_optimize -stop_before mapping
# the next step is equivalent to "do_xform_map -hier"
do_optimize -start_with mapping -stop_after mapping
# do preplacement optimizations on the mapped netlist
do_optimize -stop_before placement
# the next step is equivalent to "do_place"
do_optimize -start_with placement -stop_after placement
do_optimize -dont_legalize
do_optimize -legalize_only
```

# **Related Information**

do dissolve hierarchy

do xform prevent crosstalk

<u>get\_attribute</u>

<u>read\_verilog</u>

<u>set\_attribute</u>

```
<u>set_current_module</u>
```

```
<u>set top timing module</u>
```

write verilog

# do\_pipeline\_check

do\_pipeline\_check

Checks if the current module is a properly pipelined module and returns the number of registers used for each pipeline stage. Use this command before do\_pipeline\_retime to make sure the design is completely combinational and has a proper clock port setup.

# **Options and Arguments**

None

### **Related Information**

do pipeline retime

# do\_pipeline\_retime

do\_pipeline\_retime

Retimes the current\_module to minimize the worst slack. Before retiming, a check is made to see if the module is retimable.

### **Options and Arguments**

None

# **Related Information**

<u>do pipeline check</u>

# do\_pop\_module

do\_pop\_module

Restores the current module that was active before the last do\_push\_module command. Pop and push commands can be stacked arbitrarily. If there is no module on the stack, a do\_pop\_module command sets the current\_module to an empty string.

# **Options and Arguments**

None

### Examples

See the examples for <u>do push module</u> on page 115.

### **Related Information**

<u>do push module</u>

get\_current\_module

# do\_push\_module

do\_push\_module module\_id

Temporarily changes the current module by pushing the existing current module onto an internal stack, and changing the new current module to the module specified. Use the do\_pop\_module command to recover the previous current\_module.

Note: This command does not affect the <u>set\_top\_timing\_module</u>.

# **Options and Arguments**

```
module_id
```

The object identifier of the module that is to be made the current module after pushing the current module on the stack.

# Examples

■ The following command returns the object ID of the current\_module (mod1):

```
> get_names [get_current_module]
mod1
```

■ In this example, module mod2 is pushed onto the top of the stack, changing the current module to mod2:

```
> do_push_module [find -module mod2]
> get_names [get_current_module]
mod2
```

Here, the previous current module is restored from the stack:

```
> do_pop_module
> get_names [get_current_module]
mod1
```

# **Related Information**

<u>do pop module</u>

```
<u>get current module</u>
```

# do\_rebind

```
do_rebind [-create_inst_pins] [-delete_inst_pins]
      [-create_ports] instance_name_or_id cell_name_or_id
```

Changes the reference of any instance from a black box, technology cell, and hierarchical module to any other technology cell and hierarchical module.

A functional match is not required by do\_rebind, but if the pins on the instance do not match the pins on the new technology, cell, and hierarchical module, do\_rebind will try to do the functional match. In case the functional match also fails, the tool will try to make a match between the instance and new technology cell and hierarchical module based on the options specified.

Since a functional match is not a requisite, it is possible to corrupt the logical function of a netlist by rebinding cells inappropriately. Use the function get\_equivalent\_cells to determine the set of functionality equivalent cells for resizing purposes.

The timing analysis information is updated automatically for this change. There is no need to take any additional action to guarantee accurate timing reports or optimization after executing the do\_rebind command. After using the do\_rebind command, parasitics data is removed from the design and replaced by SDF predictors.

# **Options and Arguments**

| -create_instance_pin | S                                                                                                                                                                                                                                                                 |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Creates extra pins on the instance for ports that have no instance pins with the same name.                                                                                                                                                                       |
| -create_ports        |                                                                                                                                                                                                                                                                   |
|                      | Creates extra ports on the hierarchical module for the instance<br>pins that have no corresponding ports. This option is not valid<br>with the -delete_inst_pins option. The -create_ports<br>option is ignored when called for rebinding with a technology cell. |
| -delete_inst_pins    | Deletes the instance pins that have no corresponding port on the technology cell/hierarchical module.                                                                                                                                                             |
| instance_name_or_ic  | I Specifies the object ID or name of the instance to rebind.                                                                                                                                                                                                      |
| cell_name_or_id      | Specifies the new cell name or ID to bind the instance to.                                                                                                                                                                                                        |
|                      |                                                                                                                                                                                                                                                                   |

### Examples

■ The following example rebinds a technology cell instance:

```
> get_names [find -cellref IV*]
IV IVA IVAP IVDA IVDAP IVP
> get_equivalent_cells [find -cellref IV]
IVP IVA IV IVAP B5I B4I B5IP B4IP B2A
> do_rebind [find -instance iv] IVP
Info: Bound instance 'iv' to cell 'IVP' <TCLCMD-705>
```

■ This example rebinds a module instance:

# Before:

```
module top (in, out);
    input in;
    output out;
    sub sub1(in, out);
    sub sub2(in, out);
endmodule
module sub(in, out);
    input in;
    output out;
    assign out = ~in;
endmodule
```

# Script excerpt:

```
> do_copy_module sub sub_copy_1
> do_rebind sub1 sub_copy_1
```

### After:

```
sub sub2(.in(in), .out(out));
sub_copy_1 sub1(.in(in), .out(out));
endmodule
```

# **Related Information**

<u>create instance</u>

<u>do\_copy\_module</u>

<u>get equivalent cells</u>

# do\_remove\_design

do\_remove\_design [-hierarchical] [-all] [{list\_of\_module\_name\_or\_id}]

The do\_remove\_design command deletes modules from the database.

### **Options and Arguments**

-all

| -all                      | Deletes all modules. If you use the -all argument and provide a list_of_module_name_or_id, the list is ignored.                                                                                                                                                                                                                                  |  |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                           | <b>Note</b> : Using the -all argument will not remove globals,<br>clock_propagation mode, ideal clocks, and clock_to clock<br>assertions (such as insertion delays, path exceptions,<br>uncertainty, and so on). If you need to change these settings, you<br>can either exit the tool and restart it, or use the appropriate<br>reset commands. |  |
| -hierarchical             | Deletes the specified module and its hierarchical submodules.                                                                                                                                                                                                                                                                                    |  |
| list_of_module_name_or_id |                                                                                                                                                                                                                                                                                                                                                  |  |

Deletes the specified modules.

# Example

The following command deletes all modules of the current design from the database.

> do\_remove\_design -all

# do\_rename

do\_rename [-hierarchical] [-net] [-instance] [-net\_to\_port]

Changes the names of instances or nets in a design. The generators are used to generate names for instances and the nets created in the design. The ac\_shell has an instance generator and a net generator. The name generators defaults can be set by the set\_global command. See the set\_global net\_generator and set\_global instance\_generator commands on setting net and instance names. You can change the naming convention for nets or instances previously generated in the current module by using the do\_rename command.

To change the name of a specific net or instance use the <u>do change name</u> command.

### **Options and Arguments**

| -hierarchical              | Specifies that the renaming is also to be done for the modules in the downward hierarchical path of the current module.                                                                                                                                                                   |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance                  | Indicates that only the instance names are changed, based on the current instance generator, set using the set_global command. The net names remain unchanged.                                                                                                                            |
| -net                       | Indicates that only the net names are modified based on the current net generator, set using the set_global command. The instance names remain unchanged.                                                                                                                                 |
| -net_to_port               | Sometimes the back-end layout tools require that the net<br>connected to the port be of the same name as the port (to<br>eliminate non structural statement, such as the assign<br>statement in Verilog). This option changes the net names to<br>match that of the ports, when possible. |
| <b>Related Information</b> |                                                                                                                                                                                                                                                                                           |

do blast busses

do\_change\_name

<u>set\_global</u>

- set global buscomp generator
- set global instance generator
- set global net generator

# do\_uniquely\_instantiate

do\_uniquely\_instantiate [-hierarchical | instance\_list]

Creates unique modules for the instances. Use this command when one instance of a module needs to be optimized differently from another. For this purpose, each instance is referenced by a unique module so that different constraints can be applied and different transformations can be performed on each module.

If no option is specified, then only the instances in the current module specified by the set\_current\_module are uniquified.

**Note:** The do\_optimize command and the do\_xform\_propagate\_constants command automatically uniquifies the whole design by default unless the -dont\_uniquify option is used.

### **Options and Arguments**

| -hierarchical | Associates all instances in the hierarchical tree of the current module with uniquely created modules.                                      |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| instance_list | Specifies that only the instances in the instance_list are uniquified. The -hierarchical option is ignored when instance_list is specified. |

### Example

In the design shown in Figure 1-4 on page 123, blk11 and blk21 are instances of an adder (mod\_adder) that need different constraints during optimization. The following command generates the unique modules:

> do\_uniquely\_instantiate blk11 blk21

The two instances would appear as follows (where mod\_adder\_0 and mod\_adder\_1 are unique instances of mod\_adder):

mod\_adder\_0 blk11( ...port connections...); mod\_adder\_1 blk21( ...port connections...);

# Figure 1-4 Example of do\_uniquely\_instantiate



# **Related Information**

do dissolve hierarchy

<u>do optimize</u>

<u>set\_current\_module</u>

# do\_xform\_buffer

```
do_xform_buffer [-dont_modify_children] [-no_design_rule] [-max_area float]
      [-critical_ratio float] [-critical_offset float]
```

Inserts buffers to improve timing on the critical path.

# Important

Use of this command is not recommended or encouraged. Use the following command instead:

do\_optimize -effort low -dont\_size -dont\_clone -dont\_swap\_pins ...

# **Options and Arguments**

```
-critical_offset float
```

Adds the -critical\_offset number to the value of the worst slack. Similar to the -critical\_ratio option below.

-critical\_ratio float

Indicates the range of slack for paths to be considered critical for timing-driven buffer insertion. Specify the argument float as a fraction (a number from 0 to 1, inclusive) of the worst slack. This option allows a range of worst slack to be considered critical. This should only be used on negative slack. The critical range considered is defined as follows:

```
worst_slack * (1 - critical_ratio) +
critical_offset
Default: 0
```

**Note:** This option ignores path groups. It works on the worst slack of the overall design.

-dont\_modify\_children

Applies the optimization transform only to the portion of the design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children).

| -max_area float |                                                                               |
|-----------------|-------------------------------------------------------------------------------|
|                 | Prevents timing optimization from increasing area beyond the specified value. |
| -no_design_rule | <b>-</b>                                                                      |
|                 | Tells optimization to completely ignore all design rules.                     |

# do\_xform\_buffer\_tree

```
do_xform_buffer_tree [-min_fanout value] [-non_hierarchical]
      [-input_ports | -output_ports | -ports | -pins] [-dont_remove_buffers] [net]
```

Inserts balanced buffer trees in the current module and all sub-modules. Each buffer tree insertion is made only if there is no worsening of the local slack at the buffer tree drive cell. If there is no change of slack or the net is unconstrained, the buffer tree is inserted.

One usage of buffer tree insertion is when assembling pieces of an unoptimized design, as in a time budgeting flow. For this reason, a form of the command is provided that creates buffer trees for nets that are connected to module ports or pins only, for greater speed.

Area is not considered. Design rule cost is also not considered, but in practice the design rule violations are usually reduced with a buffer tree in place because the sizing and fanout ratios are controlled in the buffer tree to be optimal for timing, and in most libraries this places the slews, capacitances, and fanouts well within the design rule limits.

By default, any existing buffer tree containing the target net is removed and replaced by a new buffer tree. Optionally, a buffer tree can be inserted with no existing buffer cells removed, but this is not recommended in general as the quality of results is higher when the entire buffer tree is replaced with a new tree.

The do\_xform\_buffer\_tree step is performed automatically by the do\_optimize flow, immediately after the technology mapping (do\_xform\_map) step.

**Note:** Inverted loads are not considered part of the buffer tree. The buffer tree is created from a network of non inverting single input/output buffer cells.

This command is not suitable for post-placement or back-annotated optimization, because it does not preserve annotated capacitances, resistances, or SDF delays as it inserts or replaces buffer trees. Any buffers created by this command will revert to the appropriate wire load model for delay calculation.

Be careful when using the net form of this command in a Tcl loop, as the command itself will be deleting and creating nets in the design. For example, do not attempt this code because the cached list of nets may become obsolete after the first buffer insertion:

```
foreach i [find -nets] {
   do_xform_buffer_tree $i; # may fail second time
}
```

# **Options and Arguments**

| -dont_remove_buffers     | Preserves all buffers in the original design. For a given net, only new buffer cells are added.<br>Default: The existing buffer tree is replaced with a new buffer tree.                                                             |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -input_ports   -outr     | <pre>put_ports   -ports   -pins Inserts buffers only on nets connected to input or output ports, or all ports, or all pins. Cannot be given with the net argument. Default: All nets are considered for buffer tree insertion.</pre> |
| -min_fanout <i>value</i> | Do not insert a buffer tree when the number of loads is less than <i>n</i> .<br><i>Default</i> : 1, which means consider all nets for buffer tree insertion regardless of fanout.                                                    |
| net                      | The object ID of a single net in the design that is to be replaced with a buffer tree. If not given, then all nets are considered for buffer tree insertion.                                                                         |
| -non_hierarchical        | Inserts buffers in the current module only.<br><i>Default</i> : Inserts buffers in the current module and all unique<br>children, recursively.                                                                                       |

# do\_xform\_clone

```
do_xform_clone [-dont_modify_children] [-no_design_rule] [-max_area float]
      [-critical_ratio float] [-critical_offset float]
```

Performs cloning transformations. This command splits up a net into two nets by duplicating the instance driving the original net to improve timing on critical path.

# Important

Use of this command is not recommended or encouraged. Use the following command instead:

do\_optimize -effort low -dont\_size -dont\_buffer -dont\_swap\_pins

# **Options and Arguments**

-critical\_offset float

Adds the -critical\_offset number to the value of the worst slack. Similar to the -critical\_ratio option below.

-critical\_ratio float

Indicates the range of slack for paths to be considered critical for timing-driven cloning. Specify the argument float as a fraction (a number from 0 to 1, inclusive) of the worst slack. This option allows a range of worst slack to be considered critical. This should only be used on negative slack. The critical range considered is defined as follows:

```
worst_slack * (1 - critical_ratio) +
critical_offset
Default: 0
```

**Note:** This option ignores path groups. It works on the worst slack of the overall design.

-dont\_modify\_children

Applies the optimization transform only to the portion of the design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children).

| -max_area float |                                                                               |
|-----------------|-------------------------------------------------------------------------------|
|                 | Prevents timing optimization from increasing area beyond the specified value. |
| -no_design_rule |                                                                               |
|                 | Tells optimization to completely ignore all design rules.                     |

# do\_xform\_fast\_optimize

```
do_xform_fast_optimize [-effort { low | medium | high }] [-resize -buffer] [-one]
      [-critial_ratio float] [-critial_offset float]
```

Performs a simultaneous resizing and rebuffering. The algorithm is fast but the resulting slack may not be optimal.

**Note:** This command can only be used before placement and without backannotation.

### **Options and Arguments**

| -buffer              | Creates buffer trees to improve delays on nets, then skews these trees to improve delay on the critical path.                                                                                                                                                                                                                                                                                                                                                             |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -critical_offset flo | hat.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| offotoar_offoco ffo  | Adds the -critical_offset number to the value of the worst slack. Similar to the -critical_ratio option below.                                                                                                                                                                                                                                                                                                                                                            |
| aritical ratio flo   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -critical_ratio floa | Indicates the range of slack for paths to be considered critical<br>toward the end of optimization for area reclamation and timing-<br>driven buffer insertion, cloning, and resizing. Specify the<br>argument $float$ as a fraction (a number from 0 to 1, inclusive)<br>of the worst slack. This option allows a range of worst slack to be<br>considered critical. This should only be used on negative slack.<br>The critical range considered is defined as follows: |
|                      | worst_slack * (1 - critical_ratio) +<br>critical_offset<br><i>Default</i> :0                                                                                                                                                                                                                                                                                                                                                                                              |
|                      | <b>Note:</b> This option ignores path groups. It works on the worst slack of the overall design.                                                                                                                                                                                                                                                                                                                                                                          |
| -effort {low   mediu | am   high}<br>Controls the CPU time spent during the timing optimization step.<br><i>Default</i> : medium                                                                                                                                                                                                                                                                                                                                                                 |
| -one                 | Parforms only one pass, does not iterate                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Performs only one pass, does not iterate.

#### -resize

Replaces a cell with an equivalent cell with different drive if the new cell contributes toward meeting the goal of the transformation. This only occurs if the library has a choice of cells with the same functionality, but on different drives.

# do\_xform\_fix\_design\_rule\_violations

```
do_xform_fix_design_rule_violations [-footprint] [-resize] [-buffer]
      [-dont_modify_children] [-critical_ratio float] [-critical_offset float]
```

Provides a tighter control and selection on the transformations to be performed on the design. The do\_xform\_fix\_design\_rule\_violations command is another version of the <u>do optimize -design rule only</u> command. The do\_optimize command is preferable for because of better runtime and QOR.

The transformations are applied only to the design rule violators. If none of the three options, resize, buffer, or clone, are used, then by default all three transformations are applied to get the best possible results. In effect, the default is the same as using all the three options.

When you do <u>On and Off Chip Variation Analysis</u>, the max DRV limit is obtained from the library used to compute the late path. Consequently, the min DRV limit is obtained from the library used to compute the early path. Set the pvt corner to be used for late and early path by setting the global pvt\_late\_path and pvt\_early\_path.

**Note:** The do\_xform\_fix\_design\_rule\_vioaltions command does not legalize the design.

Important

Use of this command is not recommended or encouraged. Use the following command instead:

do\_optimize -design\_rule\_only

# **Options and Arguments**

-buffer

Allows buffers to be used to fix design rule violations.

-critical\_offset float

Adds the -critical\_offset number to the value of the worst slack. Similar to the -critical\_ratio option below.

-critical\_ratio float

Indicates the range of slack for paths to be considered critical for design rule violation fixing. Specify the argument float as a fraction (a number from 0 to 1, inclusive) of the worst slack. This option allows a range of worst slack to be considered critical. This should only be used on negative slack. The critical range considered is defined as follows:

|                      | worst_slack * (1 - critical_ratio) +<br>critical_offset<br><i>Default</i> :0                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | <b>Note:</b> This option ignores path groups. It works on the worst slack of the overall design.                                                                                                                                                                                                                                                                                                                                                                                                   |
| -dont_modify_childre | n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                      | Applies the optimization transform only to the portion of the design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children).                                                                                                                                                                                                                            |
| -footprint           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Substitutes cells with higher (lower) drive capability for the cells with lower (higher) drive, if both cells have the same footprints (in addition to the same functionality). This assures that there are no changes in the placement or routing of the cells. This is also referred to as in-place swapping of cells. This option is useful when operating on a netlist that has been already placed and no significant changes can be made to the netlist. This option implies -resize option. |
| -resize              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Replaces a cell with an equivalent cell with different drive if the<br>new cell contributes toward meeting the goal of the<br>transformation. This only occurs if the library has a choice of<br>cells with the same functionality, but on different drives.                                                                                                                                                                                                                                       |

# do\_xform\_fix\_hold

```
do_xform_fix_hold [-footprint] [-resize] [-buffer] [-dont_modify_children]
    [-no_design_rule] [-minimize] [-max_area float]
    [-critical_ratio float] [-critical_offset float]
    [-power]
```

Provides better control for transforming hold violators. It attempts to fix the hold times without trying to fix the setup times. If the <code>-resize</code> or <code>-buffer</code> options are not specified, the default behavior of the command is to use both options to get the best possible results. *Default*: Allows the worsening of any setup slack to fix hold, but it tries to choose moves that minimize the impact on negative setups.



This command will be obsoleted in an upcoming release. Please use  $do_fix_hold$  instead.

# **Options and Arguments**

-buffer

Allows buffers to be used to fix hold violations.

-critical\_offset float

Adds the <code>-critical\_offset</code> number to the value of the worst slack. Similar to the <code>-critical\_ratio</code> option below.

-critical\_ratio float

Indicates the range of slack for paths to be considered critical during hold fixing. Specify the argument float as a fraction (a number from 0 to 1, inclusive) of the worst slack. This option allows a range of worst slack to be considered critical. This should only be used on negative slack. The critical range considered is defined as follows:

```
worst_slack * (1 - critical_ratio) +
critical_offset
Default: 0
```

**Note:** This option ignores path groups. It works on the worst slack of the overall design.

-dont\_modify\_children

Applies the optimization transform only to the portion of the

|                 | design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children).                                                                                                                                                                                                                                                                                                               |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -footprint      | Substitutes cells with higher (lower) drive capability for the cells<br>with lower (higher) drive, if both cells have the same footprints (in<br>addition to the same functionality). This assures that there are no<br>changes in the placement or routing of the cells. This is also<br>referred to as in-place swapping of cells. This option is useful<br>when operating on a netlist that has been already placed and no<br>significant changes can be made to the netlist. This option<br>implies -resize option. |
| -max_area float | Prevents timing optimization from increasing area beyond the specified value.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -minimize       | Prevents negative setup from worsening and does not allow any positive setup to become negative, but allows positive setup to become less positive.                                                                                                                                                                                                                                                                                                                                                                     |
| -no_design_rule | Tells optimization to completely ignore all design rules.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -power          | Selects power as the secondary cost (instead of area) during hold time fixing optimization.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| -resize         | Replaces a cell with an equivalent cell with different drive if the<br>new cell contributes toward meeting the goal of the<br>transformation. This only occurs if the library has a choice of<br>cells with the same functionality, but on different drives.                                                                                                                                                                                                                                                            |

# do\_xform\_fix\_multiport\_nets

```
do_xform_fix_multiport_nets [-dont_modify_children][-fix_constant_ports]
    [-no_design_rule]
```

Splits any net connected to more than one output port into different nets, each driven by a buffer, such that each net is connected to only one port. It transforms nets connected to multiple ports. This transformation may be necessary to make it easier for some of the placement and floorplanning tools to treat the netlist properly. This transformation also inserts a buffer on every pass-through net that directly connects input port to an output port.

**Note:** For best results, do not use do\_xform\_fix\_multiport\_nets on a netlist that may have large fanout multiport nets. This command does not handle large fanout nets efficiently. Multiport nets (or assigns) are best fixed during optimization.

### **Options and Arguments**

| -dont_modify_childre | n                                                                                                                                                                                                                                                                       |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Applies the optimization transform only to the portion of the design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children). |
| -fix_constant_ports  | Performs buffer insertion on constant net (power or ground)<br>driving output ports.<br><i>Default</i> : The connections of constant nets to output ports are not<br>modified.                                                                                          |
| -no_design_rule      | Tells optimization to completely ignore all design rules.                                                                                                                                                                                                               |

# **Related Information**

<u>set\_global fix\_multiport\_nets</u>

# do\_xform\_footprint

```
do_xform_footprint [-quick] [-dont_modify_children] [-no_design_rule]
    [-fix_clock_net] [-dont_reclaim_area | -reclaim_maximum_area]
    [-max_area float] [-incremental] [-critical_ratio float]
    [-critical_offset float]
```

# /Important

This command is obsolete and will be removed in the next full release of the software. Use the do\_xform\_resize -footprint command for comparable results.

# do\_xform\_ipo

do\_xform\_ipo [-change\_limit integer] [-change\_file filename] [-max\_area float]
 [-checkpoint] [-dont\_legalize] [-dont\_swap\_pins] [-dont\_resize]
 [-dont\_buffer] [-dont\_climb\_hill] [-dont\_downsize]

# Important

This command is obsolete and will be removed in the next full release of the software. Use the do\_optimize -ipo command for comparable results.

# do\_xform\_insert\_repeaters

```
do_xform_insert_repeaters [-force] [-levelize] [-load load_value]
    [-macro cell_master_name] [-minimize_delay] [-slew slew_value]
    list_of_net_names_or_ids
```

Adds repeaters to the list of specified nets. If neither the -load or -slew options are specified, buffers are added to meet existing design rule constraints on the nets. If both are specified, buffer locations are chosen to try to obtain slews and net loads less than or equal to the targets.

Use this command on a placed design, routed or unrouted. This command creates the same kind of routing as the original net. For example, if the net has detailed routing, the new buffer tree will also have detailed routing.

**Note:** You need to run incremental froute to complete the route. There is no incremental groute, so groute needs to be routed from scratch.

# **Options and Arguments**

**Note:** If you use do\_xform\_insert\_repeaters with a list of nets but no options, only design rule violations are fixed.

| -force                   |                                                                                                                                                                                                                                                     |  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                          | Instructs PKS to consider the -slew and -load targets as constraints. Also, forces PKS to try to insert at least one buffer, even if this is unnecessary, for fixing design rule violations or timing constraints.                                  |  |
| -levelize                |                                                                                                                                                                                                                                                     |  |
|                          | Instructs PKS to try to minimize the number of levels of buffers<br>used. This is useful for large-fanout nets, especially when setup<br>slack is being optimized.                                                                                  |  |
| list_of_net_names_or_ids |                                                                                                                                                                                                                                                     |  |
|                          | Specifies the list of nets to work on. If nets are not specified, then<br>all nets in the current module and all modules contained in the<br>current module, stopping at the soft block boundaries in case of<br>physical hierarchy, are worked on. |  |
| -load load_value         |                                                                                                                                                                                                                                                     |  |
|                          | Specifies the target $\mathtt{max\_load}$ for the newly created nets in pico-Farads.                                                                                                                                                                |  |

| -macro cell_master_name |                                                                                                                                                                                                                                                                                  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | Provides the name of the buffer cell master to insert. If the name<br>is not specified, PKS chooses the best cell master based on<br>fanout, load, and slew design rule constraints, and on fixing<br>setup violations and minimizing area (in decreasing order of<br>priority). |
| -minimize_delay         |                                                                                                                                                                                                                                                                                  |
|                         | Instructs PKS to try to optimize setup slack on the net.                                                                                                                                                                                                                         |
|                         | <b>Note:</b> If do_xform_insert_repeaters -minimize_delay results in negative slack, PKS automatically tries -levelize along with -minimize_delay. The buffer tree with the best slack is inserted.                                                                              |
| -slew <i>slew_value</i> |                                                                                                                                                                                                                                                                                  |
|                         | Specifies the target slew on all input pins of the buffer tree, including the leaf pins.                                                                                                                                                                                         |

### Examples

- The following command inserts buffers on nets net\_name1 and net\_name2 in order to improve late slack through those nets:
  - > do\_xform\_insert\_repeaters -minimize\_delay {net\_name1 net\_name2}
- The following command inserts buffers on net with object id 123456 to fix design rule violations on that net:

> do\_xform\_insert\_repeaters 123456

# do\_xform\_map

```
do_xform_map [-no_partition] [-force] [-hierarchical] [-timing]
    [-critical_ratio float] [-critical_offset float] [-distributed]
    [-fanin_depth integer] [-fanout_depth integer]
```

Maps the generic netlist to the target technology library. It is used for timing-driven mapping. Timing is implied when using the <code>-timing, -fanin\_depth</code>, or <code>-fanout\_depth</code> options. If the <code>-timing</code> option is used in the absence of any of the other options then timing-driven mapping is only performed on the critical region as specified by the arguments of the <code>-critical\_ratio, -critical\_offset, -fanin\_depth</code>, and <code>-fanout\_depth</code> options whose defaults are all 0.

This command maps a generic cell netlist (ATL) to a technology specific cell netlist.

### **Options and Arguments**

```
-critical offset float
                          Adds the -critical offset number to the value of the worst
                          slack. Similar to the -critical_ratio option below.
                          Default: 0
-critical_ratio float
                          Indicates the range of slack for paths to be considered critical for
                          timing-driving mapping. Specify the argument float as a
                          fraction (a number from 0 to 1, inclusive) of the worst slack. This
                          option allows a range of worst slack to be considered critical.
                          This should only be used on negative slack. The critical range
                          considered is defined as follows:
                          worst_slack * (1 - critical_ratio) +
                          critical offset
                          Default: 0
                          Note: This option ignores path groups. It works on the worst
                          slack of the overall design.
-distributed
                          Performs the optimization in distributed mode.
-fanin_depth integer
                          Extracts the non-critical fanins on the critical path. The
                          integer value specified gives the level up to which the non-
```

|                       | critical fanins of the critical path are extracted. <i>Default</i> : 0                                                                                                                                                                                                      |  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| -fanout_depth integer |                                                                                                                                                                                                                                                                             |  |
| -ranout_depth integ   | Extracts the non critical fanouts on the critical path. The integer value specified gives the level up to which these non-critical fanouts should be extracted in the critical path.<br><i>Default</i> : 0                                                                  |  |
| -force                |                                                                                                                                                                                                                                                                             |  |
|                       | Restarts optimization with all generic optimizations. In essence, the design is unplaced and unmapped and then reoptimized from scratch.                                                                                                                                    |  |
| -hierarchical         |                                                                                                                                                                                                                                                                             |  |
| meraremear            | Performs mappings, unmappings, structuring, or removes<br>redundancies on the modules in the downward path of the<br>current module. It depends on the command being used. If this<br>option is not given, then only the current module is affected by<br>the command used. |  |
| -no_partition         |                                                                                                                                                                                                                                                                             |  |
|                       | Prevents automatic partitioning of the design into smaller<br>modules for optimization, irrespective of the size of the module.<br>Each module boundary should be retained as the partition to<br>optimize.                                                                 |  |
| -timing               |                                                                                                                                                                                                                                                                             |  |
| C                     | Performs timing-driven mapping on the netlist. <i>Default</i> , Area-driven mapping is performed.                                                                                                                                                                           |  |
|                       |                                                                                                                                                                                                                                                                             |  |

# **Related Information**

<u>do\_optimize</u>

<u>do\_xform\_unmap</u>

# do\_xform\_optimize\_generic

```
do_xform_optimize_generic [-checkpoint][-clockgate][-flatten { on | auto | off}]
    [-minimize { single_output | multiple_output }][-phase_assignment]
    [-force][-no_partition][-priority { area | time }][-distributed]
    [-dont_uniquify][-dont_propagate_constants][-dont_structure]
    [-dont_remove_redundancies]
```

```
Important
```

This command is obsolete and will be removed in the next full release of the software. Use the do\_optimize -stop\_before mapping command for comparable results.

# do\_xform\_optimize\_slack

```
do_xform_optimize_slack [-effort { low | medium | high }] [-no_design_rule]
    [-checkpoint] [-max_area float] [-critical_ratio float]
    [-critical_offset float] [-dont_reclaim_area | -reclaim_maximum_area]
    [-incremental] [-pks] [-distributed] [-power] -restructure_aware
    [-stop_before_placement] [-time_budget] [-remap_for_timing]
```

# Important

This command is obsolete and will be removed in the next full release of the software. Use the do\_optimize command for comparable results.

# do\_xform\_pre\_placement\_optimize\_slack

```
do_xform_pre_placement_optimize_slack [-effort { low | medium | high }]
    [-design_rule_have_been_fixed] [-no_design_rule] [-checkpoint]
    [-max_area float] [-critical_ratio float] [-critical_offset float]
    [-distributed] [-dont_reclaim_area | -reclaim_maximum_area] [-incremental]
    [-power] [-time_budget] [-remap_for_timing] [-dont_legalize]
```

# Important

This command is obsolete and will be removed in the next full release of the software. Use the do\_optimize -stop\_before placement command for comparable results.

# do\_xform\_prevent\_crosstalk

```
do_xform_prevent_crosstalk [-threshold num] [-tolerance num]]
     [-change_file filename]
```

Fixes crosstalk problems in a routed design and prevents crosstalk problems during PKS optimization. The do\_xform\_prevent\_crosstalk command is similar to the slew or transition DRV in that crosstalk prevention is a design rule to be fixed. Crosstalk problems are fixed heuristically such that no net in the design has a transition time longer than a given threshold. The threshold is the average transition time across all nets of the design at a given state.

Automatically calculates an average transition time the first time this command is used on a design unless the -threshold option is specified. The average transition time is calculated across all the nets in the design, taking the worst of all rise and fall transition times of each net. This threshold is stored with the design and all subsequent crosstalk operations or reports are carried out using the same threshold to avoid non-convergence, unless a new threshold is specified. See <u>reset crosstalk threshold</u> for information on how to reset the crosstalk threshold.

**Note:** Crosstalk prevention is valid only on a placed netlist. and can be performed while honoring other design rules at the same time. In addition, crosstalk prevention is only performed on data nets, NOT on clock nets.

### **Options and Arguments**

| -change_file <i>filenar</i> | ne<br>Specifies a file into which the tool outputs the changes done to<br>the netlist for crosstalk prevention. Output format is similar to                                                                                                                                                                                                                                                          |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | ipo_change_list.                                                                                                                                                                                                                                                                                                                                                                                     |
| -threshold <i>num</i>       | Specifies a new threshold against which crosstalk prevention is performed.                                                                                                                                                                                                                                                                                                                           |
| -tolerance <i>num</i>       | Specifies a number, which together with the calculated or<br>specified threshold, defines a range within which crosstalk<br>violations will be tolerated and need not be fixed. Thus, the<br>crosstalk violation at a net is calculated as the following:<br>violation = worst net transition time - (threshold + tolerance)<br>where a positive number indicates a violation.<br><i>Default</i> : 0 |

# **Related Information**

<u>do optimize</u>

reset crosstalk threshold

# do\_xform\_prevent\_wire\_self\_heat

do\_xform\_prevent\_wire\_self\_heat [-change\_file filename]

The do\_xform\_prevent\_wire\_self\_heat command is similar to the do\_xform\_ prevent\_crosstalk command as wire-self-heat prevention is completed as just another capacitance limit design rule to be fixed. Valid only on placed designs.

**Note:** The do\_xform\_prevent\_wire\_self\_heat command works only on data nets, *not* on clock nets. In addition, wire-self-heat prevention is completed while honoring and preserving other design rules.

Once wire-self-heat prevention has been performed, it will be stored with the design and used for all subsequent optimizations or design rule fixes, until do\_xform\_prevent\_wire\_self\_heat is reset using the reset\_wire\_self\_heat\_prevention command.

## **Options and Arguments**

-change\_file filename

Specifies a file into which the tool outputs the changes done to the netlist for wire-self-heat prevention.

### **Related Information**

do xform prevent crosstalk

<u>report\_crosstalk\_violations</u>

reset wire self heat prevention

# do\_xform\_propagate\_constants

do\_xform\_propagate\_constants [-dont\_uniquify]

Propagates constants throughout the design crossing hierarchical boundaries. The constants being propagated are the logic levels (0 or 1). This command also propagates unconnected property for the nets connected to those input ports that are not connected (driven) to any driver. The side effect is that it uniquifies all instances unless the -dont\_uniquify option is given.

*Default*: Removes only constant latches. To remove constant flip-flops also, set the global option <u>preserve constant flops</u> to false.

#### **Options and Arguments**

-dont\_uniquify

Tells optimization not to uniquify the design. This can be useful to save run time on structuring multiple instantiated modules.

#### **Related Information**

<u>do optimize</u>

# do\_xform\_reclaim\_area

```
do_xform_reclaim_area [-footprint] [-resize] [-buffer] [-clone]
    [-dont_modify_children] [-no_design_rule] [-critical_ratio float]
    [-critical_offset float] [-reclaim_maximum_area]
```

Applies only those transformations that reduce area, without worsening the worst negative slack. These include replacing cells with smaller area cells that have the same functionality, and removing unnecessary buffers or clones.

If none of the three options, resize, buffer, or clone, are used, then by default all three transformations are applied to get the best possible results. In effect, it is the same as using all the three options.

#### **Options and Arguments**

-buffer

Removes unnecessary buffers from the netlist as long as timing is not worsened.

-clone

Removes unnecessary clones from the netlist.

-critical\_offset float

Adds the -critical\_offset number to the value of the worst slack. Similar to the -critical\_ratio option below.

-critical\_ratio float

Indicates the range of slack for paths to be considered critical t for area reclamation. Specify the argument float as a fraction (a number from 0 to 1, inclusive) of the worst slack. This option allows a range of worst slack to be considered critical. This should only be used on negative slack. The critical range considered is defined as follows:

```
worst_slack * (1 - critical_ratio) +
critical_offset
Default: 0
```

**Note:** This option ignores path groups. It works on the worst slack of the overall design.

-dont\_modify\_children

Applies the optimization transform only to the portion of the

|                      | design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children).                                                                                                                                                                                                                                                                                              |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -footprint           | Substitutes cells with higher drive capability for the cells with<br>lower drive, if both cells have the same footprints (in addition to<br>the same functionality). This assures that there are no changes<br>in the placement or routing of the cells. This is also referred to as<br>in-place swapping of cells. This option is useful when operating<br>on a netlist that has been already placed and no significant<br>changes can be made to the netlist. This option implies -resize<br>option. |
| -no_design_rule      | Tells optimization to completely ignore all design rules.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| -reclaim_maximum_are | Performs area reclamation transforms on any slack that is better<br>than the worst slack.<br><i>Default</i> : Area reclamation is not done on any path that can<br>worsen or create negative slack.                                                                                                                                                                                                                                                                                                    |
| -resize              | Replaces a cell with an equivalent cell with different drive if the<br>new cell contributes toward meeting the goal of the<br>transformation. This only occurs if the library has a choice of<br>cells with the same functionality, but on different drives.                                                                                                                                                                                                                                           |

## do\_xform\_remove\_redundancy

do\_xform\_remove\_redundancy [-hierarchical] [-no\_partition]

Removes redundancies from the netlist. This command maps a generic cell netlist (ATL) to a generic cell netlist.

### **Options and Arguments**

-hierarchical

Performs mappings, unmappings, structuring, or removes redundancies on the modules in the downward path of the current module. It depends on the command being used. If this option is not given, then only the current module is affected by the command used.

-no\_partition Prevents automatic partitioning of the design into smaller modules for optimization, irrespective of the size of the module. Each module boundary should be retained as the partition to optimize.

### **Related Information**

<u>do\_optimize</u>

# do\_xform\_resize

```
do_xform_resize [-footprint] [-dont_modify_children] [-no_design_rule]
    [-critical_ratio float] [-critical_offset float][-max_area float]
    -upsize_only
```

Resizes the cells in the netlist. This command indicates that if the library has choice of cells with the same functionality but different drives, a cell can be replaced by an equivalent cell with different drive if the new cell contributes toward meeting the goal of the transformation.

# Important

Use of this command is not recommended or encouraged. Use the following command instead:

do\_optimize -effort low -dont\_clone -dont\_buffer -dont\_swap\_pins

## **Options and Arguments**

-critical\_offset float

Adds the -critical\_offset number to the value of the worst slack. Similar to the -critical\_ratio option below.

-critical\_ratio float

Indicates the range of slack for paths to be considered critical for timing-driven resizing. Specify the argument float as a fraction (a number from 0 to 1, inclusive) of the worst slack. This option allows a range of worst slack to be considered critical. This should only be used on negative slack. The critical range considered is defined as follows:

```
worst_slack * (1 - critical_ratio) +
critical_offset
Default: 0
```

**Note:** This option ignores path groups. It works on the worst slack of the overall design.

-dont\_modify\_children

Applies the optimization transform only to the portion of the design contained in the current module. In the absence of this option, the transforms are applied to the entire design contained in the current module including its hierarchical descendents (children).

| -footprint      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | Substitutes cells with higher (lower) drive capability for the cells<br>with lower (higher) drive, if both cells have the same footprints (in<br>addition to the same functionality). This assures that there are no<br>changes in the placement or routing of the cells. This is also<br>referred to as in-place swapping of cells. This option is useful<br>when operating on a netlist that has been already placed and no<br>significant changes can be made to the netlist. This option<br>implies -resize option. |
| -max_area float | Prevents timing optimization from increasing area beyond the specified value.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -no_design_rule | Tells optimization to completely ignore all design rules.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -upsize_only    | Allows control of the optimization process so that during resizing,<br>only upsizing moves can be allowed. No downsizing moves are<br>allowed.                                                                                                                                                                                                                                                                                                                                                                          |

# **Related Information**

<u>do\_optimize</u>

# do\_xform\_restructure

do\_xform\_restructure [-effort {low | medium | high}] [-critical\_ratio float]
 [critical\_offset float] [-max\_area float]

Performs restructuring and remapping of the critical path in order to meet the timing constraints.

### **Options and Arguments**

| -critical_offset flo | Adds the -critical_offset number to the value of the worst slack. Similar to the -critical_ratio option below.                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -critical_ratio floa | Indicates the range of slack for paths to be considered critical<br>toward the end of optimization for area reclamation and timing-<br>driven buffer insertion, cloning, and resizing. Specify the<br>argument <i>float</i> as a fraction (a number from 0 to 1, inclusive)<br>of the worst slack. This option allows a range of worst slack to be<br>considered critical. This should only be used on negative slack.<br>The critical range considered is defined as follows: |
|                      | worst_slack * (1 - critical_ratio) +<br>critical_offset<br><i>Default</i> :0                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      | <b>Note:</b> This option ignores path groups. It works on the worst slack of the overall design.                                                                                                                                                                                                                                                                                                                                                                               |
| -effort {low   mediu | <pre>um   high} Controls the CPU time spent during the timing optimization step. Default: medium</pre>                                                                                                                                                                                                                                                                                                                                                                         |
| -max_area float      | Prevents timing optimization from increasing area beyond the specified value.                                                                                                                                                                                                                                                                                                                                                                                                  |

### **Related Information**

<u>do\_optimize</u>

# do\_xform\_run\_repair\_file

do\_xform\_run\_repair\_file -set\_dont\_modify [true | false] repair\_file\_name

Runs the repair file that contains commands to repair nets found to have crosstalk violations. This command requires a PKS license.

#### Notes:

- Buffer insertions are not allowed on clock nets.
- After buffers are inserted during crosstalk repair, if they are not tagged as set\_dont\_modify, then when timing or DRV issues are fixed (post-repair), they could be removed.

### **Options and Arguments**

| repair_file_name | Specifies the name of the repair file.                                                          |
|------------------|-------------------------------------------------------------------------------------------------|
| -set_dont_modify | Marks all buffers inserted by and instances resized by do_xform_run_repair_file as dont_modify. |
|                  | Default: true                                                                                   |

#### Repair File Commands

The following are repair commands. Any line in the repair file that does not start with one of these five commands will be interpreted as a PKS Tcl command line.

**Note:** The repair file can contain comments; all characters after a # on a line are ignored.

#### bufferInsert

bufferInsert net\_name -location x y [-macro macro\_name]
[-optionalResizeTo macro\_name][-kfactor float]

Inserts buffers at a specified net name defined by the *net\_name* option. The arguments are as follows:

-kfactor float

Gives a maximum value constraint on the kfactor computed for the inserted buffer, given the net parasitics derived after the buffer is inserted. The k-factor is defined as the derivative of

|                          | delay through the buffer cell with respect to the capacitance of<br>the net driven by the buffer. The units are kilo-Ohms, that is,<br>nano-seconds for delay and pico-Farads for capacitance. The<br>value specified should be greater than 0. |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -location xy             | Specifies the location where the buffers are inserted.                                                                                                                                                                                          |
| -macro <i>macro_name</i> | Defines the type of macro to use. PKS inserts the buffer in an available site near the specified location, cuts the existing wire, and alters the logical netlist with the newly inserted buffer and corresponding net.                         |
| net_name                 | Specifies the name of the net.                                                                                                                                                                                                                  |
| -optionalResizeTo ma     | Resizes the driver of the net to the specified cell master if PKS cannot find an acceptable buffer location.                                                                                                                                    |

#### receiverReduceNetC

receiverReduceNetC receiver\_inst\_name pin\_name -value float [macro macro\_name]
[-resize macro\_name] [-kfactor float]

Performs the same functionality as the ReduceNetC command, except that the receiver instance starting point is specified. The arguments are as follows:

-kfactor float
 Gives a maximum value constraint on the kfactor computed for the inserted buffer, given the net parasitics derived after the buffer is inserted. The k-factor is defined as the derivative of delay through the buffer cell with respect to the capacitance of the net driven by the buffer. The units are kilo-Ohms, that is, nano-seconds for delay and pico-Farads for capacitance. The value specified should be greater than 0.
 -macro macro\_name
 Defines the type of macro to use.

Resizes the driver of the net to the specified cell master if PKS cannot find an acceptable buffer location.

| pin_name            | Specifies the pin name.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| receiver_inst_name  | Specifies the receiver instance starting point. More appropriate for multi-fanout nets, but can be applied to two pin nets.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -value <i>float</i> | Reduces the net wire length by X percent when used in conjunction with wire length reduction (in reduceNetC and receiverReduceNetC). For example, a value of 0.5 reduces wire length by 50%. The starting point of this percentage is at the receiver end of the net. A value of 0.3 says that the buffer is to be inserted at a point that cuts the wire length of the net by 30%, for example, after the transformation, the wire length of the net connected to the inserted buffer will be approximately 30% of the original net's wire length. The wire length of the net driven by the original driver will be approximately 70% of the original net's wire length. |

#### reduceNetC

reduceNetC net\_name -value float [-macro macro\_name]
[-optionalResizeTo macro\_name] [-kfactor float]

Inserts a buffer onto a routed net at the specified location. The arguments are as follows:

| -kfactor float           |                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Gives a maximum value constraint on the kfactor computed for<br>the inserted buffer, given the net parasitics derived after the<br>buffer is inserted. The k-factor is defined as the derivative of<br>delay through the buffer cell with respect to the capacitance of<br>the net driven by the buffer. The units are kilo-Ohms, that is,<br>nano-seconds for delay and pico-Farads for capacitance. The<br>value specified should be greater than 0. |
| -macro <i>macro_name</i> | Specifies the type of cell to insert. If none is specified, PKS determines the best macro with the least impact to timing. Once the appropriate location is determined, PKS inserts the buffer in an available nearby site, cuts the existing wire, and alters the logical netlist with the newly inserted buffer and corresponding net. Wroute is then used to make the local connections to the buffer.                                              |

| net_name             | Specifies the name of the net.                                                                               |
|----------------------|--------------------------------------------------------------------------------------------------------------|
| -optionalResizeTo ma | Resizes the driver of the net to the specified cell master if PKS cannot find an acceptable buffer location. |
| -value <i>float</i>  | Specifies fraction of net wire length driven by the new buffer.: value needs to be between 0 and 1.          |

#### resize

resize inst\_name -macro macro\_name

Resizes the specified instance to the specified macro as long as they are LEQs. As the footprint of the LEQ may be larger, adjacent cells can be shifted slightly for overlap removal. The arguments are as follows:

instance\_name

Specifies the name of the instance.

-macro macro\_name

Defines the type of macro to use.

#### splitNet

```
splitNet net_name -value int [-macro macro_name] [-resize macro_name]
[-kfactor float]
```

Inserts multiple buffers onto a single net. The *net\_name* option specifies the name of the net. The arguments are as follows:

-kfactor float

Gives a maximum value constraint on the kfactor computed for the inserted buffer, given the net parasitics derived after the buffer is inserted. The k-factor is defined as the derivative of delay through the buffer cell with respect to the capacitance of the net driven by the buffer. The units are kilo-Ohms, that is, nano-seconds for delay and pico-Farads for capacitance. The value specified should be greater than 0.

-macro macro\_name

Defines the type of macro to use, and *macro\_name* specifies the name of the macro. Once the appropriate location is

|                      | determined, PKS inserts the buffer in an available nearby site,<br>cuts the existing wire, and alters the logical netlist with the newly<br>inserted buffer and corresponding net. Wroute must then be<br>used to make the local connections to the buffer. |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| net_name             | Specifies the name of the net.                                                                                                                                                                                                                              |
| -optionalResizeTo ma | Resizes the driver of the net to the specified cell master if PKS cannot find an acceptable buffer location.                                                                                                                                                |
| -value int           | The net is split into n nets, where n is the value specified by the -value option.                                                                                                                                                                          |

# do\_xform\_structure

do\_xform\_structure [-force] [-hierarchical] [-effort { low | medium | high }]
 [-flatten { on | auto | off }] [-priority { area | time }] [-no\_partition]

Applies Boolean and algebraic algorithms and transformations to achieve logic optimization and logic structuring. These transformations are technology independent. This command is typically used prior to any technology dependent mapping or optimizations.

#### **Options and Arguments**

| -effort {low   mediu | <pre>am   high} Controls the CPU time spent during the timing optimization step. Default: medium</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -flatten [on   off   | auto]<br>Controls the operations employed for optimization of logic<br>equations. If flatten option is set to on, the logic equations are<br>flattened into a sum of products form before applying<br>optimization. This generally helps in creating faster and optimal<br>implementation of the logic, even though it may take up extra<br>area (gates). For some circuits, this option may result in<br>excessive run time or memory usage. If flatten option is set to<br>auto, only certain flattening operations are performed; some of<br>the time consuming steps are skipped. The flattening step may<br>be disabled entirely by setting the option to off.<br><i>Default</i> : off |
| -force               | Restarts optimization with all generic optimizations. In essence, the design is unplaced and unmapped and then reoptimized from scratch.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -hierarchical        | Performs mappings, unmappings, structuring, or removes<br>redundancies on the modules in the downward path of the<br>current module. It depends on the command being used. If this<br>option is not given, then only the current module is affected by<br>the command used.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| -no_partition        | Prevents automatic partitioning of the design into smaller modules for optimization, irrespective of the size of the module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Each module boundary should be retained as the partition to optimize.

-priority {area | time}

Sets area or timing minimization to be the highest priority of the technology independent optimization step. If you have a loosely constrained or unconstrained design, then the priority should be set to area. *Default*: time

### **Related Information**

<u>do\_optimize</u>

# do\_xform\_unmap

```
do_xform_unmap [-hierarchical] [-force]
    [list_of_instance_ids | list_of_instance_names]
```

Unmaps the netlist from the technology library. The result of the operation is that the netlist is back in the generic form and can be mapped again.

This command reverts a technology specific cell netlist to a generic cell netlist (ATL).

### **Options and Arguments**

| -force               | Performs all optimization steps on a generic netlist only when used with do_optimize.<br>Default: Does not transform a previously mapped or optimized netlists. After applying the transformation, the netlist must be remapped.                                            |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | When used with do_xform_remove_redundancy, unmaps a previously mapped netlist before applying the transformations.                                                                                                                                                          |
|                      | When used with do_xform_unmap, unmaps cells with a dont_modify attribute, such as test cells and IO cells. These cells are not unmapped when using do_xform_unmap.                                                                                                          |
| -hierarchical        | Performs mappings, unmappings, structuring, or removes<br>redundancies on the modules in the downward path of the<br>current module. It depends on the command being used. If this<br>option is not given, then only the current module is affected by<br>the command used. |
| list_of_instance_ids | Specifies the IDs of the instances to be unmapped.                                                                                                                                                                                                                          |
| list_of_instance_nam | nes<br>Specifies the names of the instances to be unmapped.                                                                                                                                                                                                                 |

# **Related Information**

<u>do\_optimize</u>

<u>do xform map</u>

# dump\_adb

dump\_adb ac\_shell\_process\_id

Dumps the .adb (Ambit Synthesis Database) file at the next most suitable time while allowing the run to continue. Using this command you can get a copy of the .adb file at any point during the optimization.

Once the command is invoked the following message appears in the console window and in the log file:

"Request received to dump ADB at *date & time*. Will save database at next suitable time in file *current\_module*.adb.sig.num"

The *num* variable increments after every successful . adb file dump, starting from 1. This enables you to save different snapshots of the design and prevents the snapshots from being overwritten.

If the dump\_adb command is invoked again before the database is written out, then the tool displays the following message in the console and in the log file:

"Received user request to dump ADB. Waiting for suitable time to dump ADB file"

When ac\_shell dumps the .adb file, the following message is displayed to indicate that you can now use the saved adb file to perform other operations:

Database saved in file "top\_module.adb.sig.num according to user request"

The command provides a snapshot of the database during a run.

### **Options and Arguments**

ac\_shell\_process\_id

Specifies the process ID of an ac\_shell.

# eval\_bottom\_up

```
eval_bottom_up [-skip] [-incr] [-slack float] [-derive_context]
      [min_size leaf_cell_size] [-level level_number]
```

Traverses the design tree in a bottom-up fashion and pre-processes all modules to determine which ones meet the conditions specified by the options <code>-min\_size</code>, <code>-slack</code>, and <code>-level</code>. Then it computes the time budgeting for these modules. The time budgeting will be done at once for all the pre-selected modules in the absence of the <code>-incr</code> option. Otherwise it is performed later. It performs another bottom-up tree traversing and visits each pre-selected module. If the <code>-incr</code> option is selected then it computes the time budget for each module as it visits them (incrementally). It sets the pointers <code>current\_module</code> and <code>set\_top\_timing\_module</code>, to point to each module visited and then executes the series of <code>Tcl</code> commands contained in the command's argument. It places a <code>set\_dont\_modify</code> attribute on each instance's module after it is visited, and before it visits the next module. Once it reaches the top module, it clears all the <code>set\_dont\_modify</code> attributes for all modules.

**Note:** That the eval\_bottom\_up command works on both non-uniquified and uniquified netlists.

### **Options and Arguments**

| -derive_context            | This directs the eval_bottom_up command to perform a do_derive_context operation for all instances instead of a do_time_budget operation.                                                                                                               |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -incr                      | Without this option, the eval_bottom_up command performs<br>a time budgeting for all the instances in the design at the<br>beginning of the operation. With this option, the time budgeting<br>is done incrementally as each instance is being visited. |
| -level <i>level_number</i> | This directs the eval_bottom_up command to start to execute<br>its arguments from instances that are at a distance of<br>level_number from the top cell (these are the bottom<br>instances) to the top.                                                 |
| -min_size <i>leaf_cell</i> | _size<br>This directs the eval_bottom_up command to execute its<br>arguments on instances that have a greater or equal amount of<br>cell-instances than the leaf_cell_size number.                                                                      |

| -skip        | It prevents eval_bottom_up from performing a time budgeting operation for all the instances in the design.                                                                                                                                                                                                          |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -slack float | It performs a worst case setup slack timing analysis each<br>module. It compares the result against the argument given with<br>the option. If the value of the instance's worst case setup slack is<br>less than the argument of the -slack option, then it executes the<br>argument of the eval_bottom_up command. |

#### Examples

- The following command performs a bottom-up evaluation without doing any time budgeting. It runs the do\_xform\_buffer\_tree command at each visited instance.
  - > eval\_bottom\_up -skip {do\_xform\_buffer\_tree}
- This following command performs time budgeting for all modules in the design and writes out constraints for each module. (output files follow the naming format *module\_name\_constraints.tcl* where the string *module\_name* corresponds to the actual name of each module):

> eval\_bottom\_up {write\_assertions [get\_name [ get\_current\_module ] ]\_constraints.tcl}

■ This following command starts its bottom-up evaluation from those instances that have 3000 cell\_instances or more. It performs incremental time budgeting. It only executes the list of arguments on those instances whose worst-case setup slack is less than 0 (instances that have negative slack):

```
> eval_bottom_up -incr -min_size 3000 -slack 0 {do_optimize -effort low
-no_design_rule}
```

■ This following command starts its bottom-up evaluation from those instances located three levels below the top module. It performs incremental time budgeting. It only executes the commands contained in the Tcl file fast\_procs.tcl on those instances whose slack is less than -1 ns:

> eval\_bottom\_up -incr -level 3 -slack -1 {source fast\_procs.tcl}

■ This following command performs a bottom-up evaluation from the bottom leaf instances and returns the name of the module associated with each instance:

> eval\_bottom\_up -skip {puts [get\_name [get\_current\_module]]}

# **Related Information**

set\_dont\_modify

# find

```
find [-blackboxes] [-alias_only] [-bus] [-cellrefs] [-clocks] [-dont_modify]
    [-exact] [-exclude] [-full_path_name] [-glob | -regexp] [-hierarchical]
    [-inputs] [-instances] [-modules] [-nets] [-nocase] [-noclocks]
    [-of_cell_type cell_name] [-of_lib_type lib_name]
    [-of_pin_type { data | clock | output | reset | set }] [-outputs] [-pins]
    [-ports] [-registers] [-sop] [-techlib] [-top] [-scalar] name_list
```

Finds various design objects and prepares the list for other ac\_shell commands. The design objects are found in the design database using glob style pattern matching, unless - regexp option is used. Multiple wildcard matching in a name is permitted.

Typically, the output of find command (list of objects found by this command) is an argument of another command that accepts a list of objects and performs some task. For example, all input ports of a module can be set to same arrival time as follows:

set\_data\_arrival\_time 0.2 [find -ports -input] -clock master\_ck

The search for finding objects is carried out in the current module. If the object name has hierarchy specified in it (for example cnt99/\*), then the search is carried out at the appropriate hierarchy level.

# Important

Every character after the "/" and up to the next space is considered escaped. Therefore, use a space with curly brackets if an escape character is used in the name with the find command. For example:

```
find -net -hier {mmio_o/\mmio_wr_data[2] }
```

# **Options and Arguments**

| -blackboxes | Filters for -cellref and -instances. Return only objects that are blackboxes. |
|-------------|-------------------------------------------------------------------------------|
| -bus        | Filters for nets, ports, and instance pins. Returns only bus components.      |
| -cellrefs   | Searches for cell references.                                                 |
| -clocks     | Filters for -pins and -ports. Returns only clock pins or ports.               |

| -dont_modify             | Filters for all objects types. Returns objects with dont_modify flag set. Refer to <u>set_dont_modify</u> .                                                                                                                          |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -exact                   | Searches only for exact name matches.                                                                                                                                                                                                |
| -exclude <i>namelist</i> | Excludes objects specified by <i>namelist</i> . This option works with any object type including cells. instances, net, modules, ports, pins, and techlibs.                                                                          |
| -full_path_name          | Returns the complete path name of the object, not the<br>object_id. It returns the complete path of the nets, instances,<br>and the instance pins from the current module. It returns the<br>object name for all other object types. |
| -hierarchical            | Searches the complete database hierarchically from current module.                                                                                                                                                                   |
| -inputs                  | Filters for -pin and -port. Returns only input pins or ports.                                                                                                                                                                        |
| -instances               | Searches only for instances.                                                                                                                                                                                                         |
| -modules                 | Searches for modules.                                                                                                                                                                                                                |
| -name_list               | Specifies the names of the objects to search. Pattern matching and regular expressions may be used to find many objects.                                                                                                             |
| -nets                    | Searches only for net object types.                                                                                                                                                                                                  |
| -nocase                  | Determines whether a case- insensitive search is performed.<br>Use this switch in conjunction with the <code>-module</code> or the <code>-techlibs</code> switches to specify. It is a useful in searching for the VHDL modules.     |

| -noclocks                  | Filters for -pins and -ports. Returns only nonclock pins or ports.                                                                                                                                                        |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -of_cell_type <i>cell_</i> | <pre>name Filters for -instances. Returns only the instances of cell_name, which can be *.</pre>                                                                                                                          |
| -of_pin_type {data         | clock   output   reset   set}<br>Filters for -pin. Returns the respective pins for the sequential<br>elements. This option allows you to apply path exceptions (false<br>paths, multi-cycle paths) across reused modules. |
| -outputs                   | Filters for -pins and -ports. Returns only output pins or ports.                                                                                                                                                          |
| -pins                      | Searches only for instance pins.                                                                                                                                                                                          |
| -ports                     | Searches only for ports.                                                                                                                                                                                                  |
| -regexp                    | Performs pattern matching using regular expression rules instead of glob style pattern matching by default.                                                                                                               |
| -registers                 | Filter for -instances. Returns only sequential instances.                                                                                                                                                                 |
| -sop                       | Filter for -cellref and -instances. Returns objects which are sum-of-products (SOP) logic.                                                                                                                                |
| -scalar                    | Filter for nets, ports, and instance pins. Returns only the scalar components and filters out the bus components. Useful in the cases where there is a name collision between a scalar and bus component.                 |
| -techlib                   | Searches for technology libraries.                                                                                                                                                                                        |

-top

Filter for -module. Returns only the top level module.

## **Object Types and Filters**

Valid object types and filters associated with those objects are shown in table <u>1-1</u>. Only the applicable filters will be applied to the objects. If no filters are listed, each  $object_id$  that matches a name in the *name\_list* is returned.

| Object Type | Filter       |
|-------------|--------------|
| instances   | blackbox     |
|             | dont_modify  |
|             | of_cell_type |
|             | pla          |
|             | registers    |
| ports       | bus          |
|             | clocks       |
|             | input        |
|             | no_clocks    |
|             | output       |
|             | scalar       |
| nets        | bus          |
|             | dont_modify  |
|             | scalar       |
| cells       | dont_modify  |
| modules     | dont_modify  |
|             | nocase       |
|             | top          |

### Table 1-1 Object Types and Filters

| Object Type | Filter      |
|-------------|-------------|
| pins        | bus         |
|             | clocks      |
|             | input       |
|             | noclocks    |
|             | of_pin_type |
|             | output      |
|             | scalar      |
| cellrefs    | blackboxes  |
|             | pla         |

### **Glob Style Pattern Matching**

The following symbols are used for wildcard matching:

| *       | Matches 0 or more occurrence of any character. |
|---------|------------------------------------------------|
| ?       | Matches any single character.                  |
| [a,b,c] | Matches a or b or c.                           |

# **Regular Expression Pattern Matching**

Refer to your Tcl documentation for more information about regular expressions and pattern matching.

The following symbols are used to match regular expressions:

Any character.

Zero or more occurrence of preceding character or regular expression.

•

\*

| +                 | One or more occurrence of preceding character or regular expression. |
|-------------------|----------------------------------------------------------------------|
| *                 | Matches at the start of a string.                                    |
| \$                | Matches at the end of a string.                                      |
| \x                | Matches character x.                                                 |
| [chars]           | Matches any character from the set.                                  |
| regexp1   regexp2 | Matches anything that matches regexp1 or regexp2.                    |

### **Related Information**

<u>set\_current\_module</u>

# Examples

- The following commands find all input ports:
  - > find -ports -input \*
  - > find -port -input -regexp
- The following command finds all inout ports:

```
> find -ports -input -output *
```

- The following command finds all technology libraries that have LCA prefix:
  - > find -techlibs LCA\*
- The following command finds the R3 register in all instances:
  - > find -instances -registers R3
- The following command finds all ports and all modules:
  - > find -port -mod \*

■ The following command finds all input ports and all modules:

```
> find -port -mod -input *
```

Note: The filter input applies only to ports and not modules

■ The following command finds the top level module:

```
> find -module -top *
```

■ The following command finds instances that match add1 or add2:

```
> find -instance {add[1.2])
```

■ The following command finds all input ports with name beginning with scanN and ending in \_d:

```
> find -input -port -regexp {^scan[0-9]+.*_d$}
```

### get\_area

get\_area [-cell {combinational | sequential | both} | -net] [-module module]

Queries the area of the given mapped module or the current module, and downwards in the hierarchy. It gets the area for a design module.

**Note:** If a LEF is loaded in the current version, get\_area will be based on that, not on the areas in the cell library. To get\_area in an earlier version, set the global use\_lef\_area to false.

Unmapped (generic) logic does not count towards the area of a design. There are options for cell area and net area.

#### **Options and Arguments**

| -cell                 | Returns the combinational or sequential cell area only, or both. <i>Default</i> : Both                     |
|-----------------------|------------------------------------------------------------------------------------------------------------|
| -net                  | Returns the net area as determined by the appropriate wireload model.                                      |
| -module <i>module</i> | Returns the total area of a module if neither -cell nor -net is specified.<br>Default: The current_module. |

#### Examples

■ The following command returns the total area of the current module and all its children:

> get\_area

The following command returns only the sequential cell area in the current module and its children:

> get\_area -cell sequential

■ The following command returns only the net area in the current module and its children:

> get\_area -net

■ The following command returns the total area of module buffer2 and its children:

```
> get_area -module buffer2
```

## **Related Information**

get module worst slack

<u>report area</u>

set\_current\_module

# get\_attribute

get\_attribute object\_id attribute\_name

Returns the value set for the specified attribute on the specified object. You can query tooland user-defined attributes.

### **Options and Arguments**

| attribute_name | Specifies the name of the attribute to query. Refer to the set_attribute command's <u>set_attribute</u> on page 257 for a list of tool-defined attributes. |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| object_id      | Specifies the object identifier of the module, instance, cellref, net, port, or pin you want to query.                                                     |

### Examples

- The following command returns the value of the flatten attribute for the module A:
  - > get\_attribute [find -module A] flatten
- The following command returns the value of the my\_attribute attribute on the net object my\_net:
  - > get\_attribute [find -net my\_net] my\_attribute

### **Related Information**

<u>delete attribute</u>

<u>get\_info</u>

<u>set\_attribute</u>

<u>set global</u>

# get\_build\_id

get\_build\_id

Returns the build id of the BG/PKS version. This command must be executed within the shell.

### **Related Information**

<u>get\_version</u>

# get\_buswidth

get\_buswidth object\_id

Returns the width of the specified bus object.

#### **Options and Arguments**

object\_id

Specifies the object identifier associated with a bus.

#### Example

This command returns the width of the object 73540:

```
> get_buswidth 73540
```

4

### get\_cell\_area

get\_cell\_area cell\_id

Returns the area of the specified cell.

#### **Options and Arguments**

cell\_id

Specifies the object identifier associated with a cell.

#### Example

The following command returns the cell area of cell 60979:

> get\_cell\_area 60979
16.000000

### get\_crosstalk\_threshold

get\_crosstalk\_threshold [-recalculate]

Returns any existing crosstalk threshold stored with the design.

If no crosstalk threshold is stored, it returns the three times the average slew of all the nets present in the design.

### **Options and Arguments**

-recalculate

Returns three times the average slew of all the nets present in the design, even if there is an existing crosstalk threshold.

#### **Related Information**

<u>do optimize</u>

do xform prevent crosstalk

get\_crosstalk\_tolerance

<u>report\_crosstalk\_violations</u>

### get\_crosstalk\_tolerance

get\_crosstalk\_tolerance

Returns any existing crosstalk tolerance stored with the design.

If no crosstalk tolerance is stored, it returns 0.

#### **Related Information**

<u>do optimize</u>

<u>do\_xform\_prevent\_crosstalk</u>

get\_crosstalk\_threshold

report crosstalk violations

### get\_current\_instance

get\_current\_instance

Returns the object ID of the instance which has been previously designated as the current instance by the command set\_current\_instance.

#### **Related Information**

set current instance

### get\_current\_module

get\_current\_module

Returns the object ID of the module which has been designated as the current module previously by the command set\_current\_module.

#### **Related Information**

set current module

### get\_equivalent\_cells

get\_equivalent\_cells [-exclude\_self] cell\_id

Returns a list of names of library cells that have the same functionality and pin names in nondecreasing order of cell area. Any one of the returned cell names can be used in a do\_rebind call on an instance bound to *cellid*.

### **Options and Arguments**

-exclude\_self

Excludes the name of *cell\_id* from the list.

#### **Related Information**

<u>do\_rebind</u>

# get\_global

get\_global [-default] global\_variable\_name

Returns the current value for the specified global variable. The value of any global variable can be obtained using get\_global command. The set\_global command has a one-to-one correspondence with the get\_global and reset\_global commands. Every variable defined in set\_global also applies to get\_global and reset\_global.

### **Options and Arguments**

-default global\_variable\_name Returns the default value for the specified global variable.

### **Related Information**

<u>set global</u>

# get\_hdl\_file

get\_hdl\_file module\_name

Returns the file name corresponding to the module. This command can be invoked right after reading the HDL files into BuildGates Synthesis, without having to first generate a generic netlist using do\_build\_generic.

### **Options and Arguments**

module\_name

Specifies the name of the module.

### Example

The following commands read in a Verilog module <code>TOPV</code> defined in a file <code>design.v</code> and a VHDL module <code>TOPVH</code> defined in a file <code>design.vhdl</code>. After the HDL files have been read into BuildGates Synthesis, the <code>get\_hdl\_file</code> command determines what file the modules belong to:

```
> read_verilog design.v
> get_hdl_file TOPV
design.v
> read_vhdl design.vhdl
```

> get\_hdl\_file TOPVH
design.vhdl

# get\_hdl\_hierarchy

get\_hdl\_hierarchy [module\_name]

Displays the design hierarchy where, for each design, it lists the names of the designs that are instantiated within, and whether the instantiations are parameterized (using parameters in Verilog or generics in VHDL) or not.

This command can be used to investigate the design hierarchy right after reading the HDL files into BuildGates Synthesis, without having to first generate a generic netlist using do\_build\_generic. This is very useful when design data is often organized into tens or even hundreds of HDL files.

If get\_hdl\_hierarchy is invoked without any arguments, it will return a TCL list containing information for each module that had been read using the read\_vhdl or read\_verilog command.

### **Options and Arguments**

module\_name

Specifies the name of the hierarchical module.

### Examples

The subsequent examples use the following VHDL design that consists of three modules: TOP, BOT, and BOTG. This design is in a VHDL file called design.vhd and has been read in using the read\_vhdl command.

```
entity BOTG is
  generic (WIDTH : natural := 1);
  port (0: out bit_vector(WIDTH-1 downto 0));
end;
architecture A of BOTG is
begin
  0 <= (others => '1');
end;
entity BOT is
  port (0: out integer);
end;
architecture A of BOT is
begin
  0 <= 25;
end;
```

```
entity TOP is
    port (08: out bit_vector(7 downto 0);
            01: out integer);
end;
architecture A of TOP is
begin
    I1 : entity work.BOT port map (01);
    I8 : entity work.BOTG generic map (8) port map (08);
end;
```

■ The following command returns the three modules in the HDL design pool: TOP, BOT and BOTG. It also indicates that while BOT and BOTG do not instantiate any other designs, TOP instantiates both BOT (n represents a non parameterized instantiation) and BOTG ('p' indicates a parameterized instantiation, since design BOTG contains generics):

```
> get_hdl_hierarchy
{TOP {{BOT n} {BOTG p}}} {BOT {}} {BOTG {}}
```

■ The following command returns the hierarchy for a specific design (TOP):

```
> get_hdl_hierarchy TOP
{TOP {{BOT n} {BOTG p}}}
```

## get\_hdl\_top\_level

get\_hdl\_top\_level

Displays a list containing the names of all top level designs, that is designs that are not instantiated by any other design.

This command can be invoked right after reading the HDL files into BuildGates Synthesis, without having to first generate a generic netlist using do\_build\_generic.

### Example

The following example uses this VHDL design in file design.vhdl:

```
entity BOT1 is ....
architecture A of BOT1 is ....
entity BOT2 is ....
architecture A of BOT2 is ....
entity MYDES is ....
architecture A of MYDES is
begin
I1 : entity work.BOT1 port map ...
I8 : entity work.BOT2 port map ...
end;
```

This set of commands displays the-top level module in the design:

```
> read_vhdl design.vhdl
> get_hdl_top_level
MYDES
```

# get\_hdl\_type

get\_hdl\_type module\_name

Given a specific design name, returns the language (VHDL or Verilog) in which that specific design was represented.

This command can be invoked right after reading the HDL files into BuildGates Synthesis, without having to first generate a generic netlist using do\_build\_generic.

### **Options and Arguments**

module\_name

The name of the hierarchical module.

### Example

The following commands read in a Verilog module <code>TOPV</code> defined in a file <code>design.v</code> and a VHDL module <code>TOPVH</code> defined in a file <code>design.vhdl</code>. After the HDL files have been read into BuildGates Synthesis, the <code>get\_hdl\_type</code> command determines what language the various modules were represented in:

```
> read_verilog design.v
> read_vhdl design.vhdl
> get_hdl_hierarchy
{TOPV {}} {TOPVH {}}
> get_hdl_type TOPVH
VHDL
> get_hdl_type TOPV
Verilog
```

### get\_info

get\_info object\_id [field]

Returns the Tcl data structure associated with the *object\_id*, or the specific *field* of that *object\_id*. *Default*: Returns all available fields. It can be used to show attributes.

Options and Arguments

field

Specifies the field associated with the returned object ID.

object\_id

Specifies only one *object\_id* is accepted.

### Examples

■ The following commands return the data structure of FD1:

```
> find -cellref FD1
35331
> get_info 35331
{objecttype cellref} {name FD1} {dont_utilize false} {dont_modify false}
{module 17} {pins {35350 35366 35382 35398}}
```

■ The following command passes the value returned by the find command to the get\_info command, and returns the requested information:

```
> get_info [find -module state1]
{objecttype module} {{name state1} {dont_modify false} views {72690}}
```

The following command returns the value of the dont\_modify attribute of state1:
> get\_info [find -module state1] dont\_modify

false

■ The following command returns the *object\_id* of xf\_ncnt[1]:

```
> find -net {xf_ncnt[1]}
99557
```

■ The following command returns the data structure of xf\_ncnt[1]:

```
> get_info [find -net {xf_ncnt[1]}]
{objecttype net} {name {xf_ncnt[1]}} {dont_modify false} {bus 99924}
{type 85799} {module 84385} {connections {102790 91638}}
```

■ The following commands return the values of the connections and bus fields:

```
> get_info [find -net {xf_ncnt[1]}] connections
102790 91638
> get_info [find -net {xf_ncnt[1]}] bus
99924
```

■ The following command returns the data structure of the bus field of xf\_ncnt[1]:

get\_info [get\_info [find -net {xf\_ncnt[1]}] bus]
=> {objecttype bus} {name xf\_ncnt} {module 84385} {components {92789 92805
92773 92757 99237 99269 99365 99397 99461 99493 99557 99893}}

The following command creates a list of views of module count5, and returns a list of all port identifiers for the module:

```
> set view_list [get_info [find -module count5] views]
> foreach view $view_list {
> set port_list [get_info $view ports]
> }
```

### **Related Information**

<u>find</u>

<u>get\_attribute</u>

<u>set\_attribute</u>

#### get\_message\_count

get\_message\_count [message\_ID] { error | warning | info | info\_msg }

Returns the current message count of either the specified *message\_ID* or the specified message type.

#### **Options and Arguments**

| error      | Gets the count for message type error.                   |
|------------|----------------------------------------------------------|
| info       | Gets the count for message type info.                    |
| info_msg   | Gets the count for message type info_msg.                |
| message_ID | Specifies the ID of the message whose count is returned. |
| warning    | Gets the count for message type warning.                 |

#### **Related Information**

<u>set message count</u>

<u>set\_message\_verbosity</u>

### get\_message\_verbosity

get\_message\_verbosity message\_ID

Returns the current message verbosity.

#### **Options and Arguments**

message\_ID

Specifies the ID of the message whose verbosity level will be retrieved.

#### **Related Information**

set global message verbosity level

### get\_names

get\_names object\_id

Returns the names of specified objects in the design.

#### **Options and Arguments**

object\_id

Reports the *object\_id* of the object whose name is specified by this command. The *object\_id* is typically obtained using the find command. If the *object\_id* represents a single object, a corresponding name is returned. If the *object\_id* represents a list of objects, a list of names in the order of objects in the *object\_id* list is returned.

### Example

The following command returns the name of all input ports of the current module:

> get\_names [find -input -ports \*]

### **Related Information**

<u>find</u>

### get\_net

```
get_net [-full_path_name] [-min_fanout integer] [-max_fanout integer]
    [list_of_net_path_or_id] [netname]
```

Returns net information at the current level of hierarchy. It is useful when finding nets with a pattern matching (wildcard, for example) and then filtering out certain nets based on other options of the command (that is -min\_fanout or -max\_fanout). *Default*: Returns the net IDs at the current level of hierarchy and returns full path name of the net if -full\_path\_name is specified.

#### **Options and Arguments**

| -full_path_name            | Returns full path name of net, instead of net ID                                                                                                               |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| list_of_net_path_or        | Specifies the net path or ID. Can be a pattern or regular expression. If the argument is not given, it returns all nets under the hierarchy of current module. |
| -max_fanout integer        | Returns net whose number of fanouts is not greater than the maximum number specified in <i>integer</i> .                                                       |
| -min_fanout <i>integer</i> | Returns net whose number of fanouts is not less than the minimum number specified in <i>integer</i> .                                                          |
| netname                    | Returns the ID of the specified net name.                                                                                                                      |

### Examples

■ The following command returns the net ID of i\_284:

```
> get_net i_284
94341
```

■ The following command returns all nets under the hierarchy of the current module with names beginning with *r* and having at least 300 fanouts. This command can be used to check if there are any high fanout nets:

```
> get_net -min_fanout 300 r*
r_245 r_250
```

The following command returns the full path name of all nets with fanouts less than or equal to 10:

```
> get_net -full_path_name -max_fanout 10
I311/I210/n_230
```

The following command returns the full path name of all nets with fanouts greater than 100:

```
> get_net -full_path_name -min_fanout 100
I311/I210/n_310 I311/I210/n_312
```

#### **Related Information**

<u>report\_net</u>

### get\_parent\_instances

get\_parent\_instances

Returns the parent instances of the current module.

Nothing is returned if the current module is the top level module.

#### Example

The following command returns the IDs of the four parent instances of the current module:

> get\_parent\_instances
61030 61046 61062 61078

#### **Related Information**

<u>all\_parents</u>

### get\_state\_of\_design

#### get\_state\_of\_design

Returns the state of the design. Lets you know if the design is a generic netlist, or if it is mapped, placed, or if a clock tree has been inserted. The command will return one of the following strings: generic, mapped, placed, or clock\_tree\_inserted.

A design is considered mapped if all primary instances are mapped to a technology library. A design is considered placed if all instances are mapped and placed. A design is considered clock\_tree\_inserted if all instances are mapped and placed, and the clock mode is set to propagated.

Note: No check is made if there is actually a buffer tree present on any clock network.

The do\_optimize command will use this information to determine what optimizations to run.

**Note:** ATL\_LOGIC0/1 instances are excluded from the checks above. For BG(X) a design can only be generic or mapped.

### Example

The following commands show the results of the  $get\_state\_of\_design$  command after various commands:

```
> get_state_of_design
generic
> do_optimize -stop_after mapping...
> get_state_of_design
mapped
> do_optimize -stop_after placement...
> get_state_of_design
placed
> do_optimize -stop_after clock_tree_insertion...
> get_state_of_design
clock_tree_inserted
```

### **Related Information**

<u>do\_optimize</u>

### get\_tempfilename

get\_tempfilename [directory\_name] [prefix]

Returns the temporary file name from the system's default temporary directory. You can specify the directory name and prefix, if desired.

### **Options and Arguments**

directory\_name

Specifies the name of the directory in which to create for the temporary file. *Default*: Directory name is /var/tmp/.

prefix

Specifies the prefix added to the file name.

### Example

The following commands show the results of get\_tempfilename when given different directory names and prefixes:

> get\_tempfilename
/var/tmp/CAAa006T3

> get\_tempfilename /tmp
/tmp/DAAa006T3

> get\_tempfilename /tmp Run1\_
/tmp/Run1\_FAAa006T3

# get\_version

get\_version

Returns the version of BG/PKS shell being executed.

### **Related Information**

<u>get\_build\_id</u>

# help

help [command | keyword | message\_id]

Provides online help for all  $ac\_shell$  commands. If no arguments are given to the help command, the usage syntax is displayed. This is also true for all  $ac\_shell$  commands: When a command expects some arguments that are not provided, or incorrect arguments are provided, the usage syntax is displayed.

### **Options and Arguments**

| command    | Displays the command's syntax.                                                                                                                                                                                                                                                                                            |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| keyword    | Displays a list of all commands related to the specified keyword.<br>The keyword can be any word, including partial match to one or<br>more commands.                                                                                                                                                                     |
| message_id | Displays an explanation of the message. Most of the messages—errors, warnings, or informative messages, are displayed in terse form, with a message-id associated with it. Requesting help with this message-id provides detailed information, including possible problems and suggestions for how to remove the problem. |

# highlight

highlight list\_of\_object\_ids [-center] [-verbose]

Highlights schematic instances, nets, and ports, given a list of object IDs.

Note: This command is only useful when run from the GUI.

#### **Options and Arguments**

-center

Centers schematic on the last object in *list\_of\_object\_ids*.

-verbose

Prints the name and object ID of each object that is being highlighted.

### issue\_message

issue\_message [-type {info | error | warning}] message

Issues user messages. These messages are logged in a log file. There may also be no type as an option for this command and the message ID for issuing such an information message is user-300.

### **Options and Arguments**

| -error   | Issues the message ID for this message type: user-100. |
|----------|--------------------------------------------------------|
| -info    | Issues the message ID for this message type: user-400. |
| -warning | Issues the message ID for this message type: user-200. |

### Example

The following commands show the some possible results:

```
> issue_message -type error "message"
ERROR: message<user-100>
> issue_message "message"
message <user-300>
> issue_message -type info "message"
INFO: message <user-400>
> issue_message -type warning "message"
WARNING: message <user-200>
```

## limit

```
limit {cpu_seconds | -cycles number} tcl_command
```

Executes the specified Tcl command and issues a user interrupt after *cpu\_seconds* have elapsed if the command did not finish by that time.

This command can be used to limit the time spent in a given optimization command. Actual termination of the  $tcl\_command$  is at the discretion of the application and is analogous to issuing a user interrupt (^C).

A 0 is returned if the Tcl command completes without exceeding the limit. If the limit was exceeded, limit will return a positive number representing the number of cycles executed. This number can be used to reproduce the run using the -cycles number option.

**Note:** CPU times are an approximation made by the operating system. Any script based on limiting the CPU time can result in non-reproducible results. To reproduce a CPU-time-limited run, use the option -cycles number, with the number returned by the run you wish to reproduce.

Specifying -cycles 0 is the same as specifying no limit.

### **Options and Arguments**

| cpu_seconds    | Specifies the approximate number of CPU seconds. |
|----------------|--------------------------------------------------|
| -cycles number | Specifies the number of CPU cycles.              |
| tcl_command    | Specifies a Tcl command.                         |

### Example

The following script automatically replays a previous CPU-time-limited run:

```
if { $replay } { source $replay_file }
else { set fp [open $replay_file w] }
...
set cmdl "do_optimize -effort high"
if { $replay } {
    limit -cycles $nr1 $cmd1
} else {
```

```
set cycles [limit 100 $cmd1]
   puts $fp "set nr1 $cycles"
}
...
if { $replay == 0 } { close $fp }
```

# quit

quit

Exits ac\_shell process.

### read\_adb

```
read_adb filename [-module module_name] [-echo_assertions]
    [-no_assertions] [-overwrite] [-restore_globals]
```

Reads a previously written Ambit Synthesis database file (ADB) and rebuilds the database for further synthesis and analysis of the netlist. The ADB file is a binary file.

The synthesis data stored by ac\_shell in a database can be written out in the ADB format at any stage during the synthesis process using the write\_adb command.

If the module (design) in the ADB file contains references to technology cells, the technology library must be loaded prior to loading the design from the ADB file.

#### **Options and Arguments**

| filename            | Specifies the .adb file to be read in to ac_shell.                                                                                                                                                                     |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -echo_assertions    | Echoes the timing assertions in read_adb, regardless of the set_global echo_commands.                                                                                                                                  |
| -module module_name | Name of the module to be loaded from the entire ADB file. An adb file can contain several modules. Modules from the file can be selectively loaded so that ac_shell database does not occupy unnecessary memory space. |
| -no_assertions      | Causes the assertions in the ADB being read in to be ignored. <i>Default</i> : Writes assertions into all ADBs and to apply all the assertions being read in.                                                          |
|                     | <b>Note:</b> Using this option will cause placement information to be ignored.                                                                                                                                         |
| -overwrite          | Overwrites the existing module if the module is present in the database, otherwise the existing module is automatically renamed maintaining the module's link.                                                         |
| -restore_globals    | Reads all of the globals back into the current design. By default                                                                                                                                                      |

none of the globals are read back through read\_adb. When you restore globals, globals with the same names are changed from the global's current setting. A message displays showing the globals that have been changed. This message only displays when reading an .adb file.

If you use the read\_adb command without the -restore\_globals argument, a warning message is printed out for each global that has a different value (in the current session) than the global value stored in the .adb file.

**WARNING**: Use caution when using the -restore\_globals option. Using this option will also restore the logfile and cmdfile, and will immediately start overwriting if such files already existed from a previous run. You can either move the original logfile (and cmdfile) away before loading the adb (or equivalently run the bg\_shell in a different directory then before).

### **Related Information**

<u>read alf</u>

read\_verilog

<u>read vhdl</u>

<u>write\_adb</u>

### read\_edif

read\_edif file\_name

Reads an EDIF v2.0.0 file.

#### **Options and Arguments**

file\_name

Specifies the name of the EDIF input file.

#### **Related Information**

set global edifin\_\*

<u>write\_edif</u>

Refer to the *EDIF Interface* chapter in the *HDL Modeling for BuildGates Synthesis*.

## read\_symbol

read\_symbol filename

Reads .sym symbol libraries. It sets the schematic symbol library search path to *filename*. If a current list of files is loaded (from a previous read\_symbol or read\_symbol\_update command) the list is set to *filename*.

**Note:** This command enables you to read Synopsys .slib symbol libraries. However, the .slib symbol library must first be translated to EDIF format (.edif) in the Synopsys tool, then converted to the .sym format using the edifconv program in BuildGates. BuildGates only supports the conversion of .edif symbol libraries, not .slib symbol libraries.

The schematic symbol libraries are searched in the following order:

- 1. Specified directory in the *Schematic Preferences* dialog box from the BuildGates and PKS GUI *View* menu.
- 2. Current directory
- 3. Specified directory pointed to by AMBIT\_AMVIEW\_SYMLIB

The symbol library file name, if not specified with the read\_symbol command the read\_symbol\_update command, or in the GUI Schematic Preferences dialog box, defaults to technology\_name.sym.

### **Options and Arguments**

filename

Specifies the name of the symbol library (.sym) to add to the schematic symbol library search list.

### Example

See <u>read symbol update</u>.

### **Related Information**

read symbol update

### read\_symbol\_update

read\_symbol\_update filename

Appends *filename* to the schematic symbol library search list. It provides support for loading multiple symbol library files into the schematic viewer.

The schematic symbol libraries are searched in the following order:

- 1. Specified directory in the *Schematic Preferences* dialog box from the BuildGates and PKS GUI *View* menu.
- 2. Current directory
- 3. Specified directory pointed to by AMBIT\_AMVIEW\_SYMLIB

The symbol library file name, if not specified with the <code>read\_symbol</code> command the <code>read\_symbol\_update</code> command, or in the GUI Schematic Preferences dialog box, defaults to <code>technology\_name.sym</code>.

#### **Options and Arguments**

filename

The name of the file to add to the schematic symbol library search list.

### Examples

The following command loads schematic symbol libraries; search order is the order in which the libraries are read in:

- > set SYM\_lib\_dir \${root\_dir}/LIBRARY/SYMBOL
- > read\_symbol \$SYM\_lib\_dir/IBM\_SA12E.sym
- > read\_symbol\_update \$SYM\_lib\_dir/IBM\_SA12E\_BC.sym
- > read\_symbol\_update \$SYM\_lib\_dir/IBM\_SA12E\_GA.sym
- > read\_symbol\_update \$SYM\_lib\_dir/IBM\_SA12E\_GROW.sym
- > read\_symbol\_update \$SYM\_lib\_dir/IBM\_SA12E\_IO.sym
- > read\_symbol\_update \$SYM\_lib\_dir/IBM\_SA12E\_SC.sym

### **Related Information**

<u>read\_symbol</u>

### read\_verilog

read\_verilog [-aware\_library aware\_libname] [-structural] verilog\_filenames

Reads in Verilog design files to ac\_shell. When the -aware\_library option is used, the verilog modules are stored as components in the specified AmbitWare library. For more details on AmbitWare libraries, refer to the Datapath Option of Ambit BuildGates Synthesis and Cadence PKS.

You can read in a compressed Verilog file in GNU zip format if the specified input file ends in the .gz suffix. No special option is needed to read a gzipped file. For example: read\_verilog verilog\_filename.gz. However, you cannot create a gzipped file with the read\_verilog command.

The -structural argument does not support full RTL. It only handles the structural subset of Verilog, that is, module and gate instances, concurrent assignment statements, and simple expressions (references to nets, bit-selects and part-selects of nets, concatenations of nets, and the unary ~ operator). It is not necessary to run do\_build\_generic after using the -structural argument with the read\_verilog command.

#### **Options and Arguments**

| -aware_library aware | Reads each component file, checks the syntax, and generates<br>the corresponding binary dump file (* . bd) in the specified<br>AmbitWare library. Adds an entry into the existing index file or<br>creates a new index file in the aware library.                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -structural          | Creates a netlist directly for an input file containing only structural constructs, that is, module and gate instances, concurrent assignments, and simple expressions (nets, bit-selects, part-selects of nets, concatenation of nets, and unary operators). Allows a quick reading of a Verilog netlist. Reports an error for any non-structural construct, such as a reg or an always block. Structural modules in the input files are converted to their netlist representation while non-structural modules are rejected. There is no need to issue the do_build_generic command after reading in the netlist with the -structural option. |
| verilog_filenames    | Specifies the Verilog design file or files to read into ac_shell.<br>Multiple file names are separated by blank spaces.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

### Attributes

buscomp\_generator

hdl\_verilog\_vpp\_arg

instance\_generator

net\_generator

#### Database Impact

The database contains parse tree of Verilog source when all files are read in successfully.

#### Examples

- The following command loads the Verilog file design.v into the ac\_shell:
  - > read\_verilog design.v
- The following command reads three Verilog designs into the AmbitWare library ZM122200:
  - > read\_verilog -aware\_library ZM122200 zm\_des1.v zm\_des2.v zm\_des3.
- The following command reads netlist.v and creates a netlist directly:
  - > read\_verilog -structural netlist.v

Using the -structural argument fully replaces the following commands:

- > read\_verilog netlist.v
- > do\_build\_generic
- The following command loads both design files and then automatically decompresses the gzipped file:
  - > read\_verilog sop.v addr.v.gz

### **Related Information**

<u>do build generic</u>

<u>read alf</u>

<u>read\_library\_update</u>

read\_symbol

report\_aware\_library

<u>set aware library</u>

# read\_vhdl

read\_vhdl [-aware\_library aware\_libname] | [-library libname] vhdl\_filenames

Reads in VHDL design files to ac\_shell. When the -aware\_library option is used, the VHDL modules are stored as components in the specified AmbitWare library. For more details on AmbitWare libraries, refer to <u>Cadence</u> <u>Datapath Synthesis Option of BuildGates Synthesis and Cadence Physically</u> <u>Knowledgeable Synthesis (PKS)</u>.

You can read in a compressed VHDL file in GNU zip format if the specified input file ends in the .gz suffix. No special option is needed to read a gzipped file. For example: read\_vhdl vhdl\_filename.gz. However, you cannot create a gzipped file with the read\_vhdl command.

This command analyzes the VHDL files, performs basic synthesis subset checking, and dumps the intermediate representation to the directory associated with the specified aware or VHDL library or by default into the VHDL library WORK, if no library is specified.

If the specified library has been explicitly created using the set\_vhdl\_library command, then the intermediate representation of the VHDL design units is written to the corresponding directory. Otherwise, a temporary directory will be created for storing all design units analyzed into a specific library.

VHDL design units (that is, entities, architectures, packages) can be read in any order with the following restrictions:

- Packages must be read before any other units that refer to them.
- Entities must be read before any of their architectures.

There is no restriction on the order in which entities are read for synthesis.

The following packages are pre-compiled and do not need to be analyzed:

```
std.standard
std.textio
ieee.std_logic_1164
ieee.numeric_bit
ieee.numeric_std
```

To use this command, a design library must already exist.

### **Options and Arguments**

 -aware\_library aware\_libname Reads each component file, checks the syntax, and generates the corresponding binary dump file (\* . bd) in the specified aware library. Adds an entry into the existing index file or creates a new index file in the AmbitWare library.
 -library libname
 Specifies the name of the VHDL library into which the VHDL files will be analyzed. Multiple file names are separated by blank spaces.
 vhd1\_filename
 Reads in VHDL design file or files. If no library file is specified, the VHDL files will be analyzed into the VHDL library WORK by default. Multiple file names are separated by blank spaces.

### Attributes

- set global buscomp generator
- set\_global hdl\_vhdl\_case
- set global hdl vhdl preferred architecture
- set global hdl vhdl read version

set global hdl\_vhdl\_reuse\_units

### Examples

- The following command analyzes file pack.vhd into a library MYLIB:
  - > read\_vhdl -library MYLIB pack.vhd
- The following command analyses the file use.vhd into library WORK:
  - > read\_vhdl use.vhd
- The following command reads three VHDL designs into the AmbitWare library ZM122200:
  - > read\_vhdl -aware\_library ZM122200 zm\_des1.vhd zm\_des2.vhd zm\_des3.vhd
- The following command loads both design files and then automatically decompresses the gzipped file:

> read\_vhdl sop.vhd addr.vhd.gz

### **Related Information**

report aware library

report vhdl\_library

<u>set\_vhdl\_library</u>

<u>set aware library</u>

# record\_macro

record\_macro filename

Starts the logging of interactive commands into the specified file name. Recording stops when you exit ac\_shell. The file can be "sourced" to recreate the session.

# **Options and Arguments**

filename

Specifies the name of the directory and file in which to record the logged commands.

## report\_area

```
report_area [-summary] [-block] [-hierarchical] [-cells] [{ > | >> } filename]
      [-include_hard_macros]
```

Generates a report on the area of the netlist. The information contained in the report is dependent on the options used with the command.

**Note:** If a LEF is loaded in the current release, get\_area will be based on that, not on the areas in the cell library. To get\_area in an earlier version, set the global use\_lef\_area to false.

# **Options and Arguments**

```
{ > | >> } filename
```

Specifies the name of the file in which report will be saved. If filename is not specified, the report is displayed on the standard output. Note that filename must be the last argument in the list.

-block

Provides a block summary. See the table below.

| Block report for module am            | Current Module | Cumulative |
|---------------------------------------|----------------|------------|
| Number of combination instances       | 3              | 812        |
| Number of non-combinational instances | 0              | 438        |
| Number of hierarchal instances        | 2              | 10         |
| Number of blackbox instances          | 0              | 1          |
| Total number of instances             | 5              | 1261       |
| Area of combinational cells           | 19.00          | 4181.00    |
| Area of non-combinational cells       | 0.00           | 9970.00    |
| Total cell area                       | 19.00          | 14151.00   |
| Number of nets                        | 471            | 1721       |
| Area of nets                          | 0.00           | 0.00       |
| Total area                            | 19.00          | 14151.00   |

| -cells               |                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Presents the area report on every cell (block) in the current<br>module. The cell report includes summary report for current<br>module, summary report of cumulative design hierarchy, name<br>and count of cells used, type of cells used, area for each cell,<br>total cell area, net area and total design area. If no options are<br>specified, then a summary area report will be generated. |
| -hierarchical        |                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      | Presents the area report for the entire hierarchy below the current module. If this option is not used, the data is presented only for the current module.                                                                                                                                                                                                                                        |
| -include_hard_macros |                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      | Presents the area report for hard macros, as well as the area of standard cells. The default is to just include the area of standard cells.                                                                                                                                                                                                                                                       |
| -summary             |                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      | Presents the area report in summary form. The summary information contains name of the current module, wire load model used, cell area, net area, and total area.                                                                                                                                                                                                                                 |

# Examples

- The following command generates a detailed hierarchical report on each cell and stores the report in file area.rpt:
  - > report\_area -hierarchy -cells area.rpt
- The following command writes the report timing data to the file my\_file.rpt:
  - > report\_timing > my\_file.rpt
- The following command writes the area report data to the file my\_file.rpt, overwriting the timing data:

```
> report_area > my_file.rpt
```

■ The following commands write timing and area information to my\_file.rpt:

> report\_timing > my\_file.rpt

- > report\_area >> my\_file.rpt
- The following examples show reports where the area is taken from a TLF (or ALF) file and a LEF file. The numbers in each *Cell Area* column represent the area in square microns (TLF) and in terms of the number of SITES used (LEF). You can convert the LEF area units to square microns by multiplying the SITE SIZE X\* Y.

Source of Area : Timing Library

|   | +              |                       |            |          | +          |
|---|----------------|-----------------------|------------|----------|------------|
|   | Module         | Wireload              | CellArea   | Net Area | Total Area |
|   | CSR1KT_viter   | TSMC256K_Conservative | 1114025.68 | 0.00     | 1114025.68 |
|   | • • •          |                       |            |          |            |
| 1 | Source of Area | : LEF                 |            |          |            |

| Module       | Wireload              | Cell Area | Net Area | Total Area |
|--------------|-----------------------|-----------|----------|------------|
| CSR1KT_viter | TSMC256K_Conservative | 656313.00 | 0.00     | 656313.00  |

### **Related Information**

report design rule violations

<u>report\_fsm</u>

report\_hierarchy

<u>report\_timing</u>

set current module

# report\_aware\_library

```
report_aware_library [-library library_name] [-summary filename]
    [-component pattern]
```

Generates library, summary, and components that meet the *pattern* reports.

## **Options and Arguments**

-component *pattern* Selects a component report of the components specified by *pattern*.

-library library\_name Selects a report of the aware library library\_name. -summary filename Selects a summary report, storing the summary in filename.

# Example

The following command generates a report on the library AWLOGIC.

```
> report_aware_library -library AWLOGIC
```

## **Related Information**

delete\_aware\_component

set aware component property

set aware library

# report\_crosstalk\_violations

```
report_crosstalk_violations [-threshold num] [-reset_threshold] [-tolerance num]
        [-ignore_dont_modify_nets] [-ignore_clknets] [-verbose]
```

Uses the threshold from previous crosstalk prevention fixes and stored with the design. If a threshold does not exist, this command will calculate an average transition time for the threshold automatically. See the <u>do xform prevent crosstalk</u> command for further information.

Default: Only reports nets with violations, including clock nets and dont\_modify nets. These nets are flagged accordingly in the report similar to the report\_design\_rule\_violations command.

**Note:** The report\_crosstalk\_violations command will NOT store this calculated threshold with the design. The -threshold and -reset\_threshold options result in reports based on the specified or a recalculated threshold, respectively, but these options do NOT overwrite any existing threshold stored with the design or result in a new threshold being stored with the design.

## **Options and Arguments**

| -ignore_clknets       | Excludes clock nets with crosstalk violations from the report.                                                                                                                              |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -ignore_dont_modify_: | nets<br>Excludes dont_modify nets with crosstalk violations from the<br>report.                                                                                                             |
| -reset threshold      | Recalculates a threshold for the report.                                                                                                                                                    |
| -threshold num        | Specifies a threshold for the report.                                                                                                                                                       |
| -tolerance num        | Specifies a number, which together with the calculated or specified threshold, defines a range within that crosstalk violations will be tolerated and need not be fixed. <i>Default</i> : 0 |
| -verbose              | Includes nets with no crosstalk violations in the report. Each hierarchical net is reported only once, in the module containing its driver.                                                 |

### Example

The following command displays a crosstalk violations report similar to the one shown below:

> report\_crosstalk\_violations -verbose

Transition threshold for crosstalk prevention: nnn Threshold tolerance for crosstalk prevention: nn

|           | net name | worst<br>transition | violation |
|-----------|----------|---------------------|-----------|
| Module: A |          |                     |           |
|           | ABC      | nnn                 | nnn       |
|           |          |                     |           |
|           |          |                     |           |
|           |          |                     |           |

Total Number of Nets = nn Total Number of Violations = nn

## **Related Information**

<u>do\_xform\_prevent\_crosstalk</u>

reset crosstalk threshold

report design rule violations

# report\_design\_rule\_violations

```
report_design_rule_violations [-ignore_clknet] [-min_drvs]
    [-current_module_only] [-verbose] [-ignore_dont_modify_nets]
    [{ > | >> } filename] [-summary]
```

Generates a report on all the design rule violations in the design. The information contained in the report depends on the options used.

### **Options and Arguments**

| {>   >>} filename    | Specifies the name of the report file. If <i>filename</i> is not specified, the report is displayed on standard output. <i>filename</i> must be the last argument in the list. |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -current_module_only | Only the violations in the current module are reported.                                                                                                                        |
| -ignore_clknet       | Does not report the clock net violations.                                                                                                                                      |
| -ignore_dont_modify_ | nets<br>Does not report design rule violations for nets that are set<br>dont_modify.                                                                                           |
| -summary             | Provides a summary report of the violations on each net (instead<br>of listing all of the violations). The worst violations are reported<br>for every violating net.           |
| -verbose             | Reports all design rules for every net and port in the design regardless of whether there were any violations or not.                                                          |
| Related Information  |                                                                                                                                                                                |

<u>report\_area</u>

<u>report\_fsm</u>

<u>report hierarchy</u>

<u>report\_timing</u>

<u>set\_table\_style</u>

# report\_fsm

```
report_fsm [-vector vector_name] [-state_table] [-encoding] [-hierarchical]
    [{> | >>} filename]
```

Generates a report on the finite state machines on the design. The contents of the report include the design name, number of states, inputs, outputs, and so on.

### **Options and Arguments**

| {>   >>} filename   | Saves the report with the <i>filename</i> entered. If the option is not used, the data is presented on the standard output. <i>filename</i> must be the last argument in the list. |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -encoding           | Reports all state assignments for each selected FSM.                                                                                                                               |
| -hierarchical       | Displays the downward path of all FSMs in the current module.                                                                                                                      |
| -state_table        | Generates a state transition table in report form.                                                                                                                                 |
| -vector vector_name | Displays a report on the FSM represented by the state vector <i>vector_name</i> . If this option is not used, all FSMs in the current module are reported.                         |

### Example

The following command generates the report shown below:

> report\_fsm -encoding -state\_table
+-----+
| Report | report\_fsm |
|------|
| Options | -state -encoding |
+----+
| Date | 20030514.025128 |
| Tool | bgx\_shell |
| Release | v5.xxxxx0 |
| Version | May 13 2003 23:52:05 |

# Command Reference for BuildGates Synthesis and Cadence PKS BuildGates Synthesis Commands

| ++<br>  Current Module   fsm1  <br>++                                                                                            |                                                                                                                       |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|
| Finite State Machine Report                                                                                                      |                                                                                                                       |  |  |  |
| Design<br>  State Vector<br>  File<br>  Line                                                                                     | fsm1  <br>  state_reg  <br>  test.v  <br>  20                                                                         |  |  |  |
| <pre>  States   Initial states   Equivalent states   Unreachable states   Terminal states   Preserved states   Transitions</pre> | 5  <br>  (STATE0)  <br>  <none>  <br/>  <none>  <br/>  <none>  <br/>  <none>  <br/>  13  </none></none></none></none> |  |  |  |
| Inputs<br>  Input names<br>  Unused inputs<br>  Hold signal<br>+                                                                 | 1  <br>  (reset)  <br>  <none>  <br/>  <none>  </none></none>                                                         |  |  |  |
| Outputs<br>  Output names                                                                                                        | 6  <br>  (state_out[0:2] out[0:2])                                                                                    |  |  |  |
| Clock<br>  Sense                                                                                                                 | clk                                                                                                                   |  |  |  |
| <pre>  Encoding   Encoding bit length +</pre>                                                                                    | binary  <br>  3                                                                                                       |  |  |  |
| ++<br>  State  <br>  Encoding  <br>  <br>  STATE0   000  <br>  STATE1   001  <br>  STATE2   010  <br>  STATE3   011              |                                                                                                                       |  |  |  |

## Command Reference for BuildGates Synthesis and Cadence PKS BuildGates Synthesis Commands

| STATE4   100  <br>++ |                                                                                           |                |        |  |  |  |  |
|----------------------|-------------------------------------------------------------------------------------------|----------------|--------|--|--|--|--|
| +                    | State Transition Table                                                                    |                |        |  |  |  |  |
| reset<br>            | reset   CS   NS   state_out[2] state_out[1] state_out  <br>      [0] out[2] out[1] out[0] |                |        |  |  |  |  |
| 1                    | +<br>  STATE0                                                                             | ++<br>  state0 | 000    |  |  |  |  |
| 0                    | STATE0                                                                                    | STATE1         | 000000 |  |  |  |  |
| 1                    | STATE1                                                                                    | STATE0         | 001    |  |  |  |  |
| 0                    | STATE1                                                                                    | STATE2         | 001001 |  |  |  |  |
| 1                    | STATE2                                                                                    | STATE0         | 010    |  |  |  |  |
| 0                    | STATE2                                                                                    | STATE3         | 010010 |  |  |  |  |
| 1                    | STATE3                                                                                    | STATE0         | 011    |  |  |  |  |
| 0                    | STATE3                                                                                    | STATE4         | 011011 |  |  |  |  |
| -                    | STATE4                                                                                    | STATE0         | 100    |  |  |  |  |
| 0                    | STATE4                                                                                    | STATE0         | 100100 |  |  |  |  |
| 1                    | *                                                                                         | STATE0         | 001    |  |  |  |  |
| 0                    | OTHERS                                                                                    | STATE0         | 111    |  |  |  |  |
| 1                    | OTHERS                                                                                    | STATE0         | 001    |  |  |  |  |

#### **Related Information**

<u>report area</u>

<u>report\_design\_rule\_violations</u>

report hierarchy

<u>report timing</u>

<u>set\_table\_style</u>

# report\_globals

report\_globals [-tcl\_list] [-modified] [-group group\_name] [{ > | >> } filename]

Returns the current and default values for the specified global variables. If no arguments are specified with the command, the complete list of all globals will be reported.

## **Options and Arguments**

| <pre>{&gt;   &gt;&gt;} filename</pre> | Saves the report with the <i>filename</i> entered. If the option is not used, the data is presented on the standard output. <i>filename</i> must be the last argument in the list.                                  |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -group group_name                     | Returns the current and default values of the specified global variables belonging to the specified group. Valid values for <i>group_name</i> include hdl, aware, ta, opt, pks, dft, dist, dcn, edif, misc, and ui. |
| -modified                             | Returns the current and default values of the specified global variables that have been changed from their default value.                                                                                           |
| -tcl_list                             | Returns the current and default values of the specified global variables as a Tcl list.                                                                                                                             |

## Examples

■ The following command returns the current and default values of the user interface global variables that have been modified from their default values, as is subsequently shown:

| > | report_global | s | -group | o ui | -modif | ied |
|---|---------------|---|--------|------|--------|-----|
| + |               | u | <br>i  |      | +      |     |
|   | Global        | 7 | /alue  | Dei  | Eault  |     |
|   | line_length   |   | 126    |      | 30     |     |
| т |               |   |        |      |        |     |

■ The following command returns the current and default values of the user interface global variables.

| <pre>&gt; report_globals -group ui .</pre>                                        |                                                |                                               |
|-----------------------------------------------------------------------------------|------------------------------------------------|-----------------------------------------------|
| +                                                                                 | ui                                             |                                               |
| Global                                                                            | Value                                          | Default                                       |
| acsh_prompt<br>logfile<br>message_verbosity_level<br>line_length<br>echo_commands | <pre>%t[%h]&gt; ac_shell.log 7 113 false</pre> | <pre>%t[%h]&gt; ac_shell.log 7 80 false</pre> |

■ The following command returns the current and default values of the test synthesis global variables.

#### > report\_globals -group dft

| dft                                                                                                                                                                                                                                                                  |                                                                           |                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|
| Global                                                                                                                                                                                                                                                               | Value                                                                     | Default                                                                   |
| dft_enable_combinational_loop_check<br>dft_enable_race_condition_check<br>dft_verbosity_level<br>dft_scan_avoid_control_buffering<br>dft_allow_scan_path_inv<br>dft_scan_path_connect<br>dft_scan_output_pref<br>dft_scan_enable_connect<br>dft_scan_preserve_config | false<br>false<br>1<br>false<br>true<br>chain<br>non_inv<br>true<br>false | false<br>false<br>1<br>false<br>true<br>chain<br>non_inv<br>true<br>false |

#### **Related Information**

<u>reset\_global</u>

<u>set\_global</u>

# report\_hierarchy

report\_hierarchy [-inst] [-tcl\_list] [{> | >>} filename]

Reports the structural hierarchy as it exists at various stages in the synthesis process. The hierarchy reported is always that of the netlist in memory, with the current module as the top of the hierarchy. The report uses the following symbols to distinguish hierarchical blocks:

| b | Black box module                             |
|---|----------------------------------------------|
| g | Generic (unmapped) module                    |
| 0 | Optimized module                             |
| x | dont_modify attribute is set for this module |
| m | Module contains a mapped view                |

## **Options and Arguments**

| {>   >>} filename | Saves the report with the <i>filename</i> entered. If the option is not used, the data is presented on the standard output. <i>filename</i> must be the last argument in the list. |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -inst             | Includes the instance name of the module instantiation in the output. Modules that are multiply instantiated will include a separate line of output for each instantiation.        |
| -tcl_list         | Reports the hierarchy in the form of a Tcl list. To use the output<br>of the Tcl list to generate Tcl code, use a Tcl variable, as shown<br>in the example below.                  |

### Examples

- The following command generates a report on the current hierarchy and save it in a file design.hier.rpt
  - > report\_hierarchy design.hier.rpt
- The following command displays the instance name of the module instantiation. Sample output follows the command.

```
> report_hierarchy -inst
```

```
-my_top(g)
-mid1_0 -> my_mid1(m)
-mid1_1 -> my_mid1(m)
-mid2_0 -> my_mid2(g)
```

- The following command uses the Tcl variable result to save the -tcl\_list code into the file save\_tcl\_code file.
  - > set result [report\_hierarchy -tcl\_list]
  - > echo \$result > save\_tcl\_code

### **Related Information**

<u>report\_area</u>

report design rule violations

<u>report\_fsm</u>

<u>report\_timing</u>

<u>set table style</u>

# report\_path\_group\_options

report\_path\_group\_options [-tcl\_list] [{> | >>} filename]

Produces a report of the path group options set by the set\_path\_group\_options command. The report includes the name of the path group, the effort level set, a plus sign (+) if more than the worst path is to be optimized, the target slack, the number of endpoints, the worst slack of the group, and the Total Endpoint Failing Slack (TEFS), which is the sum, over all failing endpoints in the group, of the amount by which the slack misses the target slack.

Question mark entries in this report indicate that the options for that group have not been set and that the actual values are picked up from whatever command line options are passed to the do\_optimize command.

This command is useful for checking which path group options were set (using set\_path\_group\_options command). If you just want to report the timing of all path groups, use <u>report\_path\_group\_timing</u>.

### **Options and Arguments**

| >   >> filename | Redirects the output to the named file. If this option is omitted, the default is stdout. |
|-----------------|-------------------------------------------------------------------------------------------|
| -tcl_list       | Produces the report in Tcl list form instead of a tabular format.                         |

Useful for extracting information from the report in a Tcl program.

### Example

The following command reports the group defined in the example for <u>set path group options</u>. In this example the worst slack is -0.34, which meets the target slack of -1 for path group GRPA; therefore, the TEFS is 0.00.

report\_path\_group\_options

| +                                                                                                                   | Pat                | ch Grou | up Options | s Report |                |   |  |
|---------------------------------------------------------------------------------------------------------------------|--------------------|---------|------------|----------|----------------|---|--|
| PathGroup     Effort     All     Target     Critical     Worst     TEFS       Pts     Slack     Endpoints     Slack |                    |         |            |          |                |   |  |
| <pre><default>     GRPA</default></pre>                                                                             | ?<br>  ?<br>  high | ?<br>+  | ?<br>-1.00 |          | -1.73<br>-0.34 | ? |  |

# **Related Information**

report path group timing

<u>reset path group</u>

<u>set\_path\_group</u>

set path group options

### report\_resources

report\_resources [-all] [-hierarchical] [-instance] [{ > | >> } filename]
 [-module module\_name] [-mux] [-sequential] [-shared] [-summary]

Provides information about the datapath modules in the design. The summary report contains the information about different arithmetic operators in the datapath module. By default, resources are listed for the current module, but if -module option is used, the resources are separated for the specific module.

*Default*: Contains information about the architecture, size, format and corresponding RTL line number of datapath clusters in the datapath modules.

In addition, the report\_resources command reports the resources generated by each of the ambitware generators.

### **Options and Arguments**

| -all                       | Reports all the aware resources (arithmetic, mux, and sequential components) in the current module.                                                                                                                              |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| filename                   | Writes the report in the summary file.                                                                                                                                                                                           |
| -hierarchical              | Generates a report for the hierarchy under the current module or<br>the specified module. The hierarchy of the current module or<br>specified module is traversed and the report is generated for<br>each datapath module found. |
| -instance                  | Generates a report for each instance of the datapath modules.                                                                                                                                                                    |
| -module <i>module_name</i> | Specifies the module for which all the datapath resources are to be separated.                                                                                                                                                   |
| -mux                       | Reports the multiplexers (mux) generated in the netlist and their attributes. The attributes reported are the number of data inputs to the mux, the width of the mux, and the mux architecture.                                  |
|                            | The three possible mux architectures are <i>encoded</i> , <i>decoded</i> , and <i>mixed</i> . Encoded and decoded multiplexers will automatically                                                                                |

|             | be identified with the -mux option alone. For architectures with<br>both encoded and decoded output ports (mixed mux), the<br>architecture of each individual output port is reported with the -<br>mux option. When the -mux option is used in conjunction with the<br>-summary option on a mixed mux, only its identification as a<br>mixed mux will be reported. |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | In addition, the RTL source file name and the line number of the conditional statement to which the mux is associated are also reported.                                                                                                                                                                                                                            |
|             | When -mux is used in conjunction with the -hierarchical option, all the muxes generated in a hierarchical module are reported.                                                                                                                                                                                                                                      |
|             | When -mux is used in conjunction with the -module option, the muxes in the specified module name are reported.                                                                                                                                                                                                                                                      |
| -sequential | Reports the sequential components in the netlist and the<br>attributes associated with them. Reports the type (latch or flip-<br>flop), width, and the asynchronous and synchronous set/reset<br>values associated with each bit of the sequential element.                                                                                                         |
|             | Used with -hierarchical, reports all sequential components in a hierarchical module.                                                                                                                                                                                                                                                                                |
|             | Used with -module <i>module_name</i> , reports the sequential components in the module.                                                                                                                                                                                                                                                                             |
|             | Used with -summary, reports a summary of the set/reset values of the sequential components in the current module.                                                                                                                                                                                                                                                   |
| -shared     | Reports the datapath clusters that are being shared after<br>resource sharing. By default, the report_resources<br>command prints out the datapath resources in the source<br>clusters being shared in addition to the resources in the shared<br>module.                                                                                                           |
|             | Used with -hierarchical, reports the datapath resources in all the shared modules along with the datapath resources in the unshared clusters in a hierarchical module.                                                                                                                                                                                              |

Used with -module *module\_name*, reports the datapath resources in the shared module and the datapath resources in the clusters before resource sharing.

Used with -instance, reports the instance name of the current module along with its other attributes.

-summary

Generates summary report for each datapath module. The summary contains module or instance name, type and number of each arithmetic operator in the module or instance.

### Examples

■ The following shows the report format for mux:

| report_resources -mux -hier -instance    |                                                                        |                      |           |           |        |          |                  |
|------------------------------------------|------------------------------------------------------------------------|----------------------|-----------|-----------|--------|----------|------------------|
| Report                                   | report                                                                 | report_resources     |           |           |        |          |                  |
| Options                                  | -seq -hier                                                             |                      |           |           |        |          |                  |
| Date<br>  Tool<br>  Release<br>  Version | 20010926.155535<br>  ac_shell<br>  v5.0-d147<br>  Sep 26 2001 10:43:34 |                      |           |           |        |          |                  |
| +<br>  Current Module   mux<br>+         |                                                                        | +<br>+               |           |           |        |          |                  |
| +                                        |                                                                        | +                    | +         | +         |        | +        | ++               |
|                                          | iplexer                                                                | s<br>+               |           | +         |        |          |                  |
| Instance   Moo                           | nce   Module   File   Line                                             |                      | Line      | Data      | Inputs | Width    | Swappable        |
|                                          | K_16_1<br>K_4_1                                                        | design.v<br>design.v | 8<br>  20 | 16<br>  4 |        | 1<br>  1 | true  <br>  true |

# ■ The following shows the report format for sequential elements

> report\_resources -hier -seq

:

| +                                        | +                                                                       |
|------------------------------------------|-------------------------------------------------------------------------|
| Report                                   | report_resources                                                        |
| Options                                  | -hier -seq                                                              |
| Date<br>  Tool<br>  Release<br>  Version | 20030227.114726  <br>bgx_shell  <br>v5.9-s009  <br>Feb 25 2003 11:49:53 |
| Current Module                           | foo                                                                     |

|                       | See                                                         | quential | l Element | S     |       |    |    |    |    |
|-----------------------|-------------------------------------------------------------|----------|-----------|-------|-------|----|----|----|----|
| Module                | File                                                        | Line     | Name      | Type  | Width | AS | AR | ss | SR |
| AWMEM_LATCH_<br>x_reg | /ambit/regress/bg/<br>hls/tests/reportRe<br>so/sequential.v | 8        | x_reg     | LATCH | 1     | N  | N  | -  | -  |
| AWMEM_LATCH_<br>y_reg | /ambit/regress/bg/<br>hls/tests/reportRe<br>so/sequential.v | 8        | y_reg     | LATCH | 1     | N  | N  | -  | -  |
| AWMEM_LATCH_<br>z_reg | /ambit/regress/bg/<br>hls/tests/reportRe<br>so/sequential.v | 8        | z_reg     | LATCH | 1     | N  | N  | -  | -  |

### ■ This shows the report format for the -shared option:

> report\_resources -hier -shared

|              | Arithme                                                          | etic | Resources             |              |                |                   |                               |
|--------------|------------------------------------------------------------------|------|-----------------------|--------------|----------------|-------------------|-------------------------------|
| Module       | File                                                             | С    | Arch                  | q0           | Line           | Out               | In                            |
| AWDP_partiti |                                                                  | 1    | ripple                | +            |                | 16u               | 16ux16u                       |
| on_2         |                                                                  |      | booth                 | *            |                | 16u               | 16ux16u                       |
|              |                                                                  | #    | fcla/boot<br>h        | * *          | 17             | 16u               | 16ux16u                       |
|              |                                                                  | #    | fcla<br>booth<br>fcla | + * +        | 12<br>12<br>14 | 16u<br>16u<br>16u | 16ux16u<br>16ux16u<br>16ux16u |
| AWDP_MULT_2  | /ambit/regress/bg/<br>  hls/tests/res_shar<br>  e/incr/addmult.v | 1    | ripple/bo<br>  oth    | +<br>  *<br> | +<br>  16<br>  | 16u               | 16ux16u                       |

#: Source cluster. A module can share multiple source clusters.

# report\_skewed\_clock\_pins

```
report_skewed_clock_pins [-all]
```

Reports each sequential element in the netlist that is driven by a buffer not driving any other gate. It also reports the name of the buffer, the delay added, the worst slack checked by this clock pin, and the worst slack triggered by this clock pin.

This command can be useful for getting an overview of which sequential elements in the netlist have been skewed at the leaf of the clock tree (see <u>do optimize</u> -skew\_clock).

### **Options and Arguments**

-all Reports all clock pins of sequential elements in the netlist.

## Example

The following command generates the subsequent report:

> report\_skewed\_clock\_pins

| + |          | Skewed Clock  | Pins Re | eport   | +       |
|---|----------|---------------|---------|---------|---------|
|   | Pin      | Buffer(s)     | Skew    | D-Slack | Q-Slack |
|   | Q_reg/CK | DLY1X1 BUFX20 | 0.98    | -0.67   | -0.69   |

# **Related Information**

<u>do optimize</u> -skew\_clock

# report\_vhdl\_library

report\_vhdl\_library [-verbose] [library] [{ > | >> } filename]

Lists the mappings between all the defined VHDL libraries and the directories to which they are mapped. This command can be used to check where BuildGates Synthesis picks up VHDL units such as packages.

## **Options and Arguments**

| file_name | Names the file to which the report is written.    |
|-----------|---------------------------------------------------|
| library   | Lists the mapping for the specified VHDL library. |
| -verbose  | Lists the contents of the VHDL library.           |

### **Related Information**

set global hdl vhdl read version

set vhdl library

# report\_wire\_self\_heat\_violation

```
report_wire_self_heat_violation [-ignore_dont_modify_nets] [-ignore_clknets]
    [-verbose]
```

Reports all nets with wire-self-heat violations, such as a violation whose current measures exceed its corresponding current limit.

## **Options and Arguments**

| -ignore_clknets      |                                                       |
|----------------------|-------------------------------------------------------|
|                      | Excludes clock nets from the report.                  |
| -ignore_dont_modify_ | nets<br>Excludes dont_modify nets from the report.    |
| -verbose             | Reports all nets, including those without violations. |

### Example

The following command displays a report similar to the one shown below:

> report\_wire\_self\_heat\_violation -verbose

|           | Net | Slew   | Freq  |           |
|-----------|-----|--------|-------|-----------|
|           |     | Сар    | Limit | Violation |
|           |     | I_ave  | Limit | Violation |
|           |     | I_peak | Limit | Violation |
|           |     | I_rms  | Limit | Violation |
| Module A: |     |        |       |           |
|           | ABC | nnn    | nnn   |           |
|           |     | nnn    | nnn   | nnn       |
|           |     | nnn    | nnn   | nnn       |
|           |     | nnn    | nnn   | nnn       |
|           |     | nnn    | nnn   | nnn       |
|           |     |        |       |           |

| Net | Slew | Freq |   |
|-----|------|------|---|
|     |      |      | • |
|     |      | •    | • |
|     |      | •    | • |

Total Number of Nets = nnn Total Number of Violations = nnn

### **Related Information**

<u>do optimize</u>

do xform prevent wire self heat

reset wire self heat prevention

# reset\_crosstalk\_threshold

reset\_crosstalk\_threshold

Clears any existing crosstalk threshold stored with the design.

Use this command for any design that has previously gone through crosstalk prevention and has a threshold stored with it.

### **Related Information**

<u>do\_optimize</u>

do xform prevent crosstalk

report crosstalk violations

# reset\_dont\_modify

reset\_dont\_modify [-network] [-stop\_at\_complex\_gates] [-hierarchical]
 [-no\_hierarchical] list\_of\_object\_ids

Removes the dont\_modify attribute set by a previous set\_dont\_modify command, applied to a design module, instance, or port. Use set\_cell\_property for applying and removing properties on library cells.

## **Options and Arguments**

| -hierarchical        | Valid only for module, net and port object types. It is the default<br>for net and port object types.If -hierarchy is specified for<br>modules, all lower levels of hierarchy below the specified module<br>are also removed.                                                                                                            |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| list_of_object_ids   | Specifies the list of object IDs for the instances, modules, nets, pins, or ports to be reset. Ports must be either input or inout ports of modules or output or inout pins of instances. When ports are specified, it is equivalent to specifying the nets connected to those ports. See the <u>set_dont_modify</u> command.            |
| -network             | Removes the dont_modify attribute from the combinational path connected to the given object. This option is valid with net and port object types.                                                                                                                                                                                        |
| -no_hierarchical     | Valid for only net and port object types. It is the default for module object ids. If -no_hierarchical is specified, the dont_modify attribute will be removed from nets and instances connected to the specified nets or ports that are in the same hierarchy or in the combinational path (if -network is specified) of the hierarchy. |
| -stop_at_complex_gat | Stops the tool's traversal of the hierarchy at the input to complex gates (non-buffer and non-inverter gates). The dont_modify flag will not be reset on objects beyond this point.                                                                                                                                                      |
|                      | <b>Note:</b> To use this option, you must also specify the <i>-network</i> option.                                                                                                                                                                                                                                                       |

# **Related Information**

do dissolve hierarchy

do uniquely instantiate

set\_cell property

set\_dont\_modify

# reset\_failsafe

reset\_failsafe

Restores the name of the file in which to store the database in the event of a fatal error to the default location of  $/tmp/process_id$ .

### **Related Information**

<u>set\_failsafe</u>

# reset\_global

reset\_global global\_variable\_name

Sets the specified global variable to its default value.

### **Options and Arguments**

global\_variable\_name

The name of the global variable to reset.

### Example

The following command resets the VHDL version for writing out VHDL netlists to the default: 1993.

reset\_globals hdl\_vhdl\_write\_version

### **Related Information**

<u>set\_global</u>

### reset\_register\_type

reset\_register\_type register\_instance\_id\_list

Removes the register type constraint imposed by the previously issued set\_register\_type command. Subsequent mapping will not enforce mapping to the previously specified register type.

### **Options and Arguments**

register\_instance\_id\_list Specifies the list of object IDs for the register instances.

### Example

The following commands set, then remove the LD1 and FD1 register type constraint:

```
> set_register_type -latch LD1 -flip_flop FD1 [find -registers *]
...
> reset_register_type [find -registers *]
```

Subsequent mapping will not enforce mapping to register cells of the same type as LD1 and FD1.

### **Related Information**

<u>set\_register\_type</u>

### reset\_vhdl\_library

reset\_vhdl\_library library\_name

Removes all VHDL units that have been analyzed into a specific library. This is useful if a package was mistakenly analyzed into the wrong library, or if you wish to clear the library of all VHDL units previously analyzed into it and start over.

### **Options and Arguments**

library\_name

Specifies the name of the library from which all analyzed units are to be deleted.

### Examples

- The following command resets the library MYLIB after a VHDL package from wrongpack.vhd was analyzed into it:
  - > read\_vhdl -library MYLIB wrongpack.vhd
  - > reset\_vhdl\_library MYLIB
- The following command reads the correct package into MYLIB:
  - > read\_vhdl -library MYLIB rightpack.vhd

### **Related Information**

report vhdl library

set vhdl library

### reset\_wire\_self\_heat\_prevention

reset\_wire\_self\_heat\_prevention

Clears any existing wire-self-heat stored with the design.

Use this command for any design that has previously gone through wire-self-heat prevention and has a threshold stored with it.

#### **Related Information**

<u>do\_optimize</u>

- do xform prevent crosstalk
- report wire self heat violation

### set\_attribute

set\_attribute object\_id attribute\_name attribute\_value

Sets the value set for the specified attribute on the specified object. You can set tool- and user-defined attributes.

The set\_attribute command can be used to disable some of the default do\_optimize behavior. You can set the *object\_id*, the *attribute\_name*, and the *attribute\_value*. The corresponding options for do\_optimize are -force, -no\_partition, -priority, -flatten, -phase, -multiple\_output.

By default, do\_optimize partitions the module. If you do not want to partition a particular module, then you can use the following command:

set\_attribute object\_id no\_partition true

If you use the do\_optimize -no\_partition command and you want to partition a particular module, then use the following:

set\_attribute object\_id no\_partition false

If the following command is used:

set\_attribute [find -techlib lca300kv] default\_operating\_conditions WCCOM

the software treats default\_operating\_conditions as a user-specified attribute having a value of WCCOM. This attribute is set on the object lca300kv.

You can use the following command to query the attribute:

get\_info [find -techlib lca300kv]

The set\_attribute command can be used to set the operating conditions, but it is recommended that you use the <u>set\_operating\_conditions</u> command instead.

The set\_attribute command is not limited to setting the attributes listed below. Userdefined attributes are also valid.

### **Options and Arguments**

| attribute_name  | Specifies the name of the attribute to set. Refer to the <u>Attributes</u> list below for a list of tool-defined attributes. |
|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| attribute_value | Sets the attribute to this value.                                                                                            |

object\_id

The ID of the module, instance, cellref, net, port, or pin to modify.

### Attributes

The attributes below are defined by the BuildGates Synthesis tool. User-defined attributes are also valid.

| flatten {on   off    | Controls the operations used for the optimization of logic<br>equations. If the flatten option is set to on, the logic equations are<br>flattened into a sum of products form before applying the<br>optimization. This helps to create a faster and more optimal<br>implementation of the logic, even though it may use extra area<br>(gates). If the flatten option is set to auto, only certain flattening<br>operations are performed; some of the time consuming steps are<br>ignored. The flattening step may be disabled entirely by setting<br>the option to off.<br><i>Default</i> : off. |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| force {true   false} | Forces this command to carry out all of its steps irrespective of the initial state of the design.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| no_partition {true   | <pre>false} Indicates that the design should not be automatically partitioned into smaller modules for optimization, irrespective of the number of input pins on the cells in the module. Each module boundary should be retained as the partition to optimize.</pre>                                                                                                                                                                                                                                                                                                                              |
| phase {true   false} | Performs phase assignment on module <code>object_id</code> in logic minimization during structuring if the module is flattened into two levels of logic successfully with option <code>-flatten</code> auto or <code>-flatten</code> on (or attribute flatten) or on sum-of-products logic hierarchy, if any, that is inferred from constant case statement within the module <code>object_id</code> . <i>Default</i> : false                                                                                                                                                                      |
|                      | Below are two examples.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                      | Set phase attribute to false on all modules in the design hierarchy except module module_A, then optimize.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

set\_attribute module\_A phase true do\_optimize Apply phase assignment on all modules in the design hierarchy in structuring except module module\_B, then optimize using the <u>-phase\_assignment\_option</u>. set\_attribute module\_B phase false do\_optimize -phase\_assignment priority {area | time} Sets area or timing minimization to be the highest priority of the technology, independent of the optimization step. If you have a loosely constrained or unconstrained design\_then the priority

technology, independent of the optimization step. If you have a loosely constrained or unconstrained design, then the priority should be set to area. Default: time

### Examples

The following examples demonstrate how you can use the set\_attribute command to change the default behavior of do\_optimize:

■ The following command prevents the partition of the module module\_x1. By default, do\_optimize partitions modules:

```
> set_attribute module_x1 no_partition true
```

■ The following command shows how you can partition a particular module even if you previously used the do\_optimize -no\_partition command. This command allows the partition of the module module\_x2:

```
> set_attribute module_x2 no_partition false
```

■ The following command sets the user-defined attributes. The following command sets the attribute my\_attribute on the net object my\_net to a value of my\_value:

> set\_attribute [find -net my\_net] my\_attribute my\_value

■ The following commands query the attribute, as shown below:

> get\_attribute [find -net my\_net] my\_attribute

or

> get\_info [find -net my\_net]

### **Related Information**

<u>delete attribute</u>

### <u>get\_attribute</u>

<u>get\_info</u>

<u>set global</u>

### set\_aware\_component\_property

Allows the property to be set on an aware component. The only allowed property is dont\_utilize. When this property is set on a component, it is not available for use.

### **Options and Arguments**

| component_name       | Specifies the name of the component for which the property is to be set.                                                                                                                                                             |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dont_utilize {true   | <pre>false} Currently, the only allowed property is dont_utilize.</pre>                                                                                                                                                              |
| -library library_nam | Selects the name of the aware library to which the component<br>belongs. If no library is specified, then the component is<br>searched in all aware libraries (in the order determined by the<br>global aware_library_search_order). |

#### Example

The following command sets the dont\_utilize property on the AWARITH\_ABS component from the AWARITH library:

> set\_aware\_component\_property -library AWARITH dont\_utilize true AWARITH\_ABS

#### **Related Information**

delete aware component

<u>set\_aware\_library</u>

<u>report aware library</u>

### set\_aware\_library

set\_aware\_library library\_name library\_path

Maps the logical library name *library\_name* to the physical path *library\_path*.

### **Options and Arguments**

| library_name | Specifies the name of the aware library.           |
|--------------|----------------------------------------------------|
| library_path | Specifies the path to map to <i>library_name</i> . |

### Example

The following example maps the logical name of the library AWMYLIB to the existing directory /home/smith/libs/lib1 where the analyzed components physically reside:

> set\_aware\_library AWMYLIB /home/smith/libs/lib1

### **Related Information**

<u>delete\_aware\_component</u>

# set\_cell\_property

set\_cell\_property property value -lib library\_name cell\_names

Sets properties of one or more cells to specified values. These properties can be dont\_modify, dont\_utilize, and so on. The value of the properties can be set to true or false.

**Note:** The set\_tech\_info, get\_tech\_info, and reset\_tech\_info commands should be used instead of this command. These are powerful mechanisms which can go beyond the functionality of set\_cell\_property. They can be used to update library information. The set\_cell\_property command will be phased out in the future.

# Important

The following commands and associated options do not cause optimization to automatically remap instances in an already mapped netlist:

set\_tech\_info -lib lib\_name -cell cell\_name -dont\_utilize true
set\_cell\_property dont\_utilize true [find -cellrefs cell\_name]

If you set the dont\_utilize attribute on a cell after mapping your design, the tool may still use that cell during subsequent optimization. To ensure that the cell is not used, you must either unmap your design or use the do\_optimize \_force option, and then remap and re-optimize your design.

### **Options and Arguments**

| cell_names               | Specifies the cells whose properties will be changed.                                                                                                                                                                                                              |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -lib <i>library_name</i> | Specifies the library containing a list of properties that will be changed.                                                                                                                                                                                        |
| property                 | <pre>Specifies the name of a property for the cell that needs to be set. Properties include: dont_modify {true   false} dont_utilize {true   false} objecttype type module id pins id All the properties of a cell can be listed using the command get_info.</pre> |

value

Specifies a new value for the property.

### **Related Information**

<u>get info</u>

set\_current\_module

### set\_current\_instance

```
set_current_instance [instance_name]
```

Sets the instance given by *instance\_name* to be the current instance. Design objects referenced by subsequent commands can be found relative to this instance. All searches for design objects are started in this instance. If design objects are referenced hierarchically, *instance\_name* is used as the root (top) of the hierarchy.

The set\_current\_instance command is used instead of the <u>set\_current\_module</u> command when a module has multiple instances and each instance requires a separate set of constraints.

### **Options and Arguments**

```
instance_name
```

Specifies the name of the instance to become the current instance. If *instance\_name* is not given, the current instance is set to the top instance of the hierarchy.

### Example

The following example sets the current instance to MAC/MULTI, then later sets it back to top:

```
> set_current_instance MAC/MULT1
...
...
> set_current_instance
```

# **Related Information**

<u>get\_current\_instance</u>

set current module

### set\_current\_module

set\_current\_module module\_name

Sets the module represented by *module\_name* as the current module. Design objects referenced by subsequent commands can be found relative to this module. All searches for design objects are started in this module. If design objects are referenced hierarchically, *module\_name* is used as the root (top) of the hierarchy.

If a module has multiple instances and each instance requires a separate set of constraints, then the set\_current\_instance command is used.

Note: When the set\_current\_module command is used, the *current\_instance* is reset to the <u>set top timing module</u>.

### **Options and Arguments**

module\_name

Names the module that is being used in the current context.

### Example

This example sets the mycounter module as the current context. Now the constraints can be applied to the ports of mycounter:

> set\_current\_module mycounter

To apply constraints to ports of another module use the set\_current\_module command with another module name or use the hierarchical name of the ports.

### **Related Information**

do uniquely instantiate

<u>get current module</u>

set top timing module

# set\_dissolve\_hierarchy

```
set_dissolve_hierarchy {obj_id_list} {true | false}
```

Sets the dissolve property for each module or hierarchical instance in the specified list. During optimization, modules or instances tagged true are dissolved into their parent modules. Modules or instances with the dont\_modify attribute are not touched by this command.

**Note:** This command has no effect on AmbitWare (AW) or Datapath modules.

### **Options and Arguments**

| {obj_id_list}  | Lists the modules or hierarchical instances to be dissolved during optimization. |
|----------------|----------------------------------------------------------------------------------|
| {true   false} | Specifies the value to set the dissolve property.                                |

#### **Related Information**

do create hierarchy

<u>do dissolve hierarchy</u>

# set\_dont\_modify

```
set_dont_modify [-network] [-hierarchical | -no_hierarchical]
    [-stop_at_complex_gates] list_of_object_ids
```

Prevents instances, modules, nets, pins, or ports from being modified. This is useful when those objects have already been optimized. No further optimization will be done on the specified instances, modules, nets, pins, or ports. The command is also useful when macros are instantiated from a library.

**Note:** When an instance pin or port is specified, it is equivalent to specifying the nets connected to those pins or ports.

Once a module is marked for no modifications, the commands

do\_uniquely\_instantiate or do\_dissolve\_hierarchy are ignored for that module. When a net is specified, all the connecting instances are affected by the set\_dont\_modify property. When an instance pin or port is specified, the net connected to the pin or port is marked as dont\_modify.

The nets, modules or instances identified by this command are preserved "as is" during the synthesis process.

For nets, ports, and pins, all nets and instances connected hierarchically to the specified nets or ports will be marked dont\_modify. If the -network option is specified, then hierarchies will be traversed to mark all nets and instances in the combinational path of specified nets and ports as dont\_modify.

Note: PKS does not set the dont\_modify attribute on generic instances.

### **Options and Arguments**

| -hierarchical    | Valid only for module object types. It is the default for net and port object types. If -hierarchy is specified for modules, all lower levels of hierarchy below the specified module are also marked.                                                                                                                         |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -no_hierarchical | Valid for only net and port object types. It is the default for module object ids. If -no_hierarchical is specified, then only nets and instances connected to the specified nets or ports that are in the same hierarchy or in the combinational path (if -network is specified) of the hierarchy will be marked dont_modify. |

| list_of_object_id    |                                                                                                                                                                                                                                                                                                       |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies the list of object IDs for the instances, modules, nets,<br>pins, or ports to be preserved. Ports must be either input or inout<br>ports of modules or output or inout pins of instances. When ports<br>are specified, it is equivalent to specifying the nets connected to<br>those ports. |
| -network             |                                                                                                                                                                                                                                                                                                       |
|                      | Specifies that the dont_modify attribute applies to the combinational path connected to the given object. This option is valid with net and port object types.                                                                                                                                        |
| -stop_at_complex_gat | es                                                                                                                                                                                                                                                                                                    |
|                      | Stops the tool's traversal of the hierarchy at the input to complex gates (non-buffer and non-inverter gates). The dont_modify flag will not be set on objects beyond this point.                                                                                                                     |
|                      | <b>Note:</b> To use this option, you must also specify the <i>-network</i> option.                                                                                                                                                                                                                    |

### Examples

■ The following example shows how the highlighted nets in the figure below are preserved. (If the -no\_hierarchical option was specified the highlighted path in the instance 14 (shown by the dotted boundary), and the nets n1, n2 would not be preserved):

> set\_dont\_modify -network [find -net rst]



■ The following command preserves the module myRAM and all of its hierarchy:

> set\_dont\_modify -hierarchical [find -mod myRAM]

■ The following command marks the instance RAPID\_FIFO for preservation:

```
> set_dont_modify [find -inst RAPID_FIF0]
```

■ The following command marks the net and the two or more instances to which it connects as dont\_modify:

```
> set_dont_modify [find -net n_190]
```

■ The following command marks the net connected to the port as dont\_modify, but not the other end instance:

```
> set_dont_modify [find -port port_A]
```

■ The following command marks the net connected to the port and all the other end instances in the fanout cone as dont\_modify, stopping at a hierarchical port or a sequential cell:

```
> set_dont_modify -network -no_hierarchical [find -port port_A]
```

- The following command marks the net connected to the port and all the other end instances in the fanout cone as dont\_modify, without stopping at a hierarchical port:
  - > set\_dont\_modify -network [find -port port\_A]

### **Related Information**

do dissolve hierarchy

do uniquely instantiate

reset\_dont\_modify

set current module

### set\_failsafe

set\_failsafe filename

Sets the name of the file in which to store the database in the event of a fatal error. The specified file name is used instead of the system default location of /tmp/process\_id.

### **Options and Arguments**

filename

Specifies the name of the directory and file in which to store the database in the event of a fatal error.

### **Related Information**

<u>reset\_failsafe</u>

# set\_global

set\_global global\_name value

Sets the global variables for the ac\_shell. These variables are independent of the design, but affect the overall run procedure and the ac\_shell policies on various global matters, for example, the Verilog module naming style, message verbosity level, slew limit, and line length in reports.

All global variables have default value when ac\_shell starts up. Once a variable is set to a new value, it retains that value for the current ac\_shell session unless a subsequent use of this command sets a new value for the variable. User-specified values for global variables are not saved in the Ambit Synthesis database (ADB) file.

The value of any global variable can be obtained using get\_global command. The value of any global variable can be set to the default value using reset\_global command. The set\_global command has a one-to-one correspondence with the get\_global and reset\_global commands. Every variable defined in set\_global also applies to get\_global and reset\_global.

For a complete list of globals and their descriptions, see <u>Global Variable Reference for</u> <u>BuildGates Synthesis and Cadence PKS</u>.

### **Options and Arguments**

| global_name         | The name of the global you wish to set.                                                                   |
|---------------------|-----------------------------------------------------------------------------------------------------------|
| value               | Any argument necessary for the global (for example: true, false, a string, or an integer or float value). |
| Related Information |                                                                                                           |
| get global          |                                                                                                           |

<u>reset\_global</u>

<u>set\_attribute</u>

# set\_logic0

set\_logic0 port\_list

Sets ports to logic 0 so that the optimization tool can better optimize the design.

### **Options and Arguments**

port\_list

Lists the ports that are to be set to logic 0.

### Example

The following command sets all ports with names beginning with "rst" to logic 0.

> set\_logic0 [find -port rst\*]

### **Related Information**

do xform propagate constants

<u>set\_logic1</u>

# set\_logic1

set\_logic1 port\_list

Sets ports to logic 1 so that the optimization tool can do a better optimization of the design.

### **Options and Arguments**

port\_list

Lists the ports that are to be set to logic 1.

### Example

This command sets all ports with names beginning with "preset" to logic 1.

> set\_logic1 [find -port preset\*]

### **Related Information**

do xform propagate constants

<u>set\_logic0</u>

#### set\_message\_count

set\_message\_count [message\_ID | { error | warning | info | info\_msg }] integer

Sets the count for the specified message\_ID or type of message (error, warning, info, or info\_msg) to the value of *integer*. If *integer* is not specified, zero is assumed.

### **Options and Arguments**

| error      | Sets the count for message type error.                                            |
|------------|-----------------------------------------------------------------------------------|
| info       | Sets the count for message type info.                                             |
| info_msg   | Sets the count for message type info_msg.                                         |
| integer    | Sets the count value of the <i>message_ID</i> or message type. <i>Default</i> : 0 |
| message_ID | Specifies the ID of the message whose count will be changed.                      |
| warning    | Sets the count for message type warning.                                          |

#### Example

The following command resets the count on the error type of messages to zero.

> set\_message\_count error

### **Related Information**

<u>get message count</u>

<u>set message verbosity</u>

### set\_message\_verbosity

```
set_message_verbosity message_ID {on | off | 0-9}
```

Controls the level of verbosity of the messages generated by ac\_shell in reporting information, warnings, and errors.

You can assign a new verbosity level to each message to filter the ac\_shell messages given out by the ac\_shell. The messages displayed by the ac\_shell have a message ID attached to them. These IDs are used to assign new message verbosity levels. Each message has a default verbosity level assigned to it.

All fatal errors have a verbosity level of 0, 1 or 2. It is recommended that message verbosity level be set greater than 2.

Note: If message verbosity is set to 9 then it will override all other messages.

### **Options and Arguments**

| message_ID     | Specifies the ID of the message whose verbosity level will be changed.                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| on   off   0-9 | Sets the verbosity level of the message. The message can be turned on, off, or set as a number between 0 and 9. A lower number implies that more messages will be reported. |

### Examples

- The following command turns off "# delays not supported" warnings.
  - > set\_message\_verbosity VLOGPT-035 off
- The following command sets "range for parameters ignored" warnings to verbosity 7.
  - > set\_global message\_verbosity CDFG-345 7

#### **Related Information**

set global message verbosity level

# set\_path\_group\_options

```
set_path_group_options group_name [-effort {none | low | medium | high}]
      [-target_slack float] [-all_end_points]
```

Specifies which do\_xform\_optimize\_slack options to apply to the named group.

Options specified to the do\_xform\_optimize\_slack command will apply only to groups that have no set\_path\_group\_options specified and to the null group (the set of paths that do not belong to a named group). Default: medium

#### **Options and Arguments**

| -all_end_points     |                                                                                                                                                                                                                                                                                                                            |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | Without this option, optimization only works on the worst<br>endpoint in the path group and gives up if it cannot improve that<br>endpoint. If this option is used, when optimization has trouble<br>optimizing endpoint 1, it does not skip this group. Instead it<br>optimizes the next critical endpoint in that group. |
|                     | This option works in conjunction with the -target_slack value.                                                                                                                                                                                                                                                             |
| -effort {none   low | <pre>  medium   high} Controls the CPU time spent during the timing optimization step.</pre>                                                                                                                                                                                                                               |
|                     | high<br>Further improvements by applying various time- consuming<br>algorithms.                                                                                                                                                                                                                                            |
|                     | <b>low</b><br>Operation is done quickly to meet requirements through easy<br>optimization steps.                                                                                                                                                                                                                           |
|                     | medium<br>Extra time is spent searching for alternate mappings and<br>structures to meet all the constraints. This is the default.                                                                                                                                                                                         |
|                     | <b>none</b><br>No slack optimization is done on the named group.                                                                                                                                                                                                                                                           |

| group_name          | Specifies the name of the group to be optimized with the options specified in this command. Required argument.                                                                                       |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -target_slack float | Specifies the worst slack allowed for any path in the group.<br>Optimization proceeds until all paths in the group have slack<br>equal to or greater than the target slack.<br><i>Default</i> : 0.0. |
|                     | You can specify negative slack to compensate for overconstraining.                                                                                                                                   |

### Examples

The following command directs optimization to proceed with various algorithms until the worst slack in the group is equal to or greater than -1ns and to continue until all endpoints in the group with slack less than -1ns are optimized:

set\_path\_group\_options GRPA -effort high -target\_slack -1 -all\_end\_points

#### **Related Information**

report path group options

reset path group

<u>set path group</u>

Using Path Groups for Optimization in the Common Timing Engine (CTE) User Guide.

### set\_port\_property

set\_port\_property -boundary\_optimization {true | false} port\_list

Sets the specified property on all ports in the port list.

### **Options and Arguments**

```
-boundary_optimization {true | false}
Specifies whether the specific ports of specific modules listed in
port_list are to be kept isolated from boundary optimization
(constant propagation and so forth).
Default: true
port_list
Specifies the names or IDs of module ports that you want to keep
isolated from boundary optimization.
```

#### **Related Information**

do xform propagate constants

### set\_register\_type

```
set_register_type [-exact] [-latch example_latch_cell_name]
        [-flip_flop example_flipflop_cell_name] register_instance_id_list
```

Specifies the latch or flip-flop library cell type for certain register instances in the design. A latch or flip-flop cell type is represented by an example latch or flip-flop; any latch or flip-flop that has the same sequential characteristics as the example latch or flip-flop is considered that type. A latch type, a flip-flop type, or both can be specified. The subsequent technology mapping enforces mapping to register cells of the same type for the specified register instances.

The set\_register\_type command is "sticky" in the sense that subsequent mapping and unmapping/remapping enforce mapping to the specified register type, unless command reset\_register\_type is issued or another set\_register\_type command is issued on the same register instances.

Example latch or flip-flop cells cannot be multi-bit register, even if the global map\_to\_multibit\_registers is turned on.

The register type is ignored in a DFT scan flow where register instances will be mapped to appropriate scan registers based on the chosen scan style.

#### **Options and Arguments**

| -exact                    | Enforces an exact mapping to the example latch or flip-flop cell.              |
|---------------------------|--------------------------------------------------------------------------------|
| -flip_flop                | Enforces mapping to flip-flop cells of the same type as the example flip-flop. |
| -latch                    | Enforces mapping to latch cells of the same type as the example latch.         |
| register_instance_id_list |                                                                                |

Specifies the list of object IDs for the register instances.

### Examples

The following command enforces mapping to latch cells of the same type as LD1 and flipflop cells of the same type as FD1 for all register instances in the design: > set\_register\_type -latch LD1 -flip\_flop FD1 [find -registers \*]

The following command enforces an exact mapping to FD1 for all register instances whose names match Q\_reg\_\*.

> set\_register\_type -exact -flip\_flop FD1 [find -registers Q\_reg\_\*]

#### **Related Information**

<u>reset register type</u>

set global map to multibit registers

### set\_table\_style

```
set_table_style -name table_name [-reverse_rows] [-major_sort integer]
  [-minor_sort integer] [-max_widths list_of_integers]
  [-min_widths list_of_integers] [-indent integer]
```

Disables printing of specific columns and allows for specifying the minimum and maximum size of each column. It allows for reversing the data, for controlling the left indent, and for controlling the sorting of the columns.

**Note:** Do *not* include a blank space between commas "," when specifying widths. If you are specifying a value for the width(s), make sure there is *no* leading or trailing blank space.

### **Options and Arguments**

| -indent <i>integer</i>     | Specifies the number of spaces to leave on the left for that particular table                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -major_sort integer        | Specifies the column to be used in the major sort. If the column number is negative, it reverses the sort.                                                                                                                                                                                                                                                                                                                                                             |
| -max_widths <i>list_of</i> | _integers<br>Specifies the maximum widths of each column for example, the<br>option {0,5,7} specifies that first column is to be zero width<br>(deleted) and the second column is to remain and the previously<br>specified width, or the default width if a previous width was not<br>specified. Each column resizes itself to be between the range of<br>the maximum and minimum widths specified for that column<br>based on the data in that column. See examples. |
| -min_widths                | Specifies the minimum column width allowed. Each column resizes itself to be between the range of the maximum and minimum widths specified for that column based on the data in that column.                                                                                                                                                                                                                                                                           |
| -minor_sort integer        | Specifies the column to be used in the minor sort. It applies to ALL rows that have the same values in the major_sort column. If the column number is negative, it reverses the sort.                                                                                                                                                                                                                                                                                  |

| -name table_name | Specifies the table that is being controlled. Each table has one of the following unique names: |
|------------------|-------------------------------------------------------------------------------------------------|
|                  | area_slack1<br>area_slack2<br>informed_register                                                 |
|                  | inferred_register<br>pa_inst_int_pwr_rep_table                                                  |
|                  | pa_inst_int_pwr_rep_table1                                                                      |
|                  | pa_inst_leak_pwr_rep_table                                                                      |
|                  | pa_inst_net_pwr_rep_table                                                                       |
|                  | pa_inst_fall_slew_table                                                                         |
|                  | pa_inst_rise_fall_slew_table                                                                    |
|                  | pa_inst_rise_slew_table                                                                         |
|                  | pa_module_fall_slew_table                                                                       |
|                  | pa_module_rise_fall_slew_table                                                                  |
|                  | pa_module_rise_slew_table                                                                       |
|                  | pa_tc_stats_table                                                                               |
|                  | <pre>popt_report_clock_gating_table</pre>                                                       |
|                  | report_area_cell                                                                                |
|                  | report_area_cell_hier                                                                           |
|                  | report_area_cell_summary                                                                        |
|                  | report_area_summary                                                                             |
|                  | report_case_stats                                                                               |
|                  | report_comb_loop                                                                                |
|                  | report_library                                                                                  |
|                  | report_library_cell                                                                             |
|                  | report_library_header                                                                           |
|                  | report_library_operating_condtions                                                              |
|                  | report_power_inst                                                                               |
|                  | report_power_net                                                                                |
|                  | report_timing                                                                                   |
|                  | report_timing_header                                                                            |
|                  | report_timing_summary                                                                           |
|                  | report_timing_prologue                                                                          |
|                  | report_fanin                                                                                    |
|                  | report_fanout                                                                                   |
|                  | report_fsm                                                                                      |
|                  | report_fsm_transition                                                                           |

-reverse\_rows

Reverses the data rows. This is useful, for example, if you want to trace back from an end point and the default report traces forward from the end point.

#### Examples

The following command alters the table style in the main report\_library table, allowing columns 1-3 (cell name, type, cell area) to be the default size, and adjusting column 10 (the function column) to have a maximum width of 40. The table will be sorted based on column 3, but when two cells have identical area, these will be sorted based on column 1 (the cell name):

```
set_table_style -name report_library_cell -max_widths {,,,0,0,0,0,0,0,40}
-major_sort 3 -minor_sort 1
```

This disable columns 4-9 in the main report\_library table:

- dont\_modify flag
  dont\_utilize flag
  footprint
  outputs
  inputs
  inouts
- The following command resizes the first column to a maximum range of 70 and specifies a default width of 50 for the second column. The default for the maximum width is 50 and the default for the minimum width is 5:

```
> set_table_style -name report_timing -max_widths {70,}
```

**Note:** Do *not* include a blank space between commas ", " when specifying widths. If you are specifying a value for the width(s), make sure there is *no* leading or trailing blank space.

■ The following command tells the report\_timing command to list the hierarchical pin and arrival times in the report:

```
> set_global report timing format {hpin arrival}
```

- The following command specifies a default width of 50 for the first and second column:
  - > set\_table\_style -name report\_timing -max\_widths {,}
- The following command specifies a default width of 50 for the first and second column:
  - > set\_table\_style -name report\_timing -max\_widths {,}

| Related Information                |  |
|------------------------------------|--|
| <u>report analysis coverage</u>    |  |
| <u>report cell instance</u> -power |  |
| report_power                       |  |
| report cell instance timing        |  |
| report clocks                      |  |
| <u>report_ports</u>                |  |
| report slew for power analysis     |  |
| report timing                      |  |
| <u>report_tc_stats</u>             |  |
| <u>set global line length</u>      |  |

### set\_unconnected

set\_unconnected port\_list

Sets the ports listed as unconnected. The optimization phase will remove the driving logic.

Note: This command is applicable for top-level output ports only.

This command will set an attribute, \_propagated\_value, on the ports. You can remove the attribute by using the <u>delete\_attribute</u> command.

#### **Options and Arguments**

port\_list

Specifies the list of port names to disconnect from.

### **Related Information**

<u>delete\_attribute</u>

<u>set current module</u>

<u>set\_logic0</u>

<u>set\_logic1</u>

# set\_vhdl\_library

set\_vhdl\_library library\_name directory\_name

Defines a logical VHDL library name and the name of the directory used to store the analyzed VHDL units. The following libraries are currently preset on starting up ac\_shell:

| AMBIT | <pre>install_dir/BuildGates/version/lib/tools/vhdl/1993/ambit</pre> |
|-------|---------------------------------------------------------------------|
| IEEE  | <pre>install_dir/BuildGates/version/lib/tools/vhdl/1993/ieee</pre>  |
| STD   | <pre>install_dir/BuildGates/version/lib/tools/vhdl/1993/std</pre>   |
| TEMP  | /tmp/?/TEMP                                                         |
| WORK  | TEMP                                                                |

The VHDL library WORK must be mapped to an existing logical library. To change the mapping, use set\_vhdl\_library WORK library\_name.

### **Options and Arguments**

| directory_name | The physical path name to the directory where VHDL units are stored. |
|----------------|----------------------------------------------------------------------|
| library_name   | The logical name of the VHDL library                                 |

#### Examples

- This example shows how you can define libraries where the VHDL source file has a library(use) clause referring to libraries other than the five listed above, you can use this command to define those libraries, for example:
  - > set\_vhdl\_library MYLIB /home/user\_name/libs/mylib
- VHDL units can be analyzed into that library by reading source VHDL files.

> read\_vhdl -library MYLIB pack.vhd

The analyzed files are sent to /home/user\_name/libs/mylib.

It is useful to explicitly specify libraries with the set\_vhdl\_library command because the VHDL units (such as packages) analyzed into such a library are not deleted when you exit from the synthesis tool. The VHDL units can be reused in a subsequent invocation of the synthesis tool. If an attempt is made to analyze files into a library that has not been created with the set\_vhdl\_library command, a default directory for that library is created in the /tmp area (the scratch area pointed to by the environment variable AMBIT\_TMP\_DIR). However, such a library (and the corresponding directory) will be deleted when you exit from the synthesis tool.

Note: Two different libraries should not be mapped to the same physical directory.

### **Related Information**

<u>read\_vhdl</u>

report vhdl library

# unalias

unalias *name* 

Removes an alias created by the alias command

### **Options and Arguments**

name

Specifies the name of an existing alias

### **Related Information**

<u>alias</u>

# write\_adb

write\_adb [-all] [-no\_assertions] [-no\_acl] [-hierarchical |-no\_hierarchical]
 file\_name

Writes design data stored by ac\_shell to the database using the Ambit Synthesis database (ADB) file format. Writes out the entire hierarchy, automatically using the -hierarchical option with the command so you do not have to specify it. In ADB format, the data can be quickly loaded to perform further synthesis or analysis of data when running ac\_shell. The read\_adb command loads data from the .adb file into the database.



If the software terminates abnormally, an ADB recovery file is created in the /TMP file. To use a directory other than the default /TMP, use the environment variable AMBIT\_TMP\_DIR. For example: setenv AMBIT\_TMP\_DIR ./adb\_dir.

When generating an ADB using the write\_adb command, all globals are written to a special section in the .adb file. When reading an .adb file, you have the option of reading all of the globals back into the current design using the <code>read\_adb-restore\_globals</code> command.

| -all                 |                                                                                                                                                                                                                                                             |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Dumps all of the modules in the database.<br><i>Default</i> : Dumps the current module and the hierarchy below.                                                                                                                                             |
| file_name            | Specifies the name of the ADB output file.                                                                                                                                                                                                                  |
| -hierarchical   -no_ | hierarchical<br>Writes out only the current module, if -no_hierarchical is<br>specified.<br><i>Default</i> : -hierarchical.                                                                                                                                 |
| -no_acl              | Does not dump ACL modules.                                                                                                                                                                                                                                  |
| -no_assertions       | The assertions are not included in the ADB that is currently being written out. By default the assertions are written into all ADBs and all the assertions read in are applied. When using the read_adb command, this flag causes the assertions in the ADB |

being read in to be ignored. *Default*: Writes assertions into all ADBs and to apply all the assertions being read in.

**Note:** Using this option will cause placement information to be ignored (not written out).

# Example

This command writes out an .adb file of the current module, dumping it into a file called mydesign.adb:

> write\_adb -no\_hierarchical mydesign.adb

# **Related Information**

<u>read adb</u>

write\_verilog

# write\_edif

write\_edif [-hierarchical] file\_name

Writes out designs in EDIF format.

### **Options and Arguments**

-hierarchical

If the -hierarchical option is not specified, EDIF is only written out for the current module.

Specifies the name of the EDIF output file.

### Example

The following example assumes that the current module is TOP which has the following hierarchical structure

```
report_hierarchy
TOP(g)
MIDDLE(g)
BOTTOM(g)
```

The following command writes out an EDIF description of all the three modules: TOP, MIDDLE, and BOTTOM:

> write\_edif -hierarchical out.edif

### **Related Information**

<u>read\_verilog</u>

set\_global edifout\_\*

Refer to the <u>EDIF Interface</u> chapter in the HDL Modeling for BuildGates Synthesis manual.

# write\_globals

write\_globals [-modified] [-group group\_name] [file\_name]

Writes out all globals in the system in a format that can be read back in through the bg\_shell Tcl interface.

# **Options and Arguments**

file\_name

The name of the globals output file. Filename must be the last argument specified. If you do not specify a filename, the globals are written to the screen.

-group group\_name Includes only global variables belonging to the specified group. Valid values for group\_name include hdl, aware, ta, opt, pks, dft, dist, dcn, edif, misc, and ui.

-modified Includes only global variables that have been changed from their default value.

### Examples

- The following command writes out all global variables that have been modified:
  - > write\_globals -modified my\_globals.tcl
- The following command reads the globals file back into the tool:
  - > source my\_globals.tcl

# **Related Information**

<u>report\_globals</u>

# write\_verilog

write\_verilog [-hierarchical] [-equation] verilog\_file\_name

Writes out a netlist stored in the database in Verilog format. The netlist is generated by the do\_build\_generic command or do\_optimize command.

You can write out the Verilog netlist in a compressed Verilog file in GNU zip format if the specified output file ends in the .gz suffix. No special option is needed to write out a gzipped file. For example: write\_verilog verilog\_file\_name.gz.The read\_verilog command automatically reads compressed outputs.

If the netlist is written out after the do\_build\_generic command it contains instances of ATL and XATL cells. For gate level verification of this netlist, the Ambit Synthesis Verilog Library must be used for simulation.

If the netlist is written out after you use the do\_optimize command then it contains instances of cells in the target technology library. To verify this netlist, a Verilog library of the target technology must be used for simulation.

Note: If you get assign statements in the output you must use the command do\_xform\_fix\_multiport\_nets or set\_global fix\_multiport\_nets.

| -equation     | Writes the verilog output without reference to atl, xatl, or library cells. Instead, each combinational or tristate cell instance is represented with an equation, and a simulation model for each sequential cell is written out. |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -hierarchical | Writes the netlist out as a hierarchical netlist. If this option is not<br>used, the command writes out a netlist for the current module<br>and any implied hierarchy created by BuildGates Synthesis,<br>such as ACL modules.     |
| -rtl          | Writes RTL-style netlists for AmbitWare arithmetic components<br>and multiplexer modules. This style can quickly simulate gate-<br>level netlists and integrate with downstream FPGA synthesis<br>tools.                           |

verilog\_file\_name

Specifies the file in which the Verilog netlist will be saved.

#### Attributes

set global hdl verilog out columns

set global hdl\_verilog\_out\_compact

<u>set global hdl verilog out source track</u>

set global hdl verilog out use supply

#### Examples

- The following command saves the hierarchical netlist in the file counter.v.net: write\_verilog -hierarchy counter.v.net
- The following command writes out a gzipped (compressed) file by appending the .gz extension to the file

write\_verilog addr.v.gz

#### **Related Information**

<u>do build generic</u>

<u>do optimize</u>

read verilog

write\_assertions

# write\_vhdl

write\_vhdl [-hierarchical] [-equation] [-no\_wrap] vhdl\_file\_name

Writes out a VHDL netlist. The resulting netlist preserves the original VHDL types of the ports of the current module being written. As the internal representation of the module is in terms of bits, any required wrapper functions to convert between the port types and the internal bit type are also generated. This enables you to do a comparison of the netlist with the original VHDL description through simulation or verification.

You can write out the VHDL netlist in a compressed VHDL file in GNU zip format if the specified output file ends in the .gz suffix. No special option is needed to write out a gzipped file. For example: write\_vhdl vhdl\_file\_name.gz. The read\_vhdl command automatically reads compressed outputs.

All of the submodules will have equivalent std\_logic or std\_logic\_vector ports. If the module being written did not originate from a VHDL source file, then all ports are written out in terms of equivalent std\_logic ports.

| -hierarchical  |                                                                                                                                                                                                                                       |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | Writes the netlist out as a hierarchical netlist. If this option is not<br>used, the command writes out a netlist for the current module<br>and any implied hierarchy created by BuildGates Synthesis,<br>such as ACL modules.        |
| -equation      |                                                                                                                                                                                                                                       |
|                | Writes the vhdl output without reference the atl, xatl, or library<br>cells. Instead, each combinational or tristate cell instance is<br>represented with an equation, and writes out a simulation model<br>for each sequential cell. |
| -no_wrap       | Writes the current module with equivalent std_logic or std_logic_vector representation (that is, do not preserve the original VHDL port types).                                                                                       |
| vhdl_file_name | Specifies the file to which the VHDL netlist will be written.                                                                                                                                                                         |

### Examples

The following examples refer to the following hierarchy of VHDL entities:

```
report_hierarchy
-TOP(g)
-MIDDLE(g)
-BOTTOM(g)
```

■ In the following example, the entity TOP will have its port types preserved while MIDDLE and BOTTOM will have std\_logic ports.

```
> set_current_module MIDDLE
MIDDLE
```

```
> report_hierarchy -MIDDLE(g) -BOTTOM(g)
```

```
> write_vhdl -hierarchical netlist.vhd
```

■ The following command specifies both entities MIDDLE and BOTTOM will have std\_logic ports.

```
> write_vhdl -hierarchical -no_wrap netlist.vhd
```

■ The following command writes out a gzipped (compressed) file by appending the .gz extension to the file:

write\_vhdl addr.vhd.gz

### **Related Information**

<u>read vhdl</u>

set global hdl vhdl write version

# **CTPKS Commands**

This chapter describes the CTPKS commands and attributes available with the Cadence<sup>®</sup> Physically Knowledgeable Synthesis (PKS) tool.

**Note:** Because CTPKS works simultaneously on the logic design and the physical design, most CTPKS commands are only relevant when used at the top level (corresponding to the entire physical design).

- Commands
  - □ <u>do build\_clock\_tree</u> on page 300
  - □ <u>do build physical tree</u> on page 305
  - □ <u>do xform optimize clock tree</u> on page 308
  - □ <u>get\_clock\_tree\_constraints</u> on page 317
  - □ <u>get clock tree objects</u> on page 318
  - □ <u>report clock tree</u> on page 320
  - □ <u>report\_clock\_tree\_violations</u> on page 327
  - □ reset clock tree constraints on page 329
  - □ <u>set clock tree constraints</u> on page 330
  - □ <u>define\_structure</u> on page 333 (CT-Gen command)
- Attributes
  - □ <u>ct dont utilize</u>
  - □ <u>ct\_excluded</u>
  - □ <u>ct\_leaf</u>
  - □ <u>ct lps associated gating component</u>
  - □ <u>ct lps main gating component</u>

- □ <u>ct\_no\_leaf</u>
- □ <u>ct\_preserve</u>
- □ <u>ct preserve tree</u>
- □ <u>ct\_specify\_padding</u>

# do\_build\_clock\_tree

```
do_build_clock_tree [-pin list_of_pins] [-save_structure filename]
  [-use_structure filename] [-noplace] [-no_gated {rising | falling}] [-power]
  [-fast] [-move_gated][-clock_model list_of_files] [-pad_after_gated]
  [-use_family list_of_families] [-use_buffers buffer_list]
  [-use_inverters inverter_list] [-effort {low | medium | high}]
  [-merge_delay_chains] [-no_isolation_buffer] [-fix_drv_on_excluded_pins]
  [-no_verbose]
```

Generates a clock tree using parameters set by the set\_clock\_tree\_constraints command. If no constraints are set, the command has no effect. This command requires that all the modules that contain a clock net are uniquified. The command will fail otherwise.

**Note:** If no physical data is available (for instance, if you are using BuildGates Synthesis or BuildGates Extreme Synthesis), the do\_build\_clock\_tree command will work in wireload model mode.

When you invoke this command, the following changes are made to the database:

- Buffers, inverters, or both are added.
- An isolation buffer is automatically inserted between the output of any drive boosters and any excluded clock tree pins to reduce the capacitance at the drive boosters. This isolation buffer prevents slew degradation at the drive booster output when there is a large number of excluded clock tree pins.
- The clock propagation mode is set to propagated.
- The + USE CLOCK property is added in a DEF on all clock nets.
- The + SHIELDNET property is propagated to all clock nets if it is present on the subtree root net.
- The NONDEFAULTRULE, and layer usage table information is propagated to all clock nets if it is present on the subtree root net.

**Note:** If you use a general clock model, the resulting shielding, NONDEFAULTRULE, and layer usage table information come from the general clock model file. See the <u>General Clock Model</u> section in the *BuildGates Synthesis User Guide* for more details about the general clock model.

| -clock_model list_of | _files<br>Loads general clock model definition files. Each resulting tree will<br>match one family defined within these files. When the<br>-clock_model switch is used, the global variable<br><u>ctpks_default_global_clock_model_file</u> is ignored.<br>The use of a general clock model is not compatible with the use<br>of a structure file. See the <u>General Clock Model</u> section in the<br><i>BuildGates Synthesis User Guide</i> for more details about the<br>general clock model. |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -effort {low   mediu | m   high}<br>Specifies the level of CPU usage when building a clock tree.<br>When you specify -low, CPU usage is low, but the quality of<br>results (QoR) may be affected. When you specify -high, CPU<br>usage is higher, but the QoR is better.<br>Default: low                                                                                                                                                                                                                                 |
| -fast                | Tells the tool to do a quick job. It picks only the fastest cell from<br>all available buffers and inverters and builds a clock tree with it.<br>The number of internal trials is also reduced. This option is useful<br>to check if a clock tree can be built with the constraints you have<br>chosen. In most cases, the resulting clock tree should not be<br>used as is.                                                                                                                      |
| -fix_drv_on_excluded | _pins<br>Instructs CTPKS to attempt to fix DRVs on such pins. Unless<br>specified, CTPKS does not fix design rule violations on excluded<br>pins.                                                                                                                                                                                                                                                                                                                                                 |
| -merge_delay_chains  | Reduces the number of clock tree buffers (padding cells) used to<br>balance different subtrees. Several subtrees are gathered and<br>delayed at the same time using the same chain of clock tree<br>buffers.                                                                                                                                                                                                                                                                                      |
|                      | <b>Note</b> : This option cannot be used in conjunction with the -save_structure option. If you specify both options, CTPKS will issue an error message.                                                                                                                                                                                                                                                                                                                                          |

| -move_gated          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                      | Specifies that the gated components can be moved to optimize performance.                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| -no_gated {rising    | falling}<br>Specifies that the clock tree stops at the first cells downstream<br>from the root that are neither buffer nor inverter. If the active edge<br>at this point is not specified, the edge given on the command line<br>is used.                                                                                                                                                                                                                                                                               |  |
| -no_isolation_buffer | Prevents the insertion of isolation buffers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| -no_verbose          | Disables message generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| -noplace             | Specifies that incremental Qplace will not be invoked.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                      | <b>Note</b> : Some inserted buffers or inverters may be illegally placed.                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| -pad_after_gated     | Forces the padding (buffers or inverters added in order to delay<br>a particular point) to be inserted after the gating components.<br>This switch will be ignored if the ct_specify_padding<br>attribute is set on the gated component instance.                                                                                                                                                                                                                                                                       |  |
| -pin list_of_pins    | Specifies the pin of an instance or input port as the root of the clock tree. Without -pin, CTPKS will run on all clock trees previously specified with the set_clock_tree_constraints command.                                                                                                                                                                                                                                                                                                                         |  |
| -power               | Adds a new criteria when CTPKS selects the best clock-tree<br>topology. When CTPKS finds several topologies which meet<br>constraints with a higher priority (DRVs, max delay, skew, and so<br>on), it calculates the power usage of these topologies and<br>chooses the one with the minimum power consumption. The<br>consumption is measured on all clock objects, including buffers<br>inverters, and registers.<br><b>Note</b> : This option requires BuildGates Extreme, which includes<br>the low power feature. |  |

#### -save\_structure filename

Writes the clock tree structure to a file whose syntax is identical to the syntax of <u>define structure</u> on page 333. If you use a general clock model, the resulting net characteristics as defined in the general clock model will not be saved in the structure file.

**Note**: This option cannot be used in conjunction with the -merge\_delay\_chains option. If you specify both options,CTPKS will issue an error message.

#### -use\_buffers buffer\_list

Specifies the list of buffers to be used. If you do not want any buffer to be used, use empty braces, (-use\_buffers {}).

#### -use\_family list\_of\_families

Defines the list of families to be tried from the general clock model definition files given either by the -clock\_model switch or by the <u>ctpks</u> <u>default</u> <u>global</u> <u>clock</u> <u>model</u> <u>file</u> global variable. See the <u>General Clock Model</u> section in the *BuildGates Synthesis User Guide* for more details about the general clock model.

-use\_inverters inverter\_list

Specifies the list of inverters to be used. If you do not want any inverters to be used, use empty braces (-use\_inverters {}).

-use\_structure filename

Loads the clock tree structure you want to use from a file. CTPKS applies the semi-automatic mode to this structure. If the from\_pin or from\_iopin specified in the file matches the clock pin being treated by CTPKS, the corresponding tree structure is used. The syntax is similar to the syntax of <u>define structure</u> on page 333. The use of a structure file is not compatible with the use of a general clock model.

#### Examples

In the following example, the first command sets minimum and maximum insertion delays, maximum skew, and maximum transition on the clock tree starting from the port clk. The second command builds the clock tree using buffers CLKBUFX1 and CLKBUFX2 and no inverters. The third command builds the entire clock tree and saves the structure to a file named tcl.struct.

```
> set_clock_tree_constraints -min_delay 0.1 -max_delay 1.0 -max_skew 0.3
-max_tree_transition 0.3 -pin [find -port clk]
```

- > do\_build\_clock\_tree -use\_buffers {CLKBUFX1 CLKBUFX2} -use\_inverters {}
- > do\_build\_clock\_tree -save\_structure tc1.struct

The following is an example of do\_build\_clock\_tree output:

Warning: Clock Propagation Mode is ideal <CTPKS-105> Info: Setting clock propagation mode to propagated. <CTPKS-104>

| Clock tree root clk                                                                                                                                                                                                                                                                                                                                | Clock Tree<br>Constraints        | Actual                                                                   | Area                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------|-------------------------------------------------|
| Number of Inserted Instances<br>Max. transition time at tree pins<br>Min. insertion delay to leaf pins<br>Max. insertion delay to leaf pins<br>Max. skew between leaf pins<br>Number of Violations<br>Number of Buffers<br>Number of Buffers<br>Number of Instances<br>Total Number of Instances<br>Number of Excluded Pins<br>Number of Leaf Pins | 0.300<br>0.100<br>1.000<br>0.300 | 3<br>0.131<br>0.144<br>0.211<br>0.067<br>0<br>0<br>3<br>0<br>3<br>0<br>4 | 0.000<br>134.400<br>0.000<br>134.400<br>134.400 |

#### **Related Information**

do uniquely instantiate

<u>report clock tree</u>

<u>report\_clock\_tree\_violations</u>

<u>set clock tree constraints</u>

# do\_build\_physical\_tree

```
do_build_physical_tree list_of_pins_or_ports[-noplace] [-fast]
    [-clock_model list_of_files] [-use_family list_of_families]
    [-use_buffers buffer_list] [-use_inverters inverter_list]
    [-save_structure filename] [-use_structure filename]
    [-effort {low | medium | high}]
```

Creates a balanced tree starting from the given pins or ports specified by *list\_of\_pins\_or\_ports*. All buffers and inverters in the downstream tree are removed and replaced by the new tree. The tree stops at any cell that is not a buffer or an inverter. The attributes ct\_preserve, ct\_leaf, ct\_excluded, ct\_preserve\_tree, and ct\_dont\_utilize are taken into account when building the tree. When there is no physical tree constraint at root, the smallest alternative tree (respecting design rules) is kept.

Unlike to the do\_build\_clock\_tree command, do\_build\_physical\_tree does not propagate 'use clock' attributes.

**Note:** If no physical data is available (for instance, if you are using BuildGates Synthesis or BuildGates Extreme Synthesis), the do\_build\_physical\_tree command will work in wireload model mode.



This command can only be used with pins and ports, not net names or net IDs. It cannot be used on constant pins or pins specified as dont\_modify.

# **Options and Arguments**

-clock\_model list\_of\_files

Loads general clock model definition files. Each resulting tree will match one family defined within these files. The global variable <a href="https://cital.clock.model\_file">ctpks\_default\_global\_clock\_model\_file</a> is never taken into account for do\_build\_physical\_tree. The use of the general clock model is not compatible with the use of a structure file. See the <u>General Clock Model</u> section in the *BuildGates Synthesis User Guide* for more details about the general clock model.

-effort {low | medium | high}
 Specifies the level of CPU usage when building a clock tree.
 When you specify -low, CPU usage is low, but the quality of
 results (QoR) may be affected. When you specify -high, CPU

|                             | usage is higher, but the QoR is better.<br><i>Default</i> : low                                                                                                                                                                                                                                                                                             |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -fast                       | Tells the tool to do a quick job. It picks only the fastest cell from<br>all available buffers and inverters and builds a clock tree with it.<br>The number of internal trials is also reduced.                                                                                                                                                             |
| list_of_pins_or_po          | <i>rts</i><br>Specifies the names or IDs of pins or ports from which to start<br>physical tree.                                                                                                                                                                                                                                                             |
| -noplace                    | Specifies that incremental Qplace will not be invoked.                                                                                                                                                                                                                                                                                                      |
|                             | Note: Some inserted buffers or inverters may be illegally placed.                                                                                                                                                                                                                                                                                           |
| -save_structure file        | name<br>Writes the clock tree structure to a file whose syntax is identical<br>to the syntax of <u>define_structure</u> on page 333.                                                                                                                                                                                                                        |
| -use_buffers <i>buffer_</i> | _list<br>Specifies the list of buffers to be used. If you do not want any<br>buffer to be used, use empty braces, (-use_buffers {}).                                                                                                                                                                                                                        |
| -use_family list_of_        | <i>_families</i><br>Defines the list of families to be tried from the general clock<br>model definition files given by the -clock_model option.                                                                                                                                                                                                             |
| -use_inverters <i>inver</i> | <pre>ster_list Specifies the list of inverters to be used. If you do not want any inverters to be used, use empty braces (-use_inverters {}).</pre>                                                                                                                                                                                                         |
| -use_structure filen        | Loads the clock tree structure you want to use from a file. CTPKS<br>applies the semi-automatic mode to this structure. If the<br>from_pin or from_iopin specified in the file matches the<br>clock pin being treated by CTPKS, the corresponding tree<br>structure is used. The syntax is similar to the syntax of<br><u>define_structure</u> on page 333. |

# Examples

- The following command builds a balanced clock tree starting from the pin in1:
  - > do\_build\_physical\_tree D1
- The following is an example of output from the do\_build\_physical\_tree command:

| Physical tree root Dl                                                                                                                                                                                                                                                                                         | Physical<br>Tree<br>Constraints | Actual                                                               | Area                                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|----------------------------------------------------------------------|-----------------------------------------------|
| Number of Inserted Instances<br>Min. insertion delay to leaf pins<br>Max. insertion delay to leaf pins<br>Max. skew between leaf pins<br>Number of Violations<br>Number of Buffers<br>Number of Inverters<br>Number of Interes<br>Total Number of Instances<br>Number of Excluded Pins<br>Number of Leaf Pins | 0.000<br>1.000<br>0.500         | 2<br>0.111<br>0.112<br>0.001<br>0<br>2<br>0<br>2<br>0<br>2<br>0<br>2 | 89.600<br>89.600<br>0.000<br>89.600<br>89.600 |

### **Related Information**

<u>report clock tree</u>

<u>Attributes</u>

set\_clock\_tree\_constraints

# do\_xform\_optimize\_clock\_tree

```
do_xform_optimize_clock_tree {-asymmetric | -symmetric |
    -mix_symmetric_and_asymmetric | -rebalance_subtrees | -merge_delay_chains |
    -resize_gating_cells | -incremental [-effective_skew] |
    -useful_skew [-decreasing_slack_order | -increasing_slack_order]
    [-do_not_allow_slack_degradation] [-slack_limit] [-ignore_hold]
    [-balance_output_neg_slack] } [-no_gated {rising | falling}] [-no_drv]
    [-fix_drv_on_excluded_pins] [-use_buffers buffer_list]
    [-use_inverters inverter_list] [-smaller_cells_only]
    [-no_degradation_allowed] [-pin list_of_pins] [-use_repeaters]
```

Applies one or more transforms to clock trees. The transforms that are applied depend on the given argument. The applied transforms try to optimize the clock tree(s) according to the criteria to minimize the following in decreasing priority order:

- Number of design rule violations
- Worst maximum latency violation
- Worst skew violation
- Worst minimum latency violation
- Area

Depending on the transforms that are used, this command may produce the following modifications to the database: swap, insertion or deletion of buffers and inverters of the clock tree(s), placement modification of the buffers and inverters of the clock trees, swap of gated components of the clock trees.

**Note:** If no physical data is available (for instance, if you are using BuildGates Synthesis or BuildGates Extreme Synthesis), the do\_xform\_optimize\_clock\_tree command will work in wireload model mode.

# **Options and Arguments**

-asymmetric

Optimizes the subtrees of the clock tree(s) by resizing the buffers without keeping the symmetry of the subtrees: different buffers are allowed at the same level.

-fix\_drv\_on\_excluded\_pins

Instructs CTPKS to attempt to fix DRVs on such pins. Unless specified, CTPKS does not fix design rule violations on excluded pins.

| -incremental [-effec | tive_skew] [-no_degradation_allowed]<br>Resizes one or more buffers that are producing the worst<br>violation. If the worst violation is reduced enough, the transform<br>applies recursively on the next worst violation.                                                                         |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | When the worst violation cannot be improved any further by<br>changing the buffer producing it, the incremental mode algorithm<br>continues to try to improve timing by allowing some degradation<br>in the worst violation, as long as successive optimizations result<br>in further improvement. |
|                      | -effective_skew Works on effective skew minimization instead of global skew minimization.                                                                                                                                                                                                          |
|                      | -no_degradation_allowed Stops optimizations when the worst violation cannot be improved any further by any change to the buffer producing it.                                                                                                                                                      |
|                      | In contrast to the default behavior, optimization stops as soon as<br>changes start degrading timing, regardless of whether<br>successive optimizations would result in further improvement.                                                                                                       |
| -merge_delay_chains  | Reduces the number of clock tree buffers inserted to balance<br>subtrees. Several subtrees are gathered and the same chain of<br>buffers is used to delay them. Use this option in conjunction with<br>the -rebalance_subtrees option.                                                             |
| -mix_symmetric_and_a | Asymmetric<br>Applies the -symmetric option to symmetrical subtrees and<br>-asymmetric option to asymmetrical subtrees.                                                                                                                                                                            |
| -no_drv              | Instructs CTPKS to not check for design rule violations.                                                                                                                                                                                                                                           |
| -no_gated {rising    | falling}<br>Specifies that the clock tree stops at the first cells downstream<br>from the root that are neither buffer nor inverter. If the active edge<br>at this point is not specified, the edge given on the command line<br>is used.                                                          |

| -pin list_of_pins    | Specifies the list of root pins of clock trees to work on. Without the -pin switch, the do_xform_optimize_clock_tree command will run on all clock trees previously specified with the set_clock_tree_constraints command.                                                                                                                                                                                                                    |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| -rebalance_subtrees  | Balances the subtrees of the clock tree(s) by inserting padding buffers.                                                                                                                                                                                                                                                                                                                                                                      |  |
| -resize_gating_cells | Optimizes the subtrees of the clock tree(s) by resizing the gated component of the clock tree(s).                                                                                                                                                                                                                                                                                                                                             |  |
| -smaller_cells_only  | Specifies that cell substitutions be performed only with cells the same size as the original or smaller.                                                                                                                                                                                                                                                                                                                                      |  |
| -symmetric           | Optimizes the subtrees of the clock tree(s) by resizing the buffers<br>by level in order to keep the symmetry. If the subtrees are not<br>symmetrical, this option does not optimize the clock tree.                                                                                                                                                                                                                                          |  |
|                      | <b>Note:</b> CTPKS does not build symmetrical clock trees when gating components are involved. CTPKS builds symmetrical subtrees from the output of each gating component, but then it adds buffers (padding cells) in front of these gating components to balance between all of these subtrees. This results in a final clock tree that is non-symmetrical.                                                                                 |  |
| -use_repeaters       | Repeater insertion is done to reduce design rule violations (DRVs) and transition (slew) violations. The maximum number of repeaters CTPKS places in a repeater chain is 10. It selects the length of the repeater chain based on the cost function. The length which reduces the maximum number of DRVs, without degrading the max-delay/skew/min-delay, is selected as the best length and the repeater chain with that length is inserted. |  |
|                      | The various modes in XFORM in which repeater insertion is done is as follows:                                                                                                                                                                                                                                                                                                                                                                 |  |
|                      | Mode 1—Incremental (with -incremental option)                                                                                                                                                                                                                                                                                                                                                                                                 |  |

|              | Mode 2—Asymmetric (with -asymmetric option)                                                                                                                                                                                                                                                                                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | Mode 3—Symmetric (with -symmetric option)                                                                                                                                                                                                                                                                                                                                                               |
|              | Mode 1—Incremental                                                                                                                                                                                                                                                                                                                                                                                      |
|              | In the incremental mode, XFORM tries to fix the most critical violation and when this is fixed, it goes to the next critical violation. Whenever the most critical violation is a slew violation, then repeaters are inserted to fix it.                                                                                                                                                                |
|              | Mode 2—Asymmetric                                                                                                                                                                                                                                                                                                                                                                                       |
|              | This flow is same as the asymmetric flow. After resizing the current instance, if the <i>-use_repeaters</i> option is used, the following occurs:                                                                                                                                                                                                                                                       |
|              | 1. Gets the fanout pins of the current instance, that is the inputs that the current instance is driving.                                                                                                                                                                                                                                                                                               |
|              | 2. Iterates over the fanout-trace pins                                                                                                                                                                                                                                                                                                                                                                  |
|              | a. If any of the fanout-trace pins has a transition violation, then it tries to insert repeaters ahead of this fanout_tracepin                                                                                                                                                                                                                                                                          |
|              | Mode 3—Symmetric                                                                                                                                                                                                                                                                                                                                                                                        |
|              | The current level of the subtree is checked if it has any transition violations. If the level has transition violations, that is if any of the instance in that level drives a sink which has transition violation, then a repeater chain is inserted for each instance in the current level. The length of the repeater chain is also same for all the instances in the current level of the sub-tree. |
| -useful_skew | Applies the useful_skew transform on the clock trees defined<br>by the root clock pins. The useful_skew transform attempts to<br>fix a setup violation on a flip-flop of the clock tree by adding<br>buffers or inverters (and by extension, by adding delay) before<br>the clock pin. The fix will occur if no additional violation is<br>created.                                                     |

This transform finds the best solution in terms of area or number of inserted instances, and does not introduce new clock tree violations (except for skew).

In the useful skew methodology, the clock arrival times on each modified flip-flop are meant to be different (the skew is required to be non-zero).

The default behavior is to correct the worst negative slack. Correction stops when the worst slack cannot be improved any further.

The behavior options for -useful\_skew are as follows:

#### -balance\_output\_neg\_slack

Checks that the slack degradation on the data path for all leaf registers connected to the currently optimized leaf register is no larger than the slack obtained for the optimized register.

For example, consider a shift register containing just two flipflops, where the slack at the first register is -0.8 ns, and the slack at the connected register is -0.4. During useful skew optimization of the first register, the slack at the connected register can worsen. If optimization results in a slack of -0.6 ns at first register, the connected register will never have a slack worse than -0.6 ns with this option.

This option prevents the useful skew algorithm from looping when data feedback loops between leaf registers are present (data output of a leaf register connected through logic to data input of another leaf register in its fanin cone).

#### -decreasing\_slack\_order

Reduces all individual setup slacks, starting from the worst slack and continuing as long as there is fixable negative slack.

#### -do\_not\_allow\_slack\_degradation

Does not allow any slack degradation if you use one of the arguments specifying order.

#### -ignore\_hold

Ignores early slack (hold slack) degradations for all leaf registers.

#### -increasing\_slack\_order

Reduces all individual setup slacks, starting from the flip-flop with the smallest slack and continuing as long as there is fixable negative slack.

#### -random\_slack\_order

Reduces all individual setup slacks, in random order, as long as there is fixable negative slack.

If you do not specify an order, this option allows slack degradations smaller than the worst slack.

# -slack\_limit

Specifies a slack value. If the slack of a flip-flop is above the slack limit value, the command will skip it.

-use\_buffers buffer\_list

Specifies the list of buffers to be used. If you do not want any buffer to be used, use empty braces, (-use\_buffers {}).

```
-use_inverters inverter_list
```

Specifies the list of inverters to be used. If you do not want any inverters to be used, use empty braces (-use\_inverters {}).

#### Examples

■ The following command reoptimizes the clock tree starting at the root pin CLK using buffers BUFX1 and BUFX2:

```
> do_xform_optimize_clock_tree -pin CLK -incremental -use_buffers {BUFX1
BUFX2} -use_inverters {}
```

■ The next command corrects timing violations by applying a useful skew transform on the clock tree starting at the root pin CLK using buffers BUFX1 and BUFX2:

```
> do_xform_optimize_clock_tree -pin CLK -useful_skew -use_buffers {BUFX1
BUFX2} -use_inverters {}
```

■ The following is an example of the report generated when using the -useful\_skew option:

Info: Useful skew : fixed slack on leaf pin dff1999/CP (start slack=-1. 00000000, end slack -0.72127247) using 2 instances <CTPKS-122>.

| +   |                                      |                     | +                  |
|-----|--------------------------------------|---------------------|--------------------|
| Rep | oort useful skew for root<br>pin clk | Before<br>transform | After<br>transform |
|     | Number of negative slack             | 2                   | 2                  |

■ The following example shows how repeaters are inserted.

Assume that the driver and sink are placed as shown below and the transform got the Steiner points from the PKS as shown. Also, the celltype of the repeater is decided as follows:

```
If (celltype of sink is a buffer or inverter )
      then celltype of repeater is same as celltype of sink
else if ( celltype of driver is a buffer or inverter)
      then celltype of repeater is same as celltype of driver
else
      no repeater insertion is done.
```



If the best repeater chain length is supposed to be 2, then the repeaters are inserted along the Steiner path, such that the repeaters are evenly placed along the path. The distance between the repeaters should be equal.

If the repeater is a buffer (nbRepeaters\_ =2), then the insertion would be done as shown below.



If the repeater is an inverter (nbRepeaters\_ =2), then the insertion would be done as shown below.



# **Related Information**

do xform optimize clock gate

# get\_clock\_tree\_constraints

get\_clock\_tree\_constraints [-pin list\_of\_pins][-physical\_tree]

Displays the constraints on all clock trees or on a specific clock tree.

#### **Options and Arguments**

| -pin list_of_pins | Specifies the list of pin of instance or input ports for which to return the constraints.                       |
|-------------------|-----------------------------------------------------------------------------------------------------------------|
| -physical_tree    | Specifies that the constraints to be reported are for the do_build_physical_tree command for non-clock signals. |

### Example

The following command retrieves the constraints for the clock tree starting at the port clk: get\_clock\_tree\_constraints -pin [find -ports clk]

#### Output:

Info: Clock clk: min\_delay 0.000000, max\_delay 3.000000, max\_skew 0.
100000, max\_leaf\_transition 0.030000 <CTPKS-111>

#### **Related Information**

do build clock tree

<u>do\_build\_physical\_tree</u>

<u>get clock tree constraints</u>

reset clock tree constraints

# get\_clock\_tree\_objects

```
get_clock_tree_objects [{-leaf_only | -tree_only}] [-pin list_of_pins]
        [-no_gated] [-buffers] [-inverters] [-physical_tree]
```

Returns a list of objects in the form specified by the selected argument.

| -buffers   -inverter | Returns a Tcl list of IDs from the library cells usable for the clock<br>tree. Selecting buffers returns the buffer IDs. Selecting<br>inverters returns the inverter IDs.                                                                                                                                                                                                                                                                                                                             |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| {-leaf_only   -tree_ | _only}<br>Returns a Tcl list of object IDs that are part of the clock tree.<br>Selecting leaf_only returns only leaf instances; tree_only<br>returns only tree elements (pins, instances, and nets).                                                                                                                                                                                                                                                                                                  |
| -no_gated            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                      | Returns a Tcl list of clock tree objects seen from the root pin up<br>to the very first cells that are neither buffers nor inverters. Inputs<br>of combinational cells are reported as leaves.                                                                                                                                                                                                                                                                                                        |
| -physical_tree       | Use when physical constraints (set_clock_tree_constraints -physical) but no clock phase were applied at root pin.                                                                                                                                                                                                                                                                                                                                                                                     |
| -pin list_of_pins    | Returns clock tree objects from the root pins of clock trees<br>specified by <i>list_of_pins</i> . You can invoke this command on<br>any module in the hierarchy. If given by name, the root pin should<br>be the complete path name as seen from the<br>top_timing_module. If given by ID, the ID should be returned<br>by a find command executed from the top_timing_module<br>(see example below). If no pin is given, the pins on the clock tree<br>constraints that have been set will be used. |

#### Examples

The following commands store the IDs of the clock tree objects (nets, pins, instances) as my\_list:

```
set clock_root [find -hier -pin ul/u2/i_234/Y]
set my_list [get_clock_tree_objects -pin $clock_root]
```

■ The following command displays the list of cells available for clock tree building:

```
issue_message "list of cells available for clock tree:
[get_names [get_clock_tree_objects -buffer -inverter]]"
```

# report\_clock\_tree

Valid columns: pin\_name (hierarchical pin name), cellref (cell type), edge (^ (rising) or v (falling)), latency (delay from root pin on the considered edge), violation (violation codes), slew (slope of the signal on the considered edge), predecessor\_pin (name of the preceding hierarchical pin), level (number of cells in the tree from the root), increment (delay from predecessor pin), x\_y (X and Y location of the pin), fanout (number of successors and leaf pins (in parentheses) in tree), load (total capacitance on the net), info (informational codes), error (error code), power (power consumption)

Violation codes: C (a maximum capacitance violation on the net connected to the pin), F(a fanout violation on the pin), L (the delay on the pin violates the constraint), S (a max sink violation on the net connected to the pin), T (a max transition violation on the pin), W (a wire self heat violation on the net connected to the pin)

Info codes: A (associated pin (for clock gating networks) specified with the ct\_lps\_associated\_gating\_component attribute), e (pin or port defined as excluded with a ct\_excluded attribute), G (pin belonging to a gating component), H (hierarchical physical pin), I (pin belonging to an input padcell), l (pin or port defined as a leaf with a ct\_leaf attribute), L (clock pin of register recognized as a leaf), m (main pin (for clock gating networks) specified with the ct\_lps\_main\_gating\_component attribute), M (instance which is set dont\_modify), O( pin belonging to an output padcell), p (instance with the ct\_preserve attribute set), P (instance with the ct\_preserve\_tree attribute set to true)

Error codes: C (combinational cell with disabled path), D (data input of register not defined as leaf or excluded), F (timing not available), N (point closest to the root not driving any leaf), O (output port not defined as leaf or excluded), R (reconvergent clock (clock phase reconvergence)) T (point in tree twice (connectivity reconvergence from clock root))

Generates a report that displays (in a text table) the clock tree structure from its root component to all its leaf cells. If both edges of the clock are used, the report appears in two parts; one for the rising edge and the other for the falling edge. Excluded pins always appear in both parts. Also, when a cell has insertion delay, the displayed latency value includes the insertion delay. The value appears with an asterisk at the end (for instance, 4.17\*). When the insertion delay has a min and max value, the two latency values are displayed separated by a slash (for instance, 3.54/4.17\*).

# Important

The insertion delay calculated and used by all CTPKS commands is equal to the difference between the arrival time at the root and at the arrival time at the leaf. If the root is a port, and that port has a non-zero arrival time (that is, the port has a driver cell constraint), the insertion delay calculated by CTPKS will differ from that calculated by report\_timing by the value of the arrival time at the root. See <u>report\_timing</u> for more information on how that command handles insertion delay.

| <pre>{&gt;   &gt;&gt; file_name}</pre>                                                         | Specifies file redirection.                                                                                                                                                           |
|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -breadth_first_searc                                                                           | The Generates a report that displays the pins by level order (from the root). Pins (leaf or not) of the same level appear together.                                                   |
| -depth_first_search                                                                            | Generates a report that displays the pins in the order in which<br>they are found by going as far in the tree as possible. Leaf pins<br>connected to the same branch appear together. |
| -effective_skew                                                                                | Computes the effective skew value corresponding to the max<br>latency difference at clock pins between any two related registers<br>and displays it in the header summary.            |
| <pre>-format {list_of_columns}     Specifies the report format (must type curly braces):</pre> |                                                                                                                                                                                       |
|                                                                                                | pin_name: Hierarchical pin name                                                                                                                                                       |
|                                                                                                | cellref: Cell type                                                                                                                                                                    |
|                                                                                                | edge: ^ (rising) or v (falling)                                                                                                                                                       |
|                                                                                                | latency: Delay from root pin on the considered edge                                                                                                                                   |
|                                                                                                | violation: violation code:<br>C: Maximum capacitance violation on net connected to the pin                                                                                            |

| <ul> <li>F: Fanout violation on the pin</li> <li>L: Latency (delay) on the pin violates the constraint</li> <li>S: Max sink violation on the net connected to the pin</li> <li>T: Max transition violation on the pin</li> <li>W: Wire self heat violation on the net connected to the pin</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| slew: Slope of signal on the considered edge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| predecessor_pin: Name of the preceding hierarchical pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>level</b> : Number of cells in the tree from the root                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| increment: Delay from predecessor pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| $\mathbf{x}_{\mathbf{y}}$ : X and Y location of the pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>fanout</b> : Number of successors and leaf pins (in parentheses) in tree, for instance, 10(6L)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| load: Total capacitance on the net                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <pre>info: Informational code:<br/>A: Associated pin (for clock gating networks) specified with the<br/>ct_lps_associated_gating_component attribute<br/>e: Pin or port defined as excluded with a ct_excluded attribute<br/>G: Pin belonging to a gating component<br/>H: Hierarchical physical pin<br/>I: Pin belonging to an input padcell<br/>1: Pin or port defined as a leaf with a ct_leaf attribute<br/>L: Clock pin of register recognized as a leaf.<br/>m: Main pin (for clock gating networks) specified with the<br/>ct_lps_main_gating_component attribute<br/>M: Instance which is set dont_modify<br/>O: Pin belonging to an output padcell<br/>p: Instance with the ct_preserve attribute set<br/>P: Instance with the ct_preserve_tree attribute set to true</pre> |
| <ul> <li>error: Displays a character that indicates the error that prevents building a clock tree:</li> <li>C: Combinational cell with disabled path</li> <li>D: Data input of register not defined as leaf or excluded</li> <li>F: Timing not available</li> <li>N: Point closest to the root not driving any leaf</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|                      | <ul> <li>O: Output port not defined as leaf or excluded</li> <li>R: Reconvergent clock (clock phase reconvergence)</li> <li>T: Point in tree twice (connectivity reconvergence from clock root)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | power: Displays the power consumption                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| {-increasing_latency | <pre>-decreasing_latency} Specifies the order in which the pins should appear when depth_first_search or breadth_first_search do not fully determine it. The input and output of a cell always appear on two consecutive lines, only output latency is considered for ordering.</pre>                                                                                                                                                                                                                                                                                       |
| -leaf_only           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                      | Generates a report that will not display intermediate cells (buffers, inverters, and gating cells).                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| -min_max_only        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                      | Generates a report that will only report the cells involved in the smallest and longest latency.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| -no_gated {rising    | falling}<br>Generates a report that will consider each input (of non buffer<br>and non inverter cell) as a leaf pin. If no edge is specified, each<br>pin of the tree is shown in both the rising edge and falling edge<br>section unless the active edge can be derived for the timing<br>model. If an edge is specified, it is used as an active edge for the<br>pins whose active edge can not be derived from the timing<br>model. If clock tree constraints exist on the root pin, the report<br>will display constraints and flag violations in the violation column. |
| -physical_tree       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                      | Generates a report that will consider each input (of non buffer<br>and non inverter cell) as a leaf pin. Each pin of the tree is shown<br>in both the rising edge and falling edge section. This switch is<br>used in conjunction with the do_build_physical_tree<br>command or in order to detect a gated clock. If physical tree<br>constraints exist on the root pin, the report will display constraints<br>and flag violations in the violation column.                                                                                                                |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <pre>-print_effective_skew_leaves     Displays tables showing effective skew leaves. This option is only     valid with the -effective_skew option.</pre> |                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| -pvt {min   typ   ma                                                                                                                                      | <pre>ax} Specifies in which pvt the timing values displayed by the report_clock_tree command will be calculated.</pre>              |
| -summary                                                                                                                                                  | Displays only the report header.                                                                                                    |
| -tcl_list                                                                                                                                                 | Generates a report (Tcl list) that can be used by another Tcl script.                                                               |
| -to clock_tree_instances_pin_list<br>Reports clock tree paths between the clock tree root and the<br>specified list of clock tree instance pins.          |                                                                                                                                     |
| -through <i>clock_tree</i>                                                                                                                                | _instances_list<br>Reports all clock tree paths going through each clock tree<br>instance in the specified list.                    |
| -tree_only                                                                                                                                                | Generates a report that will not display leaf cells (flip-flops). The fanout column should be used to see the number of leaf cells. |

#### Examples

■ The following example shows a report generated by the report\_clock\_tree command:

### Output:

| +                                                                 | +                                                                 |
|-------------------------------------------------------------------|-------------------------------------------------------------------|
| Report                                                            | report_clock_tree                                                 |
| Options                                                           | -pin clk                                                          |
| Date<br>Tool<br>Release<br>Version                                | 20020103.144136<br>pks_shell<br>v5.0-a080<br>Dec 14 2001 14:29:26 |
| Module<br>  Timing<br>  Slew Propagation<br>  Operating Condition | tcl<br>LATE<br>WORST<br>slow                                      |

# Command Reference for BuildGates Synthesis and Cadence PKS CTPKS Commands

| PVT Mode<br>Tree Type<br>Process<br>Voltage<br>Temperature<br>time unit<br>capacitance u<br>resistance u                                                                                                                                                                                                             | unit                                                                  | max<br>Dalanced<br>1.00<br>2.25<br>125.00<br>1.00 ns<br>1.00 pF<br>1.00 kOhr | n                                                                                   | +                                                                    |            |                               |      |                                             |                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------|-------------------------------|------|---------------------------------------------|--------------------------|
| Clo                                                                                                                                                                                                                                                                                                                  | ock tree ro                                                           | oot clk                                                                      |                                                                                     | Clock<br>Constra                                                     |            | <br>  Actua                   | al   | Area                                        | +<br>a                   |
| Max. transition time at tree pins<br>Min. insertion delay to leaf pins<br>Max. insertion delay to leaf pins<br>Max. skew between leaf pins<br>Number of Violations<br>Number of Buffers<br>Number of Inverters<br>Number of Instances<br>Total Number of Instances<br>Number of Excluded Pins<br>Number of Leaf Pins |                                                                       |                                                                              | (                                                                                   | 0.300<br>0.100<br>1.000<br>0.300                                     |            | 45<br>12<br>57<br>0<br>3<br>0 | 134. | 000                                         |                          |
| pin   risir<br>clk   edge                                                                                                                                                                                                                                                                                            | e  <br>                                                               |                                                                              |                                                                                     |                                                                      |            |                               |      |                                             |                          |
| pin_name                                                                                                                                                                                                                                                                                                             | cellref<br>+                                                          | edge<br>+                                                                    | latency<br>+                                                                        | slew                                                                 | viola<br>+ | ation                         | lev  | el  <br>                                    | fanout<br>+              |
| clk<br>i_43/A<br>i_43/Y<br>i_44/A<br>i_44/Y<br>i_448/A<br>i_448/Y<br>dffn_bi/CKN<br>dff_bb/CK                                                                                                                                                                                                                        | INVX8<br>INVX8<br>INVX8<br>INVX8<br>INVX8<br>INVX8<br>DFFNX1<br>DFFX1 |                                                                              | $\begin{array}{c} 0.00\\ 0.00\\ 0.06\\ 0.14\\ 0.15\\ 0.21\\ 0.21\\ 0.15\end{array}$ | 0.00<br>0.00<br>0.07<br>0.13<br>0.13<br>0.07<br>0.07<br>0.07         |            |                               |      | 0  <br>1  <br>2  <br>3  <br>3  <br>3  <br>3 | 1<br>1<br>3(2L)<br>2(2L) |
| pin   falli<br>clk   edge                                                                                                                                                                                                                                                                                            |                                                                       |                                                                              |                                                                                     |                                                                      |            |                               |      |                                             |                          |
| pin_name                                                                                                                                                                                                                                                                                                             | cellref                                                               | edge                                                                         | latency                                                                             | slew                                                                 | viola      | ation                         | lev  | el                                          | fanout                   |
| clk<br>i_43/A<br>i_43/Y<br>i_44/A<br>i_44/Y<br>i_448/A<br>i_448/Y<br>dff_bi/CK                                                                                                                                                                                                                                       | INVX8<br>INVX8<br>INVX8<br>INVX8<br>INVX8<br>INVX8<br>INVX8<br>DFFX1  | V<br>V<br>^<br>V<br>V<br>~                                                   | 0.00<br>0.00<br>0.06<br>0.06<br>0.15<br>0.15<br>0.21<br>0.21                        | 0.00<br>0.00<br>0.09<br>0.09<br>0.12<br>0.12<br>0.12<br>0.08<br>0.08 | +          |                               |      | 0  <br>1  <br>2  <br>2  <br>3  <br>4        | 1<br>1<br>3(2L)<br>2(2L) |

# ■ The following example shows a report that includes the effective skew leaves:

> report\_clock\_tree -summary -effective\_skew -print\_effective\_skew\_leaves -pin
FXLOGICI\_KClk

| Clock tree root FXLOGICI_KClk                                                                                                                                                                                                                                                                                                           | Clock Tree<br>Constraints | Actual                                                                       | Area                             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------------------------------------------------|----------------------------------|
| Min. insertion delay to leaf pins<br>Max. insertion delay to leaf pins<br>Max. skew between leaf pins<br>Effective skew between leaf pins<br>Number of Violations<br>Number of Buffers<br>Number of Inverters<br>Number of gated/pad/preserved Instances<br>Total Number of Instances<br>Number of Excluded Pins<br>Number of Leaf Pins | 1.000<br>3.000<br>0.100   | 2.470<br>15.565<br>13.094<br>12.060<br>6319<br>1<br>0<br>0<br>1<br>0<br>6323 | 3.000<br>0.000<br>0.000<br>3.000 |

| Effective skew leaves for pin FXLOGICI_KClk | +                                     |
|---------------------------------------------|---------------------------------------|
| Min. effective skew leaf pin                | TXCOMPI/Factor1_regx22x/CP            |
| Max. effective skew leaf pin                | FOGI/retime_fifoxInDataReg_regx86x/CP |

# report\_clock\_tree\_violations

report\_clock\_tree\_violations [-pin list\_of\_pins] [-no\_gated {rising | falling}]

Generates a report that provides an exhaustive list of clock tree violations.

#### **Options and Arguments**

```
-no_gated {rising | falling}
Generates a report that will consider each input (of non buffer
and non inverter cell) as a leaf pin. If no edge is specified, each
leaf pin is considered as both a rising edge and a falling edge pin
unless the active edge can be derived for the timing model. If an
edge is specified, it is used as an active edge for the pins whose
active edge can not be derived from the timing model. This
switch is used in conjunction with the
do_build_physical_tree command.
```

clock tree. Without -pin, it reports on all clock trees previously specified with a set\_clock\_tree\_constraints command.

#### Example

The following command generates a report listing any violations for the clock tree starting at the pin clk:

```
_____
     Clock tree root clk | Clock Tree | Actual
Constraints |
-----+
Min. insertion delay to leaf pins0.1000.144Max. insertion delay to leaf pins0.2000.208Max. skew between leaf pins0.0500.064
_____
     Clock Tree Violations Summary | Violations
-----
No. of max. clock skew violations:
                                     | 1
No. of max. load capacitance violations:
                                      0
No. of max. rise transition time violations:
                                     3
                                      Ο
No. of max. fall transition time violations:
                                      0
No. of min. rise required time violations:
No. of min. fall required time violations:
                                      Ο
No. of max. rise required time violations:
                                      1
No. of max. fall required time violations:
                                     1
      _____
```

report\_clock\_tree\_violations -pin clk

# Command Reference for BuildGates Synthesis and Cadence PKS CTPKS Commands

| +                                             |                         |                         |
|-----------------------------------------------|-------------------------|-------------------------|
| Max. clock<br>skew<br>violations              | Desired                 | Actual                  |
| clk                                           | 0.050                   | 0.064                   |
| Max. rise<br>transition<br>time<br>violations | Desired                 | Actual                  |
| dff_bb/CK<br>dffn_bb/CKN<br>i_332/A           | 0.100<br>0.100<br>0.100 | 0.116<br>0.116<br>0.116 |
| Max. rise<br>required<br>time<br>violations   | Desired                 | Actual                  |
| dff_bi/CK                                     | 0.200                   | 0.203                   |
| Max. fall<br>required<br>time<br>violations   | Desired                 | Actual                  |
| dffn_bi/CKN                                   | 0.200                   | 0.208                   |

# **Related Information**

do build clock tree

<u>set\_clock\_tree\_constraints</u>

# reset\_clock\_tree\_constraints

reset\_clock\_tree\_constraints [-pin list\_of\_pins | -all] [-physical\_tree]

Removes previously set clock tree constraints.

#### **Options and Arguments**

| -all              | Specifies that all constraints are to be removed.                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------------|
| -physical_tree    | Specifies that the constraints to be removed are for the do_build_physical_tree command for non-clock signals. |
| -pin list_of_pins | Specifies the pin of an instance or an input port as the root of the clock tree.                               |

#### Example

In the following example, the first command removes constraints from the clock tree starting at the pin clk. The second command removes all constraints from all clock trees. The third command removes constraints for the do\_build\_physical\_tree command for non-clock signals.

reset\_clock\_tree\_constraints -pin [find -port clk]
reset\_clock\_tree\_constraints -all
reset\_clock\_tree\_constraints -pin [find -port reset] -physical\_tree

# **Related Information**

<u>get clock tree constraints</u>

<u>set clock tree constraints</u>

# set\_clock\_tree\_constraints

```
set_clock_tree_constraints [-pin list_of_pins] [-min_delay value]
  [-max_delay value] [-max_skew value] [-max_leaf_transition value]
  [-max_tree_transition value] [-self_heat] [-physical_tree]
  [-file CTS_CLK.cstr]
```

Specifies the clock tree constraints for a specific source or multiple sources if more than one pin is specified. Clock tree constraints are saved in .adb files.

The actual max slew for the leaf pins of the clock tree will be the smallest of the max\_leaf\_transition, the max\_tree\_transition, the global variable <u>slew\_time\_limit</u>, or the limit specified in the library.

The actual max slew for the non-leaf pins of the clock tree will be the smallest of the max\_tree\_transition, the global variable <u>slew\_time\_limit</u>, or the limit specified in the library.

# **Options and Arguments**

```
-file CTS_CLK.cstr
```

Specifies that the following data be read into CTPKS from the CTS constraint file (All others tokens will be silently ignored):

```
MacroModel port | pin maxRise minRise maxFall
  minFall cap
MaxDelay delay
MinDelay delay
MaxSkew delay
SinkMaxTran delay
BufMaxTran delay
Buffer "clock tree cell list"
NoGating NO falling rising
LeafPort rising falling
LeafPin rising falling
ExcludedPort
ExcludedPin
ThroughPin
PreservePin
End
```

#### Notes:

■ The buffer list will not saved into the adb, and will be

|                         | overwritten if you use the -use_buffers and -use_inverters flags with a build command.                                                                                                                                                                       |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | The noGating attribute will not be saved into the adb, and<br>will be overwritten if you use the<br>-no_gated option.                                                                                                                                        |
|                         | <ul> <li>Only AutoCTSRootPin is supported by this command.<br/>ClockNetName and AutoClockNetName are not<br/>supported.</li> </ul>                                                                                                                           |
| -max_delay value        | Specifies the maximum acceptable clock leaf pin insertion delay.                                                                                                                                                                                             |
|                         |                                                                                                                                                                                                                                                              |
| -max_leaf_transition    | value<br>Specifies the maximum acceptable transition time at any leaf pin<br>of the clock tree.                                                                                                                                                              |
| 1 7                     |                                                                                                                                                                                                                                                              |
| -max_skew <i>value</i>  | Specifies the maximum acceptable difference between any two clock leaf pin insertion delay (max_skew is smaller or equal to max_delay and min_delay).                                                                                                        |
| -max_tree_transition    | value<br>Specifies the maximum acceptable transition time at any pin of<br>the tree, even leaf pins.                                                                                                                                                         |
| -min_delay <i>value</i> | Specifies the minimum acceptable clock leaf pin insertion delay.                                                                                                                                                                                             |
| -physical_tree          | Specifies that the constraints are for the do_build_physical_tree command for non-clock signals.                                                                                                                                                             |
| -pin list_of_pins       | Specifies the pin of an instance or an input port as the root of the clock tree.                                                                                                                                                                             |
| -self_heat              | Calculates wire self heat effects on the nets in the clock tree.<br>While building the clock tree, checks are made for wire self heat<br>violations, and the clock tree that minimizes the number of<br>violations or eliminates the violations is selected. |

#### Example

In the following example, the first command sets various constraints for the clock tree starting at the pin clk. The second command sets various constraints for the clock tree starting at the pin clock, and specifies that the wire self heat effect is to be taken into account when building the clock tree.

```
set_clock_tree_constraints -min_delay 0.1 -max_delay 1.0 -max_skew 0.3
-max_tree_transition 0.3 -pin [find -port clk]
```

```
set_clock_tree_constraints -self_heat -pin clock -min_delay 0.5 -max_delay 1.0
-max_skew 0.4
```

#### **Related Information**

get clock tree constraints

# define\_structure

**Note:** The define\_structure command has been added to this chapter only for reference. This command is included with the Cadence Clock Tree Generator tool and provides significant information that supports several CTPKS commands mentioned in this chapter.

```
define_structure
    {from_pin `component_name' `output_pin_name' |
    from_iopin input_iopin_name'}
    [drive_booster 'cell_name' ['cell_name']]
    [noninverting_tree ['cell_name' parent_fanout ...]
        [to_rising_clock_pins 'cell_name' parent_fanout ...]
        [to_falling_clock_pins 'cell_name' parent_fanout ...]
        [to_pin 'component_name' 'pin_name' ['cell_name'] ...]
        [to_rising_clock_pins 'cell_name' parent_fanout ...]
        [to_rising_clock_pins 'cell_name' parent_fanout ...]
        [to_falling_clock_pins 'cell_name' parent_fanout ...]
        [to_falling_clock_pins 'cell_name' parent_fanout ...]
        [to_falling_clock_pins 'cell_name' parent_fanout ...]
        [to_falling_clock_pins 'cell_name' parent_fanout ...]
        [to_pin 'component_name' 'pin_name' ['cell_name'] ...]
```

Defines the clock tree structure. The following are some usage notes to keep in mind:

- If you use this command, you must define the structure for every subtree of the overall clock tree topology.
- The define\_structure command is optional for each clock tree command set (specify\_tree/set\_constraints command pair) you use in the constraints file.
- You cannot use both the define\_cells command and the define\_structure command for the same clock tree.
- You specify the subtrees with the from\_pin and from\_iopin options, and you can specify the subtrees in any order.
- Each subtree specification must start with either the from\_pin or the from\_iopin option. These options specify the given subtree root.
- The polarity of the drive\_booster must always be noninverting. You can specify one buffer cell, two buffer cells, or two inverter cells. Specifying one inverter cell, or one buffer cell and one inverter, will cause an error.
- If you specify an inappropriate subtree topology option (for example, if you use only the inverting\_tree option for a particular subtree that has only noninverted paths to clock pins), you will see an error message.
- If you omit a necessary subtree topology option (for example, if the subtree has both noninverted and inverted paths to clock pins and you specified only the noninverting\_tree option), you will see an error message.

# **Options and Arguments**

| cell_name            | Specifies the cell name of a buffer or inverter.                                                                                                                                                      |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| component_name       | Specifies the component name.                                                                                                                                                                         |
| drive_booster        | Specifies that the given subtree root should have two inverters or<br>one or two buffers connected directly to it to boost its drive.                                                                 |
| input_iopin_name     | Specifies the name of an input I/O pin.                                                                                                                                                               |
| inverting_tree       | Specifies the inverted subtree topology from the given root to the clock pin subtree, gating pins, and block pins.                                                                                    |
| noninverting_tree    | Specifies the non-inverted subtree topology from the given root to the clock pin subtree, gating pins, and block pins.                                                                                |
| output_pin_name      | Specifies the name of an output component pin.                                                                                                                                                        |
| parent_fanout        | Specifies the number of fanouts associated with the parent of the previously specified buffer or inverter.                                                                                            |
| to_falling_clock_pin | s<br>Specifies the buffer subtree topology to falling-edge triggered<br>clock pins (the subtree does not include gating pins or block<br>pins).                                                       |
| to_pin               | Specifies the padding in front of a gating pin or block pin.                                                                                                                                          |
|                      | <b>Note</b> : The to_pin option can only be used to specify padding in front of input pins to gating components or input pins to blocks with the TLF insertion_delay construct for an internal clock. |
| to_rising_clock_pins | Specifies the buffer subtree topology to rising-edge triggered clock pins (the subtree does not include gating pins or block pins).                                                                   |

# Example

In this example, the non-inverting buffer tree connected to pin CKPAD1 Z drives the CKBUF which is at the root of the to\_rising\_clock\_pins tree as well as the three gating pins (CKNAND1 A, CKNAND2 A, and CKNAND3 A) and the CKBUF padding in front of the block pin

(IPBLOCK CK). The to\_pin 'IPBLOCK' 'CK' 'CKBUF' 'CKBUF' statement specifies that two CKBUFs should be in front of the IPBLOCK CK pin to equal out delays. (The IPBLOCK has no from\_pin statement because the tree does not go through this block.)

```
define structure
     from_pin 'CKPAD1' 'Z'
       noninverting_tree 'CKBUF' 'CKBUF' 1 'CKBUF' 'CKBUF' 2
               to_rising_clock_pins 'CKBUF' 1 'CKBUF' 4 'CKBUF' 6
               to_pin 'CKNAND1' 'A'
               to_pin 'CKNAND2' 'A'
               to_pin 'CKNAND3' 'A'
               to_pin 'IPBLOCK' 'CK' 'CKBUF' 'CKBUF'
          from_pin 'CKNAND1' 'Z'
               inverting_tree 'CKINV' 1
                    to_rising_clock_pins 'CKBUF' 4
          from_pin 'CKNAND2' 'Z'
               inverting_tree 'CKINV' 1
                   to_rising_clock_pins 'CKBUF' 4
          from_pin 'CKNAND3' 'Z'
               inverting_tree 'CKINV' 1
                    to_rising_clock_pins 'CKBUF' 4
```

The schematic diagram for the noninverting tree connected to  $CKPAD \ Z$  is as shown below. Note that the tree contains repeaters.



The first, third, and fourth levels of buffers are considered repeaters and the clock tree generator distributes them evenly along the estimated routing path between the nonrepeating cells.

# Attributes

set\_attribute [cell\_id ct\_dont\_utilize {true | false}]
 [pin\_id ct\_no\_leaf {true | false} | "{true | false} pin\_name"]
 [object\_id ct\_preserve {true | false}]
 [object\_id ct\_preserve\_tree {true | false}]
 [pin\_or\_port\_id ct\_leaf {rising | falling} | "{rising | falling} {value |
 min\_value max\_value}"]
 [library\_cell\_pin\_id ct\_leaf {rising | falling}]
 [pin\_id ct\_excluded {true | false}]
 [instance\_id ct\_preserve\_tree false]]
 [instance\_id ct\_lps\_associated\_gating\_component name]
 [instance\_id ct\_lps\_main\_gating\_component name]

Sets the value set for the specified attribute on the specified object. You can set tool- and user-defined attributes. See <u>set attribute</u> on page 257 for a more detailed description of the this command.

# **Options and Arguments**

```
cell_id ct_dont_utilize {true | false}
                         Allows you to declare which cells you do not want to use in
                         CTPKS. Selecting true tells CTPKS to ignore the cells specified
                         by cell id. Selecting false tells CTPKS to use the cells
                         specified by cell_id.
instance_id ct_lps_associated_gating_component name
                         See ct_lps_main_gating_component below.
instance_id ct_lps_main_gating_component name
                         Defines a set of cells as belonging to same gating group. The
                         name provided should be the same for all the instances of a
                         group.
                         The instances directly on the clock path should have the
                         ct_lps_main_gating_component while the instances that
                         are not on the clock path should have the
                         ct_lps_associated_gating_component attribute. No
                         buffering will be added between the "main" gating element and
                         an "associated" element that is attached to the clock net. This
                         prevents a sequential element used as a filter for the enabling of
                         the gating component to be considered a leaf.
                         All elements of a gating group will be moved together if the gating
                         element is moved when the option -move_gated is used for
                         do_build_clock_tree.
```

| <i>instance_id</i> ct_speci    | <pre>ify_padding {before   after} Determines the behavior of the padding on this specific instance, when set on an instance, whether or not the switch -pad_after_gated is specified with the do_build_clock_tree command.</pre>                                                                                                                                                                                                          |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| library_cell_pin_ic            | d ct_leaf {rising   falling}<br>Treats all instances of the specified cell pin as a leaf pin when<br>this pin would have otherwise been internal to the tree. CTPKS<br>will not trace through this pin. Using a value other than rising<br>or falling is treated as if no attribute was set.                                                                                                                                              |
| <i>object_id</i> ct_preser     | <pre>ve {true   false} Preserves an instance in the final tree. This option is only useful on buffers and inverters. Selecting true preserves an instance (specified by object_id) in the final tree. The instance is then treated as a gating component. A subtree is built from the output of the instance. Selecting false removes an instance (specified by object_id) from the final tree.</pre>                                     |
| <i>object_id</i> ct_preser     | ve_tree {true   false}<br>Preserves a portion of the tree starting from an instance in the<br>final tree. Selecting true preserves the portion of the tree<br>starting from the instance (specified by <i>object_id</i> ) in the final<br>tree. Selecting false or any other value, treats the instance as<br>normal when building the clock tree.                                                                                        |
| pin_id ct_excluded             | <pre>{true   false} Prevents CTPKS from considering some input pins as leaf pins in the generated buffer subtree. Excluded pins are connected directly to the output pin at the root of the generated buffer subtree. If the pin is an output pin, the pin has to belong to a gated component that has several outputs.</pre>                                                                                                             |
| <pre>pin_id ct_no_leaf {</pre> | {true   false}   "{true   false} pin_name"}<br>When true, allows the tree to be considered through a pin<br>identified as a clock pin that would otherwise be considered as a<br>leaf. In the case of sequential gating component, any<br>combinational arc will be followed. In the case of a purely<br>sequential element such as in a clock divider, the sequential arc<br>will be followed provided the output pin name is specified. |

pin\_or\_port\_id ct\_leaf {{rising | falling} | "{rising | falling} {value | min\_value max\_value}"} Treats the specified instance pin (input pin or output port) as leaf pins when these pins would have otherwise been internal to the tree. If a single value is associated to the edge, it is used to model the insertion delay of the downstream clock tree from this pin. If a pair of values are passed, the first value models the minimum insertion delay of the downstream logic.

# Example

The following commands set attributes on various cellrefs, instances, and pins.

set\_attribute [find -cellref ssnid6] ct\_dont\_utilize true set\_attribute [find -inst i\_47] ct\_preserve true set\_attribute [find -inst i\_47] ct\_preserve\_tree true set\_attribute [find -pin u1/G] ct\_no\_leaf true set\_attribute [find -pin u2/CLK] ct\_no\_leaf "true Q" set\_attribute [find -pin gated\_component/A0] ct\_leaf rising set\_attribute [find -pin i\_273/A] ct\_leaf "rising 1.27 1.35" set\_attribute [find -pin decoder/Y3] ct\_excluded true

# **Related Information**

do build clock tree

do build physical tree

# **Distributed Synthesis Commands**

This chapter describes the commands and global variables used with distributed synthesis.

- <u>check\_batch</u> on page 342
- <u>check\_dist</u> on page 344
- <u>check\_host</u> on page 345
- <u>get host info</u> on page 346
- <u>get job info</u> on page 349
- <u>get weight batch option</u> on page 355
- <u>kill job</u> on page 356
- <u>remove host</u> on page 358
- <u>remove\_job</u> on page 359
- report job on page 360
- <u>reset dist bits</u> on page 361
- <u>reset\_dist\_rlimit</u> on page 362
- <u>reset\_dist\_point</u> on page 363
- <u>reset dist weight</u> on page 364
- <u>set\_dist\_bits</u> on page 365
- <u>set\_dist\_point</u> on page 366
- <u>set dist rlimit</u> on page 368
- <u>set host config</u> on page 369
- <u>set host list</u> on page 372

- <u>set\_dist\_weight</u> on page 373
- <u>set weight batch option</u> on page 374

# check\_batch

check\_batch { queue | " "} { test\_number | -all } [-debug] [-force] [-silent]
 [-timeout time] [-verbose] [-weight integer]

Checks a batch queue by running the rac\_shell script in diagnostic mode.

For more information about the rac\_shell script, see <u>Appendix A, "Testing Distributed</u> <u>Synthesis,"</u> of the <u>Distributed Processing of BuildGates Synthesis</u> manual.

# **Options and Arguments**

| -debug                        | Displays detailed debug information.                                                                                                                                                                                              |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -force                        | Forces rac_shell tests to run, even on hosts that are embargoed.                                                                                                                                                                  |
| queue   " "                   | Checks the LSF batch <i>queue</i> or the current batch queue. (See also the <u>dist batch queue</u> global variable.)                                                                                                             |
| -silent                       | Displays the minimum amount of information for each test.                                                                                                                                                                         |
| <pre>test_number   -all</pre> | Runs the specified rac_shell test or all tests.                                                                                                                                                                                   |
| -timeout <i>time</i>          | Specifies an optional timeout limit for each test, in<br>days-hh:mm:ss.mmm format.                                                                                                                                                |
| -verbose                      | Displays detailed log information printed for each test.                                                                                                                                                                          |
| -weight <i>integer</i>        | Uses the weight value to test the LSF Batch options that you have set with the set_weight_batch_options command. You must have already used set_weight_batch_option to set the weight to <i>integer</i> before using this option. |

# Example

rac\_shell batch -batch\_queue queue -test n

# **Related Information**

#### <u>check host</u>

set\_weight\_batch\_option

# check\_dist

check\_dist [-force] [-print] [-silent]

Verifies the settings of the distributed global variables and returns the number of errors detected. For example, if <u>dist max jobs</u> is set to 6 and <u>dist min jobs</u> is set to 8, an error is returned.

# **Options and Arguments**

| -force  | Forces all of the tests to run, even on hosts that are embargoed. |
|---------|-------------------------------------------------------------------|
| -print  | Displays more detailed log information for each test.             |
| -silent | Displays the minimum amount of information for each test.         |

# **Related Information**

<u>check\_batch</u>

<u>check\_host</u>

# check\_host

```
check_host { host | -all } { test_number | -all } [-debug] [-force] [-silent]
       [-timeout time] [-verbose]
```

Checks one or all of the hosts in a host list by running the rac\_shell script in diagnostic mode.

For more information about the rac\_shell script, see <u>Appendix A</u>, "<u>Testing Distributed</u> <u>Synthesis</u>," of the <u>Distributed Processing of BuildGates Synthesis</u> manual.

#### **Options and Arguments**

| -debug               | Displays detailed debug information.                                 |
|----------------------|----------------------------------------------------------------------|
| -force               | Forces rac_shell tests to run, even on hosts that are embargoed.     |
| host   -all          | Checks host or all of the hosts that are currently in the host list. |
| -silent              | Displays the minimum amount of information for each test.            |
| test_number   -all   | Runs the specified rac_shell test, or all tests.                     |
| -timeout <i>time</i> | Sets a timeout period for each test, in <i>days-hh:mm:ss.mmm</i> .   |
| -verbose             | Displays detailed log information for each test.                     |

#### Example

rac\_shell catbert -test 2

# **Related Information**

<u>set\_host\_list</u>

# get\_host\_info

get\_host\_info { host | -all [-force] } { attribute... }

Returns information about the hosts in your host list or LSF batch queue. Allows specifying one or all hosts for which you want to return information. Also allows specifying one or all attributes for those hosts.

# **Options and Arguments**

| attribute    | Requests the value of the specified <i>attribute</i> or, if no attribute is specified, all attributes of the specified hosts. You specify an attribute by its name. (See below for a list of attributes.)                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -force       | Requests the current value of attributes that can change during<br>a job run. Otherwise, get_host_info returns the last known<br>value of the attribute. The -force option also forces<br>get_host_info to return information on embargoed hosts. |
| host   -all  | Requests information for $host$ or for all the hosts that are currently in the host list.                                                                                                                                                         |
| Attributes   |                                                                                                                                                                                                                                                   |
| access       | Returns the access to the host. If 0 is returned, the host cannot be accessed. This attribute is dynamic. You must use the -force option to return the current value.                                                                             |
| cpus         | Returns the number of CPUs on the host.                                                                                                                                                                                                           |
| embargo      | Returns on if the host cannot run jobs; returns off if the host can run jobs. This attribute is dynamic. You must use the -force option to return the current value.                                                                              |
| embargo_secs | Returns the temporary embargo time, in seconds.                                                                                                                                                                                                   |
| embargo_time | Returns the temporary embargo time, in <i>hours:minutes:seconds</i> . If this value is nonzero, it represents the time period for which this host cannot run a remote job. (See also the <u>dist embargo delay</u> global variable.)              |

# Command Reference for BuildGates Synthesis and Cadence PKS Distributed Synthesis Commands jobs Returns the total number of jobs that ran on the host. load Returns the normalized load, between 0 and 100 percent. This attribute is dynamic. You must use the -force option to return

max\_load Returns the maximum load allowed for the host.

the current value.

- memory Returns the memory size of the host, in MBytes.
- name Returns the given host name.
- named Returns the short name of the host.
- name\_domain Returns the long host name, including the domain name.
- nice Returns the nice value for jobs on this host.
- release Returns the version number of distributed synthesis that you are running.
- rlogin\_ok Returns the remote access permission to the host.
- ruser\_ok Returns the remote access permission from the master to this host.
- speed Returns the clock speed of the CPU, in MHz.
- swap Returns the swap space, in MBytes.
- weight Returns the weight of the host (the relative size of the jobs that the host can handle). The size of the jobs that the host can handle increases as the weight increases, beginning with 1. A weight of 0 indicates that the host can run any job. There is no upper limit on the weight of a host.

#### Examples

■ The following command returns all attributes for a host:

```
get_host_info firefly
firefly
{name firefly} {namedomain firefly} {cpus 1} {embargo off} {jobs 1} {kind
{SunOS sun4u}} {load 1} {load_time -28.737} {memory 512} {release v4.0} {rlogin
OK} {ruser OK} {speed 440} {swap 1025}
```

The following command returns the value of a specific attribute:

get\_host\_info firefly speed

The following command returns the numbers of CPUs for all hosts (a line of information is printed for each host only if the <u>dist verbose</u> global variable is nonzero):

get\_host\_info -all cpus -force

The -force option updates the attribute value:

■ The following command finds the total number of accessible hosts:

get\_host\_info -all access

The following command returns the total number of CPUs that are currently running and accessible:

get\_host\_info -all cpus

■ The following command returns the recent load of all hosts:

get\_host\_info -all load

The following command determines the current, actual load of all hosts, including embargoed hosts:

get\_host\_info -all load -force

The following command determines the version of distributed synthesis that you are running:

```
get_host_info firefly release
v4.0
```

The following command determines how many hosts are capable of running a job of a certain weight:

get\_host\_info -all weight integer

#### **Related Information**

<u>set\_host\_config</u>

<u>set\_host\_list</u>

# get\_job\_info

get\_job\_info { job\_id | -last\_top | -all } attribute

Returns the attribute values for a specific job, the top job, or all jobs.

#### **Options and Arguments**

| attribute                 | Specifies the attribute whose value you want to return. (See below for a list of job attributes.)                             |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| <i>job_id</i>   -last_top | <pre>  -all Returns the attribute information for a specific job (job_id), the top job (-last_top), or all jobs (-all).</pre> |

#### Attributes

| batch       | Returns 1 if the job is a batch job, otherwise 0.                               |
|-------------|---------------------------------------------------------------------------------|
| batch_id    | Returns the LSF job ID of a batch job.                                          |
| batch_queue | Returns the name of the LSF batch queue to which the job was submitted.         |
| cells       | Returns the number of primitive and modifiable instances in the job module.     |
| child_ids   | Returns a list of job IDs for this job's child jobs.                            |
| children    | Returns the number of child jobs.                                               |
| cpu_secs    | Returns the CPU time for the job, in seconds.                                   |
| cpu_time    | Returns the CPU time for the job, in days-hours:minutes:seconds.                |
| depth       | Returns the level of the job in the job hierarchy, calculated from the top job. |
| done_at     | Returns the time at which the job completed, in days-hours:minutes:seconds.     |

| done_at_secs     | Returns the time at which the job completed, in seconds.                                                                                |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| exit_at          | Returns the time at which the job completed, in days-hours:minutes:seconds.                                                             |
| exit_at_secs     | Returns the time at which the job completed, in seconds.                                                                                |
| exit_status      | Returns the job exit status. A value of 0 indicates that the job finished correctly. A non-zero value indicates that an error occurred. |
| failures         | Returns the number of recoverable errors in the most recent attempt to run.                                                             |
| family_ids       | Returns a list of all job IDs below a job or a top job.                                                                                 |
| height           | Returns the number of remote job levels below and including this job.                                                                   |
| height_all       | Returns the number of all job levels below and including this job.                                                                      |
| host             | Returns the name of the host on which the job was launched.<br>(See also the rhost job attribute.)                                      |
| instances        | Returns the number of modifiable instances in a job module.                                                                             |
| job_id           | Returns a unique job identifier for the job. This attribute value must be 1 or greater.                                                 |
| job_secs         | Returns the entire job time, in seconds.                                                                                                |
| job_time         | Returns the entire job time, in days-hours:minutes:seconds.                                                                             |
| kind             | Returns the job type: structured, mapped, bottomup, or bottomupskip.                                                                    |
| launched_at      | Returns the moment at which the job was launched, in <i>days-hours:minutes:seconds</i> .                                                |
| launched_at_secs | Returns the moment at which the job was launched, in seconds.                                                                           |

| listed_at      | Returns the time at which the job was listed to run, in days-hours:minutes:seconds.                      |
|----------------|----------------------------------------------------------------------------------------------------------|
| listed_at_secs | Returns the time at which the job was launched, in seconds.                                              |
| module         | Returns the ID of the module to be optimized by the job, or 0 if the ID is not available.                |
| most_jobs      | Returns the maximum number of jobs that actually ran in parallel at any time during the distributed run. |
| name           | Returns the full name of the job module.                                                                 |
| name_path      | Returns the hierarchical path name of the job, specified by job name.                                    |
| name_truncated | Returns the truncated name of the job, if it exceeds the name limit.                                     |
| new_at         | Returns the job creation time, in days-hours:minutes:seconds.                                            |
| new_at_secs    | Returns the job creation time, in seconds.                                                               |
| nice           | Returns the nice value for the job. (See also the <u>dist_nice</u> global variable.)                     |
| ordinal        | Returns the order (number) of the job in the run list.                                                   |
| ordinal_ids    | Returns the list of dependent job IDs, in ascending ordinal order.                                       |
| parent_id      | Returns the job ID of the primary parent job.                                                            |
| parent_ids     | Returns the list of all parent jobs, beginning with the primary parent.                                  |
| parents        | Returns the number of parent jobs.                                                                       |
| path           | Returns the location of the job in the hierarchy, specified by the $job_id$ . For example, 1-12-13.      |
| pid            | Returns the process ID of the job on the local host.                                                     |

| queued_at       | Returns the moment the job was queued to batch queue, in <i>days-hours:minutes:seconds</i> .                                                                                                       |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| queued_at_secs  | Returns the moment when the job was queued to the batch queue, in seconds.                                                                                                                         |
| remote_ids      | Returns a list of all remote job IDs below the top job.                                                                                                                                            |
| re_used         | Returns the module reuse count. A value of 0 indicates a unique module (no module reuse).                                                                                                          |
| rhost           | Returns the name of the remote host where the job ran.                                                                                                                                             |
| rpid            | Returns the process ID of the job on the remote host.                                                                                                                                              |
| run             | Returns the run number. The first retry is run number 2.                                                                                                                                           |
| run_secs        | Returns the run time, in seconds. (The run time is the elapsed time between the start and the exit time of the job.)                                                                               |
| run_time        | Returns the run time, in <i>days-hours:minutes:seconds</i> .                                                                                                                                       |
| shutoff         | Returns the shut-off timeout period, in seconds                                                                                                                                                    |
| size            | Returns the size of the job.                                                                                                                                                                       |
| started_at      | Returns the launch time, in days-hours:minutes:seconds.                                                                                                                                            |
| started_at_secs | Returns the launch time, in seconds.                                                                                                                                                               |
| startup         | Returns the start-up timeout period, in seconds.                                                                                                                                                   |
| startup_secs    | Returns the startup time, in seconds.                                                                                                                                                              |
| startup_time    | Returns the startup time, in days-hours:minutes:seconds.                                                                                                                                           |
| status          | Returns one of the following job status values: created,<br>listed, waiting, ready, launched, queued, starting,<br>running, exit, done, interrupted, killed, failure,<br>error, <b>Or</b> deleted. |

| timeout        | Returns the run-time timeout period, in seconds.                                                                                                                                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| top_id         | Returns the job ID of the top job in the distributed run.                                                                                                                                                                                                             |
| total_cpu_secs | Returns the total CPU time of the job and its dependent jobs, in seconds.                                                                                                                                                                                             |
| total_cpu_time | Returns the total CPU time of the job and its dependent jobs, in days-hours:minutes:seconds.                                                                                                                                                                          |
| total_run_secs | Returns the total run time of the job and its dependents, in seconds.                                                                                                                                                                                                 |
| total_run_time | Returns the total run time of the job and its dependent jobs, in days-hours:minutes:seconds.                                                                                                                                                                          |
| total_size     | Returns the total job size of the job and its dependents.                                                                                                                                                                                                             |
| type           | Returns one of the following job types: top, remote, master, or lumped.                                                                                                                                                                                               |
| wait_secs      | Returns the total wait time before a job is launched, in seconds.                                                                                                                                                                                                     |
| wait_time      | Returns the total wait time before a job is launched, in days-hours:minutes:seconds.                                                                                                                                                                                  |
| weight         | Returns the weight of the job. When the weight is greater than 0, the host must have a weight that is equal to or greater than the job weight. There is no upper limit on the weight that you can assign to a job. When the weight is 0, the job can run on any host. |
| width          | Returns the maximum number of remote jobs that can run in parallel.                                                                                                                                                                                                   |
| width_all      | Returns the maximum number of all jobs that can run in parallel.                                                                                                                                                                                                      |

# Examples

- The following command returns a list of all the jobs: get\_job\_info -all
- The following command returns a list of  $job_ids$  below the job specified, including the specified  $job_id$ :

get\_job\_info 2 family\_ids

- The following command returns the value of a specific attribute: get\_job\_info 2 cells
- The following command returns the *job\_ids* of all top jobs: get\_job\_info -all top\_ids
- The following command returns the job\_ids of all remote jobs: get\_job\_info -all remote\_ids

# get\_weight\_batch\_option

get\_weight\_batch\_option integer

Gets the LSF batch options associated with the weight attribute.

#### **Options and Arguments**

*integer* Specifies the weight of the host on the batch queue.

#### **Related Information**

set\_weight\_batch\_option

# kill\_job

```
kill_job { job_id... | -last_top | -all } [-force] [-hierarchical] [-signal sig]
       [-silent] [-verbose]
```

Kills all processes when a failure is detected, and sends a signal to a specific job, to a job and all of its children, or to all jobs.

Default: SIGTERM, and the signal is sent only to jobs that are launched, started, or running.

# **Options and Arguments**

| -force                    | Sends a signal to all jobs for which the local or remote pid is available.                                                                                                                         |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -hierarchical             | Kills all child jobs of the specified job.                                                                                                                                                         |
| <i>job_id</i>   -last_top | <pre>  -all Kills the specified job (job_id), the most recent top job (-last_top), or all currently running jobs (-all).</pre>                                                                     |
| -signal <i>sig</i>        | Specifies the name or number of a UNIX/POSIX signal used to kill all local and remote job processes. Signals SIGHUP, SIGINT, SIGQUIT, or SIGTERM are recommended, but others can be used.          |
|                           | <b>Note:</b> SIGKILL and SIGSTOP are ignored.<br><i>Default</i> : SIGTERM                                                                                                                          |
| -silent                   | Does not display the signals that the command sends to the remote processes.<br><i>Default</i> : The value of the <u>dist kill verbose</u> global variable determines whether this is the default. |
| -verbose                  | Displays all signals that the command sends to kill the remote processes.<br>Default: The value of the <u>dist kill verbose</u> global variable determines whether this is the default.            |

# Examples

kill\_job -last\_top -hierarchical -force
kill\_job -all -force

# **Related Information**

<u>remove\_job</u>

# remove\_host

```
remove_host { host | -all }
```

Permanently removes one, several, or all hosts from the host list. Removing a host from the host list removes all information about that host.

# **Options and Arguments**

*host* | -all Removes the specified host or all hosts from the host list.

#### Examples

remove\_host host
remove\_host -all

# **Related Information**

<u>set\_host\_list</u>

# remove\_job

remove\_job { job\_id | -last\_top | -all } [-hierarchical]

Permanently removes all information about the specified job. All job information exists only during the ac\_shell run. It is lost upon exit.

# **Options and Arguments**

| -hierarchical             | Removes all child jobs of the specified job.                                                                                     |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| <i>job_id</i>   -last_top | <pre>  -all Removes the specified job (job_id), the most recent top job (-last_top), or all currently running jobs (-all).</pre> |

# **Related Information**

<u>kill job</u>

# report\_job

report\_job { job\_id | -last\_top | -all } [-hierarchical] [-parents]

Generates a report on one or several jobs.

# **Options and Arguments**

| -hierarchical             | Generates a report on the child jobs of the specified job.                     |
|---------------------------|--------------------------------------------------------------------------------|
| <i>job_id</i>   -last_top | -all<br>Generates a report on job_id, the most recent top job, or all<br>jobs. |
| -parents                  | Generates a report on the parent jobs of the specified job.                    |

# **Related Information**

<u>get\_job\_info</u>

### reset\_dist\_bits

reset\_dist\_bits list\_of\_module\_name\_or\_ids

Sets the distributed synthesis ac\_shell to 32 bits. Equivalent to set\_dist\_bits 0. *Default*: 32 bits.

### **Options and Arguments**

### **Related Information**

<u>set\_dist\_bits</u>

### reset\_dist\_rlimit

reset\_dist\_rlimit {list\_of\_module\_names\_or\_ids}

Resets the limit for distributed synthesis jobs.

**Note:** The value reset\_dist\_rlimit... is equivalent to set\_dist\_rlimit {} ....

### **Options and Arguments**

{list\_of\_module\_names\_or\_ids}

Specifies the module names or IDs where you want to reset the limit for distributed synthesis jobs.

### **Related Information**

<u>set\_dist\_rlimit</u>

### reset\_dist\_point

reset\_dist\_point [-hier] {list\_of\_modules | -all}

Reverses the effect of a previous set\_dist\_point command (formerly the reset\_distribution\_point command). In other words, the modules specified are no longer explicitly set to be distribution points; the distributed synthesis tool determines whether they are distribution points.

Default: The size of a module determines whether it can become a distribution point.

### **Options and Arguments**

| -hier           | Resets the entire hierarchy, starting from the modules specified in the <i>list_of_modules</i> .                                                      |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| list_of_modules | <ul> <li>-all</li> <li>Resets the specified module names or module IDs, or all modules in the hierarchy, starting from the current module.</li> </ul> |

### **Related Information**

<u>set\_dist\_point</u>

### reset\_dist\_weight

reset\_dist\_weight list\_of\_module\_names\_or\_ids

Sets the weight attribute of the specified modules to 0 (formerly the reset\_weight command). A module with a weight of 0 can run on any host.

Sets the weight of a module to indicate its size relative to other modules in your design. The higher the weight, the larger the module. When the distributed synthesis tool allocates jobs, it compares the weight of the job to the weight assigned to the host machines. A job is launched only on hosts whose weights are equal to or greater than the weight of the job.

### **Options and Arguments**

### **Related Information**

set\_dist\_weight

### set\_dist\_bits

set\_dist\_bits { non-negative\_power\_of\_2 | list\_of\_module\_names\_or\_ids }

Specifies the -bits value for a distributed synthesis job on the module in the design to be either 32- or 64-bits. The -bits size of the job can never exceed the -bits size of the master ac\_shell.

### **Options and Arguments**

### **Related Information**

<u>reset dist bits</u>

### set\_dist\_point

set\_dist\_point { on | off | auto } [-hier] list\_of\_modules

Controls whether a module, either in a list of modules or within the hierarchy of a listed modules, can become a distribution point. The list of modules can include module names or modules IDs (formerly the set\_distribution\_point command).

Default: The size of a module determines whether it can become a distribution point.

### Important

Call reset\_distribution\_point for the modules that you want to set before you call set\_distribution\_point. This way you won't define conflicting distribution points for those modules.

### **Options and Arguments**

| -hier           | Marks the entire hierarchy, starting from the modules specified in the list_of_modules. |
|-----------------|-----------------------------------------------------------------------------------------|
| list_of_modules | Specifies the module names or module IDs to set.                                        |
| on   off   auto | Determines whether a module can be a distribution point, as follows:                    |
|                 | on<br>Sets the module as a distribution point, no matter what its size.                 |
|                 | off<br>Sets the module to not be a distribution point, no matter what its<br>size.      |
|                 | auto<br>Sets the module as a distribution point, according to its size.                 |

### Examples

The following command marks only the specified module as a distribution point:

reset\_dist\_point -hier [get\_current\_module]
set\_dist\_point on [get\_current\_module]

The following command marks some modules and the entire hierarchies below those modules as distribution points. Allows the tool to mark the distribution points for the remaining parts of the hierarchy based on size.

```
reset_dist_point -hier list_of_module_names_or_IDs
set_dist_point on list_of_module_names_or_IDs
```

The following command marks some modules as distribution points and sends out those modules as remote jobs. Allows the tool to mark distribution points based on size for the remaining parts of hierarchies. For example, if a child module is large enough to go out as separate job, it should do that, even if its parent (or some other ancestor) is marked as distribution point.

reset\_dist\_point -hier list\_of\_module\_names
set\_dist\_point on list\_of\_module\_names

### **Related Information**

reset dist point

### set\_dist\_rlimit

set\_dist\_rlimit {-cycle num\_cycles | time\_limit} list\_of\_module\_names\_or\_ids

Sets a time limit for distributed synthesis jobs. When running distributed synthesis, the value of *num\_cycles* or *time\_limit* determines the maximum amount of time that can be spent processing the specified modules or IDs.

### **Options and Arguments**

-cycle num\_cycles Specifies the maximum number of cycles to be spent processing the specified modules or IDs. list\_of\_module\_names\_or\_ids Specifies the module names or IDs where you want to set the limit for distributed synthesis jobs. time\_limit Specifies the maximum amount of time (hh:mm:ss) to be spent processing the specified modules or IDs.

### Examples

The limit must be specified as a single argument in the set\_dist\_rlimit command, for example:

```
set_dist_rlimit -cycle n ....
```

The following examples use the global dist\_rlimit and the command set\_dist\_rlimit to limit jobs to a specific amount of CPU time:

```
# limit all jobs to 2 hours CPU time
set_global dist_rlimit 2:00:00
# except two large modules which require 10 hours
set_dist_rlimit 10:00:00 [module1 | module2]
# go do it ....
do_optimize -distributed ...
....
```

### **Related Information**

<u>reset\_dist\_rlimit</u>

### set\_host\_config

set\_host\_config { host... | -all } { attribute... | -auto [-force] }

Configures the host machine by modifying the individual attributes of the host. The configuration of a host is defined by a list of attributes. One or all hosts can be configured automatically.

Use  $\underline{get host info}$  to query the host status and check the values of the attributes for a host.

### **Options and Arguments**

| attribute   | Configures the specified host <i>attribute</i> . (See below for a description of the host attributes.)                                                                                                                                                          |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -auto       | Configures the critical host attributes automatically: cpus, embargo, and rlogin_ok.                                                                                                                                                                            |
| -force      | Launches a remote ac_shell on the specified host, even if the host is embargoed or overloaded. Use the -force option with the -auto option. If the -force option is not used, only lightly loaded hosts and hosts which have not been embargoed are configured. |
| host   -all | Configures a specific host or all hosts currently in the host list.<br>The host must be present in the current host list. (See also<br><u>set host list</u> .)                                                                                                  |

### Attributes

| cpus integer | Specifies the number of CPUs on the host. |
|--------------|-------------------------------------------|
|              | Default: 1                                |

### Important

The cpus attribute must be set for correct distributed operation.

| embargo { on   off } | Prevents remote jobs from running on the host when set to $on$ .                     |
|----------------------|--------------------------------------------------------------------------------------|
| kind <i>string</i>   | Specifies the machine type.<br>Default: The result from the csh command uname -srpi. |

### Command Reference for BuildGates Synthesis and Cadence PKS Distributed Synthesis Commands

| max_load percent        | Specifies the maximum load allowed on the host. (See also the $\underline{dist max load}$ global variable.)                                                                                                                                                                                           |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| memory MBytes           | Specifies the memory size of the host, in MBytes.                                                                                                                                                                                                                                                     |
| name_domain <i>name</i> | Specifies the full host name, including the domain name. For example, ra.Cadence.com.                                                                                                                                                                                                                 |
| nice integer            | Specifies the nice value for remote jobs on the host. It must be a non-negative value. (See also the <u>dist_nice</u> global variable.)                                                                                                                                                               |
| rlogin_ok { ok   no     | unknown }<br>Sets the permissions for remote access to the host. This attribute<br>must be set for correct distributed operation.                                                                                                                                                                     |
| ruser_ok { ok   no      | unknown }<br>Sets the permission for access to the host from the master host.<br>This attribute must be set for correct distributed operation.                                                                                                                                                        |
| speed MHz               | Specifies the CPU speed, in MHz.                                                                                                                                                                                                                                                                      |
| swap <i>MBytes</i>      | Specifies the swap space, in MBytes                                                                                                                                                                                                                                                                   |
| user name               | Specifies your account name on this host.                                                                                                                                                                                                                                                             |
| weight <i>integer</i>   | Specifies the weight of the host (the relative size of the jobs that the host can handle). The size of the jobs that the host can handle increases as the weight increases, beginning with 1. A weight of 0 indicates that the host can run any job. There is no upper limit on the weight of a host. |

### Examples

- The following command sets the number of CPUs of a host: set\_host\_config firefly cpus 2
- The following command removes an embargo on a host: set\_host\_config firefly embargo off
- The following command removes the embargo on all hosts:

```
set_host_config -all embargo off
```

■ The following command retrieves the critical configuration attributes (cpus, rloginok and ruserok) for the host:

set\_host\_config firefly -auto timeout

An ac\_shell is launched on the specified host. The *timeout* limits the total run time of the automatic configuration; 0 means no timeout. *Default*: 2:00 (2 minutes).

■ The following command launches a remote ac\_shell on all hosts to retrieve the critical configuration attributes:

set\_host\_config -all -auto timeout

*timeout* is an optional run-time timeout value for each remote ac\_shell. *Default*: 2:00 (2 minutes).

■ The following command sets the embargo switch for all hosts to on:

set\_host\_config -all -embargo on

### **Related Information**

<u>get\_host\_info</u>

### set\_host\_list

set\_host\_list host...

Adds one or more hosts to the existing host list.

### **Options and Arguments**

host

Specifies the name of the host to add to the host list.

### **Related Information**

<u>check\_host</u>

### set\_dist\_weight

set\_dist\_weight integer list\_of\_module\_names\_or\_ids

Sets the weight attribute of the specified modules. You can set the weight of a module to indicate its relative size. The higher the weight, the larger the module.

When the distributed synthesis tool allocates jobs, it compares the weight of the job to the weight of the host machines. A job is launched only on a host whose weights is equal to or greater than the weight of the job.

When you set the weight of a module to 0, it can run on any host.

### **Options and Arguments**

*integer* Specifies the weight of the module.

list\_of\_module\_names\_or\_ids

Specifies one or more module names or module IDs whose weight you want to set.

### **Related Information**

<u>set\_host\_config</u>

set weight batch option

<u>reset dist weight</u>

### set\_weight\_batch\_option

set\_weight\_batch\_option integer any\_LSF\_bsub\_option\_string

Sets the LSF Batch options based on the weight attribute.

### **Options and Arguments**

any\_LSF\_bsub\_option\_string
Specifies the LSF Batch options whose weight attribute you want
to set.
integer
Specifies the weight of the host on the batch queue.

### **Related Information**

get weight batch option

# 4

## Low Power Synthesis (LPS) Commands

This chapter describes the Low Power Synthesis (LPS) commands for  $BuildGates^{\$}$  Synthesis and Cadence<sup>®</sup> PKS:

- <u>check cg logic</u> on page 378
- <u>do\_remove\_cg\_dummy\_hierarchy</u> on page 380
- do xform insert sleep mode on page 381
- <u>do xform optimize clock gate</u> on page 383
- <u>do xform optimize power</u> on page 386
- get clock gating options on page 390
- <u>get clock tree power</u> on page 392
- <u>get dynamic peak power</u> on page 393
- get dynamic power on page 394
- <u>get gating instance list</u> on page 396
- get\_list\_of\_cg\_instances on page 398
- <u>get power</u> on page 399
- <u>get power display unit</u> on page 402
- <u>get\_power\_optimization\_options</u> on page 403
- get sleep mode instance list on page 404
- <u>get sleep mode options</u> on page 406
- <u>read\_saif</u> on page 407
- <u>read\_tcf</u> on page 409
- <u>read tcf update</u> on page 412

- <u>read\_vcd</u> on page 416
- report clock gating on page 418
- <u>report power</u> on page 422
- <u>report\_slew\_for\_power\_analysis</u> on page 431
- <u>report tc stats</u> on page 434
- <u>reset slew for power analysis</u> on page 437
- <u>reset\_switching\_activity</u> on page 439
- <u>set clock gating options</u> on page 441
- <u>set power display unit</u> on page 453
- <u>set\_power\_optimization\_options</u> on page 454
- <u>set sleep mode options</u> on page 457
- <u>set slew for power analysis</u> on page 459
- <u>set\_switching\_activity</u> on page 461
- <u>write clock gating attribute</u> on page 463
- <u>write psf</u> on page 465
- <u>write\_sleep\_mode\_attribute</u> on page 466
- <u>write tcf</u> on page 468
- Low Power for Existing BuildGates Synthesis Commands on page 473

### check\_cg\_logic

check\_cg\_logic [-instance list\_of\_dummyEnableHierIds]
 [-no-hier]

Checks the integrity of the clock-gating logic, that is, whether the gating instances are properly connected to the register banks of the same clock-gating domain. Returns an error if it detects some anomaly. You must read the timing and clock constraints, and inserted some clock-gating logic before you can use this command. Use this command when you start a new session with an updated netlist to check the integrity of your clock-gating logic.

### **Options and Arguments**

```
-instance list_of_dummyEnableHierIds
```

Specifies a list of dummy enable hierarchy instances that must be checked. Specify the instances using their identifiers (IDs). *Default*: Checks all dummy enable hierarchy instances starting from the current module.

-no\_hier

Limits checking of the dummy enable hierarchy instances to the current module.

### Example

The following example shows where you use this command in the flow:

```
read_verilog design.v
do_build_generic
# set constraints (including clock constraints)
# Clock gating exploration
do_optimize -stop_for_power_simulation -power
write_verilog -hier my_design.v
write_clock_gating_attribute -file cgattr.tcl
# at this point you can run external (Cadence or third-party) tool
do_remove_design -all
# read the updated netlist
read_verilog my_design_updated.v
do build generic
# set constraints (including clock constraints)
# read attributes associated with clock-gating modules
source cgattr.tcl
# check current module
check_cg_logic -no_hier
```

### **Related Information**

get gating instance list

write clock gating attribute

### do\_remove\_cg\_dummy\_hierarchy

do\_remove\_cg\_dummy\_hierarchy
 [-remove\_scan\_enable\_dummy]

Removes any clock-gating dummy module that was added during clock-gating insertion. All the dummy modules in the current module and in the hierarchy below the current module are removed. If a module is marked dont\_modify, then all the dummy modules in that module or any modules in the hierarchy below it are kept. Optionally, also removes any scan enable dummy hierarchies.

You must insert clock-gating logic with LPS before you can use this command.

**Note:** You can only remove clock-gating dummy modules if they can be identified. Modules are identified by special attributes set on them.

### Important

You cannot decommit clock-gating logic or insert root-gating logic in modules where this command was issued. Because the dummy module is required to identify clock-gating logic, you must invoke this command after decommitting and reporting of clock-gating instances, and insertion of root-gating logic.

### **Options and Arguments**

```
-remove_scan_enable_dummy
Removes any scan enable dummy hierarchies.
```

### Example

The following example shows where you use this command in the flow:

```
read_tlf tech.tlf
read_verilog ckt.v
do_build_generic
do_optimize -power -stop_for_power_simulation
write_verilog -hier ckt.vc
<simulate>
read_tcf ckt.tcf
do_optimize -power # this command performs decommittment, root-gating insertion
get_gating_instance_list/ get_list_of_cg_instances
do_remove_cg_dummy_hierachy
write_verilog final.v
```

### **Related Information**

get gating instance list

### do\_xform\_insert\_sleep\_mode

Lets you manually insert LPS sleep-mode candidates. You must have read the netlist.

### **Options and Arguments**

| -data_net {list_of_          | net}<br>Specifies the nets on which to insert the sleep mode logic. The<br>specified nets must belong to the same module. Specify the nets<br>using their identifiers (IDs) or names.                                                                                    |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -data_pin { <i>list_of</i> _ | pins}<br>Specifies the instance input pins, in front of which the sleep<br>mode logic to be inserted. The specified pins must belong to the<br>same instance. Specify the pins using their identifiers (IDs) or<br>names.                                                |
|                              | You must use this option if the nets on which the sleep mode logic must be inserted have more than one fanout.                                                                                                                                                           |
| -enable { <i>list_of_ne</i>  | <i>ts</i> }<br>Specifies the nets which are the enable function for the sleep<br>mode logic to be inserted. The nets can be in different<br>hierarchical modules, in which cases extra ports may be created.<br>Specify the nets using their identifiers (IDs) or names. |
| -function {and   or}         | Specifies the Boolean function for the enable function if the number of nets in option -enable is more than 1. <i>Default</i> : and                                                                                                                                      |

### Example

The following command inserts a sleep mode module on pin a of instance mult and uses en1 and en2 as enable nets:

```
> do_xform_insert_sleep_mode -data_pin [find -pin mult/a*] \
        -enable [find -port -input en*]
```

Figure 4-1 shows the original schematic and the schematic with the sleep mode module inserted.





original schematic

schematic with sleep-mode module

### **Related Information**

do build generic -sleepmode

do xform optimize power

<u>set\_sleep\_mode\_options</u>

### do\_xform\_optimize\_clock\_gate

```
do_xform_optimize_clock_gate [-clone ] [-declone ]
    [-decommit] [-root_gate] [-rg_decommit]
    [-clock list_of_clocks]
```

Performs transformations (specifically de-cloning, cloning, adding root-gating logic) to reduce the clock tree insertion delay and clock skew, and decommits clock-gating on the clock network to minimize the power dissipation. You can run this command before or after do\_build\_clock\_tree.

**Note:** You must place the design and source the clock constraints before you can use this command. To verify whether you set the clock constraints properly, you can run the report\_clock\_tree command with the -sum option. If the report\_clock\_tree command indicates a clock tree trace failure, you need to exclude these objects from clock tree consideration by using the set\_attribute ct\_excluded true command. For more details, refer to the <u>Cadence Physically Knowledgeable Synthesis (PKS) User Guide</u>. You must also read a toggle count format (TCF) file before you run this command, unless you set the global <u>power\_opt\_no\_tcf</u> to true.

The circuit is modified such that:

- CTPKS has a higher probability of synthesizing a clock tree that will meet the clock constraints
- Final power dissipated by the post-clock tree inserted circuit is less than if there was no transformation

**Note:** The accessory logic in clock-gating (latch, control-gate) is not targeted for de-cloning or cloning (*or* is not affected by the -clone and -declone options).

### **Options and Arguments**

| -clock list_of_cloc | ks                                                                 |
|---------------------|--------------------------------------------------------------------|
|                     | Limits the transformations to the specified clocks.                |
|                     | Default: The transformation is performed on all clocks.            |
|                     |                                                                    |
| -clone              |                                                                    |
|                     | Clones a gating cell such that the gated clock tree is balanced,   |
|                     | localized, and consumes less power.                                |
|                     |                                                                    |
| -declone            |                                                                    |
|                     | Merges all logically equivalent gating cells to minimize the power |
|                     | dissipated in the clock network.                                   |
|                     |                                                                    |

| -decommit    |                                                                                                                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | Decommits clock-gating logic that does not significantly reduce<br>power dissipation of the design or violate timing constraints. This<br>optimization takes clock insertion delays into consideration while<br>performing the timing checks.               |
| -rg_decommit |                                                                                                                                                                                                                                                             |
|              | Removes any root-gating logic specified after the clock tree is<br>generated, if it does not save power or improve timing. The<br>hierarchical module containing the logic inserted during root<br>gating must be present for performing this optimization. |
| -root_gate   | Reduces the overall clock tree power dissipation by inserting gating logic at the root or subroots of the clock tree.                                                                                                                                       |

#### **Default Behavior**

If neither of the -clone, -declone, -decommit, -rg\_decommit, and -root\_gate options are specified and if clock\_propagation\_mode is set to ideal, -clone, -declone, and root\_gate are performed, but not necessarily in that order.

If neither of the -clone, -declone, -decommit, -rg\_decommit, and -root\_gate options are specified and if clock\_propagation\_mode is set to propagated, -decommit and -rg\_decommit are performed.

If any of the -clone, -declone, -decommit, -rg\_decommit, and -root\_gate are options specified, then only that transformation will be applied.

De-cloning, cloning, and adding root-gating logic can only be performed if clock\_propagation\_mode is set to ideal.

#### Limitations

Currently, there is no automatic decommitment of the root-gating logic. To remove any inserted root-gating logic, use the set\_clock\_gating\_options -rg\_ignore command.

Cloning ignores *clock\_gating\_integrated\_cells* with observability ports.

### Example

The following command sets the maximum number of the enable signals per root gating logic to three:

> set\_clock\_gating\_options -rg\_max 3
> do\_xform\_optimize\_clock\_gate -root\_gate

### **Related Information**

<u>do optimize</u>

do xform optimize clock tree

<u>report clock tree</u>

set clock gating options

set\_attribute

### do\_xform\_optimize\_power

```
do_xform_optimize_power [-effort {low | medium | high}]
    [-no_design_rule] [-ignore_timing] [-ipo]
    [-preserve_hold] [-critical_ratio {0.0-1.0}]
    [-critical_offset float] [-fix_clock_net]
    [-cell_replace] [-resize_by_footprint]
    [-sleep_mode] [-clock_gate] [-gate_level]
```

Analyzes and commits sleep-mode logic and clock-gating logic to the design when sleep-mode and clock gating is inserted during front-end optimization. This command also performs gate-level optimizations to improve average power consumption in the design, while honoring the power constraints set with <u>set power optimization options</u>.

**Note:** You must insert switching activities into the design before you run this command, unless you set the global <u>power opt no tcf</u> to true. To insert switching activities, use one of the following commands: <u>read tcf</u>, <u>read saif</u>, or <u>read vcd</u> -dynamic.

Use this command instead of do\_optimize -power if you have a timing-optimized netlist.

By default, this command applies any gate-level transformation for power optimization. The default behavior of the command for a non-placed and a placed design with different options is shown in Tables 4-1 and 4-2. On routed designs, however, only resizing is applied.

Table 4-1 Default Behavior for a Non-Placed Design (bgx\_shell and pks\_shell)

|                                     | -clock_gate | -sleep_mode | -gate_level |
|-------------------------------------|-------------|-------------|-------------|
| do_xform_optimize_power             | yes         | yes         | yes         |
| do_xform_optimize_power -clock_gate | yes         | no          | no          |
| do_xform_optimize_power -sleep_mode | no          | yes         | no          |
| do_xform_optimize_power -gate_level | no          | no          | yes         |

**Note:** If none of the three optimization options are specified and the design is not placed, then wire-load model-based clock gating, sleep mode and gate-level optimization is applied.

### Table 4-2 Default Behavior for a Placed Design (pks\_shell)

|                                     | -clock_gate | -sleep_mode | -gate_level |
|-------------------------------------|-------------|-------------|-------------|
| do_xform_optimize_power             | no          | no          | yes         |
| do_xform_optimize_power -clock_gate | yes         | no          | no          |
| do_xform_optimize_power -sleep_mode | no          | yes         | no          |
| do_xform_optimize_power -gate_level | no          | no          | yes         |

To reduce power using sleep-mode analysis, run these commands in the following order:

set\_sleep\_mode\_options
do\_build\_generic -sleep\_mode

To reduce power with clock-gating logic, run these commands in the following order:

set\_clock\_gating\_options
do\_optimize -power -stop\_before\_mapping

### **Options and Arguments**

| -cell_replace        |                                                                                                                                                                                                                                                                                                                              |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Only replaces the current cells with functionally equivalent cells<br>of the same size. This option is useful in the post-route multiple<br>threshold voltage power optimization flow where low threshold<br>voltage cells are replaced with high threshold voltage cells that<br>have the same area and physical footprint. |
| -clock_gate          |                                                                                                                                                                                                                                                                                                                              |
|                      | Controls the commitment of clock-gating logic.                                                                                                                                                                                                                                                                               |
|                      | If the design is not placed, clock-gating logic is decommitted based on the wire-load model estimation of the clock network.                                                                                                                                                                                                 |
|                      | If the design is placed, clock-gating logic is decommitted based<br>on the CTPKS estimation of the clock network.                                                                                                                                                                                                            |
| -critical_offset flo | at                                                                                                                                                                                                                                                                                                                           |
|                      | Specifies the offset for paths to be considered for the timing-driven power optimization. The floating number is added to the value of the worst slack. <i>Default</i> : 0                                                                                                                                                   |

```
-critical_ratio {0.0 - 1.0}
                           Specifies the range of target slack for paths to be considered for
                           timing-driven power optimization. The ratio is expressed as a
                           percentage of the worst slack. This allows a range of worst slack
                           which is considered critical by the command. Specify a positive
                           number.
                           Default: 0
                           The target slack used in timing-driven power optimization is
                           computed as follows:
    For negative worst slack
    (worst slack * (1 - critical ratio) + critical offset, worst slack)
    For positive worst slack
    (worst_slack * (1 + critical_ratio) + critical_offset, worst_slack)
-effort {low | medium | high}
                           Specifies the scope of the gate-level power optimization that you
                           want. Performs gate-level transformations, such as resizing, pin
                           swapping, and restructuring, to minimize power consumption
                           without worsening the current slack.
                           In general, a higher effort level implies more optimization
                           iterations and longer run times than for a lower effort level. The
                           low effort is recommended for post-timing optimized designs.
                           Default: medium
-fix clock net
                           Allows gate-level power optimization transformations on clock
                           nets.
                           Default: The clock network is not modified by the power
                           optimization transformations.
-gate_level
                           Performs gate-level power optimization.
                           If the design is not placed, wire-load model-based gate-level
                           power optimization is applied.
                           If the design is placed, PKS integrated gate-level power
                           optimization is applied.
-ignore_timing
                           Ignores all timing constraints while optimizing power
```

| -ipo                 | Limits gate-level power optimization to resizing when optimizing for power.                                                   |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------|
| -no_design_rule      | Ignores design rule checking (such as slew rate) while optimizing power.                                                      |
| -preserve_hold       | Prevents early slack from getting worse while optimizing power.                                                               |
| -resize_by_footprint | Resizes to cells with the same footprints.                                                                                    |
|                      | <b>Note:</b> PKS optimization does not rely on footprints. but if foot print check is required, you must specify this option. |
| -sleep_mode          | Controls the commitment of sleep modules.                                                                                     |
|                      | If the design is not placed, sleep mode modules are committed based on power savings and delay penalty.                       |
|                      | If the design is placed, committed sleep modules are decommitted if they violate timing.                                      |

### Examples

The following command allows to set a target slack of -0.47: do\_xform\_optimize\_power -critical ratio 1 -critical\_offset -0.47

### **Related Information**

<u>do build generic</u>

<u>do optimize</u>

<u>report\_power</u>

Gate-level power optimization-only flow in the <u>Low Power for BuildGates Synthesis and</u> <u>Cadence PKS</u>

### get\_clock\_gating\_options

get\_clock\_gating\_options [-tcl\_list]

Displays the current clock-gating settings.

### **Options and Arguments**

-tcl\_list

Displays the settings of the clock gating options in Tcl list format. *Default*: The options and their values are shown in a tabular format.

#### Examples

The following commands set all options to their default and show the settings in tabular format:

```
> set_clock_gating_options -default
> get_clock_gating_options
```

```
gee_ereen_gaerng_opere
```

Returns the following output:

| Clock-Gating OptionsOptionsValue-auto_test_portfalse-controlnone-control_modeuse_test_mode-control_portNOT_SET-domainall-forceNOT SET-gating_stylelatch-ignoreNOT SET-max_fanoutNOT SET-mo_timingfalse-observefalse-obs_styleport-remove_allfalse-rg_forceNOT SET-rg_ignoreNOT SET-rg_max10-same_polarityfalse | +                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -auto_test_portfalse-controlnone-control_modeuse_test_mode-control_portNOT_SET-domainall-forceNOT SET-gating_stylelatch-ignoreNOT SET-max_fanoutNOT SET-minsize3-no_timingfalse-observefalse-obs_styleport-remove_allfalse-rg_forceNOT SET-rg_ignorenot SET                                                    | Clock-Gating                                                                                                                                                                                                                                                                                    | g Options                                                                                                                                                                                 |
| -controlnone-control_modeuse_test_mode-control_portNOT_SET-domainall-forceNOT SET-gating_stylelatch-ignoreNOT SET-max_fanoutNOT SET-minsize3-no_timingfalse-observefalse-obs_styleport-remove_allfalse-rg_forceNOT SET-rg_max10                                                                                | Options                                                                                                                                                                                                                                                                                         | Value                                                                                                                                                                                     |
| -xor_depth 5                                                                                                                                                                                                                                                                                                   | <pre>-control<br/>-control_mode<br/>-control_port<br/>-domain<br/>-force<br/>-gating_style<br/>-ignore<br/>-max_fanout<br/>-minsize<br/>-no_timing<br/>-observe<br/>-obs_style<br/>-remove_all<br/>-rg_dissolve<br/>-rg_force<br/>-rg_force<br/>-rg_ignore<br/>-rg_max<br/>-same_polarity</pre> | none<br>use_test_mode<br>NOT_SET<br>all<br>NOT SET<br>latch<br>NOT SET<br>NOT SET<br>3<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false |

- The following commands set some options and show the settings in tabular format:
  - > set\_clock\_gating\_options -max\_fanout 2 -control pre\_seq\_element \
  - > -observe -domain dft\_domain -ignore {127987}
  - > get\_clock\_gating\_options

Returns the following output:

| Clock-Gatin                                                                                                                                                                                                                                                              | ng Options                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Options                                                                                                                                                                                                                                                                  | Value                                                                                                                                                                                          |
| -auto_test_port<br>-control<br>-control<br>port<br>-domain<br>-force<br>-gating_style<br>-ignore<br>-max_fanout<br>-minsize<br>-no_timing<br>-observe<br>-obs_style<br>-remove_all<br>-rg_dissolve<br>-rg_force<br>-rg_ignore<br>-rg_max<br>-same_polarity<br>-xor_depth | false<br>none<br>pre_seq_element<br>NOT_SET<br>dft_domain<br>NOT SET<br>latch<br>127987<br>2<br>3<br>false<br>true<br>port<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>5 |

■ The following commands set some options and show the settings in Tcl list format:

> set\_clock\_gating\_options -max\_fanout 2 -control pre\_seq\_element \

- > -observe -no\_latch -force {121203} -ignore {127987}
- > get\_clock\_gating\_options -tcl\_list

Returns the following output:

```
{-auto_test_port false} {-control pre_seq_element}
{-control_mode use_test_mode} {-control_port NOT_SET} {-domain dft_domain}
{ -force { } } {-gating_style latch} { -ignore {127987} } {-max_fanout 2}
{-minsize 3} {-no_timing false} {-observe true} {-obs_style port}
{-remove_all false} {-rg_dissolve false} { -rg_force { } } { -rg_ignore { } }
{-rg_max 10} {-same_polarity false} {-xor_depth 5}
```

#### **Related Information**

<u>set\_clock\_gating\_options</u>

### get\_clock\_tree\_power

get\_clock\_tree\_power clock\_pin [-tree\_only]

Returns the total power consumed by all the instances on the clock tree that have the specified pin or port as clock root. Only one clock pin can be specified. Use the get\_power\_display\_unit command to show the power units.

Note: You must insert a clock tree, before you can use this command.

### **Options and Arguments**

| clock_pin  | Specifies the port or instance output pin that is the root of the clock tree. Any port in the clock tree can be specified.                                 |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -tree_only | Excludes the power dissipated by the clock sink objects (sequential elements). <i>Default</i> : The power consumed by the sequential elements is included. |

### Example

The following command returns the total power consumed by all the instances on the clock tree that have pin ctrl/clk as clock root:

> get\_clock\_tree\_power ctrl/clk

Returns an output similar to the following:

{81830 7.290e-07 }

The first number is the clock pin ID and the next number is the total power consumption.

### **Related Information**

<u>get power display unit</u>

<u>report clock tree</u>

### get\_dynamic\_peak\_power

get\_dynamic\_peak\_power

Reports the peak dynamic power—the maximum of the dynamic power values calculated by read\_vcd for the incremental timing windows.

**Note:** To report the dynamic peak power, you must have run read\_vcd -dynamic -time\_period *time*, and the specified time window must be larger than zero. If you change any slew or capacitance values for the design, you need to read in the VCD file again to recalculate the dynamic power.

### **Related Information**

get power display unit

<u>read vcd</u>

### get\_dynamic\_power

```
get_dynamic_power [-instance {list_of_instances}]
    [-net {list_of_nets}]
```

Traverses the hierarchy and returns the average cycle-by-cycle power consumed for the specified instances or nets of the current module in the period during which the events are monitored. This period is defined with the read\_vcd command. Use the get\_power\_display\_unit command to show the power units.

LPS computes the power for each transition in the VCD file that is relevant to the specified instances and nets.

**Note:** You must read a VCD file (using read\_vcd -dynamic) before you can run the get\_dynamic\_power command. If you change any slew or capacitance values for the design, you need to read in the VCD file again to recalculate the dynamic power.

### **Options and Arguments**

```
-instance {list_of_instances}
    Specifies the instances for which you want to obtain the power.
    Instances must be separated by a space.
-net {list_of_nets}
    Specifies the nets for which you want to obtain the power. Nets
    must be separated by a space.
```

must be separated by a space. In this case, the get\_dynamic\_power command reports for each net the power that is consumed by the capacitance of the net and by the capacitance of the pins driven by the specified net.

**Note:** If you do not use any of these options (default), the command returns the power for all the instances and all the nets in the current module.

### Examples

For the following examples, consider the circuit shown in Figure <u>4-2</u>.

### Figure 4-2 Schematic for get\_dynamic\_power Example



### Command Reference for BuildGates Synthesis and Cadence PKS Low Power Synthesis (LPS) Commands

■ The following commands return the average cycle-by-cycle power for all the instances and all the nets in module inst\_and:

```
> read_vcd -dynamic -module inst_and and.vcd
> get_dynamic_power
```

```
> 1.739e-3
```

■ The following commands return the average cycle-by-cycle power for instance i\_0:

```
> read_vcd -dynamic -module inst_and and.vcd
```

- > get\_dynamic\_power -instance i\_0
- > 1.413e-3
- The following commands return the average cycle-by-cycle power for net a:

```
> read_vcd -dynamic -module inst_and and.vcd
> get_dynamic_power -net a
```

- > 1.730e-4
- The following commands return the average cycle-by-cycle power for nets a and b:
  - > read\_vcd -dynamic -module inst\_and and.vcd
  - > get\_dynamic\_power -net {a b}

```
> {1.730e-4 1.533e-4}
```

### **Related Information**

<u>get\_power</u>

get power display unit

<u>read vcd</u>

### get\_gating\_instance\_list

```
get_gating_instance_list
    [-instance {list_of_instances}] [-hier]
```

Returns a list with the following elements:

- Top-level clock identifier
- Dummy enable hierarchy identifier associated with the clock-gating logic
- Enable net identifier
- Identifiers of all clock-gating instances in the clock-gating domain

In case of multiple clock-gating domains, the command returns a list for each domain.

**Note:** You must insert clock-gating logic with LPS before you can use this command.

### Important

This command does not work after clock-gate commitment or when the dummy hierarchies are removed with the do\_remove\_cg\_dummy\_modules command.

### **Options and Arguments**

-hier

Searches for clock-gating logic down the hierarchy, starting from the current module.

-instance {list\_of\_instances Specifies the instances that must be searched for clock-gating logic. You must specify the instances using their identifiers (IDs). Default: The tool looks for clock-gating logic in the current module.

### Examples

The following command returns information for clock-gating logic in the hierarchy, starting from instance 78499:

> get\_gating\_instance\_list -instance {78499} -hierarchy

Returns an output similar to the following:

 $\{77877 73411 71621 76067\}$ 

where members of each quadruplet have the following meaning:

{clkId dummyEnableHierId enableNetId gatingInstanceId}

■ The following command returns information for all clock-gating logic in the hierarchy, starting from the current module:

> get\_gating\_instance\_list -hierarchy

Returns an output similar to the following:

{77877 78979 77509 79523} {77877 73411 71621 76067}

#### **Related Information**

get\_list\_of\_cg\_instances

## get\_list\_of\_cg\_instances

get\_list\_of\_cg\_instances
 -enable\_id dummyEnableHierId [-include\_ff]

Obtains all the logic instances for the specified enable identifier. The enable is associated with one of the clock-gating logic blocks.

**Note:** You must insert the clock-gating logic with LPS and run the get\_gating\_instance\_list command to get the dummy enable hierarchy identifiers, before you can use this command.

#### **Options and Arguments**

| -enable_id |
|------------|
|------------|

Specifies the dummy hierarchy for which the associated clock gating logic must be listed. You must specify the enable identifier (ID).

-include\_ff

Includes the flip-flops associated with the given clock-gating logic in the returning list. In other words, includes the flip-flops driven by the clock-gating logic.

#### Examples

The following command obtains the identifiers of all logic instances associated with enable identifier 73411:

> get\_list\_of\_cg\_instances -enable\_id 73411

Returns an output similar to the following:

73411 76067 73763

■ The following command obtains the identifiers of all logic instances associated with enable identifier 73411, including the flip-flops driven by the clock-gating logic:

> get\_list\_of\_cg\_instances -enable\_id 73411 -include\_ff

Returns an output similar to the following:

73411 76067 73763 73235 80003 79715 79635

#### **Related Information**

get gating instance list

## get\_power

```
get_power [-instance {list_of_instances}]
     [-net {list_of_nets}]
```

Traverses the hierarchy and returns the total power for the specified instances or nets of the current module. Use the get\_power\_display\_unit command to show the power units.

**Note:** If you did not read a TCF file, LPS uses default toggle counts for each primary input and sequential cell output (see power default prob and power default toggle rate globals), performs probabilistic analysis on the rest of the design incrementally, and generates the power.

## **Options and Arguments**

-instance {list of instances} Specifies the instances for which you want to obtain the power. Instances must be separated by a space.

-net {list\_of\_nets} Specifies the nets for which you want to obtain the power. Nets must be separated by a space. In this case, the get power command reports for each net the power consumed by the capacitance of the net and the capacitance of the pins driven by the specified net.

Note: If you do not use any of these options (default), the command returns the power for the all the instances and all the nets in the current instance and the hierarchy below.

## **Examples**

For the following examples consider the schematic in Figure 4-3 on page 400.

**Note:** The precision of the power value is three digits. So, if you have a total power of 0.00345, it is displayed as 0.345E-2. You can change the units used to display the power units with the set\_power\_display\_unit command.

## Figure 4-3 Schematic for get\_power Examples



The following command returns the total power for all the instances and all the nets in the current module:

> get\_power

Returns an output similar to the following:

0.234

■ The following command returns the total power for instance A/B:

```
> get_power -instance A/B
```

Returns an output similar to the following:

0.119

The following command returns the total power for instances A/B/I1, A/B/I2, and A/B:

```
> get_power -instance {A/B/I1 A/B/I2 A/B}}
```

Traverses the hierarchy as shown in Figure 4-3 and returns an output similar to the following:

{3.45E-04 5.27E-04 0.119}

The following command returns the total power for nets n1, A/B/I1/n2, and A/B/n3, where n1 is a net in the top module, n2 is a net in instance I1, and n3 is a net in instance B:

```
> get_power -net {n1 A/B/I1/n2 A/B/n3}
```

Returns an output similar to the following:

{0.565E-5 0.12E-6 1.1E-6}

#### **Related Information**

get current instance

power internal power scaling global

<u>read\_tcf</u>

<u>report power</u>

report slew for power analysis

# get\_power\_display\_unit

get\_power\_display\_unit

Returns the power display unit.

## Example

The following command displays the units used in the power reports.

> get\_power\_display\_unit

Returns an output similar to the following:

m₩

where mW is the value you specified with the set\_power\_display\_unit command.

## **Related Information**

<u>set power display unit</u>

## get\_power\_optimization\_options

get\_power\_optimization\_options [-tcl\_list]

Displays the current settings you have for power optimization.

#### **Options and Arguments**

-tcl\_list

Displays the settings of the power optimization options in Tcl list format. *Default*: The options and their values are shown in a tabular format.

#### Examples

- In the following example, the first command instructs LPS to focus on optimizing the leakage power only, the second command shows the weight factors used for the power components during power optimization in tabular format.
  - > set\_power\_optimization\_options -instance\_leakage\_power 1
  - > get\_power\_optimization\_options

#### Returns the following:

The following command returns the previous information in Tcl list format.

> get\_power\_optimization\_options -tcl\_list

Returns the following:

```
{-instance_internal_power 0.00} {-instance_leakage_power 1.00}
{-net_power 0.00}
```

#### **Related Information**

set power optimization options

# get\_sleep\_mode\_instance\_list

```
get_sleep_mode_instance_list
    [-instance {list_of_instances}][-hierarchy]
```

Returns a list of object identifiers (IDs) for each sleep mode module in the following form:

{sleepMode\_1 dataBus\_1 enable\_1\_1 enable\_1\_2 ... enable\_1\_k}
{sleepMode\_2 dataBus\_2 enable\_2\_1 enable\_2\_2 ... enable\_1\_k}

The actual enable function of a sleep mode module may be a complex Boolean function of a set of signals in the original design. In this case, the number of enable signals reported for that sleep mode module is more than one.

For example, for the sleepMode\_1 sleep module, the corresponding controlled data bus identifier is dataBus\_1. The enable function for this module is a complex Boolean function of the signals enable\_1\_1, enable\_1\_2, ...

**Note:** You must run do\_build\_generic -sleep\_mode before you can use this command.

#### **Options and Arguments**

 -hierarchy
 Traverses the hierarchy (that is, all sub-modules below the current module) and reports all sleep mode modules found. Default: The report is run on the current module.
 -instance {list\_of\_instances
 Reports all sleep mode modules in the specified instances. You must specify the instances using their identifiers (IDs). Default: Reports all sleep mode modules starting from the current module.

#### Example

The following command reports all sleep mode modules found in the hierarchy of the current module.

> get\_sleep\_mode\_instance\_list -hier

Returns an output similar to the following:

```
{245859 227748 227813 227781} {247475 227188 227813 227781}
```

In this case, two sleep-mode modules are found. The first number in each list identifies the sleep-mode module. The second number identifies the data bus. The next two numbers identify the enable signals.

#### **Related Information**

do build generic -sleep\_mode

## get\_sleep\_mode\_options

get\_sleep\_mode\_options [-tcl\_list]

Lists all sleep mode options you have set using the set\_sleep\_mode\_options command.

#### **Options and Arguments**

-tcl\_list

Displays the settings of the sleep mode options in Tcl list format. *Default*: The options and their values are shown in a tabular format.

#### Examples

■ The following command lists all sleep mode options in Tcl list format:

> get\_sleep\_mode\_options -tcl\_list

Returns the following output:

| {-no_dissolve true}   | {-timing_driven full} | {-force NOT_SET} |
|-----------------------|-----------------------|------------------|
| {-remove_all NOT_SET} | {-ignore NOT_SET}     |                  |

■ The following command lists all sleep mode options in tabular format:

> get\_sleep\_mode\_options

Returns the following output:

| Sleep Mode                     | +<br>Options |
|--------------------------------|--------------|
| Options                        | Value        |
| -no_dissolve<br>-timing_driven | true<br>full |

The tabular format displays only the options that were set.

## **Related Information**

set sleep mode options

# read\_saif

read\_saif -instance instance\_name saif\_file

Reads switching activity information in Synopsys activity interchange format (SAIF) for power estimation.

The SAIF file provides more detailed information about the switching behavior of nets and ports, which leads to more accurate power estimation. Besides net and port signal probability and transition activity information, the SAIF file also contains the transition activities of path and pin power arcs. If the cell has conditional leakage power, the SAIF file contains the signal probabilities of these when conditions.



For the power calculation, LPS assumes that you specify the power arcs for each port and the when conditions for the leakage power in SAIF file, in the same order as they appear in the technology library.

After reading the SAIF file, you can use the get\_power or report\_power commands to get power estimates.

## **Options and Arguments**

-instance instance\_name

Specifies the top module in the design. Activities are asserted and events observed on all the nets in this module and in the instances that belong to the hierarchy of this module.

saif\_file

Specifies the file containing the switching activity information. The file must be in SAIF format. The file can have any name, suffix, or length.

## Example

In the following example, ports A, B, and C have pin-based power arcs, while port Y has path-based power arcs. The SAIF file contains the transition activities for each power arc. For the leakage power, the file also contains the signal probability of the when condition. This additional information allows for a more accurate power estimation, because the tool does not need to calculate the transition activity of the power arcs based on the ports signal probability and transition activities. Similarly, for leakage power, instead of calculating the probability of the when conditions, the tool can derive the probability directly from the SAIF file.

```
(INSTANCE U111
     (PORT
           ( C
                 (TO 199650) (T1 250) (TX 100)
                 (COND (!B*!A) (RISE) (TC 0) (IG 0)
                 COND (!B*!A) (FALL) (TC 0) (IG 0)
                 )
            )
            (A
                 (TO 199650) (T1 250) (TX 100)
                 (COND ((!C*B) | (!C*!B) | (C*B)) (RISE) (TC 1) (IG 0)
COND ((!C*B) | (!C*!B) | (C*B)) (FALL) (TC 2) (IG 0)
                  )
            )
           (Y
                 (TO 199650) (T1 250) (TX 100)
                 (COND ((B*A) | (!B*A) | (B*!A)) (RISE)
                 (IOPATH C (TC 1) (IG 0)
                 COND ((B*A) | (!B*A) | (B*!A)) (FALL)
                  (IOPATH C (TC 0) (IG 0)
                 COND (C*!A) (RISE)
                 (IOPATH B (TC 0) (IG 0)
                 COND (C*!A) (FALL)
                  (IOPATH B (TC 0) (IG 0)
                 COND (C*!B) (RISE)
                 (IOPATH A (TC 0) (IG 0)
                 COND (C*!B) (FALL)
                 (IOPATH A (TC 0) (IG 0)
                 COND_DEFAULT (TC 2) (IG 0)
                  )
            )
            (B
                 (TO 199850) (T1 0) (TX 150)
                 (COND ((!C*A) | (!C*!A) | (C*A)) (RISE) (TC 0) (IG 0)
COND ((!C*A) | (!C*!A) | (C*A)) (FALL) (TC 0) (IG 0)
                 )
           )
     )
      (LEAKAGE
           (COND (A *B *C) (TO 155000) (T1 45000)
           COND (!A *B *!C) (TO 50000) (T1 150000)
           )
     )
)
```

## **Related Information**

<u>get power</u>

<u>report power</u>

# read\_tcf

read\_tcf [-hier\_down] [-scale scale] tcf\_file

Reads toggle counts from the specified file and puts assertions into the database, so they can be used for power estimation and optimization.

To run power analysis or optimization, you should read in a toggle count format (TCF) file. Without a TCF file, the tool uses default toggle count values at the primary inputs and sequential cell outputs and performs probabilistic analysis after that.

Note: You must read the synthesis library and the netlist before you can use this command.

#### **Options and Arguments**

| -hier_down          | Traverses the hierarchy and sets the same probability and toggle count values on nets or pins whose names match the net or pin name with the wild card in the TCF file. <i>Default</i> : The activity values are only added to the current module, even if the module is hierarchical.                                                                                        |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | For example, assume your TCF file contains                                                                                                                                                                                                                                                                                                                                    |
|                     | <pre>instance (a/b/*) {    net {      n* : "0.5 500";      } } With hier_down specified, the tool traversers all the instances under a/b and sets the probability and toggle count values to 0.5 and 500 respectively, on all the nets starting with n*. Default: Only the instances in a/b are annotated but not the instances in the hierarchy below these instances.</pre> |
| -scale <i>scale</i> | Scales the simulation duration. Use a positive floating number. <i>Default</i> : 1.0                                                                                                                                                                                                                                                                                          |
| tcf_file            | Specifies the file containing the toggle counts. The file must be in TCF format. The file can have any name, suffix, or length.                                                                                                                                                                                                                                               |

## Examples

The following examples refer to the schematic shown in Figure 4-4 on page 410.





■ In the following TCF file, the No value for HierDown indicates not to read this file with the -hier\_down option:

| tcffile () {<br>tcfversion :<br>generator :<br>date : |          | Verilog PLI";<br>9 16:45:44 2000"; |
|-------------------------------------------------------|----------|------------------------------------|
| duration :                                            | "1.50000 |                                    |
| unit :                                                | "ns";    |                                    |
| HierDown :                                            | "No";    |                                    |
| instance () {                                         |          |                                    |
| pin () {                                              |          |                                    |
| "i_12/Z"                                              | :        | "0.566 747";                       |
| "n_n1/B"                                              | :        | "0.516 475";                       |
| "hier1/i_0/Z"                                         | :        | "0.5 500";                         |
| "hier1/n_n0/Z"                                        | :        | "0.5 500";                         |
| "hier1/n_n0/A"                                        | :        | "0.5 500";                         |
| "hier1/n_n0/D"                                        | :        | "0.5 500";                         |
| "hier1/i_0/A"                                         | :        | "0.5 500";                         |
| "hier1/i_0/B"                                         | :        | "0.5 500";                         |

```
"n_n1/A" : "0.61 516";
}
}
```

To read this TCF file (example1.tcf), use the following command:

```
> read_tcf example1.tcf
```

■ In the following TCF file (example2.tcf), the duration is half of the duration of the previous example. Furthermore, the value of HierDown is set to Yes. This implies that the probability and transition count will be set to 0.5 and 500 for all the pins in the hierarchy of hier1.

```
tcffile () {
   tcfversion : "1.0";
   generator : "BGPower Verilog PLI";
   date : "Wed Aug 9 16:45:44 2000";
   duration : "0.75000e+05";
   unit : "ns";
   HierDown : "Yes";
   instance () {
      pin () {
         "i_12/Z" : "0.566 747";
         "n_n1/B" : "0.516 475";
         "hier1/*" : "0.5 500";
         "n_n1/A" : "0.61 516";
      }
   }
}
```

To make the probability and transition density on all pins the same as in the previous example, use the following command:

> read\_tcf -hier\_down -scale 2.0 example2.tcf

The -scale option makes the new duration for this TCF file equal to 1.5e+5.

## **Related Information**

set sleep mode options

# read\_tcf\_update

```
read_tcf_update [-hier_down] [-weight w]
    [-scale scale] tcf_file
```

Updates the probability and transition density of pins and nets.

Note: You must read the synthesis library and the netlist before you can use this command.

If the probability and transition density were not previously user asserted, the new probability and transition density are given as follows:

```
prob_new = prob_spec;
td_new = td_spec;
```

where prob\_new and td\_new are the new values, and prob\_spec and td\_spec are the values specified in the TCF file.

If the probability and transition density were previously user asserted, the new probability and transition density are calculated as follows:

```
prob_new = (prob_prev + w * prob_spec)/(1+w)
td_new = (td_prev + w * td_spec)/(1+w)
```

where prob\_prev and td\_prev are the previous values, and prob\_spec and td\_spec are the values specified in the new TCF file.

In the database, the transition activity (count) is stored as transition density. However, for writing the TCF file using the write\_tcf command, the duration is needed to convert transition density into transition count. For this purpose, the duration is internally stored. This duration is updated as follows:

□ If duration was not previously stored:

duration\_new = duration\_spec

□ If duration was previously stored:

```
duration_new = ( 1 + w) * duration_old
```

For example, if you specify

w = (simulationTime\_spec)/(simulationTime\_prev)

(where simulationTime\_spec and simulationTime\_prev are the new and old simulation period) then prob\_new and td\_new will be as follows:

```
prob_new = (prob_prev * simulationTime_prev + prob_spec * simulationTime_spec)
/(simulationTime_prev + simulationTime_spec);
td_new = (td_prev * simulationTime_prev +
td_spec*simulationTime_spec)/(simulationTime_prev + simulationTime_spec);
duration new = simulationTime prev + simulationTime spec
```

In the example above, prob and td are updated based on the simulation times.

## **Options and Arguments**

| -hier_down          | Traverses the hierarchy and sets the same probability and toggle count values on nets or pins whose names match the net or pin name with the wild card in the TCF file. <i>Default</i> : The activity values are only added to the current module, even if the module is hierarchical.                              |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | For example, assume your TCF file contains                                                                                                                                                                                                                                                                          |
|                     | <pre>instance (a/b/*) {    net {         n* : "0.5 500";     } }</pre>                                                                                                                                                                                                                                              |
|                     | With hier_down specified, the tool traversers all the instances under a/b and sets the probability and toggle count values to 0.5 and 500 respectively, on all the nets starting with n*.<br><i>Default</i> : Only the instances in a/b are annotated but not the instances in the hierarchy below these instances. |
| -scale scale_factor | Scales the simulation time in the TCF file. Use a positive floating number.<br>Default: 1.0                                                                                                                                                                                                                         |
| tcf_file            | Specifies the file containing the toggle counts to be used. There are no restrictions on filenames or length of the filenames. The toggle count file does not need to use a .tcf suffix, but must be in TCF format.                                                                                                 |
| -weight w           | Specifies the weight value. Use a positive floating number. <i>Default</i> : 1.0                                                                                                                                                                                                                                    |

## Examples

Consider the schematic shown in Figure 4-5 on page 414.

#### Figure 4-5 Schematic for read\_tcf\_update Example



Assume you have the following TCF file (example.tcf) for this schematic:

```
tcffile () {
   tcfversion
                :
                         "1.0";
                       "BGPower Verilog PLI";
"Wed Aug 9 16:45:44 2000";
"1.000000e+05";
                :
   generator
   date
               :
               :
   duration
               :
                         "ns";
   unit
             :
                        "No";
   HierDown
   instance () {
     pin () {
         "i_0/A"
                       :
                                 "0.5 500";
         "i_0/B"
                        :
                                 "0.6 600";
         "i_0/Z"
                                  "0.7 700";
                        :
      }
    }
 }
```

Now execute the following command.

```
> read_tcf_update -weight 0.5 example.tcf
```

The duration and transition counts in the new TCF file are updated as follows:

```
tcffile () {
  tcfversion
             :
                      "1.0";
  generator :
                    "BGPower Verilog PLI";
                     "Wed Aug 9 16:45:44 2000";
  date
              :
            :
                      "1.500000e+05";
  duration
  unit
              :
                      "ns";
  HierDown
              :
                     "No";
  instance () {
    pin () {
       "i_0/A"
                    :
                            "0.5 750";
       "i_0/B"
                             "0.6 900";
                    :
       "i_0/Z"
                    :
                            "0.7 1050";
     }
   }
 }
```

■ Consider the original TCF file again and execute the following command:

> read\_tcf\_update -weight 0.5 -scale 2 example.tcf

The duration and transition counts in the new TCF file are now updated as follows:

```
tcffile () {
   tcfversion : "1.0";
   generator : "BGPower Verilog PLI";
   date : "Wed Aug 9 16:45:44 2000";
   duration : "1.500000e+05";
   unit : "ns";
   HierDown : "No";
   instance () {
        pin () {
            "i_0/A" : "0.5 417";
            "i_0.6 500";
            "i_0.7 584";
        }
   }
}
```

#### **Related Information**

<u>read\_tcf</u>

set switching activity

write tcf

# read\_vcd

```
read_vcd [-static | -dynamic] -module module_name
  [-scale scale] [-start_time start_monitoring_time]
  [-end_time end_monitoring_time] [-time_window time]
   vcd_file
```

Reads a Value Change Dump (VCD) file to either assert switching activities on nets or pins, or estimate the average cycle-by-cycle power of the design.

Use this command for either the static or dynamic power analysis:

- For static power analysis (to compute the signal probabilities and switching activities from the VCD file), use read\_vcd -static. Follow this command by commands to estimate static power (for example, get\_power)
- For average dynamic (or average cycle-by-cycle) power estimation, use read\_vcd -dynamic. Follow this command by commands to estimate dynamic power (for example, get\_dynamic\_power or get\_dynamic\_peak\_power)

This command also reports the percentage of nets in the VCD file that have switching information.

## **Options and Arguments**

| -dynamic             |                                                                                                                                                                                                                                                             |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -                    | Stores the necessary information to perform cycle-by-cycle power estimation on the specified instances and nets.                                                                                                                                            |
| -end_time end_monito | oring time                                                                                                                                                                                                                                                  |
|                      | Specifies the time you want to end monitoring the switching activities or events. Specify a value larger than zero in nanoseconds. If you do not specify this option, the activities or events are monitored till the end (last timestamp of the VCD file). |
| -module module_name  |                                                                                                                                                                                                                                                             |
|                      | Specifies the top module in the design. Activities are asserted<br>and events observed on all the nets in this module and in the<br>instances that belong to the hierarchy of this module.                                                                  |
| -scale scale_factor  |                                                                                                                                                                                                                                                             |
|                      | Scales the simulation duration. Use a positive floating number. <i>Default</i> : 1.0                                                                                                                                                                        |

| -start_time <pre>start_m</pre> | onitoring_time                                                                                                                                                                                                                                                                                                 |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | Specifies the time you want to start monitoring the switching activities or events. Specify a value equal to or larger than zero in nanoseconds. If you do not specify this option, the first timestamp in the VCD file is considered as the start time to monitor.                                            |
| -static                        |                                                                                                                                                                                                                                                                                                                |
|                                | Calculates the switching activity and transition density of each of<br>the nets and pins from the time you want to start monitoring the<br>switching activities to the time you want to stop monitoring, and<br>then stores the information as assertions on the nets and pins.<br>This is the default option. |
| -time_window <i>window</i>     | Specifies the time increment, in nanoseconds, in which you want LPS to divide the period during which the events are monitored. The specified time window must be larger than zero for LPS to calculate the dynamic power for each time window.                                                                |
| vcd_file                       | Specifies the name of the value change dump file.                                                                                                                                                                                                                                                              |
|                                |                                                                                                                                                                                                                                                                                                                |

#### **Related Information**

- get dynamic peak power
- get dynamic power

<u>get\_power</u>

#### <u>lpsvcd2tcf</u>

<u>read tcf</u>

# report\_clock\_gating

```
report_clock_gating [-detailed] [-not_gated] [-gated]
    [-bank_width number]
```

Reports clock gating information for the design. The information depends on whether the clock gating has been inserted or not:

- For designs without clock-gating insertion, reports the percentage of register banks that can potentially be clock-gated or not.
- For designs with clock-gating logic inserted, the information depends on whether the report is requested for registers that are gated or not.
  - □ **Gated**—Reports for each clock-gating domain, the instance name of the gating cell, the net that enables the clock-gating logic, the size of the register bank that is clock gated, and whether the clock gating was forced.
  - **Not gated**—Reports whether clock gating was forced on the registers or not.

To adjust the format of the table generated with report\_clock\_gating, specify popt\_report\_clock\_gating\_table as the table name when using the <u>set\_table\_style</u> command.

## **Options and Arguments**

| -bank_width <i>number</i> | Creates two categories of register banks for the report: one category with a width larger than or equal to the specified width, and one category with a width smaller than the specified width. |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | If no value is specified, the bank width defaults to the value of the -minsize option of the <u>set clock gating options</u> command. If that option was omitted, the number defaults to 3.     |
| -detailed                 |                                                                                                                                                                                                 |
|                           | Adds the names of registers to the report.                                                                                                                                                      |
|                           | Before clock-gating insertion, reports the registers for each category. See -bank_width option and Examples on page 419 for more information.                                                   |
|                           | After clock-gating insertion, reports the registers in each clock-gating domain, and the library cell used for the clock-gating cell.                                                           |

| -gated     | Reports for each clock-gating domain, the instance name of the gating cell, the net that enables the clock-gating logic, the size of the register bank that is clock gated, and whether the clock gating is forced by the user. |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | Only applies if clock-gating logic was inserted.                                                                                                                                                                                |
| -not_gated | Reports for each register that could not be clock gated, whether the user tried to force clock gating on the register or not.                                                                                                   |
|            | Only applies if clock-gating logic was inserted.                                                                                                                                                                                |

#### **Examples**

The following command reports the clock-gating candidates before clock-gating insertion:

| report_clock_gating |                                                                                          |                      |                                       |
|---------------------|------------------------------------------------------------------------------------------|----------------------|---------------------------------------|
| +                   | Clock Gating Potential H                                                                 | Report               | +                                     |
|                     | Category                                                                                 | Number of<br>Domains | Percentage<br>of<br>Registers         |
| Clock gating candid | lates with bank width >= 3<br>lates with bank width < 3<br>ed (Const enable/User ignore) | 4<br>0<br>1          | 80.769231%<br>0.000000%<br>19.230769% |

The following command gives a detailed report of the clock-gating candidates before clock-gating insertion:

report\_clock\_gating -detailed

| Clock Gating Potential Report                                                                                                                  |                      |                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---------------------------------------|
| Category                                                                                                                                       | Number of<br>Domains | Percentage<br>of<br>Registers         |
| Clock gating candidates with bank width >= 3<br>Clock gating candidates with bank width < 3<br>Clock gating skipped (Const enable/User ignore) | 4<br>0<br>1          | 80.769231%<br>0.000000%<br>19.230769% |

Clock Gatable registers with bank width >= 3 are :
 { regs/small\_active/data\_out\_reg\_2 regs/small\_active/data\_out\_reg\_1
regs/small\_active/data\_out\_reg\_0}
 { regs/big\_normal/data\_out\_reg\_7 regs/big\_normal/data\_out\_reg\_6
regs/big\_normal/data\_out\_reg\_5 regs/big\_normal/data\_out\_reg\_4
regs/big\_normal/data\_out\_reg\_3 regs/big\_normal/data\_out\_reg\_2
regs/big\_normal/data\_out\_reg\_1 regs/big\_normal/data\_out\_reg\_0}

# Clock Gating skipped for following registers : { ctrl/STATE\_reg\_4 ctrl/STATE\_reg\_4 ctrl/STATE\_reg\_4 ctrl/STATE\_reg\_4 ctrl/STATE\_reg\_4} <POPT-027>.

The following command reports the inserted clock-gating logic:

report\_clock\_gating

| +                                                                                                                                                                                                                                                   | Clock                                   | Gating Summary Report                                                                                                                                                        |                        |                        |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------|--|--|
| Total Number of Gating Cells : 4<br>Total Number of Registers : 26<br>Total Number of Gated Reg (bank width >= 3) : 21 (80.769231%)<br>Total Number of Gated Reg (bank width < 3) : 0 (0.000000%)<br>Total Number of Non Gated Reg : 5 (19.230769%) |                                         |                                                                                                                                                                              |                        |                        |  |  |
| +                                                                                                                                                                                                                                                   | Clock Gating Report For Gated Registers |                                                                                                                                                                              |                        |                        |  |  |
| CG Domain   Enable Net   CG                                                                                                                                                                                                                         |                                         | CG Instance                                                                                                                                                                  | CG Width               | Force<br>Gated         |  |  |
| Domain #1 enable regs/media<br>Domain #2 enable regs/small                                                                                                                                                                                          |                                         | <pre>regs/medium_less_active/i_2_LPS_CG_GATING_1 regs/medium_constrained/i_2_LPS_CG_GATING_1 regs/small_active/i_2_LPS_CG_GATING_1 regs/big_normal/i_2_LPS_CG_GATING_1</pre> | 5<br>  5<br>  3<br>  8 | N<br>  N<br>  N<br>  N |  |  |

#### ■ The following command gives a detailed report of the inserted clock-gating logic:

report\_clock\_gating -detailed

| +                                            | Clock Gating Summary Report                                                                                                                                                        |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Total Number<br>Total Number<br>Total Number | of Gating Cells : 4<br>of Registers : 26<br>of Gated Reg (bank width >= 3) : 21 (80.769231%)<br>of Gated Reg (bank width < 3) : 0 (0.000000%)<br>of Non Gated Reg : 5 (19.230769%) |

| +                                                | Clock Gating Report For Gated Registers |                                                                                                                                                                            |                  |                        |                                                     |  |  |
|--------------------------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------|-----------------------------------------------------|--|--|
| CG Domain                                        | Enable Net                              | CG Instance                                                                                                                                                                | CG Width         | Force<br>Gated         | CG Cell                                             |  |  |
| Domain #0<br>Domain #1<br>Domain #2<br>Domain #3 | enable<br>enable<br>enable<br>enable    | regs/medium_less_active/i_2_LPS_CG_GATING_1<br>regs/medium_constrained/i_2_LPS_CG_GATING_1<br>regs/small_active/i_2_LPS_CG_GATING_1<br>regs/big_normal/i_2_LPS_CG_GATING_1 | 5<br>5<br>3<br>8 | N<br>  N<br>  N<br>  N | OAI21XL<br>OAI21XL<br>OAI21XL<br>OAI21XL<br>OAI21XL |  |  |

The following register groups have been clock gated :

{ regs/medium\_constrained/data\_out\_reg\_0 regs/medium\_constrained/data\_out\_reg\_1 regs/medium\_constrained/ data\_out\_reg\_2 regs/medium\_constrained/data\_out\_reg\_3 regs/medium\_constrained/data\_out\_reg\_4 } { regs/small\_active/data\_out\_reg\_0 regs/small\_active/data\_out\_reg\_1 regs/small\_active/data\_out\_reg\_2 }

{ regs/small\_active/data\_out\_reg\_0 regs/small\_active/data\_out\_reg\_1 regs/small\_active/data\_out\_reg\_2 } { regs/big\_normal/data\_out\_reg\_0 regs/big\_normal/data\_out\_reg\_1 regs/big\_normal/data\_out\_reg\_2 regs/big\_ normal/data\_out\_reg\_3 regs/big\_normal/data\_out\_reg\_4

regs/big\_normal/data\_out\_reg\_5regs/big\_normal/data\_out\_reg\_6 regs/big\_normal/data\_out\_reg\_7 } <POPT-027>.

#### The following command reports the registers that could not be gated:

report\_clock\_gating -not\_gated

| +  | Gating Repo<br>Gated Regis |                   |
|----|----------------------------|-------------------|
| FF | name                       | Force<br>Nongated |

|   | ctrl/STATE_reg_0 | N |  |
|---|------------------|---|--|
|   | ctrl/STATE_reg_1 | N |  |
|   | ctrl/STATE_reg_2 | N |  |
|   | ctrl/STATE_reg_3 | N |  |
|   | ctrl/STATE_reg_4 | N |  |
| 4 |                  |   |  |

## **Related Information**

set clock gating options

## report\_power

```
report_power [-instance {list_of_instances}]
    [-net {list_of_nets}] [-maxcount nworst] [-hier]
    [>|>> report_file] [-tcl_list] -dynamic
```

Reports the power consumption for the specified instances. *Default*: The report\_power command provides the total power of the current module.

**Note:** Before you use report\_power, you must set the top timing module correctly because the power for each net is computed by using the assertions set with respect to the top timing module. It is not necessary to set it to a specific module, but you must set it to manipulate the power assertions only.

If you did not read a TCF file, LPS uses default toggle counts for each primary input and sequential cell output (specified through the <u>power\_default\_prob</u> and <u>power\_default\_toggle\_rate</u> globals).

The following table indicates the table names to be specified with the <u>set table style</u> command if you want to adjust the format of the tables.

| Table Name for set_table_style | Corresponds to Second Table for |
|--------------------------------|---------------------------------|
| report_power_inst              | report_power [-instance]        |
| report_power_net               | report_power -net               |

## **Options and Arguments**

| -dynamic | Reports the dynamic power estimation. You must first run the <u>read vcd</u> -dynamic command, otherwise the command reports zero numbers.                                                                                                                                                                                                                          |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -hier    | Works in conjunction with -instance and -net options.                                                                                                                                                                                                                                                                                                               |
|          | Traverses the hierarchy starting from the current module to<br>report the power consumption of all instances (-instance) or<br>of all nets (-net) in the hierarchy below the current module.<br><i>Default</i> : Power consumption is only reported in the instances or<br>nets of the current module without traversing the hierarchy below<br>the current module. |

| -instance {list_of_:    | Specifies the instances for which to report the power dissipation.<br><i>Default</i> : The power is only reported for the current module. With<br>the -hier option, the hierarchy is traversed.<br><i>Default</i> : The power for each instance in current module is<br>reported.                                                                                                                                                                 |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -maxcount <i>nworst</i> | Limits the number of entries in the report to the specified number that have the worst (highest) power value. <i>Default</i> : The five worst power values for all instances in your design are reported.                                                                                                                                                                                                                                         |
| -net {list_of_nets}     | Specifies the nets for which to report net statistics, such as the signal probability, toggle rate, net capacitance, and the total power of each of the nets. If you do not specify any net with this option, the power for each net in the current module is reported. In this case, the report_power command reports for each net the power consumed by the capacitance of the net and the capacitance of the pins driven by the specified net. |
| report_file             | Specifies the name of the file to which to write the report. The filename must be the last argument included with this command. <i>Default</i> : The report is written to stdout.                                                                                                                                                                                                                                                                 |
| -tcl_list               | Displays the report in Tcl list format.<br>Default: The report is shown in a tabular format.                                                                                                                                                                                                                                                                                                                                                      |

## Examples

## Figure 4-6 Schematic for report\_power Examples



■ The following command reports the power of the current module to file rep.txt:

| <pre>&gt; report_power &gt;</pre>                                                                                 | rep.txt                                                                           |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| Report                                                                                                            | report_power                                                                      |
| Options                                                                                                           | > rep.txt                                                                         |
| Date<br>Tool<br>Release<br>Version                                                                                | 20020220.151310<br>pks_shell<br>v5.0-b012<br>Feb 19 2002 02:05:47                 |
| Module<br>Operating Condition<br>Process<br>Voltage<br>Temperature<br>time unit<br>capacitance unit<br>power unit | add<br>slow<br>1.000000<br>1.620000<br>125.000000<br>1.00 ns<br>1.00 pF<br>1.00uW |

## Command Reference for BuildGates Synthesis and Cadence PKS Low Power Synthesis (LPS) Commands

| + |       | <br>é   | add              |           |           |           |
|---|-------|---------|------------------|-----------|-----------|-----------|
|   |       | Library | Internal<br>Cell | Leakage   | Net       | Total     |
| M | odule |         | Power(uW)        |           | Power(uW) | Power(uW) |
| a | dd    |         | · ·              | 2.916e-04 | 0.4229    | 1.296     |

## ■ The following command reports the power of all instances in the current module:

#### > report\_power -instance

| Report                                                                                                            | report_po                                                                         | ower    |                  |                        |               |                  |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------|------------------|------------------------|---------------|------------------|
| Options                                                                                                           | -inst > 1                                                                         | rep.txt |                  |                        |               |                  |
| Date<br>Tool<br>Release<br>Version                                                                                | 20020220<br>pks_shel<br>v5.0-b01<br>Feb 19 20                                     | 1       | 47               |                        |               |                  |
| Module<br>Operating Condition<br>Process<br>Voltage<br>Temperature<br>time unit<br>capacitance unit<br>power unit | add<br>slow<br>1.000000<br>1.620000<br>125.000000<br>1.00 ns<br>1.00 pF<br>1.00uW |         | +                |                        |               |                  |
|                                                                                                                   |                                                                                   | č       | add              |                        |               |                  |
|                                                                                                                   |                                                                                   | Library | Internal<br>Cell | Leakage                | Net           | Total            |
| Module                                                                                                            | Instance                                                                          | Cell    | Power(uW)        | Power(uW)              | Power(uW)     | Power(uW)        |
| AWDP_ADD_partition_0                                                                                              |                                                                                   | +       | 0.8737<br>0.8737 | 2.916e-04<br>2.916e-04 | 0.1678 0.4229 | 1.0418<br>1.2969 |

■ The following command traverses all the instances in the current module and reports their power to file rep.txt:

| +                                                                               | +                                                                 |
|---------------------------------------------------------------------------------|-------------------------------------------------------------------|
| Report                                                                          | report_power                                                      |
| Options                                                                         | -inst -hier > rep.txt                                             |
| Date<br>Tool<br>Release<br>Version                                              | 20020220.151119<br>pks_shell<br>v5.0-b012<br>Feb 19 2002 02:05:47 |
| Module<br>Operating Condition<br>Process<br>Voltage<br>Temperature<br>time unit | add<br>slow<br>1.000000<br>1.620000<br>125.000000<br>1.00 ns      |

> report\_power -instance -hier > rep.txt

#### Command Reference for BuildGates Synthesis and Cadence PKS Low Power Synthesis (LPS) Commands

| capacitance unit<br>  power unit<br>+ | 1.00 pF<br>  1.00uW |                  |                                      |                                                  |                                      |                                      |
|---------------------------------------|---------------------|------------------|--------------------------------------|--------------------------------------------------|--------------------------------------|--------------------------------------|
|                                       |                     | ē                | add                                  |                                                  |                                      |                                      |
|                                       |                     | Library          | Internal<br>Cell                     | Leakage                                          | Net                                  | Total                                |
| Module                                | Instance            | Cell             | Power(uW)                            | Power(uW)                                        | Power(uW)                            | Power(uW)                            |
| AWDP_ADD_partition_0<br>add           | i_0/i_0<br>i_0/i_1  | ADDHXL<br>XOR3X2 | 0.0852<br>0.7885<br>0.8737<br>0.8737 | 1.458e-04<br>1.458e-04<br>2.916e-04<br>2.916e-04 | 0.1079<br>0.0599<br>0.1678<br>0.4229 | 0.1933<br>0.8485<br>1.0418<br>1.2969 |

The following command reports the power for instance i\_0 to file rep.txt:

| +                                                                                                                 |                                                                                  |             | +                |           |           |           |
|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------|------------------|-----------|-----------|-----------|
| Report                                                                                                            | report_po                                                                        | ower        |                  |           |           |           |
| Options                                                                                                           | -inst i_(                                                                        | ) > rep.txt |                  |           |           |           |
| Date<br>Tool<br>Release<br>Version                                                                                | 20020220<br>pks_shell<br>v5.0-b012<br>Feb 19 20                                  | L           | 17               |           |           |           |
| Module<br>Operating Condition<br>Process<br>Voltage<br>Temperature<br>time unit<br>capacitance unit<br>power unit | add<br>slow<br>1.000000<br>1.620000<br>125.00000<br>1.00 ns<br>1.00 pF<br>1.00uW | )0          | +                |           |           |           |
| +                                                                                                                 |                                                                                  | ۔۔۔۔<br>ة   | add              |           |           |           |
|                                                                                                                   |                                                                                  | Library     | Internal<br>Cell | Leakage   | Net       | Total     |
| Module                                                                                                            | Instance                                                                         | Cell        | Power(uW)        | Power(uW) | Power(uW) | Power(uW) |
| AWDP_ADD_partition_0                                                                                              |                                                                                  |             | 0.8737           | 2.916e-04 | 0.1678    | 1.0418    |

> report\_power -instance i\_0 > rep.txt

# ■ The following command traverses the hierarchy of instance i\_0 and reports the power to file rep.text:

> report\_power -instance i\_0 -hier > rep.txt

| +Report                            | report_power                                                      |
|------------------------------------|-------------------------------------------------------------------|
| Options                            | -inst i_0 -hier > rep.txt                                         |
| Date<br>Tool<br>Release<br>Version | 20020220.151727<br>pks_shell<br>v5.0-b012<br>Feb 19 2002 02:05:47 |

| Module              | add        |
|---------------------|------------|
| Operating Condition | slow       |
| Process             | 1.000000   |
| Voltage             | 1.620000   |
| Temperature         | 125.000000 |
| time unit           | 1.00 ns    |
| capacitance unit    | 1.00 pF    |
| power unit          | 1.00uW     |

| add                                |                    |                  |                            |                                     |                            |                            |  |
|------------------------------------|--------------------|------------------|----------------------------|-------------------------------------|----------------------------|----------------------------|--|
| Library Internal Leakage Net Total |                    |                  |                            |                                     |                            |                            |  |
| Module                             | Instance           | Cell             | Power(uW)                  | Power(uW)                           | Power(uW)                  | Power(uW)                  |  |
| AWDP_ADD_partition_0               | i_0/i_0<br>i_0/i_1 | ADDHXL<br>XOR3X2 | 0.0852<br>0.7885<br>0.8737 | 1.458e-04<br>1.458e-04<br>2.916e-04 | 0.1079<br>0.0599<br>0.1678 | 0.1933<br>0.8485<br>1.0418 |  |

# ■ The following command reports the power of all the nets in the current module to file rep.text:

| > | report_ | power | -net | > | rep.txt |
|---|---------|-------|------|---|---------|
|---|---------|-------|------|---|---------|

| report_power                                                                      |
|-----------------------------------------------------------------------------------|
| -net > rep.txt                                                                    |
| 20020220.151852<br>pks_shell<br>v5.0-b012<br>Feb 19 2002 02:05:47                 |
| add<br>slow<br>1.000000<br>1.620000<br>125.000000<br>1.00 ns<br>1.00 pF<br>1.00uW |
|                                                                                   |

|        |                                                          | add                                                            |                                                                               |                                                                      |                                                          |
|--------|----------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------|
| Module | Net                                                      | Probability                                                    | Trans. Den.                                                                   | Capacitance                                                          | Power(uW)                                                |
|        | out[1]<br>out[0]<br>in1[1]<br>in1[0]<br>in2[1]<br>in2[0] | *0.4999<br>*0.5190<br>*0.5025<br>*0.5065<br>*0.4936<br>*0.4994 | *0.0126<br>*8.493e-03<br>*4.255e-03<br>*4.388e-03<br>*4.063e-03<br>*4.105e-03 | 3.629e-03<br>3.629e-03<br>0.0183<br>8.209e-03<br>0.0102<br>9.449e-03 | 0.0599<br>0.0404<br>0.1023<br>0.0473<br>0.0546<br>0.0509 |

■ The following command traverses the hierarchy and reports the power of all the nets in the current module to file rep.txt:

> report\_power -net -hier > rep.txt

| 1                                                                                                                 |                                                                                   |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| Report                                                                                                            | report_power                                                                      |
| Options                                                                                                           | -net -hier > rep.txt                                                              |
| Date<br>Tool<br>Release<br>Version                                                                                | 20020220.152111<br>pks_shell<br>v5.0-b012<br>Feb 19 2002 02:05:47                 |
| Module<br>Operating Condition<br>Process<br>Voltage<br>Temperature<br>time unit<br>capacitance unit<br>power unit | add<br>slow<br>1.000000<br>1.620000<br>125.000000<br>1.00 ns<br>1.00 pF<br>1.00uW |

|                   |                                                                  | add                                                                       |                                                                                             |                                                                                |                                                                    |
|-------------------|------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------|
| Module            | Net                                                              | Probability                                                               | Trans. Den.                                                                                 | Capacitance                                                                    | Power(uW)                                                          |
| i_0<br>i_0<br>i_0 | out[0]<br>n_23<br>out[1]<br>in1[1]<br>in1[0]<br>in2[1]<br>in2[0] | *0.5190<br>*0.2435<br>*0.4999<br>*0.5025<br>*0.5065<br>*0.4936<br>*0.4994 | *8.493e-03<br>*4.255e-03<br>*0.0126<br>*4.255e-03<br>*4.388e-03<br>*4.063e-03<br>*4.105e-03 | 3.629e-03<br>0.0121<br>3.629e-03<br>0.0183<br>8.209e-03<br>0.0102<br>9.449e-03 | 0.0404<br>0.0675<br>0.0599<br>0.1023<br>0.0473<br>0.0546<br>0.0509 |

#### The following command reports the power of instances $i_0/n_23$ and in1[1]:

> report\_power -net {i\_0/n\_23 in1[1] }

| +                                                                                                   | +                                                                       |
|-----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| Report                                                                                              | report_power                                                            |
| Options                                                                                             | -net i_0/n_23 in1[0] > rep.txt                                          |
| Date<br>Tool<br>Release<br>Version                                                                  | 20020220.152352<br>pks_shell<br>v5.0-b012<br>Feb 19 2002 02:05:47       |
| Module<br>Operating Condition<br>Process<br>Voltage<br>Temperature<br>time unit<br>capacitance unit | add<br>slow<br>1.000000<br>1.620000<br>125.000000<br>1.00 ns<br>1.00 pF |

#### Command Reference for BuildGates Synthesis and Cadence PKS Low Power Synthesis (LPS) Commands

| power unit<br>+ | 1.00uW         |                    | <br>++                   |                     |                  |
|-----------------|----------------|--------------------|--------------------------|---------------------|------------------|
| +               |                | add                |                          |                     | +                |
| Module          | Net            | Probability        | Trans. Den.              | Capacitance         | Power(uW)        |
| i_0             | n_23<br>in1[0] | *0.2435<br>*0.5065 | *4.255e-03<br>*4.388e-03 | 0.0121<br>8.209e-03 | 0.0675<br>0.0473 |

#### ■ The following command reports both the net power and instance power to file rep.txt:

> report\_power -net -instance i\_0 > rep.txt

| Report              | report_power             |
|---------------------|--------------------------|
| Options             | -net -inst i_0 > rep.txt |
| Date                | 20020220.153024          |
| Tool                | pks_shell                |
| Release             | v5.0-b012                |
| Version             | Feb 19 2002 02:05:47     |
| Module              | add                      |
| Operating Condition | slow                     |
| Process             | 1.000000                 |
| Voltage             | 1.620000                 |
| Temperature         | 125.000000               |
| time unit           | 1.00 ns                  |
| capacitance unit    | 1.00 pF                  |
| power unit          | 1.00uW                   |

|        |                                                          | add                                                            |                                                                               |                                                                      |                                                          |
|--------|----------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------|
| Module | Net                                                      | Probability                                                    | Trans. Den.                                                                   | Capacitance                                                          | Power(uW)                                                |
|        | out[1]<br>out[0]<br>in1[1]<br>in1[0]<br>in2[1]<br>in2[0] | *0.4999<br>*0.5190<br>*0.5025<br>*0.5065<br>*0.4936<br>*0.4994 | *0.0126<br>*8.493e-03<br>*4.255e-03<br>*4.388e-03<br>*4.063e-03<br>*4.105e-03 | 3.629e-03<br>3.629e-03<br>0.0183<br>8.209e-03<br>0.0102<br>9.449e-03 | 0.0599<br>0.0404<br>0.1023<br>0.0473<br>0.0546<br>0.0509 |

| +                    |          | č       | add              |           |           |           |
|----------------------|----------|---------|------------------|-----------|-----------|-----------|
|                      |          | Library | Internal<br>Cell | Leakage   | Net       | Total     |
| Module               | Instance | Cell    | Power(uW)        | Power(uW) | Power(uW) | Power(uW) |
| AWDP_ADD_partition_0 |          |         | 0.8737           | 2.916e-04 | 0.1678    | 1.0418    |

#### ■ The following command reports the three nets with the worst power:

> report\_power -net -maxcount 3

+-----+ | Report | report\_power |

| Options             | -net -maxcount 3 > rep.txt |
|---------------------|----------------------------|
| Date                | 20020220.153921            |
| Tool                | pks_shell                  |
| Release             | v5.0-b012                  |
| Version             | Feb 19 2002 02:05:47       |
| Module              | add                        |
| Operating Condition | slow                       |
| Process             | 1.000000                   |
| Voltage             | 1.620000                   |
| Temperature         | 125.000000                 |
| time unit           | 1.00 ns                    |
| capacitance unit    | 1.00 pF                    |
| power unit          | 1.00uW                     |

|        |                            | add                           |                                     |                               |                            |
|--------|----------------------------|-------------------------------|-------------------------------------|-------------------------------|----------------------------|
| Module | Net                        | Probability                   | Trans. Den.                         | Capacitance                   | Power(uW)                  |
|        | in1[1]<br>out[1]<br>in2[1] | *0.5025<br>*0.4999<br>*0.4936 | *4.255e-03<br>*0.0126<br>*4.063e-03 | 0.0183<br>3.629e-03<br>0.0102 | 0.1023<br>0.0599<br>0.0546 |

## **Related Information**

<u>get power</u>

power internal power scaling global

## report\_slew\_for\_power\_analysis

```
report_slew_for_power_analysis
    [-instance {list_of_instances}] [-rise] [-fall]
    { > | >> } report_file
```

Reports the user-asserted slews and the set of instances with the asserted value.

Note: You must read the synthesis library and the netlist before you can use this command.

The following table indicates the table names to be specified with the <u>set table style</u> command if you want to adjust the format of the tables generated with report\_slew\_for\_power\_analysis.

| Table Name for set_table_style | Corresponds to Table for          |
|--------------------------------|-----------------------------------|
| pa_module_rise_fall_slew_table | e -fall -rise                     |
| pa_module_fall_slew_table      | -fall                             |
| pa_module_rise_slew_table      | -rise                             |
| pa_inst_rise_fall_slew_table   | -instance {instances} -fall -rise |
| pa_inst_fall_slew_table        | -instance {instances} -fall       |
| pa_inst_rise_slew_table        | -instance {instances} -rise       |

## **Options and Arguments**

| -fall           | Reports the slew time for falling edges.                                                                                                                       |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | If neither -fall or -rise are specified, both the user-defined rise and fall slews are reported.                                                               |
| -instance {list | _of_instances<br>Specifies the instance for which the report is to be run.<br><i>Default</i> : The report is given for all instances in the current<br>module. |
| -rise           | Reports the slew time for rising edges.                                                                                                                        |

If neither -fall or -rise are specified, both the user-defined rise and fall slews are reported.

## Examples

Consider the schematic shown in Figure 4-6 on page 424 again. In the following examples, you can assume that you set rise and fall slew values on the instances  $i_0/i_1$  and  $i_0/i_0$ .

The following command reports the rise and fall slew values for instance  $i_0/i_0$ :

> report\_slew\_for\_power\_analysis -rise -fall -instance i\_0/i\_0

Returns the following output:

| +User                         | Defined Slew Va | alues |
|-------------------------------|-----------------|-------|
| Instance                      | Rise            | Fall  |
| i_0/i_0   0.100000   0.200000 |                 |       |

- The following command reports the rise slew value for instance  $i_0/i_0$ :
  - > report\_slew\_for\_power\_analysis -rise -instance i\_0/i\_0

Returns the following output:

| User Defined | Slew Values |
|--------------|-------------|
| Instance     | Rise        |
| i_0/i_0      | 0.100000    |

The following command reports the fall slew value for instance  $i_0/i_0$ :

> report\_slew\_for\_power\_analysis -fall -instance i\_0/i\_0

Returns the following output:

| User Defined | Slew Values |
|--------------|-------------|
| Instance     | Fall        |
| i_0/i_0      | 0.200000    |

■ The following command reports the rise and fall slew values for instance i\_0/i\_0:

> report\_slew\_for\_power\_analysis -instance i\_0/i\_0

Returns the following output:

| +<br>User | Defined Slew Va | alues    |
|-----------|-----------------|----------|
| Instance  | Rise            | Fall     |
| i_0/i_0   | 0.100000        | 0.200000 |

■ The following command reports the rise and fall slew values for all instances in the current module:

> report\_slew\_for\_power\_analysis

Returns the following output:

| user     | Defined Slew Va | +<br>alues |
|----------|-----------------|------------|
| Instance | Rise            | Fall       |
| i_0/i_0  | 0.100000        | 0.200000   |
| i_0/i_1  | 0.300000        | 0.400000   |

The following command reports the rise slew value for all instances in the current module:

> report\_slew\_for\_power\_analysis -rise

Returns the following output:

| +            | +           |
|--------------|-------------|
| User Defined | Slew Values |
| Instance     | Rise        |
| i_0/i_0      | 0.100000    |
| i_0/i_1      | 0.300000    |
| +            | +           |

#### **Related Information**

reset\_slew\_for\_power\_analysis

<u>set slew for power analysis</u>

# report\_tc\_stats

```
report_tc_stats [-prob | -td]
  [-type {assert | noassert | all}]
  [-instance instance_name]
  [-range {n1 n2 ...}] [-tcl_list]
```

Reports the number of nets in the various ranges of either signal probability or transition density.

**Note:** You must read the synthesis library and the netlist before you can use this command. If you did not read a TCF file, LPS uses default toggle counts for each primary input and sequential cell output (specified through the <u>power\_default\_prob</u> and <u>power\_default\_toggle\_rate</u> globals).

If you want to adjust the format of the table generated with <code>report\_tc\_stats</code>, specify <code>pa\_tc\_stats\_table</code> as the table name when using the <u>set\_table\_style</u> command.

#### **Options and Arguments**

| -instance  | instance | _name<br>Reports the statistics of a particular instance. There is no need<br>to use this argument if statistics are needed for the whole design.                                                                                                               |  |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|            |          | Note: You can only report statistics on hierarchical instances.                                                                                                                                                                                                 |  |
| -prob   -t | d        | Reports statistics based on signal probability (-prob) or transition density (-td).<br>Default: The transition density is reported and a warning is issued to state this unless you specify the -tcl_list argument with this command. See Examples on page 435. |  |
| -range {n1 | n2}      | Provides the range values for the signal probability or transition density.<br>Default: The following values for signal probability and transition density are used to determine the ranges:                                                                    |  |
| -prob:     | 0 0.1    | 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9                                                                                                                                                                                                                                 |  |
| -td:       | 0.0001   | 0.00005 0.00001 0.00005 0.001 0.005 0.01 0.05 0.1 0.5                                                                                                                                                                                                           |  |
| -tcl_list  |          | Reports the statistics in Tcl list format.<br><i>Default</i> : The report is shown in tabular format.                                                                                                                                                           |  |

-type {assert | all} Specifies which nets to report. Choose one of the following:

| assert   | Reports nets for which the signal probability or transition density was specified in a TCF file.                                                        |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| noassert | Reports nets that have a signal probability or transition density calculated by the software.                                                           |
| all      | Reports both types of nets, as specified with the assert and noassert options. This is the default action for this command.                             |
|          | If no type is specified, a warning is issued, unless you have specified the <code>-tcl_list</code> argument with the command. See the <u>Examples</u> . |

#### **Examples**

- The following command reports the number of nets for the ranges of transition density in tabular format:
  - > report\_tc\_stats

#### Returns the following report:

--> WARNING: No range of prob/td specified. Using default value. <PA-145>. --> WARNING: No type of prob/td specified. Reporting all nets. <PA-146>.

| Transition Dens<br>Statistics For |       |
|-----------------------------------|-------|
| td                                | #nets |
| 0.000000-0.000050                 | 11    |
| 0.000050-0.000100                 | 2     |
| 0.000100-0.000500                 | 0     |
| 0.000500-0.001000                 | 6     |
| 0.001000-0.005000                 | 137   |
| 0.005000-0.010000                 | 16    |
| 0.010000-0.050000                 | 1     |
| 0.050000-0.100000                 | 0     |
| 0.100000-0.500000                 | 0     |
| 0.500000->                        | 0     |

The following command reports the number of nets for the ranges of transition density in Tcl list format:

> report\_tc\_stats -tcl\_list

#### Returns the following report:

#### **Related Information**

<u>read\_tcf</u>

# reset\_slew\_for\_power\_analysis

```
reset_slew_for_power_analysis [-rise] [-fall]
    [-instance {list_of_instances}]
```

Resets the slew times for the power analysis.

**Note:** You must read the synthesis library and the netlist before you can use this command.

#### **Options and Arguments**

| -fall               | Resets the user-specified slew time of the falling edges.                                                                                                                      |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | If neither -fall or -rise are specified, both the user-defined slew times are reset.                                                                                           |
| -instance {list_of_ | <i>instances</i><br>Resets any user-specified slew times for the specified instances.<br><i>Default</i> : The slew times are reset for all instances in the current<br>module. |
| -rise               | Resets the user-specified slew time of the rising edges.                                                                                                                       |
|                     | If neither -fall or -rise are specified, both the user-defined slew times are reset.                                                                                           |

#### Examples

Consider the schematic shown in Figure 4-6 on page 424. In the following examples, you can assume that you set rise and fall slew values on the instances  $i_0/i_1$  and  $i_0/i_0$ .

The following commands reset the rise user slew value on instance  $i_0/i_0$ :

> reset\_slew\_for\_power\_analysis -rise -instance i\_0/i\_0
> report\_slew\_for\_power\_analysis -instance i\_0/i\_0

#### Returns the following report:

| User     | Defined Slew Va | alues    |
|----------|-----------------|----------|
| Instance | Rise            | Fall     |
| i_0/i_0  |                 | 0.200000 |

- The following commands reset the fall user slew value on instance  $i_0/i_1$ .
  - > reset\_slew\_for\_power\_analysis -fall -instance i\_0/i\_1
  - > report\_slew\_for\_power\_analysis -instance i\_0/i\_1

Returns the following report:

| +- | User     | Defined Slew Va | alues |
|----|----------|-----------------|-------|
|    | Instance | Rise            | Fall  |
|    | i_0/i_1  | 0.300000        | -     |

- The following commands reset the slew values on the current module and on all the instances in the current module.
  - > reset\_slew\_for\_power\_analysis
  - > report\_slew\_for\_power\_analysis

Returns the following report:

When no user slew values are set, issues the following warning:

--> WARNING: No user slew value is set in the current context. No need to reset/report it. <PA-241>.

#### **Related Information**

report slew for power analysis

set\_slew\_for\_power\_analysis

# reset\_switching\_activity

```
reset_switching_activity
  [-instance {list_of_instances}]
  [-net {list_of_nets}] [-pin {list_of_pins}]
```

Resets the switching activity.

Note: You must read the synthesis library and the netlist before you can use this command.

#### **Options and Arguments**

| -instance |                                                                                                                                                                                                      |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Resets the probability and activity assertions of the pins and nets connected to the specified instance(s). You can specify a list of instance identifiers or a list of hierarchical instance names. |
|           | If a hierarchal instance is provided, all the net pins in the hierarchy will be reset.                                                                                                               |
| -net      |                                                                                                                                                                                                      |
|           | Resets the probability and activity assertions of the specified<br>nets. You can specify a list of net identifiers or a list of hierarchical<br>net names.                                           |
| -pin      |                                                                                                                                                                                                      |
| -         | Resets the probability and activity assertions of the specified pins. You can specify a list of pin identifiers or a list of hierarchical pin names.                                                 |
|           |                                                                                                                                                                                                      |

**Note:** If neither -instance, -pin, or -net is specified, the probability and activity will be reset for all the nets in the current module.

## Examples

Consider the schematic shown in Figure 4-6 on page 424.

- The following command resets the probability and transition density of all nets and pins under the instance i\_0/i\_1.
  - > reset\_switching\_activity -instance i\_0/i\_1
- The following command traverses all instances under i\_0 and resets the probability and transition density of all the nets and pins.

```
> reset_switching_activity -instance i_0
```

The following command resets the probability and transition density for the specified pins and nets:

```
> reset_switching_activity -pin {i_0/i_1/A i_0/i_0/B} \
> -net {i_0/i_0/in1[0] i_0/i_1/n_23}
```

■ The following command resets the probability and transition density of all nets and pins under instance i\_0/i\_1and for the specified nets and pins:

```
> reset_switching_activity -instance i_0/i_1 \ > -net i_0/out[0] -pin i_0/A
```

#### **Related Information**

<u>read tcf</u>

set\_switching\_activity

# set\_clock\_gating\_options

```
set_clock_gating_options [-default]
     [-auto_test_port {true | false}]
     [-control {none | pre_seq_element | post_seq_element }]
     [-control_mode {use_scan_enable | use_test_mode}]
     [-control_port signal_name]
     [-domain {all | dft_domain | clock_net}]
     [-no_timing {true [false}] [-observe {true [false}]]
     [-obs_style {port | register | reg_module}]
     [-xor_depth depth] [-same_polarity {true|false}]
     [-exclude {list_of_cells}
     [-force {list_of_instances}]
     [-ignore {list_of_instances}]
     [-remove_all {true|false}]
     [-gating_style {none | latch| flipflop}]
     -reset {true | false} [-max_fanout size]
     [-minsize reg_bank_size] [-rg_dissolve {true|false}]
     [-rg_force] [-rg_ignore] [-rg_max number]
```

Sets various clock-gating functions for clock-gating insertion and for clock-gating logic commitment during gate-level power optimization. This command does not overwrite any options previously set by this command.

Note: You must read the synthesis library and the netlist before you can use this command.



Options are preserved even after you run the do\_remove\_design -all command, which removes the design.

LPS can automatically map to the dedicated gating cells in the library if they have either the attribute is\_clock\_gating\_cell (set to true) or clock\_gating\_integrated\_cell.

#### Support for Multiple Clock Domains

To support multiple clock domains controlled by different test signals, you must use the set\_test\_mode\_setup command to associate the clock with the corresponding test-mode pin. See the set test mode\_setup on page 783 command for more information.

For more information about multiple clock domains, see <u>Low Power for BuildGates</u> <u>Synthesis and Cadence PKS</u>.

#### **Options and Arguments**

-auto\_test\_port {true|false}

Inserts test-mode pins automatically at the top module for all the clock domains when inserting DFT logic during clock gating. This is only done if the clock domains with DFT settings do not have a corresponding test-mode pin defined. The name of the added test-mode pins are composed of the value of the global environment variable <u>dft\_test\_mode\_port\_name\_prefix</u>, followed by a numeric. If this global is set to the default, TEST\_MODE, then the first test\_mode pin added is called TEST\_MODE\_1. *Default*: true

You can only set this option if you set -control to a value other than none.

-control {none | pre\_seq\_element | post\_seq\_element} Controls the addition of controllability logic to the gated clocks.

| none (default)   | Does not add any controllability logic.                         |
|------------------|-----------------------------------------------------------------|
| pre_seq_element  | Adds the controllability logic prior to the sequential element. |
| post_seq_element | Adds the controllability logic after the sequential element.    |

If the gating\_style is none, you can set either of the pre\_seq\_element or post\_seq\_element options. They both have the same effect.

If you set -domain to either dft\_domain or clock\_net, the clock is made controllable (controllability logic is inserted) by associating the test-mode pin with the corresponding clock as defined by the set\_test\_mode\_setup command.

Because of the gated logic, it might not be possible to control the clock signal feeding the set of registers affecting clock gating, which can affect design testability. Using this argument gives you that control.

| •                         | enable   use_test_mode}<br>ies the type of signal to use to make the gated clock<br>ollable.                                                                                                                                                                                                |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | an only set this option if -control is currently set to a other than none.                                                                                                                                                                                                                  |
| use_scan_ena              | Uses the scan enable of the registers driven by<br>the corresponding gated clock. All the registers<br>that are driven by the gated clock must be driven<br>by the same scan enable signal.                                                                                                 |
| use_test_mod<br>(default) | <pre>de Uses the test mode signal. The signal used<br/>depends on the settings of the -control_port,<br/>-domain and -auto_test_mode options.</pre>                                                                                                                                         |
| for all<br>interr<br>modu | ifies the name of the signal to use to control the gated clock<br>clock domains. The signal can be either a port or an<br>nal pin. You must specify the complete path from the current<br>ile. You should also specify the signal as a test_mode signal<br>the set_test_mode_setup command. |
|                           | an only set this option if -control is currently set to a other than none and -domain is set to all.                                                                                                                                                                                        |
| set by                    | all options to the default values and removes any attributes<br>y -force and -ignore. See <u>Examples</u> for the software<br>Ilt values.                                                                                                                                                   |

| -domain {all dft_domain clock_net}<br>Specifies how to group gating signals for controllability,<br>observability, or both. Choose one of the following:                 |                                                                                                                                                                                                       |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| all (defaul                                                                                                                                                              | t) Groups all gating signals in the same<br>observability logic. This is the default when you<br>also set the -observe option.                                                                        |  |  |
|                                                                                                                                                                          | Makes all clocks controllable by a single<br>test-mode pin, if you also have -control_mode<br>set to use_scan_enable.                                                                                 |  |  |
|                                                                                                                                                                          | You can only set this value if you set -control<br>to pre_seq_element or post_seq_element.                                                                                                            |  |  |
| dft_domai                                                                                                                                                                | n Groups all gating signals of clock domains that<br>are associated with the same test-mode signal<br>together in the same observability logic, if you<br>also have -observe set for this command.    |  |  |
|                                                                                                                                                                          | Makes all clocks associated with a given test<br>mode pin controllable by this test mode pin if the<br>association between the clocks and test-mode pin<br>is done through the set_test_mode command. |  |  |
| clock_net                                                                                                                                                                | Groups all gating signals driven by the same clock signal under DFT settings. This option is only relevant for observable domains.                                                                    |  |  |
|                                                                                                                                                                          | The controllability is governed by the association in the set_test_mode_setup.                                                                                                                        |  |  |
| This option is only valid if you -control_mode is set to use_test_mode.                                                                                                  |                                                                                                                                                                                                       |  |  |
| tra                                                                                                                                                                      | or a detailed description of the three different ways the tool can ace the clock net back through the design, see <u>Low Power for uildGates Synthesis and Cadence PKS</u> .                          |  |  |
| -exclude {list_of_cells}<br>Prevents the specified library cells from being used for clock<br>gating logic. You must specify the cells using their identifiers<br>(IDs). |                                                                                                                                                                                                       |  |  |
|                                                                                                                                                                          |                                                                                                                                                                                                       |  |  |

| -force {list_of_instances}<br>Applies to clock gating only. |                                                                                                                                                             |                                                                                                                                                                       |  |
|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                             | Commits clock-gating logic for the specified instances. You must specify the instances using their identifiers (IDs) or their hierarchical instance name.   |                                                                                                                                                                       |  |
|                                                             | If you set this option on the flip-flops before inserting clock-gating logic, LPS will force insertion of clock-gating logic for these flip-flops.          |                                                                                                                                                                       |  |
|                                                             | logic, LPS w                                                                                                                                                | s option on the flip-flops after inserting clock-gating<br>ill blindly commit insertion of clock-gating logic for<br>ps without checking timing or power constraints. |  |
|                                                             | To force commitment of any gating logic, you should set this option after do_optimize -stop_for_power_sim -power or do_optimize -stop_after mapping -power. |                                                                                                                                                                       |  |
|                                                             | You can set this option on any flip-flop and it commits the clock-gating domain the flip-flop belongs to.                                                   |                                                                                                                                                                       |  |
| -gating_style {none                                         | Controls whe                                                                                                                                                | flipflop}<br>ether to add any logic to prevent glitches on the<br>al. Choose one of the following options:                                                            |  |
| none                                                        |                                                                                                                                                             | Does not add any logic. The clock-gating logic does not contain any latches nor flip-flops.                                                                           |  |
|                                                             |                                                                                                                                                             | If you specify none, you need to source the timing constraints before inserting clock gates.                                                                          |  |
| latch (                                                     | default)                                                                                                                                                    | Uses a latch to prevent glitches on the clock-gating enable signal.                                                                                                   |  |
| flipflo                                                     | Þ                                                                                                                                                           | Uses a flip-flop to prevent glitches on the clock-gating enable signal.                                                                                               |  |

-ignore {list\_of\_instances}

Does not insert or commit clock-gating logic for the specified instances. You must specify the instances using their identifiers (IDs).

|                           | If you specify set_clock_gating_options -ignore prior to inserting the clock-gating logic, the clock-gating logic for the instances specified is not inserted.                                                     |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | If you specify set_clock_gating_options -ignore after inserting the clock-gating logic, clock-gating logic for the specified instances is not committed.                                                           |
|                           | You can set this option on any flip-flop and it decommits the clock-gating domain the flip-flop belongs to.                                                                                                        |
| -max_fanout <i>number</i> | Clones the clock-gating cell whenever this cell is driving more registers than the specified number.                                                                                                               |
|                           | LPS clones only the clock-gating cell and not the entire clock-gating logic (latch, controlling logic, and so on).                                                                                                 |
| -minsize reg_bank_s:      | <i>ize</i><br>Enables clock-gating insertion for any register bank larger than<br>the specified size.<br><i>Default</i> : The register bank is clock gated based on the estimated<br>power savings it can produce. |
|                           | For optimal results, let the tool decide the minimum register size based on the power estimation.                                                                                                                  |
| -no_timing {true fal      | Ignores timing when inserting clock-gating logic. Even if the clock-gating logic causes a timing violation, the logic will be committed.<br>Default: true                                                          |
| -observe {true false      | Makes all gated signals observable. Each gating signal is added<br>to an XOR tree and the output of the XOR tree is connected to<br>either a port or observability register.<br>Default: false.                    |
|                           | Note that the XOR tree can span through several modules. All observability signals in a module corresponding to a clock domain under DFT settings are put into an XOR tree in that                                 |

|            |           | module and a single observability signal crosses the module boundary, when necessary.                                                                      |                                                                                                                                                                                                                                                                                                     |  |
|------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|            |           | Clock gating makes the gating signals unobservable. When you set this option, you enable the addition of extra logic to make the signals observable again. |                                                                                                                                                                                                                                                                                                     |  |
|            |           | You can only value other t                                                                                                                                 | <b>v set this option if</b> -control <b>is currently set to a</b> han none.                                                                                                                                                                                                                         |  |
|            |           |                                                                                                                                                            | nay cause module changes because a new port may<br>the observable signal.                                                                                                                                                                                                                           |  |
|            |           |                                                                                                                                                            | n and -obs_style options control the set of points to be inserted in a single XOR tree.                                                                                                                                                                                                             |  |
| -obs_style | {port reg |                                                                                                                                                            | v to create the observability domain. Choose one of                                                                                                                                                                                                                                                 |  |
|            | port (de  | fault)                                                                                                                                                     | Creates a port in the top module for each observability domain and its logic is connected to this port through an XOR tree.                                                                                                                                                                         |  |
|            | registe   | r                                                                                                                                                          | Connects the observability logic to an observability register that is inserted in the scan chain. This is limited by the <code>-xor_depth</code> value.                                                                                                                                             |  |
|            |           |                                                                                                                                                            | Default: The register is clocked with the inverted<br>signal of the physical clock net driving the<br>registers in that observability domain. The register<br>is inserted at the outermost hierarchy that has the<br>corresponding clock signal. The<br>-same_polarity option changes this default. |  |
|            |           |                                                                                                                                                            | The logic can span across modules except in modules where the clock signal is not present.                                                                                                                                                                                                          |  |
|            |           |                                                                                                                                                            | If you select this option, you must also set<br>-obs_domain clock_net.                                                                                                                                                                                                                              |  |

| reg_mod              | ule                                                | Completes the observation observability domain in module. This avoids the creation in any hierarch                                    | the register i<br>e observabilit               | n that                  |
|----------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------|
|                      |                                                    | If you select this option<br>-domain clock_net                                                                                        | •                                              | so set                  |
|                      | Note: You c<br>-observe.                           | an only set the -obs_st                                                                                                               | cyle option i                                  | f you set               |
| -remove_all {true fa | •                                                  | inserted clock-gating lo                                                                                                              | gic.                                           |                         |
| -reset {true false}  | Automaticall<br>Default: fai                       | y adds reset logic to the                                                                                                             | glitch removi                                  | ng logic.               |
|                      | integrated ce<br>When you se                       | et this option to true, or<br>ells in the library that hav<br>et this option to false, o<br>ells in the library without               | ve a reset pin<br>only those clo               | are used.<br>ock-gating |
|                      |                                                    | e registers in the clock-g<br>is reset or preset signal,<br>al logic.                                                                 | •                                              |                         |
|                      | of the register<br>represent the<br>registers in t | n represent the asynchro<br>ers in the clock-gating do<br>asynchronous preset s<br>he clock gating domain,<br>glitch removal latch/FF | omain, and p<br>signals for eac<br>LPS determi | 1,p2,,pn<br>ch of the   |
|                      | (cl+pl) A                                          | ND (c2+p2) AND                                                                                                                        | AND (cn-                                       | +pn).                   |
|                      | or                                                 |                                                                                                                                       |                                                |                         |
|                      | reset signal                                       | er in the clock-gating do $c_x$ and an asynchronous he reset signal for the g                                                         | s preset signa                                 | al px, LPS              |
|                      | (c1+p1) A                                          | ND (c2+p2) AND                                                                                                                        | AND (cn·                                       | +pn).                   |

| -rg_dissolve {true false}   |                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                             | Dissolves the hierarchical module created during root gating. <i>Default</i> : true                                                                                                                                                                                                                                                                                                                      |  |  |
| -rg_force {list_of_         | <i>instances</i> }<br>Automatically considers the specified list of sequential elements<br>and clock-gating instances for root gating, without considering<br>cost.                                                                                                                                                                                                                                      |  |  |
|                             | <b>Note:</b> You cannot force the tool to consider the clock gating latch for root gating.                                                                                                                                                                                                                                                                                                               |  |  |
| -rg_ignore { <i>list_of</i> | <pre>_instances } Ignores the specified list of sequential elements and clock-gating instances for root gating. If you specify any root-gating logic instance in the list, the instance will be decommitted after you invoke the do_xform_optimize_clock_gate -root command.</pre>                                                                                                                       |  |  |
| -rg_max number              |                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                             | Specifies the maximum number of enable signals for every root-gating logic to be inserted. Specify a positive integer. <i>Default</i> : 10. If you specify the -rg_force option at the same time, the -rg_max option will be ignored.                                                                                                                                                                    |  |  |
| -same_polarity {true        | <ul> <li>false</li> <li>Sets the clock polarity for the observability register to that of the driving registers in the clock-gating domain.</li> <li>Default: The clock polarity of the observability register is opposite to that of the driving registers of the clock-gating domain. This default provides an additional half cycle to allow the signal to propagate through the XOR tree.</li> </ul> |  |  |
|                             | You can only set this option if you set -obs_style to register or reg_module.                                                                                                                                                                                                                                                                                                                            |  |  |
| -xor_depth depth            | Adds a register whenever the depth of the XOR tree is equal to the specified depth. This ensures that the maximum depth of the XOR tree is limited to the value specified here. <i>Default</i> : 5                                                                                                                                                                                                       |  |  |

You can only set this option if you set -obs\_style to register or reg\_module.

## Examples

- The following command prevents some OAI cells from being used for clock-gating logic:
  - > set\_clock\_gating\_options [-exclude find -cellrefs {OAI\_2 OAI\_3}]
- The following command sets all options to the default values and removes any attributes set by -force and -ignore:
  - > set\_clock\_gating\_options -default
    > get\_clock\_gating\_options

# Returns the default values:

| Clock-Gating Options                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                        |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Options                                                                                                                                                                                                                                                                                                                            | Value                                                                                                                                                                                                                                  |  |  |
| <pre>-auto_test_port<br/>-control<br/>-control_mode<br/>-control_port<br/>-domain<br/>-force<br/>-gating_style<br/>-ignore<br/>-max_fanout<br/>-minsize<br/>-no_timing<br/>-observe<br/>-obs_style<br/>-remove_all<br/>-rg_dissolve<br/>-rg_force<br/>-rg_force<br/>-rg_ignore<br/>-rg_max<br/>-same_polarity<br/>-xor_depth</pre> | false<br>none<br>use_test_mode<br>NOT_SET<br>all<br>NOT SET<br>latch<br>NOT SET<br>NOT SET<br>3<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false |  |  |

■ The following commands limit the number of registers driven by a single clock gating cell to 2, indicates to add the controllability logic before the sequential element and to make all gating signals observable, commits clock gating logic for instance 121203, and decommits the lock gating logic for instance 127987:

```
> set_clock_gating_options -max_fanout 2 -control pre_seq_element \setminus
```

```
> -observe -force [find -hier -register reg_1]
```

> -ignore [find -hier -register reg\_3]

```
> get_clock_gating_options
```

Returns the settings in tabular format:

| ++<br>Clock-Gating Options                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                      |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Options                                                                                                                                                                                                                                                                                | Value                                                                                                                                                                                                                |  |  |
| -auto_test_port<br>-control<br>-control_port<br>-control_mode<br>-domain<br>-force<br>-gating_style<br>-ignore<br>-max_fanout<br>-minsize<br>-no_timing<br>-observe<br>-obs_style<br>-remove_all<br>-rg_dissolve<br>-rg_force<br>-rg_ignore<br>-rg_max<br>-same_polarity<br>-xor_depth | false<br>pre_seq_element<br>NOT_SET<br>use_test_mode<br>all<br>121203<br>none<br>127987<br>2<br>3<br>false<br>true<br>port<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false<br>false |  |  |

The following commands indicate in addition to the previous example not to add any logic to prevent glitches on the enable signal:

```
> set_clock_gating_options -max_fanout 2 -control pre_seq_element \
```

> -observe -gating\_style none -force {121203} -ignore {127987}

```
> get_clock_gating_options -tcl_list
```

Returns the settings in Tcl list format:

```
{-auto_test_port false} {-control pre_seq_element} {-control_mode
use_test_mode} {-control_port NOT_SET} { -force {121203 } } {-gating_style
latch} { -ignore {127987} } {-max_fanout 2} {-minsize 3} {-no_timing false}
{-observe true} {-obs_style port} {-remove_all false} {-rg_dissolve false}
{ -rg_force { } } { -rg_ignore { } } { -rg_max 10} {-same_polarity false}
{ -xor_depth 5}
```

The following commands control different clocks with different test mode pins, group all gating signals associated with test pin tp1 in the same controllability logic, and do the same for all gating signals associated with test pin tp2:

```
> set_test_mode_setup tp1 1 -clock clk1
> set_test_mode_setup tp2 1 -clock {clk2 clk3}
> set_clock_gating_options -control pre_seq_element -domain dft_domain
```

The following command creates an observability tree with a depth no greater than 10, observed by register per module:

> set\_clock\_gating\_options -control post\_seq\_element -domain clock\_net -auto\_test\_port -observe true -obs\_style reg\_module -xor\_depth 10

The following commands decommit all clock-gating domains except for i\_5\_LPS\_CG\_GATING\_6:

> set\_clock\_gating\_options -ignore [find -hier -inst \*LPS\_CG\_GATING\*]
> set\_clock\_gating\_options -force [find -hier -inst i\_5\_LPS\_CG\_GATING\_6]

- The following command uses the scan enable of the registers to make the gated clock controllable:

```
set_scan_mode SE 1
check_dft_rules
set_clock_gating_options -control_mode use_scan_enable
do_optimize -power
```

#### **Related Information**

do\_xform\_optimize\_clock\_gate

get clock gating options

# set\_power\_display\_unit

set\_power\_display\_unit power\_unit

Causes any power reports to be displayed in the units specified.

#### **Options and Arguments**

power\_unit

Specifies the power unit. You can specify any of the following units: kW, W, mW, uW, nW, pW, fW, and aW. The power units are case insensitive. *Default*: mW

#### Example

The following command sets the unit to be used in the power reports to mW:

> set\_power\_display\_unit nW

#### **Related Information**

get power display unit

# set\_power\_optimization\_options

```
set_power_optimization_options
```

```
[-instance_leakage_power leakage_factor]
[-instance_internal_power internal_factor]
[-net_power net_factor] [-default]
[-power_constraint target_power] [-default]
```

Sets the weight factors for each component in the total power calculation during optimization only.

During power optimization, LPS calculates the power as:

total\_power = total\_instance\_power + net\_factor × total\_net\_power

where

*instance\_power* = *leakage\_factor* × *instance\_leakage\_power* + *internal\_factor* × *instance\_internal\_power* 

*Default*: All power components are given an equal weight factor of 1. The weight factors instruct LPS to optimize a different aspect of the total power. For more information about power concepts and how LPS calculates the power, refer to <u>Power Analysis Concepts</u> in *Low Power for BuildGates Synthesis and Cadence PKS*.

**Note:** This command does not change the results obtained with get\_power and report\_power. It only changes the power cost function during optimization.

## **Options and Arguments**

| -default             | Sets all weight factors back to the default values.                                                                                                                                                          |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance_internal_p | ower internal_factor<br>Specifies the weight of the instance internal power in the power<br>calculation. Specify a floating number between 0 and 1. When<br>not specified, this weight factor is set to 0.0. |
| -instance_leakage_po | wer leakage_factor<br>Specifies the weight of the instance leakage power in the power<br>calculation. Specify a floating number between 0 and 1. When<br>not specified, this weight factor is set to 0.0.    |

| -net_power <i>net_factor</i> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                              | Specifies the weight of the net power in the power calculation.<br>Specify a floating number between 0 and 1. When not specified,<br>this weight factor is set to 0.0.                                                                                                                                                                                                                                                                                                                                                                                   |  |
| -power_constraint ta         | arget power                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| <u>Four-</u> origonation of  | Specifies the power optimization target. Specify the target power<br>in the units specified with get_power_display_unit. LPS<br>interprets the target power differently depending on the setting of<br>the other command options (see Examples below for more<br>details). If not specified, the target power defaults to -1, which<br>allows the power optimizer to return the best result possible.                                                                                                                                                    |  |
|                              | <b>Note:</b> Setting this constraint is no guarantee of meeting that constraint. Setting this constraint only ensures that the optimization stops when the constraint is met. Also, if the optimizer meets the constraint, LPS resets the constraint so that the power optimizer continues to optimize the design when you issue more power optimization commands to lower the power even more. If the user target is too optimistic and LPS stops before meeting the target, you should try power optimization commands by increasing the effort level. |  |

# Examples

■ The following command optimizes leakage power only:

> set\_power\_optimization\_options -instance\_leakage\_power 1

The weight factors for the instance internal power and net power are set to 0.

- The following command optimizes dynamic switching power only:
  - > set\_power\_optimization\_options -instance\_internal\_power 1 -net\_power 1

The weight factor for the instance leakage power is set to 0.

The following command optimizes all power components, but skews the optimization towards leakage power optimization:

> set\_power\_optimization\_options -instance\_leakage\_power 0.8
-instance\_internal\_power 0.2 -net\_power 0.2

■ The following command specifies that the target power is the target for the total power.

> set\_power\_optimization\_options -instance\_internal\_power 0.5 \

```
> -instance_leakage_power 0.9 -net_power 1.0 -power_constraint 123.1960
```

- The following command specifies that the target power is the target for the leakage power.
  - > set\_power\_optimization\_options -instance\_internal\_power 0 \
  - > -instance\_leakage\_power 1 -net\_power 0 -power\_constraint 23.19

#### **Related Information**

get power optimization options

Power Analysis Concepts in Low Power for BuildGates Synthesis and Cadence PKS

# set\_sleep\_mode\_options

```
set_sleep_mode_options
  [-timing_driven {none | partial | full}]
  [-no_dissolve {true|false}]
  [-remove_all {list_of_instances}] [-default]
  [-ignore {list_of_instances}]
  [-force {list_of_instances}]
```

Lets you choose settings for the sleep-mode logic commitment or decommitment. You can set these options any time before you commit or decommit the sleep-mode logic.

**Note:** You must read the synthesis library and the netlist, and run do\_build\_generic -sleep\_mode before you can use this command.

## **Options and Arguments**

```
-default
```

Sets all options for this command to the default settings.

```
-force {list_of_instances}
```

Specifies a list of sleep-mode candidates that will be committed at the time of the sleep-mode commitment phase. Specify a list of instance identifiers.

Default: All sleep-mode logic is committed.

```
-ignore {list_of_instances}
```

Removes the inserted sleep-mode logic for the specified instances only if it improves timing by doing so. If no instances are specified all inserted sleep-mode logic become candidates.

-no\_dissolve {true|false}

Does not dissolve the hierarchy of a gating module when it is committed during sleep mode. Default: true

```
-remove_all {list_of_instances}
```

Blindly removes the inserted sleep-mode logic for the specified instances. If no instances are specified, all inserted sleep-mode logic is removed.

| -timing_driven {none   partial   full}<br>Determines to what degree timing is considered when<br>committing sleep-mode logic. Choose one of the following: |                                                                                                                                                                                                                  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| none                                                                                                                                                       | Does not consider timing when committing the sleep-mode gating logic. Only power is considered.                                                                                                                  |  |  |
| partial                                                                                                                                                    | Commits all modules based on power, but then<br>runs timing optimization to improve slack. If the<br>timing constraints are not met, the command tries<br>to improve the slack by decommitting gated<br>modules. |  |  |
| full (default)                                                                                                                                             | Commits each gating module if committing it does not violate a timing constraint.                                                                                                                                |  |  |

#### Example

The following commands set all options to the default settings:

- > set\_sleep\_mode\_options -default
- > get\_sleep\_mode\_options

#### Reports the following settings:

| +                              | +            |  |
|--------------------------------|--------------|--|
| Sleep Mode Options             |              |  |
| Options                        | <br>Value    |  |
|                                | +            |  |
| -no_dissolve<br>-timing_driven | true<br>full |  |
| +                              | +            |  |

## **Related Information**

get\_sleep\_mode\_options

# set\_slew\_for\_power\_analysis

```
set_slew_for_power_analysis
    {-rise slew | -fall slew | -rise slew -fall slew
    | user_slew} [-instance {list_of_instances}]
```

Sets the slew times for the specified instances to be used during power analysis.

While estimating the power, the tool first tries to get the user-defined slew for an instance. If no user-defined slew is available, the tool uses the slew calculated by the timing analyzer. The slew is calculated based on the value of the <u>power slewmode for power analysis</u> global. This global takes the values worst, best, avg.

## **Options and Arguments**

| -fall <i>slew</i>    | Specifies the value of the fall slew time.                                                                                                                                                                                                                                                                                         |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance {list_of_i | nstances }<br>Specifies the instances to which the specified slew times apply<br>during power analysis. If any instance is hierarchical, the<br>user-defined slew is used during power analysis for all primitive<br>instances inside that hierarchy.<br>Default: The slew values apply to all instances of the current<br>module. |
| -rise <i>slew</i>    | Specifies the value of the rise slew time                                                                                                                                                                                                                                                                                          |
| user_slew            | Specifies both the rise and fall slew times.                                                                                                                                                                                                                                                                                       |

## Examples

For the following examples, see the schematic shown in Figure 4-6 on page 424.

The following command sets the rise slew value to 0.1 and the fall slew value to 0.2 on instance  $i_0/i_0$ :

> set\_slew\_for\_power\_analysis -rise 0.1 -fall 0.2 -instance i\_0/i\_0

The following command sets the rise slew value to 0.1 and the fall slew value to 0.2 on instance  $i_0$  and all the instances below  $i_0$ :

> set\_slew\_for\_power\_analysis -rise 0.1 -fall 0.2 -instance i\_0

#### Command Reference for BuildGates Synthesis and Cadence PKS Low Power Synthesis (LPS) Commands

- The following command sets the rise and fall slew values to 0.2 on instance i\_0 and all the instances below i\_0:
  - > set\_slew\_for\_power\_analysis 0.2 -instance i\_0
- The following command sets the rise slew value to 0.2 on instance  $i_0/i_0$ :
  - > set\_slew\_for\_power\_analysis -rise 0.2 -instance i\_0/i\_0

#### **Related Information**

report\_slew\_for\_power\_analysis

reset slew for power analysis

# set\_switching\_activity

```
set_switching_activity [-prob probability]
[-td transition_density]
-net {list_of_nets} -pin {list_of_pins}
```

Sets the switching activity (probability and toggle count).

You must read the synthesis library and the netlist before you can use this command.

**Note:** The set\_switching\_activity command is not meant to set the switching activity of each net one-by-one. Rather, it is meant to set the switching activity of some of the nets that are critical to your design.

## **Options and Arguments**

| -net {list_of_nets}      | Specifies the nets on which the probability and activity assertions are set. You can specify a list of the net identifiers or hierarchical net names.                                                            |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -pin {list_of_pins}      | Specifies the pins on which the probability and activity assertions are set. You can specify a list of the pin identifiers or hierarchical pin names.                                                            |
| -prob <i>probability</i> | Specifies the probability value. Specify a value between 0 and 1. <i>Default</i> : Corresponds to the value of the <u>power default prob</u> global variable.                                                    |
| -td transition_dens      | <i>ity</i><br>Specifies the transition density. Specify a positive floating<br>number larger than zero.<br><i>Default</i> : Corresponds to the value of the<br><u>power default toggle rate</u> global variable. |

**Note:** You can specify a list of nets, pins or a combination. If no option is given an error message is displayed.

## Examples

Consider the schematic shown in Figure 4-6 on page 424.

The following command sets the probability to 0.5 and the transition density to 0.0006 on the specified nets and pins:

```
> set_switching_activity -prob 0.5 -td 0.0006 -net {in1[0] in2[0]}|
> -pin {i_0/i_1/A i_0/i_1/B}
```

The following command sets the probability to 0.5 and the transition density to 0.0006 on the specified nets:

```
> set_switching_activity -prob 0.5 -td 0.0006 -net {in1[0] in2[0]}
```

■ The following command sets the probability to 0.5 and the transition density to 0.0006 on the specified pins:

> set\_switching\_activity -prob 0.5 -td 0.0006 -pin {i\_0/i\_1/A i\_0/i\_1/B}

## **Related Information**

<u>read\_tcf</u>

<u>read tcf update</u>

reset\_switching\_activity

<u>Setting Switching Activity Takes a Long Time</u> in *Low Power for BuildGates Synthesis and Cadence PKS* 

# write\_clock\_gating\_attribute

write\_clock\_gating\_attribute [-file filename]

Dumps all the attributes which are needed to perform clock-gating transformations in a Tcl script. You must explore the clock gating and read the clock constraints before you can use this command.

By sourcing the Tcl script generated by this command you can commit or decommit clock-gating logic at any stage in the flow starting from the updated Verilog netlist.

Important

Do not edit this file or LPS cannot guarantee its functionality.

#### **Options and Arguments**

-file *filename* 

Specifies the name of the file in which to dump the attributes. *Default*: clockGatingAttributes.tcl

#### Example

The following example shows where you use this command in the flow:

```
read_verilog design.v
do_build_generic
# set timing constraints (including clock constraints)
# Clock gating exploration
do_optimize -stop_for_power_simulation -power
write_verilog -hier my_design.v
write_clock_gating_attribute -file cgattr.tcl
# at this point you can run an external (Cadence or third-party) tool
do_remove_design -all
# read the updated netlist
read_verilog my_design_updated.v
do_build_generic
```

# set timing constraints (including clock constraints)

# read attributes associated with clock-gating modules
source cgattr.tcl

After reading the attributes, all clock-gating transformations can be performed.

# **Related Information**

<u>check cg logic</u>

# write\_psf

write\_psf file\_name

Writes the level 1 power specification file (PSF). This power information model is used for defining currents and maximum voltage drop limits.

The PSF file contains the power and ground current demands (in amperes) for each of the flat instances. The PSF file can also be used for IR drop analysis of power grid.

From the current module the command will traverse all the flat instances and reports the average current drawn from the supply.

**Note:** You must read the synthesis library and the netlist before you can use this command. If you did not read a TCF file, LPS uses default toggle counts for each primary input and sequential cell output (specified through the <u>power\_default\_prob</u> and <u>power\_default\_toggle\_rate</u> globals).

#### **Options and Arguments**

-file filename

Specifies the name of the file to which to write the power information.

## Example

The following command writes out the power information in PSF form to the psf.out file:

> write\_psf psf.out

The following is an example of a PSF file:

```
INST_PWR_L1 {
    NAME: "i_1";
    VDD_CURRENT: 1e-8;
    GND_CURRENT: 1e-8;
   }
```

#### write\_sleep\_mode\_attribute

```
write_sleep_mode_attribute [-file filename]
```

Dumps all the attributes which are needed to perform sleep-mode transformations in a Tcl script. You must explore sleep mode before you can use this command.

By sourcing the Tcl script generated by this command you can commit or decommit sleep-mode logic at any stage in the flow starting from the updated Verilog netlist.



Do not edit this file or LPS cannot guarantee its functionality.

#### **Options and Arguments**

-file filename

Specifies the name of the file in which to dump the attributes. *Default*: sleepModeAttributes.tcl

## Example

The following example shows where you use this command in the flow:

read\_verilog design.v
# sleep-mode exploration & insertion
do\_build\_generic -sleep\_mode
write\_verilog -hier my\_design.v
write\_sleep\_mode\_attribute -file smattr.tcl
# at this point you can run an external (Cadence or third-party) tool
do\_remove\_design -all
# read the updated netlist
read\_verilog my\_design\_updated.v
# sleep-mode modules already inserted, so no -sleep\_mode
do\_build\_generic
# read attributes associated with sleep mode modules

source smattr.tcl

#### **Related Information**

do build generic -sleepmode

<u>do xform insert sleep mode</u>

do xform optimize power

# write\_tcf

```
write_tcf [-hier | -flat]
   [-instance {list_of instances}]
   -type [-assert | noassert | all]
   [-duration simulation_period] tcf_file
```

Writes the probability and toggle count of the pins and nets in the specified instances. It also includes the switching activity of all output ports of the modules.

Note: You must read the synthesis library and the netlist before you can use this command.

# **Options and Arguments**

| -assert   noassert         | all<br>Prints either asserted, non-asserted, or both (based on the<br>option) signal probability and transition count of the pins and<br>nets.<br>Default: all                                                                        |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -duration <i>simulatio</i> | n_period<br>Multiplies the transition density (td), so that the final toggle count<br>is an integer. For example, if td is 3e-3/ns and the simulation<br>period is 1e5 ns, the printed toggle count will be 300.<br>Default: 1e5 ns   |
| -hier   -flat              | Specifies the format of the TCF file.<br><i>Default</i> : -hier                                                                                                                                                                       |
| -instance {list_of_        | <i>instances</i> }<br>Specifies the instances for which the probability and toggle count<br>data is written. You can specify a list of the instance identifiers or<br>hierarchical instance names.<br><i>Default</i> : Current module |
| tcf_file                   | Specifies the name of the file in which to store the TCF data.                                                                                                                                                                        |

## Examples

Consider the schematic shown in Figure 4-6 on page 424. Assume that the following TCF file (example.tcf) has been read in.

```
tcffile () {
                            "1.0";
"BGPower Verilog PLI";
"1.0";
"Thu Feb 21 15:19:52 2002";
"1.201000e+05";
   tcfversion
                     :
   tcfversion :
generator :
genversion :
   date
duration
                     :
                     :
   unit
                     :
                               "ns";
    instance () {
      pin () {
          '__U/i_0/S" :
'i_0/i_1/Y" :
'i_0/i_0/A" :
'i_0/i_1/B" :
'j_0/;_0/:
                                           "0.518989 1020";
                                           "0.499933 1510";
"0.506495 527";
                                          "0.502498 511";
          "i_0/i_0/B"
                                          "0.499417 493";
                              :
          "i_0/i_1/A"
                                          "0.493589 488";
                              :
          "i_0/i_1/C"
                              :
                                          "0.243457 511";
      }
    }
}
```

■ The following command writes only the asserted probability and transition count for the nets of instance i\_0/i\_0:

> write\_tcf -flat -type assert -instance i\_0/i\_0 tcf\_file

This results in the following TCF file:

```
tcffile () {
   tcfversion : "1.0";
   generator : "BGPower LPS";
   genversion : "1.0";
   date : "Thu Feb 21 15:23:28 2002";
   duration : "1.201000e+05";
   unit : "ns";
   instance () {
        net () {
            "i_0/out[0]" : "0.518989 1020";
            "i_0.43457 511";
            "i_0/in1[0]" : "0.506495 527";
            "i_0.499417 493";
        }
   }
}
```

The following command writes only the nonasserted probability and transition count for the nets of instance i\_0/i\_0. Because all nets are user asserted, the net section of the new TCF file (below) is empty.

> write\_tcf -flat -type noassert -instance i\_0/i\_0 tcf\_file

This results in the following TCF file:

```
tcffile () {
  tcfversion
                       "1.0";
               :
  generator :
                       "BGPower LPS";
  genversion
               :
                       "1.0";
                      "Thu Feb 21 15:26:21 2002";
               :
  date
  date
duration :
                      "1.201000e+05";
                      "ns";
  instance () {
```

```
net () {
    }
}
}
```

■ The following commands first resets the probability and transition count of net i\_0/n\_23. LPS then calculates the probability and transition count of the net i\_0/n\_23. Next, LPS writes the nonasserted probability and transition count for the nets of instance i\_0/i\_0. Because the probability and transition count of net i\_0/n\_23 was reset, net i\_0/n\_23 now appears in the net section.

```
> reset_switching_activity -net i_0/n_23
> write tcf -flat -type noassert -instance i 0/i 0 tcf file
```

This results in the following TCF file:

```
tcffile () {
                         "1.0";
   tcfversion
                :
               :
                        "BGPower LPS";
   generator
  genversion :
                        "1.0";
                :
                        "Thu Feb 21 15:28:40 2002";
  date
  duration
                :
                        "1.201000e+05";
   unit
                 :
                        "ns";
   instance () {
    net () {
        "i_0/n_23":
                           "0.252952 488";
   }
}
```

■ The following command writes only the probability and transition count for the nets of instance i\_0/i\_0 that were asserted. Net i\_0/n\_23 is not written out as it is no longer user asserted.

> write\_tcf -flat -type assert -instance i\_0/i\_0 tcf\_file

This results in the following TCF file:

```
tcffile () {
                         "1.0";
   tcfversion
                 :
                         "BGPower LPS";
   generator
                :
                         "1.0";
   genversion
                :
                        "Thu Feb 21 15:30:20 2002";
                :
  date
                        "1.201000e+05";
  duration
                :
   unit
                        "ns";
   instance () {
    net () {
                       :
        "i_0/out[0]"
                                 "0.518989 1020";
                        :
        "i_0/in1[0]"
                                 "0.506495
                                            527";
        "i_0/in2[0]"
                        :
                                 "0.499417 493";
     }
   }
}
```

■ The following command writes both the user asserted and tool calculated values for instance i\_0/i\_0 and all nets below it:

> write\_tcf -hier -instance i\_0/i\_0 tcf\_file

This results in the following TCF file:

```
tcffile () {
  tcfversion
                :
                        "1.0";
                        "BGPower LPS";
  generator
              :
  genversion :
                       "1.0";
               :
                       "Thu Feb 21 15:36:18 2002";
  date
               :
                       "1.201000e+05";
  duration
  unit
                :
                        "ns";
  instance() {
    instance("i 0") {
      net () {
        "out[0]"
                      :
                                "0.518989
                                          1020";
                                "0.252952 488";
        "n_23"
                      :
        "in1[0]"
                      :
                                "0.506495 527";
                                "0.499417 493";
        "in2[0]"
                      :
      }
    }
   }
}
```

The following command writes the user asserted and tool calculated values for instances  $i_0/i_0$  and  $i_0/i_1$  and all nets below them:

> write\_tcf -hier -instance {i\_0/i\_0 i\_0/i\_1} tcf\_file

This results in the following TCF file:

```
tcffile () {
  tcfversion
                :
                       "1.0";
              :
                       "BGPower LPS";
  generator
  genversion :
                       "1.0";
  date
               :
                       "Thu Feb 21 15:37:26 2002";
  duration
               :
                       "1.201000e+05";
               :
                       "ns";
  unit
  instance() {
    instance("i_0") {
      net () {
        "out[Ò]"
                     :
                                "0.518989 1020";
                      :
                                "0.252952 488";
        "n_23"
        "in1[0]"
                      :
                                "0.506495 527";
        "in2[0]"
                     :
                                "0.499417 493";
        "out[1]"
                     :
                                "0.499933 1510";
        "in2[1]"
                                "0.493589 488";
                      :
                      :
                                "0.502498 511";
        "in1[1]"
      }
    }
  }
}
```

The following command writes out the default TCF format which is hierarchical. Because no instance is specified, all the nets under the current module are reported:

> write\_tcf tcf\_file

This results in the following TCF file:

```
tcffile () {
  tcfversion : "1.0";
  generator : "BGPower LPS";
  genversion : "1.0";
```

```
date : "Thu Feb 21 15:38:36 2002";
duration : "1.201000e+05";
unit : "ns";
instance() {
    net () {
        "out[0]" : "0.518989 1020";
        "n_23" : "0.252952 488";
        "in1[0]" : "0.506495 527";
        "in2[0]" : "0.499417 493";
        "out[1]" : "0.499933 1510";
        "in2[1]" : "0.493589 488";
        "in1[1]" : "0.502498 511";
      }
  }
}
```

## **Related Information**

<u>read\_tcf</u>

}

<u>read\_tcf\_update</u>

# Low Power for Existing BuildGates Synthesis Commands

Some low power functions are built into existing BuildGates Synthesis commands. Please see the appropriate command documentation for more information about the low power functionality.

- <u>check library</u> -power
- <u>do build clock tree</u> -power
- <u>do\_build\_generic</u> -sleep\_mode
- <u>do optimize</u> -power
- <u>do xform optimize slack</u> -power
- report\_cell\_instance -power

# **PKS Commands**

This chapter provides a listing of the Cadence<sup>®</sup> physically knowledgeable synthesis (PKS) commands available with the PKS tool.

This chapter describes the following PKS commands:

- add physical connection on page 479
- <u>check\_design</u> on page 481
- <u>check libraries and design compatibility</u> on page 482
- <u>check\_library</u> on page 483
- <u>create blockage</u> on page 485
- <u>create layer usages table</u> on page 488
- <u>create\_physical\_cluster</u> on page 489
- <u>create\_physical\_instance</u> on page 492
- <u>create physical net</u> on page 494
- <u>create\_physical\_pin</u> on page 495
- <u>create placement area</u> on page 497
- <u>do extract lef model</u> on page 499
- <u>do\_extract\_route\_parasitics</u> on page 500
- <u>do groute</u> on page 501
- <u>do initialize floorplan</u> on page 508
- <u>do\_insert\_filler\_cells</u> on page 509
- do place on page 510
- do pull on page 518

- <u>do\_push</u> on page 521
- <u>do refine place</u> on page 524
- <u>do remove filler cells</u> on page 525
- <u>do\_remove\_route</u> on page 526
- <u>do reset floorplan</u> on page 527
- <u>do route</u> on page 528
- <u>do\_wroute</u> on page 535
- <u>do wroute eco</u> on page 544
- <u>do xform tcorr eco</u> on page 553
- <u>generate supply rails on rows</u> on page 554
- <u>get cluster</u> on page 555
- <u>get cluster contents</u> on page 556
- <u>get\_cluster\_names</u> on page 558
- <u>get cluster physical info</u> on page 559
- <u>get current cluster</u> on page 560
- get current congestion on page 561
- get current utilization on page 562
- <u>get ground net</u> on page 563
- <u>get library layer\_offset</u> on page 564
- <u>get logic 0 net</u> on page 565
- <u>get logic 1 net</u> on page 566
- <u>get\_min\_porosity\_for\_over\_block\_routing</u> on page 567
- <u>get min wire length</u> on page 568
- <u>get physical info</u> on page 569
- <u>get pin location</u> on page 572
- <u>get power net</u> on page 573
- get route availability on page 574

- <u>get special netpins</u> on page 575
- <u>get steiner capacitance</u> on page 576
- get steiner channel width on page 577
- <u>get\_steiner\_length</u> on page 578
- <u>get steiner resistance</u> on page 579
- modify physical cluster on page 580
- pks\_shell on page 583
- prune routes on page 586
- <u>read cap table</u> on page 587
- read cap table update on page 589
- <u>read change file</u> on page 590
- <u>read\_def</u> on page 591
- <u>read\_gns</u> on page 594
- <u>read layer usages</u> on page 595
- <u>read lef</u> on page 596
- <u>read\_lef\_update</u> on page 598
- <u>read pdef</u> on page 600
- <u>read wdb</u> on page 602
- <u>remove\_blockage</u> on page 603
- remove physical cluster on page 604
- remove physical connection on page 605
- <u>remove physical instance</u> on page 606
- <u>remove physical net</u> on page 607
- remove physical pin on page 608
- <u>remove\_placement\_area</u> on page 609
- <u>remove supply rails on rows</u> on page 610
- <u>report block halo</u> on page 611

- <u>report\_blockage</u> on page 612
- <u>report cluster</u> on page 613
- <u>report floorplan parameters</u> on page 614
- <u>report\_grow\_parameters</u> on page 616
- <u>report net distribution</u> on page 617
- <u>report net rc</u> on page 618
- <u>report\_overlap</u> on page 620
- <u>report physical library</u> on page 621
- <u>report placement area</u> on page 622
- <u>report preroute parameters</u> on page 623
- <u>report supply rails on rows</u> on page 624
- <u>report unplaced</u> on page 625
- <u>reset\_dont\_move</u> on page 626
- <u>reset net physical attribute</u> on page 627
- <u>set block halo</u> on page 629
- <u>set block rc rule</u> on page 630
- <u>set current cluster</u> on page 632
- <u>set default core site</u> on page 633
- <u>set\_dont\_move</u> on page 634
- <u>set floorplan parameters</u> on page 635
- <u>set ground net</u> on page 639
- <u>set grow anchors</u> on page 640
- <u>set grow parameters</u> on page 642
- <u>set layer usages table</u> on page 644
- <u>set\_lef\_multiplier</u> on page 646
- <u>set library layer offset</u> on page 648
- <u>set logic 0 net</u> on page 649

- <u>set logic 1 net</u> on page 650
- set min porosity for over block routing on page 651
- <u>set min RC multipliers</u> on page 653
- <u>set min wire length</u> on page 654
- <u>set net physical attribute</u> on page 655
- <u>set physical info</u> on page 659
- <u>set physical instance</u> on page 661
- <u>set pin location</u> on page 662
- <u>set pin status</u> on page 664
- <u>set power net</u> on page 666
- <u>set power stripe spec</u> on page 667
- <u>set preroute parameters</u> on page 669
- <u>set\_route\_availability</u> on page 671
- <u>set special netpin</u> on page 672
- <u>set steiner channel width</u> on page 673
- <u>set\_steiner\_mode</u> on page 674
- <u>set supply rails on rows</u> on page 676
- <u>vbg pks display ilist</u> on page 677
- <u>vbg\_pks\_group\_delete</u> on page 678
- <u>vbg pks group display</u> on page 679
- <u>write def</u> on page 680
- <u>write gns</u> on page 682
- <u>write gns lib</u> on page 684
- <u>write layer usages</u> on page 685
- <u>write pdef</u> on page 686
- write wdb on page 688

# add\_physical\_connection

add\_physical\_connection -net net\_name\_or\_id [-cluster\_pin\_cluster\_pin\_list]
 [-connectivity\_rule list\_of\_connectivity\_rules]
 [-physical\_pin\_physical\_pin\_list] [-type type]

Connects true physical pins. If any pin is not found, no connection is made. In other words, this command does not create pins. It is better to define the pins on subclusters first before defining at the parent clusters. No connection is made to a logical pin (one that already exists in the logical netlist). This is done using logical level commands such as add\_netconn.

#### **Options and Arguments**

-cluster\_pin list\_of\_cpinnames Defines the list of cluster pin names in a current cluster or a direct soft-block sub-cluster. -connectivity\_rule list\_of\_connectivity\_rules Specifies a list of instance/pin combinations that need to be connected to this physical net. The syntax is a list of strings separated by white space. Each string is of the form "INSTNAME PINNAME" with a space between the names, or of the form "\* *PINNAME*". The only wildcard supported is "\*". No partial wildcards (for instance, {dir1/hier/\* pin1}) are allowed. Connectivity rules are not inherited by *push* and *pull* operations. -net physical\_netname Specifies the name of a physical net in the current cluster context. -physical\_pin list\_of\_pinnames Defines a set of specific physical cell instance pins to which the physical net is connected to. The tool matches the pin names (such as A/B/C) with that of a physical instance pin name in the current cluster. A match is made if there is a pin C for a physical instance of name A/B in the current cluster. If no match is found, it looks for a logical instance with the hierarchy name A/B in the top context containing a physical pin C. -type {special | no\_special} Specifies which router will be used to connect the pins. Selecting special uses the special router to connect all pins, which will

appear in the SPECIAL NETS section. Selecting no\_special uses wroute to connect all pins. Default: special

## Examples

The following commands state that if root cluster R contains a soft cluster C, and a power net VDD needs to be connected to top-level port VDD (assuming that the power port on C that receives the same net is called VDD!).

```
set_current_cluster /C
create_physical_pin VDD!
create_physical_net VDD -use power
add_physical_connection -net VDD -cluster_pin VDD! -connectivity_rule {"*VDD"}
set_current_cluster /
create_physical_pin VDD
create_physical_net -use power VDD
add_physical_connection -net VDD -cluster_pin {VDD C/Vdd!} -connectivity_rule
{"*VDD"}
```

## **Related Information**

create physical net

create\_physical\_pin

set current cluster

# check\_design

check\_design filename

Reports the cells of the design that don't exist in the physical library or have different pin names.

## **Options and Arguments**

filename

Specifies the name of the file that stores the report.

## **Related Information**

check libraries and design compatibility

check\_library

# check\_libraries\_and\_design\_compatibility

check\_libraries\_and\_design\_compatibility

Checks the compatibility between physical and logical libraries to anticipate possible stoppages during optimization. It also checks the compatibility between the physical libraries and the design and pin name inconsistencies. The return values are TCL\_ERROR and TCL\_OK. The TCL\_ERROR value states that there is an incompatibility between libraries and the design and optimization will stop. The TCL\_OK value states that the libraries and design are compatible and optimization will proceed.

#### **Related Information**

check\_design

check\_library

# check\_library

check\_library [-logical] [-physical] [-power] filename

Verifies the different properties associated with the design libraries, such as the power properties and the compatibility between the physical and logical libraries. This command also checks to see if pin names are the same.

## **Options and Arguments**

| filename  | Specifies the name of the file that stores the report.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -logical  | Reports the cells of the logical libraries that don't exist in the physical libraries.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| -physical | Reports the cells of the physical libraries that don't exist in the logical libraries and reports pin name problems.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -power    | Identifies libraries that contain power information.<br>If you specify check_library -power filename, the<br>command checks whether the cell has a power model and<br>reports the names of cells that do not have a power model.<br>Names are printed to the screen if a filename is not specified.<br>You need an LPS license to run the command with this option.<br>If you specify check_library -power -logical<br>-physical filename, the command checks for a power<br>model and then continue with a check for logical and physical<br>models. Results are printed into the specified file. You need both<br>an LPS and PKS license to run the command this way. |

#### Examples

check\_library -logical library\_log.rpt
check\_library -physical library\_phy.rpt
check\_library library.rpt

## **Related Information**

check\_design

check libraries and design compatibility

# create\_blockage

```
create_blockage [-bbox {lx ly ux uy}] [-layer list_of_layernames]
    [-instance name_or_id]
    [-type {placement_only | routing_only | soft_block | all}]
```

Creates a user-defined blockage in a specified layer or in all layers.

**Note:** PKS may ignore a blockage on a layer not specified by the set\_preroute\_parameters command. PKS may also ignore a blockage if it is smaller
than the minimum size specified by the set\_preroute\_parameters command. However,
these blockages will still be considered during global and final routing steps.

#### **Options and Arguments**

-bbox {lx ly ux uy}

Describes the shape and location of the blockage using the four coordinates  $\{lx \ ly \ ux \ uy\}$ .

-instance name\_or\_id

Attaches the blockage to any instance of CLASS BLOCK in the design (this needs to be an instance in the logical netlist). However, it has effect only when the block instance is placed. It has no effect otherwise. When the <code>-instance</code> option is specified in conjunction with a <code>-bbox</code> option, then the bbox is interpreted as applied to that portion of the instance in the normal 'N' configuration. Multiple such blockages can be applied to a particular instance to simulate a non-rectangular blockage pattern on an instance. If the <code>-bbox</code> option is not specified then by default, the blockage will be assumed to cover the whole instance.

**NOTE**: The bbox is relative to the specification of the block as in LEF. The translation to the die (absolute) coordinates will happen at the time of blockage usage.

In this context, it can be viewed as similar to the *Overlap Layer* definition in LEF; but can be done dynamically during the flow and also applied to only one instance of a macro as opposed to statically as with the Overlap Layer and LEF approach. These blockages will be used by the tool in addition to the LEF Overlap layer obstacles for the macro.

| -layer list_of_layer | <i>Creates</i><br>Creates blockage only on the layers specified. This is an optional<br>argument. If not specified, it will create a blockage at that location<br>on all routing layers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -type {placement_onl | y   routing_only   soft_block   all}<br>Identifies the type of blockage you are creating. The blockage<br>you create normally applies to both placement as well as routing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                      | placement_only<br>Specifies the blockage will only affect placement and will not<br>cause any routing blockages. This could be useful in known<br>congestion hotspots, like around macro block corners, to prevent<br>the placer from adding cells in those corners that would add to<br>congestion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                      | <b>all</b><br>Specifies each blockage is applied for both placement and<br>routing considerations based on the preroute parameters. If the<br>-type option is not specified, all is used, and the blockage<br>applies to both placement and routing.<br><i>Default</i> : all                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                      | Advanced Options                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                      | <pre>routing_only<br/>Specifies, the blockage will only affect routing and will not cause<br/>any placement blockages. A routing_only blockage can be<br/>used to add blockages for the Steiner router in PKS. As<br/>mentioned above, this blockage will not be seen by the global or<br/>final router and will not be output in the .def or .wdb file. This<br/>option can be used to make the Steiner router avoid certain<br/>regions without creating a real blockage that will be seen by the<br/>router. This kind of control is needed only for very specific<br/>situations and as such should be used with care. If the -layer<br/>option is given with a routing_only blockage, it needs to be<br/>consistent with the set_preroute_parmeters command<br/>settings to be considered.</pre> |

## $soft_block$

Creates a blockage that represents an external soft block to be handled appropriately during grow. When replacing pins and hard macros they will not overlap the soft-block boundaries in the cluster being grown. This requires that you specify the above information for each block.

Any top-level blockage that is not of soft\_block type is not included in the overlap check. It is to be expected that hard blocks may overlap with preroutes. This option is only useful in dynamic floorplanning situations.

## Examples

■ The following command creates a blockage on all layers for a specified bbox:

create\_blockage {10 20 30 30}

**Note:** This by definition causes both a placement and a routing blockage for that region, resulting in modeling keepouts.

■ The following command creates a blockage only on metal1:

create\_blockage {10 20 30 30} metal1

**Note:** Depending on the place or route blockage layers specified using the set\_preroute\_parameters command, this may or may not define a place or route blockage.

## **Related Information**

remove blockage

report blockage

# create\_layer\_usages\_table

create\_layer\_usages\_table filename [-number\_intervals int]

Creates a layer usages table for a routed design.

#### **Options and Arguments**

filename Name of output file.

-number\_intervals int

Number of intervals you want in the layer usages table.

#### **Additional Information**

read layer usages

set layer usages table

set net physical attribute

write layer usages

# create\_physical\_cluster

```
create_physical_cluster -name cluster_name
  [-allow_place_overlap {true | false}]
  [-allow_route_overlap {true | false}]
  {[-bbox {lx ly ux uy}] | [-utilization float] [-aspect_ratio float] |
  [-width float] [-height float]} [list_of_inst_or_ids]
  [-relative_cluster cluster_name] [-type {soft_block | region}]
```

Creates a sub-cluster of the specified name at the current cluster level. If the cluster already exists, the command will error out. After creating the physical cluster, you can use the – modify\_physical\_cluster command to place the cluster and stretch it appropriately.

#### **Options and Arguments**

```
-allow_place_overlap {true | false}
                          Allows the parent cluster to place over any placeable areas in the
                           newly created cluster. Note that it does not place over any
                          overlap layer obstacles created on the cluster. If false is
                          selected, the newly created cluster is completely blocked for all
                           placement at the parent level, even if overlap blockages are
                           defined.
                           Default: false
-allow_route_overlap {true | false}
                           Allows the parent cluster to route over any routable areas in the
                           newly created cluster. Note that it does not route over any
                           overlap layer obstacles created on the cluster. If false is
                           selected, the newly created cluster is completely blocked for all
                           routing at the parent level, even if overlap blockages are defined.
                           Default: false
-bbox {lx ly ux uy} | -utilization float -aspect_ratio float |
                           -width float -height float
                           You can use one of three methods (below) to define the initial
                           starting shape for the physical cluster.
                           -bbox \{lx \ ly \ ux \ uy\}
                           Describes the shape and location of the cluster using the four
                           coordinates \{1x \ 1y \ ux \ uy\}. All coordinates are assumed to
                          be absolute with respect to UNPLACEDTOP (except if
                           -relative_cluster is specified).
```

-utilization float -aspect\_ratio float Estimates the appropriate bounding box by specifying the desired initial -utilization (0-100) and -aspect\_ratio (>0). For this to be useful, the cluster should also be associated with instances. The placement information (if applicable) of any contained instances will be ignored. The available row area is estimated based on row spacing rules of the containing soft cluster. No estimation blockages are considered.

-width float -height float Specifies the starting shape using the -width and -height options.

**Note**: If no options are specified, the value of 80% utilization and an aspect ratio of 1 will be used to estimate the initial starting shape. If no cells are assigned, then the default bbox size of 1x1 will be used. *Default*: 80%

list\_of\_inst\_or\_ids

Specifies the name of the instances or IDs.

| -name cluster_name          | Specifies the name of the subcluster at the current cluster level.                                                                                                                                                                                   |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -relative_cluster <i>cl</i> | <pre>uster_name Treats the -bbox coordinates as relative to that cluster. Note that an error will result if the cluster specified by -relative_cluster is not a parent cluster of the current cluster and also a child cluster of UNPLACEDTOP.</pre> |
| -type {soft_block           | region}<br>Defines the type of cluster you want to create. Note that if you<br>request a -type soft_block and more than one or no<br>hierarchical instance is specified, the command will error out.                                                 |

## Example

The following command creates a physical cluster C2 and allows for placement overlaps: create\_physical\_cluster -name C2 -allow\_place\_overlap true

# **Related Information**

modify physical cluster

# create\_physical\_instance

```
create_physical_instance instance_name [-location location]
  [-macro macroname] [-orient {N | S | W | E | FE | FW | FS | FN}]
  [-state {placed | fixed | unplaced | cover}]
  [-type {spare | filler | core | cover}]
```

Creates a physical instance in the set\_current\_cluster context. The macro must exist in the LEF file. If not, an error is given. Note that this will always create an instance in the current cluster even if the name is intended to be physically hierarchical. The *name* must not clash with the logical instance name (or physical instance name) at the containing soft-block cluster level.

**Note:** *name* is non-hierarchical so you need to be in the appropriate set\_current\_cluster context prior to issuing this command.

#### **Options and Arguments**

| -location <i>loc</i>       |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Specifies the location where the physical instance will be placed.<br>When specified, automatically changes the state from unplaced<br>(if applicable) to placed. If -location is not specified, the<br>physical instance will be in an unplaced state and will not be<br>accounted for in LUT calculations. Location coordinates are<br>absolute in the context of UNPLACED_TOP.<br>Note that you must type the curly braces in the command syntax. |
| -macro macroname           | Specifies the name of the macro.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| -orient {N $ $ S $ $ W $ $ | E   FE   FW   FS   FN}<br>Specifies the orientation of the physical instance.                                                                                                                                                                                                                                                                                                                                                                        |
| -state {placed   fixe      | ed   unplaced   cover}<br>Identifies the state of the instance as placed, fixed,<br>unplaced, or cover. Specifying the state as fixed or cover<br>results in an error if the physical instance is not currently in a<br>placed state, or the -location option is not specified at the<br>same time.                                                                                                                                                  |
| -type {spare   fill        | er   core   cover}<br><b>Specifies the macro type</b> .                                                                                                                                                                                                                                                                                                                                                                                              |

## Example

The following command creates a physical instance in the current cluster at the absolute location (200, 300) assuming there are no unplaced clusters other than the top:

create\_physical\_instance -macro ANDX2 -location {200 300}

# create\_physical\_net

Creates specially-routed nets, such as VDD and GND. It can also be used for physical only Wrouted nets.

## **Options and Arguments**

net\_name
Specifies the non-hierarchical name to be associated with the
physical net. The name must not clash with a logical net or
another physical net in the same cluster.
-use {power | ground | clock | signal | analog | tieoff}
Specifies the type of physical net you are creating.

#### Example

The following command creates physical net VDD and designates it as a power net:

create\_physical\_net VDD -use power

# create\_physical\_pin

```
create_physical_pin pin_name [-layer layername] [-bbox bounding_box]
    [-location location] [-size size][-index pin_index] [-side side_char]
    [-state placement_state] [-type {special | no_special}]
    [-use {power | ground | clock | signal | analog | tieoff}]
```

Creates a pin of specified *name* in the current cluster. This command can only be applied on a soft cluster. The name of the pin cannot clash with any logical pin for that soft cluster. It is also not interpreted for hierarchy.

#### **Options and Arguments**

| -bbox bounding_box     | Defines the geometry for the pin.                                                                                                                                                                                                                                   |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -index pin_index       | Defines the relative index for the pin on the side it has been assigned. Accepts any <i>number</i> value greater than 1. This is used in conjunction with the -side option. Cannot be used in conjunction with the -location or -bbox options (except during grow). |
| -layer layername       | Defines the layer of where the pin is placed.                                                                                                                                                                                                                       |
| name                   | Specifies the name of the pin your creating.                                                                                                                                                                                                                        |
| -side <i>side_char</i> | Defines the side that the pin is assigned. Can be one of the following: {left   right   bottom   top}. This is used in conjunction with the -index option. Cannot be used in conjunction with the -location or -bbox options (except during grow).                  |
| -state placement_st    | ate<br>Defines the state that the pin is assigned. Can be one of the<br>following: {fixed   placed   cover   unplaced}.                                                                                                                                             |
|                        | Default: unplaced                                                                                                                                                                                                                                                   |

Specifies the type of physical pin you are creating.

## Example

The following command creates pin A on layer M2 as an unplaced signal pin positioned as pin 2 on the top side:

create\_physical\_pin A -layer M2 -index 2 -side top -use signal -state unplaced

#### **Related Information**

get pin location

## create\_placement\_area

create\_placement\_area [-name name] lx ly ux uy

Creates a named placement area. The placement areas work in conjunction with DEF rows. Use the placement areas to limit the region where you want the cells to be placed. Useful for:

Low utilization design

Such as forcing QP to a cluster in the middle.

- Part of a semi-hierarchical flow
- Avoiding thin strips of row area (around macros)

The command generates an error if:

- The specified box intersects the chip die box.
- The specified name already exists.

The command generates a warning if:

- The specified box intersects another placement area.
- The specified box is adjusted to account for the rows along the edges. Supports both horizontal and vertical rows.

#### **Options and Arguments**

| lx                | The lower left x coordinate.    |
|-------------------|---------------------------------|
| ly                | The lower left $y$ coordinate.  |
| -name <i>name</i> | Name of the placement area.     |
| ux                | The upper right x coordinate.   |
| uy                | The upper right $y$ coordinate. |

## Example

create\_placement\_area -name al 100. 200. 1000. 1100.

### **Related Information**

remove placement area

report placement area

# do\_extract\_lef\_model

do\_extract\_lef\_model [-all | -cluster list\_of\_clusters] -file filename

Passes a simplified LEF model of all soft-block sub-clusters to Qplace and Wroute. The LEF file contains basic abstracts. Information contains size, soft-block cluster pins, and route blockages (at the level of the internal blockage maps) if the allow\_overlap argument is true. If not, a block on all routing layers is introduced. For hierarchical designs, use this command to create a LEF file for each soft-block cluster if it is being written to a DEF file and read into an external tool, such as for final route. This is because the DEF file will instantiate any soft-block sub-clusters as LEF instances.

Note: You can only model soft-block clusters. Cluster names can be hierarchical.

#### **Options and Arguments**

```
-all | -cluster {list_of_clusters}
Creates a macro definition for each soft block in the current top-
timing module (only current module soft blocks, no child soft
blocks). Note that -all creates a macro definition of all soft
blocks and -cluster creates a macro definition of all soft
blocks specified in list_of_clusters. The cluster names
that you specify must be with respect to the current top-timing
module. Use the do_push command if you want to get a macro
listing of the child soft blocks.
```

#### Example

The following command creates a LEF macro abstract for SOFT\_BLK1 and SOFT\_BLK2 clusters as specified in -cluster {list\_of\_clusters}. The macro name will be the module name of the instance associated with the soft-block cluster:

do\_extract\_lef\_model -cluster {"SOFT\_BLK1", "SOFT\_BLK2"} -file my.lef

## do\_extract\_route\_parasitics

do\_extract\_route\_parasitics wdb\_name

**Note:** This command is being replaced by the read\_wdb -rspf\_only command. This command is still available but will become obsolete in the next full release of the software.

Reads in a Wroute database that contains either global and or detailed routing of the design, extracts the parasitics from the routing segments, and annotates them to the nets in the design for timing analysis use. After extraction, the routing information is deleted.

The Wroute database contains physical library information (LEF), design netlist information (DEF), and global and or detailed routing information. The Wroute database has to be consistent with ADB or in-core design data at the time of extraction. Otherwise, parasitics cannot be extracted and annotated correctly. As an example, the ADB saved right before or after do\_route is consistent with the WDB that is saved at the end of do\_route. If one of them has been changed after saving, they can potentially become inconsistent.

## **Options and Arguments**

wdb\_name

Specifies the name of the Wroute database.

## **Related Information**

read\_wdb

## do\_groute

do\_groute -input\_db\_name filename [-assign\_routing\_direction {true | false}] [-def name list of file names] [-def out name filename] [-discourage\_planar\_routing {true | false}] [-follow\_pins] [-force {true | false}] [-qqrid max size 16] [-qqrid min size 5] [-qqrid mode {user | align | uniform}] [-qqrid opt size 10] [-groute\_num\_opt\_pass num] [-ignore\_unplaced\_component {true | false}] [-no\_follow\_pins] [-output\_db\_name filename] [-output\_full\_def {true | false}] [-pin\_access\_compat\_mode {true | false}] [-processors] [-region\_relax\_percent] [-route\_area {lx|ly|ux|uy}] [-route\_bottom\_layer\_limit value] [-route\_on\_grid\_only {true | false}] [-route pin access compat mode {auto | normal | offGrid | upViaEnclosure | upVia | upViaReserve | narrowPin}] [-route\_select\_net [~] list\_of\_net\_names] [-route\_select\_net\_first {true | false}] [-route\_select\_net\_layer\_range {layer:layer | layer}] [-route soft top layer limit {true | false}] [-route\_stripe\_center\_connect {true | false}] [-route\_stripe\_follow\_pin\_only {true | false}] [-route\_top\_layer\_limit value] [-route\_use\_range\_rule obstruction | pin | obstruction+pin] [-straighten\_net net\_name\_list] [-timing\_driven {true | false}] [-timing\_net\_percentage\_delta [0 to 100]] [-use\_auto\_ggrid {true | false}] [-use max xy spacing {true | false}] [-version]

Starts Wroute in standalone mode to do a global routing on the design and saves the global routing information in the Wroute database. See <u>do wroute</u> on page 535 for more information.

**Note:** You must specify the path to the wroute executable, either by including it in your UNIX search path, or setting the <u>pks wroute exe</u> global.

## **Options and Arguments**

```
-assign_routing_direction {true | false}
```

Tells the router, when true, to automatically assign routing directions in the channels between blocks to take advantage of available routing tracks. This variable is useful, for example, if channel congestion between blocks occurs because the preferred routing tracks are perpendicular to the orientation of the channel. In this case, this variable lets the router reassign the preferred routing direction in the channel. *Default*: false

```
-def_name list_of_file_names
```

Specifies the name of the DEF file(s) that Wroute reads.

| -def_out_name filename |                                                                                                                                                                                                                                                                                                             |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | Specifies the name of the output DEF file that Wroute writes to.                                                                                                                                                                                                                                            |
|                        | <b>Note</b> : This option is primarily used to change the output DEF <i>filename</i> . If this option is not used, the DEF is automatically written to the following default DEF filename: wdb_name.def.                                                                                                    |
| -discourage_planar_r   | outing {true   false}<br>Eliminates the use of planar routing over blocks<br><i>Default</i> : false                                                                                                                                                                                                         |
| -follow_pins           | Removes existing power rails (if applicable) and generates new ones.                                                                                                                                                                                                                                        |
| -force {true   false   | 1                                                                                                                                                                                                                                                                                                           |
| -iorce (true   faise   | Stops global routing, if false, when more than 90% of the nets<br>are final routed. If true, will continue global routing while<br>preserving all final routes. Note that global routing will continue<br>and also issue a warning when < 90% of the design is final<br>routed.                             |
| -ggrid_max_size 16     | Sets the maximum gcell grid size in tracks. ggrid size has a                                                                                                                                                                                                                                                |
|                        | significant effect on QOR (quality of results). It is recommended<br>you use a smaller <i>ggrid</i> size unless your design has a large<br>number of obstacles or is memory constrained. See<br>-ggrid_min_size and -ggrid_opt_size for more options.                                                       |
| -ggrid_min_size 5      |                                                                                                                                                                                                                                                                                                             |
|                        | Sets the minimum gcell grid size in tracks. <i>ggrid</i> size has a significant effect on QOR (quality of results). It is recommended you use this <i>ggrid</i> size unless your design has a large number of obstacles or is memory constrained. See -ggrid_max_size and -ggrid_opt_size for more options. |
| -ggrid_mode {align     | uniform   user}                                                                                                                                                                                                                                                                                             |
|                        | Sets the global routing grid generation mode. The global routing grid partitions the routing portion of a standard cell design into rectangles called gcells. The arguments for this variable set the grid as follows:                                                                                      |

Generates a global routing grid that aligns with the channels and macro block boundaries in your design. This argument improves routing quality for block-based designs because, by aligning the grids, the global router can route more effectively in empty gcells in the channel area.

#### uniform

Generates a uniform global routing grid.

user

Uses the global routing grid defined in the DEF file. *Default*: user

-ggrid\_opt\_size 10

Sets the optimal gcell grid size in tracks. *ggrid* size has a significant effect on QOR (quality of results). It is recommended you use a smaller *ggrid* size unless your design has a large number of obstacles or is memory constrained. See -ggrid\_max\_size and -ggrid\_min\_size for more options.

-groute\_num\_opt\_pass num

Sets the number of optimization passes in groute, specified by the value num. If no value is given for num, the default value is used.

Default: Auto tuned.

-input\_db\_name filename

Specifies the database directory.

-no\_follow\_pins

Removes existing power rails (if applicable).

-output\_db\_name filename

Specifies the router's output database. The database is in binary form. To save your design into a router database without running routing, specify the database filename with this option and set all the routing variables to false. The router will save your design into database format without making any routing passes.

|                      | <b>Note</b> : This option is primarily used to change the output database <i>filename</i> . If this option is not used, the database is automatically written to the following default output database filename: design_name.wdb. This option is useful, for example, if you are routing several different floorplans or placements. You can use this option to save each database that the router creates to a different routing binary. Then you can load the best results from the saved database. |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -output_full_def {tr | rue   false}<br>Outputs a full DEF file, when true, instead of a DEF file<br>containing only placement information.<br><i>Default</i> : true                                                                                                                                                                                                                                                                                                                                                          |
| -pin_access_compat_m | node {true   false}<br>Enables pin access compatibility mode.<br><i>Default</i> : false                                                                                                                                                                                                                                                                                                                                                                                                               |
| -processors          | Specifies the number of processors to use while running global routing. The maximum is 4. <i>Default</i> : 1                                                                                                                                                                                                                                                                                                                                                                                          |
| -region_relax_percer | Controls group and region constraints. Constraints are ignored if the percent is negative. Takes values 0.0 - 1.0. <i>Default</i> : 0                                                                                                                                                                                                                                                                                                                                                                 |
| -route_area {lx ly u | Routes the specified area. The coordinates for the area are in database units. If no arguments are given, the full chip is routed.                                                                                                                                                                                                                                                                                                                                                                    |
| -route_bottom_layer_ | Limit [0]<br>Limits the bottom routing layer to the specified value. A value of<br>0 disables this option. Routing below the specified layer is<br>allowed, but at a very high cost. Thus, the wire length below the<br>specified layer is kept short. For example, in a design with six<br>layers, a value of 4 requests that the router start routing at the<br>fourth layer.                                                                                                                       |

| -route_on_grid_only  | {true   false}<br>Routes to the on-grid geometries of port only.<br><i>Default</i> : false                                                                                                                                                                                                              |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -route_pin_access_co | <pre>ompat_mode {auto   normal   offGrid   upViaEnclosure   upVia   upViaReserve   narrowPin} Sets the option for processing pin geometries. The arguments for this variable are:</pre>                                                                                                                 |
|                      | auto<br>Processes the pin geometries as it did in previous versions of the<br>software. This is the default value for this environment variable.                                                                                                                                                        |
|                      | <b>normal</b><br>Processes the pin geometries as it did in previous versions of the<br>software. This is the default value for this environment variable.                                                                                                                                               |
|                      | offGrid<br>Shrinks the pin geometries by one-half the wire width. The<br>reminder of the pin geometry is valid for the router to make a<br>connection using a regular wire. The router checks the<br>connection using a one-half wire width plus spacing rule.                                          |
|                      | <b>upViaEnclosure</b><br>Shrinks the pin geometries by one-half a via width. The<br>remainder of the pin geometries is valid for the router to make a<br>connection using a via that is fully enclosed by the pin. The router<br>checks the connection using a one-half via width plus spacing<br>rule. |
|                      | upVia<br>Does not shrink the pin, so the full size of the pin geometry is<br>valid for the router to make a connection using a via. The router<br>checks the connection using a one-half via width plus spacing<br>rule.                                                                                |
|                      | <b>upViaReserve</b><br>Shrinks the pin geometries by one-half the wire width. The<br>remainder of the pin geometries is valid for making a connection<br>using a via. The router checks the connection using a one-half<br>via width plus spacing rule.                                                 |

Does not shrink the pin geometries. The full size of the pin geometries is valid for making a connection using a regular wire. The router checks the connection using a one-half via width plus spacing rule.

-route\_select\_net [~] *list\_of\_net\_names* where ~ represents negation. Using ~ routes all but the specified nets. No ~ routes only the specified nets.

-route\_select\_net\_first {true | false}
 Routes the selected nets first, followed by all other nets.
 Default: false

-route\_select\_net\_layer\_range {layer:layer | layer} Routes the selected nets on the specified layer range.

-route\_soft\_top\_layer\_limit {true | false}

Specifies that the top routing limit is soft, if set to true. *Default*: false

-route\_stripe\_center\_connect {true | false}

Connects to the center of the stripe only. Does not connect to POWER and GROUND pins. *Default*: false

-route\_stripe\_follow\_pin\_only {true | false} Connects to the follow pin stripe only. Default: false

-route\_top\_layer\_limit [*value*] Limits the top routing layer to the specified value. A value of 0 disables this argument. A value of n means the placer uses routing resources from layer 1 to layer n. Default: 0

-route\_use\_range\_rule (obstruction | pin | obstruction+pin)
Specifies the clearance distance used for spacing rule checks
using one or more of: pin, obstruction, or obstruction+pin.
Default: obstruction+pin

| -straighten_net <i>net</i> _ | _name_list<br>Straightens the selected nets specified by net_name_list.<br>Default: [ ]                                                                                                                                                                                                                                                                                                                        |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -timing_driven {true         | <ul> <li>false}</li> <li>Turns on timing-driven routing when set to true. To perform timing-driven routing, the router decides the order in which to route the constrained nets based on their timing criticality, and routes them accordingly. The most timing-critical nets are routed first to achieve the shortest routes.</li> </ul>                                                                      |
|                              | The router modifies its routing priorities as appropriate during the routing process. For example, if the router places a net low on the priority list to start, but later realizes that the net must be routed more directly to meet timing constraints, it will reroute the net. The router also considers the layer RC values when determining how to route the timing-critical nets. <i>Default</i> : true |
| -timing_net_percenta         | nge_delta [0 to 100]<br>Specifies the percentage change in the timing-critical nets.<br>Default: 0                                                                                                                                                                                                                                                                                                             |
| -use_auto_ggrid {tru         | ue   false}<br>Uses Wroute's default auto tune settings, if set to true. If<br>false, uses the PKS smaller ggrid size.<br>Default: true                                                                                                                                                                                                                                                                        |
| -use_max_xy_spacing          | ${true   false}$<br>Uses the maximum values of x and y for spacing checks.<br>Default: false                                                                                                                                                                                                                                                                                                                   |
| -version                     | Checks the version number and build information for routing.<br>This option only works after a gate-level netlist is loaded.                                                                                                                                                                                                                                                                                   |

# do\_initialize\_floorplan

do\_initialize\_floorplan

Initializes the die box and other floorplan parameters based on the floorplan parameters set using the set\_floorplan\_parameters command or using the read\_def or read\_pdef commands. This command also initializes the pin positions based on the pin locations from read\_def or read\_pdef commands, or from the pin indices set by the user.

#### **Related Information**

report floorplan parameters

## do\_insert\_filler\_cells

do\_insert\_filler\_cells -macro {list\_of\_filler\_cell\_macro\_names}
 [-prefix string] [-area {lx ly ux uy}]

Inserts filler cells in empty regions of rows in a legally placed design. If the design is not legally placed, an error is generated.

#### **Options and Arguments**

```
-area {lx ly ux uy)
```

Specifies the area where filler cells are to be placed. The area is a rectangle where 1x and 1y represent the x and y coordinates of the lower left corner of the rectangle, and ux and uy represent the x and the y coordinates of the upper right corner. Coordinate values are in microns.

-macro {list\_of\_filler\_cell\_macro\_names} Creates a list of LEF macro cells that can be used as filler cells. You must type the curly braces when providing the list of macros.

Specifies the prefix to the filler cell name that will be added. *Default*: PKSFILLER\_

## Example

The following command uses the ANDX2 macro as a filler cell:

do\_insert\_filler\_cells -macro {ANDX2}

## **Related Information**

do remove filler cells

## do\_place

```
do_place [-area_util {1 b r t util}] [-block {true | false}]
     [-clock_buffer_site site] [-cong_max_util util]
     [-cong_mode2 {true | false}] [-cut_ratio float]
     [-def name list of file names] [-def out name file name]
     [-eco {true | false}] [-fix_placed_cell {true | false}] [-batch_mode]
     [-free_track_percent_1 0-1] [-free_track_percent_2 0-1]
     [-free_track_percent_3 0-1] [-free_track_percent_4 0-1]
     [-free_track_percent_5 0-1] [-free_track_percent_6 0-1]
     [-free_track_percent_7 0-1] [-free_track_percent_8 0-1]
     [-free_track_percent_9 0-1] [-groute_analysis report_filename]
     [-groute num opt pass num] [-incremental {true | false}]
     [-incr_size size] [-llc_ignore_layer_1 {true | false}]
     [-llc_ignore_layer_2 {true | false}] [-llc_ignore_layer_3 {true |
                                                                       false}]
     [-llc_ignore_layer_4 {true | false}] [-llc_ignore_layer_5 {true |
                                                                       false}]
     [-llc ignore layer 6 {true | false}] [-llc ignore layer 7 {true |
                                                                       false}]
     [-llc_ignore_layer_8 {true | false}] [-llc_ignore_layer_9 {true | false}]
     [-llc_prewire_keep_out {true | false}] [-mega_cell_keep_out_x distance]
     [-mega_cell_keep_out_y distance]
     [-net_weight "tcl_or_net_name_list integer_weight"]
     [-output_full_def {true | false}] [-pin {concurrent|refine}]
     [-pin_layer {left|bottom|right|top} layer_name]
     [-pin same side \{true | false\}] [-place area \{l b r t\}]
     [-place_io_net_weight [1 to 100]] [-region_exclusive {true | false}]
     [-region_exclusive_name name1 name2 ...] [-region_relax_percent [0 to 1]]
     [-route_bottom_layer_limit [0 to 9]] [-route_top_layer_limit [0 to 9]]
     [-scan reorder] [-spare cell cell name list] [-timing driven {true | false}]
     [-timing io net weight [1 to 10]] [-timing weight weight]
     [-use_region {true | false}] [-version]
```

Creates the initial placement of the design.

#### **Options and Arguments**

```
-area_util 1 b r t util
Defines the row utilization for an area (1 = left, b = bottom,
r = right, t = top, util = utilization}. The 1, b, r, and t
arguments are region coordinates, in database units (integer).
Utilization is defined as the ratio of the instance area and the
available area for placement in the given region (0 < util < 1).
Default: " "
```

| -batch_mode          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Invokes <code>qplace</code> in a standalone batch mode and reads the placement data back into PKS. Works with all <code>do_place -eco</code> options.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                      | <b>Note:</b> Can only be used in conjunction with the -eco true option.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -block {true   false | }<br>Places the blocks.<br><i>Default</i> : false                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| -clock_buffer_site s | Reserves <i>n</i> -sites (integer or floating number) around every core<br>component connected to nets marked +USE CLOCK for the clock<br>buffers to be inserted later on during clock tree synthesis.<br><i>Default</i> : 0.                                                                                                                                                                                                                                                                                                                                                                                |
| -cong_max_util util  | Defines the maximum local utilization. $util$ is a float value, and the range is from 0-1.<br>Default: Auto tuned.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -cong_mode2 {true    | false}<br>Allows the placer, when set to true, to reserve extra empty<br>space after each pass, producing placement results with high<br>cell density in routable areas and low cell density in congested<br>areas. As a result, congestion is spread out more evenly to<br>provide better routability, and die size is optimized for the<br>smallest possible area. This variable is especially appropriate for<br>high utilization designs with no region constraints and placement<br>run in non-timing mode.<br><i>Default</i> : In general, use the default setting, which is auto tuned<br>as follows: |
|                      | True for core cell placement without timing and region constraints.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                      | False for core cell placement with timing constraints because of<br>the die size optimization. Some areas might become too<br>congested to allow room for buffers or resized gates added as<br>the result of timing-related engineering change orders (ECOs).                                                                                                                                                                                                                                                                                                                                                |

|                         | False for core cell placement with region constraints because cells in some regions might not spread out, which reduces routability in that area.                                                                                                                                                                                                                                                                                                                                            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | True for incremental, block, and ECO placement.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| -cut_ratio <i>float</i> | Defines the ratio between the cuts in the horizontal direction versus the cuts in the vertical direction. This is used to adjust connection densities in either direction.<br>Default: 1 (0.01 < r < 100)                                                                                                                                                                                                                                                                                    |
| -def_name list_of_f     | <i>ile_names</i><br>Defines additional DEF filenames.<br><i>Default</i> : There is no default setting.                                                                                                                                                                                                                                                                                                                                                                                       |
| -def_out_name filena    | ame<br>Specifies the name of the output DEF file.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| -eco {true   false}     | Makes minor placement modifications for the engineering change order (ECO). If applicable, turn region constraints on to place the component in the requested region without moving the already-placed components. When used with the <code>-net_weight</code> option, it allows you to place the new component as close as possible to the already-placed components. Use with the <code>-timing_driven</code> option to control the locations of the new components. <i>Default</i> : true |
| -fix_placed_cell {tr    | rue   false}<br>Fixes all the placed components if true.<br><i>Default</i> : false                                                                                                                                                                                                                                                                                                                                                                                                           |
| -free_track_percent_    | Defines the percentage of free routing tracks for layer 1 specified<br>by the user-defined value from $0-1$ (.5 = 50%). The 1 in this<br>command can be replaced with the values [1-9] depending upon<br>which layer is specified.<br><i>Default</i> : Auto tuned.                                                                                                                                                                                                                           |

| -groute_analysis rep          | oort_file_name<br>Performs groute to generate the congestion map. Analysis is<br>turned off using " ".                                                                                                                                                                                                                              |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -groute_num_opt_pa            | be num<br>Defines the number of optimization passes in groute. num is an<br>integer value.<br>Default: Auto tuned.                                                                                                                                                                                                                  |
| -incremental {true            | <pre>false} Makes incremental placement and optimizations based on existing placement. Incremental placement moves cells locally only. For this reason, it might not achieve the values you set with -cong_max_util or -area_util. If so, turn off incremental placement and run placement optimization again. Default: false</pre> |
| -incr_size <i>size</i>        | Uses the number of instances as a starting point for incremental placement. Incremental size is in number of instances.                                                                                                                                                                                                             |
| -llc_ignore_layer_1           | <pre>{true   false} Turns the legal location check off (true) for specified layer 1. The 1 in this command can be replaced with the values [1-9] depending upon which layer you specify. Default: Auto tuned.</pre>                                                                                                                 |
| -llc_prewire_keep_ou          | It {true   false}<br>Places core cells away from prewires with appropriate design<br>rule.<br><i>Default</i> : false                                                                                                                                                                                                                |
| -mega_cell_keep_out_          | x <i>distance</i><br>Provides space (in microns) in the horizontal direction around<br>the macro cells.                                                                                                                                                                                                                             |
| -mega_cell_keep_out_          | y distance<br>Provides space (in microns) in the vertical direction around the<br>macro cells.                                                                                                                                                                                                                                      |
| -net_weight " <i>tcl_or</i> _ | _net_name_list integer_weight"<br>Assigns weight on the nets specified by                                                                                                                                                                                                                                                           |

tcl\_or\_net\_name\_list to give priority for placement in minimizing their wire length. You must type the double quotation marks in the syntax, as in the following examples: do\_place -net\_weight "tmp1 100" or set listA {tmp1 tmp2 tmp3} do\_place -net\_weight "\$listA 10" -output\_full\_def {true | false} Outputs a complete DEF instead of a DEF with only placement information. -pin {concurrent | refine} Performs pin placement only. Used only with the Cadence ultra placer. The concurrent argument places all cells and pins at the same time and ignores initial placement. The refine argument re-places only pins. All cells must be pre-placed to use the refine option, otherwise the placer quits. Pins marked as fixed or cover are not touched during placement. Pins marked as placed are not moved if you specify the concurrent option, but can be moved if you specify the refine option. Default: false -pin\_layer {left | bottom | right | top} layername Designates a layer name for pins on the left, bottom, right, and top sides. Used only with the Cadence ultra placer. Designs with fewer than three routing layers use metal1 and metal2 for the default layers. Designs with three or more routing layers use metal2 and metal3 for the default layers. -pin\_same\_side {true | false} Places pins to their original side. Used only with the Cadence ultra placer. Default: false  $-place_area \{l \ b \ r \ t\}$ Places instances within the left, bottom, right, or top bounding box areas. The 1, b, r, and t arguments are region coordinates. in database units (integer). Used only with the Cadence ultra placer.

| -place_io_net_weight       | [1 to 100]<br>Specifies the weight factor for nets connected to blocks, pads,<br>and IOs.<br><i>Default</i> : 1                                                                                                                                                               |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -region_exclusive {t       | rue   false}<br>Turns the exclusive region on if true.<br><i>Default</i> : false                                                                                                                                                                                              |
| -region_exclusive_na       | <pre>me name1 name2<br/>Specifies that only the components in the specified groups will<br/>be placed exclusively in the corresponding regions of the<br/>specified groups. Note that this command must be used with the<br/>-region_exclusive option.<br/>Default: "".</pre> |
| -region_relax_percen       | t [0 to 1]<br>Specifies a float value (such as 0.2), which controls the group<br>and region constraints (constraints are ignored if the percentage<br>is negative).<br>Default: 0                                                                                             |
| -route_bottom_layer_       | limit 0-9<br>Limits the bottom routing layer to the specified value. Used only<br>with the Cadence ultra placer.<br>Default: 0                                                                                                                                                |
| -route_top_layer_lim       | Linit 0-9<br>Limits the top routing layer to the specified value. Used only with<br>the Cadence ultra placer.<br>Default: 0                                                                                                                                                   |
| -scan_reorder              | Disconnects the scan chain (if any) before placement and reconnects them based on the scan element's physical location after placement. See <u>Test Synthesis for Ambit BuildGates</u> and Cadence PKS for more information.                                                  |
| -spare_cell <i>cell_na</i> | ne_list<br>Specifies the spare cells to be placed randomly. Qplace will<br>automatically place the spare cells in the design randomly within                                                                                                                                  |

the die area.

Requirements for incorporating spare cells includes: A spare cell is automatically detected if a cell has at least one signal or clock pin (other than power, ground, feedthrough, and so) and that no pin (any pin) connects to a signal or clock net which is at least a two-pin net.

If you do not want to use auto detection mode, need to include more cells as spare cells, or have a subset of spare cells, use the -spare\_cell option. For example:

set spareCells {spare1 spare2 spare3 spare4}
do\_place -spare\_cell \$spareCells -timing\_driven
false

where spareN represents the instances in the design. *Default*: Auto detect

-timing\_driven {true | false}

Performs timing-driven placement. In general, the placer auto tunes the timing arguments to provide the best possible placement results. If running the placer with the default settings does not give you satisfactory results, you can reset some arguments and rerun the placer. *Default*: false

-timing\_io\_net\_weight

Specifies an extra weight factor for the IO timing net.

-timing\_weight weight

Places weight on the timing-driven placement effort. Sacrifices wire length to meet timing. *Default*: Automatically generated.

-use\_region {true | false}

Uses the non-area cluster as region constraints. Use this option to ignore any regions that have been read in using the read\_def command.

**Default**: true unless the -eco false option is specified.

-version

Checks the version number and build information for placement. This option only works after a gate-level netlist is loaded.

## Example

The following command places all blocks in the design:

do\_place -block true

# do\_pull

```
do_pull [-cluster cluster_name | -instance inst_name] [-no_blockages]
    [-no_floorplan] [-no_physical] [-no_rows] [-physical_only]
    [-propagate_constraints]
```

Copies (pulls) *design constraints* and *physical design characteristics* (associated with a specified soft-block cluster or instance) from the lower-timing module context and applies them to the current top-timing module context.

**Note:** The following information will be ignored:

- □ Information that was tagged as *shadow* by the do\_push command.
- □ Information that was inherited by the do\_push command, unless the information was redefined in the lower-timing module context. If the information has changed, it will replace the existing information in the current top-timing module context.

This command primarily copies all place and route information and replaces the existing information in the current top-timing module context.

The *design constraints* include timing, electrical, power, and test. Refer to the <u>do derive context</u> command for more information.

The physical design characteristics include:

- Placement information for all instances hierarchically contained in the soft-block cluster
- Placement information for all physical instances contained in the current module
- Physical cluster-specific information, such as bounds
- Floorplan information associated with the current module (rows, tracks, gcells, floorplan spec, preroute spec, and power stripe spec)
- Special net connectivity and wiring
- Regular net routing
- Blockages
- Cluster pin information
- DEF properties and definitions
- Shadow physical instances to model any instances that overlap the current module, but are contained in other soft clusters (top-level buffers)

# **Options and Arguments**

| -cluster <i>cluster_na</i> | me   -instance inst_name<br>Specifies the name of the soft-block cluster or instance<br>containing the design characteristics you want to pull.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -no_blockages              | Specifies that no blockage information should be pulled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| -no_floorplan              | Specifies that no floorplan information should be pulled.<br>Floorplan information includes cluster specifications, preroute<br>specifications, and floorplan parameters.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -no_physical               | Specifies that only the timing characteristics of the specified soft-<br>block cluster (or instance) is pulled from the lower-timing module<br>context and placed in the current-timing module context.                                                                                                                                                                                                                                                                                                                                                                                                             |
| -no_rows                   | Specifies that no row information should be pulled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| -physical_only             | Specifies that only the <i>physical design characteristics</i> (of the specified soft-block cluster or instance) will be pulled from the lower-timing module context and placed in the current top-timing module context. Note that the <i>design constraints</i> will not pass.                                                                                                                                                                                                                                                                                                                                    |
| -propagate_constrain       | Pulls the timing constraints on a boundary pin in the lower-timing<br>context and applies them to a boundary pin in the top-timing<br>context.<br>Note: The boundary pin in the top-timing context must be<br>directly connected to the boundary pin in the lower-timing<br>context. It also pulls the module port user assertions and applies<br>them to the hierarchical module instance pin in the top-timing<br>context. This command propagates the following constraints:<br>– slew time assertion<br>– input delay assertion<br>– clock root assertion<br>– external delay assertion<br>– constant assertion |

- data arrival time assertions
- clock arrival time assertions
- data required time assertions
- clock required time assertions

If the instance pin of the block is directly connected to a top level input port, the above constraints are transferred to it. Otherwise, these constraints are ignored, except the

set\_constant\_for\_timing command, which is retained on the instance pin of the block.

#### Examples

The following command pulls inst1 (soft block) and places it below inst0 in the current cluster:

```
do_pull -instance {inst0/inst1}
```

■ The following command pulls inst1 (soft block) and places it below inst0 in the current cluster, but does not pull any floorplan information:

do\_pull -instance {inst0/inst1} -no\_floorplan

The following command pulls inst1 (soft block) and places it below inst0 in the current cluster, but does not pull any blockage information:

do\_pull -instance {inst0/inst1} -no\_blockages

■ The following command pulls the information from cluster C2 (subcluster of C1) and places it in cluster C1. Cluster C1 must be present in the current top-timing module:

```
do_pull -cluster {C1/C2}
```

■ The following command pulls the information from cluster C2 (subcluster of C1) and places it in cluster C1, but only pulls the timing constraints of the boundary pins from C2 into C1:

do\_pull -propagate\_constraints -cluster {C1/C2}

■ The following command pulls the information from cluster C2 (subcluster of C1) and places it in cluster C1, but only pulls the timing characteristics from C2 into C1:

```
do_pull -no_physical -cluster {C1/C2}
```

#### **Related Information**

do derive context

<u>do push</u>

<u>set\_top\_timing\_module</u>

# do\_push

```
do_push [-cluster cluster_name | -instance inst_name]
    [-budget_style {time_budget | derive_context] [no_physical] [-no_shadow]
    [-physical_only]
```

Copies (pushes) design constraints and physical design characteristics (associated with a specified soft-block cluster or instance) from the current top-timing module context to a lower-timing module context.

**Note:** Objects overlapping the soft-block cluster in the top-timing module context are also pushed to the lower-timing module context unless you specify the  $-no\_shadow$  option. This is one of the fundamental capabilities for performing top-down hierarchical synthesis.

Design constraints include:

- Timing
- Electrical
- Power
- Test.

Physical design characteristics include:

- Placement information for all instances hierarchically contained in the soft-block cluster
- Placement information for all physical instances contained in the current module
- Physical cluster-specific information, such as cluster bounds

Cluster bounds are the coordinate limits of its bounding box, for example, if the cluster has a bounding box of  $\{0 5 100 200\}$ , then 0 is the lower bound in the x- direction, 100 is the upper bound in x, 5 is the y lower bound while 200 is the y upper bound. Generally everything belonging to a cluster must physically lie within a bounding box defined by its bounds.

- Floorplan information associated with the current module (rows, tracks, gcells, floorplan spec, preroute spec, and power stripe spec)
- Special net connectivity and wiring
- Regular net routing
- Blockages
- Cluster pin information
- DEF properties and definitions

Shadow physical instances to model any instances that overlap the current module, but are contained in other soft clusters (top-level buffers)

## **Options and Arguments**

| -budget_style {time_       | <pre>_budget   derive_context} Specifies that timing characterization is to be done using the time budgeting or derive context method.</pre>                                                                                                                                                                                                                                             |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -cluster <i>cluster_na</i> | me   -instance inst_name<br>Specifies the name of the soft-block cluster or instance<br>containing the design characteristics you want to push.                                                                                                                                                                                                                                          |
| -no_physical               | Specifies that only the timing characteristics of the specified soft-<br>block cluster or instance will be pushed from the top-timing<br>context and placed in the lower-timing context.                                                                                                                                                                                                 |
| -no_shadow                 | Specifies that no objects overlapping the soft-block cluster in the top-timing module context are to be pushed to the lower-timing module context. Useful in a situation where you just want to update the contents of a lower-timing module with a read_def.                                                                                                                            |
| -physical_only             | Specifies that only the <i>physical design characteristics</i> (of the specified soft-block cluster or instance) will be pushed from the top-timing module context and placed in the lower-timing module context. Note that the <i>design constraints</i> will not be passed. Useful in a situation where you just want to update the contents of a lower-timing module with a read_def. |

## Examples

- The following command pushes inst1 (soft block) below inst0 in the current cluster: do\_push -instance {inst0/inst1}
- The following command pushes inst1 (soft block) below inst0 in the current cluster, but does not push any objects overlapping inst1:

```
do_push -instance {inst0/inst1} -no_shadow
```

■ The following command pushes inst1 (soft block) below inst0 in the current cluster, but only the timing characteristics of inst1 are pushed:

do\_push -instance {inst0/inst1} -no\_physical

■ The following command pushes cluster C2 (soft block subcluster of C1) to the lowertiming module:

do\_push -cluster {C1/C2}

Cluster C1 remains present in the current top-timing module.

#### **Related Information**

do derive context

do pull

set top timing module

## do\_refine\_place

do\_refine\_place

Starts Encounter<sup>™</sup> in batch mode and runs the refinePlace command to correct flawed cell locations. Once the legalization is complete, the final placement is read back into PKS through a DEF file generated by Encounter.

**Note:** You must specify an Encounter executable for PKS to use, either by having the executable in your UNIX search path, or by setting the <u>pks encounter exe</u> global.

#### **Additional Information**

<u>pks encounter exe</u>

## do\_remove\_filler\_cells

do\_remove\_filler\_cells [-area {lx ly ux uy}]

Removes all filler cells in the entire design or in the specified area that do not have a placement state of FIXED or COVER.

## **Options and Arguments**

```
-area {lx ly ux uy}
```

Specifies the area from which filler cells are to be removed. The area is a rectangle where lx and ly represent the x and y coordinates of the lower left corner of the rectangle, and ux and uy represent the x and the y coordinates of the upper right corner. Coordinate values are in microns.

#### **Related Information**

do insert filler cells

## do\_remove\_route

do\_remove\_route [-all] [-net net\_name]

Deletes the specified routes in the design. If no options are specified, this command removes all regular routes generated by Wroute (no power routing is removed).

## **Options and Arguments**

-all

-net net\_name

Deletes all routes under the specified *net\_name*.

#### Examples

- The following command deletes all routes routed by Wroute:
  - do\_remove\_route
- The following command deletes all routes in the design: do\_remove\_route -all
- The following command deletes all routes under the specified net\_name: do\_remove\_route -net net\_name

## **Related Information**

do route

## do\_reset\_floorplan

do\_reset\_floorplan -rows -instances -pins

Can be issued after loading a design.

#### **Options and Arguments**

-instances

|       | Specifies that all standard cells are to be unplaced. This command does not affect the placement of hard blocks or pad cells. |
|-------|-------------------------------------------------------------------------------------------------------------------------------|
| -pins | Resets the pin location information of all pins in the design.                                                                |
| -rows | Removes all user rows in the database and uses the floorplan parameters to generate cell rows.                                |

## Example

do\_reset\_floorplan -rows -instances

#### **Related Information**

do initialize floorplan

report floorplan parameters

set floorplan parameters

## do\_route

```
do_route [-assign_routing_direction {true | false}]
     [-def name list of file names] [-def out name filename]
     [-discourage_planar_routing {true | false}] [-follow_pins]
     [-force {true | false}] [-qqrid max size 16] [-qqrid min size 5]
     [-ggrid_mode {user | align | uniform}] [-ggrid_opt_size 10]
     [-groute_num_opt_pass num] [-ignore_unplaced_component {true | false}]
     [-no_follow_pins] [-output_db_name filename]
     [-output_full_def {true | false}] [-pin_access_compat_mode {true | false}]
     [-region_relax_percent] [-route_area {lx|ly|ux|uy}]
     [-route_bottom_layer_limit value] [-route_on_grid_only {true | false}]
     [-route pin access compat mode {auto | normal | offGrid | upViaEnclosure |
    upVia | upViaReserve | narrowPin}] [-route_select_net [~] list_of_net_names]
     [-route_select_net_first {true | false}]
     [-route_select_net_layer_range {layer:layer | layer}]
     [-route soft top layer limit {true | false}]
     [-route_stripe_center_connect {true | false}]
     [-route_stripe_follow_pin_only {true | false}]
     [-route_top_layer_limit value]
     [-route_use_range_rule obstruction | pin | obstruction+pin]
     [-straighten_net net_name_list] [-timing_driven {true | false}]
     [-timing_net_percentage_delta [0 to 100]] [-use_auto_ggrid {true | false}]
     [-use max xy spacing {true | false}] [-version]
```

Starts Wroute to do a global routing on the design and saves the global routing information in the Wroute database.

## **Options and Arguments**

```
-assign_routing_direction {true | false}
```

Tells the router, when true, to automatically assign routing directions in the channels between blocks to take advantage of available routing tracks. This variable is useful, for example, if channel congestion between blocks occurs because the preferred routing tracks are perpendicular to the orientation of the channel. In this case, this variable lets the router reassign the preferred routing direction in the channel. *Default*: false

```
-def_name list_of_file_names
```

Specifies the name of the DEF file(s) that Wroute reads.

| -def_out_name filena | ame                                                                                                                                                                                                                                                                                                         |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies the name of the output DEF file that Wroute writes to.                                                                                                                                                                                                                                            |
|                      | <b>Note</b> : This option is primarily used to change the output DEF <i>filename</i> . If this option is not used, the DEF is automatically written to the following default DEF filename: wdb_name.def.                                                                                                    |
| -discourage_planar_r | outing {true   false}<br>Eliminates the use of planar routing over blocks<br><i>Default</i> : false                                                                                                                                                                                                         |
| -follow_pins         | Removes existing power rails (if applicable) and generates new ones.                                                                                                                                                                                                                                        |
| -force {true   false | 1                                                                                                                                                                                                                                                                                                           |
| -iorce (true   faise | Stops global routing, if false, when more than 90% of the nets<br>are final routed. If true, will continue global routing while<br>preserving all final routes. Note that global routing will continue<br>and also issue a warning when < 90% of the design is final<br>routed.                             |
| -ggrid_max_size 16   | Sets the maximum gcell grid size in tracks. ggrid size has a                                                                                                                                                                                                                                                |
|                      | significant effect on QOR (quality of results). It is recommended<br>you use a smaller <i>ggrid</i> size unless your design has a large<br>number of obstacles or is memory constrained. See<br>-ggrid_min_size and -ggrid_opt_size for more options.                                                       |
| -ggrid_min_size 5    |                                                                                                                                                                                                                                                                                                             |
|                      | Sets the minimum gcell grid size in tracks. <i>ggrid</i> size has a significant effect on QOR (quality of results). It is recommended you use this <i>ggrid</i> size unless your design has a large number of obstacles or is memory constrained. See -ggrid_max_size and -ggrid_opt_size for more options. |
| -ggrid_mode {align   | uniform   user}                                                                                                                                                                                                                                                                                             |
|                      | Sets the global routing grid generation mode. The global routing grid partitions the routing portion of a standard cell design into rectangles called gcells. The arguments for this variable set the grid as follows:                                                                                      |

|                      | align<br>Generates a global routing grid that aligns with the channels and<br>macro block boundaries in your design. This argument improves<br>routing quality for block-based designs because, by aligning the<br>grids, the global router can route more effectively in empty gcells<br>in the channel area.                                   |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | uniform<br>Generates a uniform global routing grid.                                                                                                                                                                                                                                                                                              |
|                      | user<br>Uses the global routing grid defined in the DEF file.                                                                                                                                                                                                                                                                                    |
|                      | Default: uniform                                                                                                                                                                                                                                                                                                                                 |
| -ggrid_opt_size 10   | Sets the optimal gcell grid size in tracks. <i>ggrid</i> size has a significant effect on QOR (quality of results). It is recommended you use a smaller <i>ggrid</i> size unless your design has a large number of obstacles or is memory constrained. See -ggrid_max_size and -ggrid_min_size for more options.                                 |
| -groute_num_opt_pass | num<br>Sets the number of optimization passes in groute, specified by<br>the value num. If no value is given for num, the default value is<br>used.<br>Default: Auto tuned.                                                                                                                                                                      |
| -ignore_unplaced_com | ponent {true   false}<br>Specifies not to route to the pins of unplaced components.<br><i>Default</i> : false                                                                                                                                                                                                                                    |
| -no_follow_pins      | Removes existing power rails (if applicable).                                                                                                                                                                                                                                                                                                    |
| -output_db_name file | Specifies the router's output database. The database is in binary<br>form. To save your design into a router database without running<br>routing, specify the database $filename$ with this option and set<br>all the routing variables to $false$ . The router will save your<br>design into database format without making any routing passes. |

**Note**: This option is primarily used to change the output

|                      | database <i>filename</i> . If this option is not used, the database is automatically written to the following default output database filename: design_name.wdb. This option is useful, for example, if you are routing several different floorplans or placements. You can use this option to save each database that the router creates to a different routing binary. Then you can load the best results from the saved database. |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -output_full_def {tr | rue   false}<br>Outputs a full DEF file, when true, instead of a DEF file<br>containing only placement information.<br><i>Default</i> : true                                                                                                                                                                                                                                                                                         |
| -pin_access_compat_n | node {true   false}<br>Enables pin access compatibility mode.<br><i>Default</i> : false                                                                                                                                                                                                                                                                                                                                              |
| -region_relax_percer | Controls group and region constraints. Constraints are ignored if the percent is negative. Takes values 0.0 - 1.0.<br>Default: 0                                                                                                                                                                                                                                                                                                     |
| -route_area {lx ly u | <ul> <li>uy }</li> <li>Routes the specified area. The coordinates for the area are in database units. If no arguments are given, the full chip is routed.</li> </ul>                                                                                                                                                                                                                                                                 |
| -route_bottom_layer_ | Limit [0]<br>Limits the bottom routing layer to the specified value. A value of<br>0 disables this option. Routing below the specified layer is<br>allowed, but at a very high cost. Thus, the wire length below the<br>specified layer is kept short. For example, in a design with six<br>layers, a value of 4 requests that the router start routing at the<br>fourth layer.                                                      |
| -route_on_grid_only  | {true   false}<br>Routes to the on-grid geometries of port only.<br><i>Default</i> : false                                                                                                                                                                                                                                                                                                                                           |
| -route_pin_access_co | <pre>ompat_mode {auto   normal   offGrid   upViaEnclosure   upVia   upViaReserve   narrowPin} Sets the option for processing pin geometries. The arguments for this variable are:</pre>                                                                                                                                                                                                                                              |

this variable are:

#### auto

Processes the pin geometries as it did in previous versions of the software. This is the default value for this environment variable.

#### normal

Processes the pin geometries as it did in previous versions of the software. This is the default value for this environment variable.

#### offGrid

Shrinks the pin geometries by one-half the wire width. The reminder of the pin geometry is valid for the router to make a connection using a regular wire. The router checks the connection using a one-half wire width plus spacing rule.

#### upViaEnclosure

Shrinks the pin geometries by one-half a via width. The remainder of the pin geometries is valid for the router to make a connection using a via that is fully enclosed by the pin. The router checks the connection using a one-half via width plus spacing rule.

#### upVia

Does not shrink the pin, so the full size of the pin geometry is valid for the router to make a connection using a via. The router checks the connection using a one-half via width plus spacing rule.

#### upViaReserve

Shrinks the pin geometries by one-half the wire width. The remainder of the pin geometries is valid for making a connection using a via. The router checks the connection using a one-half via width plus spacing rule.

#### narrowPin

Does not shrink the pin geometries. The full size of the pin geometries is valid for making a connection using a regular wire. The router checks the connection using a one-half via width plus spacing rule.

| -route_select_net [~         | <ul> <li>] list_of_net_names</li> <li>where ~ represents negation.</li> <li>Using ~ routes all but the specified nets.</li> <li>No ~ routes only the specified nets.</li> </ul>                     |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -route_select_net_fi         | rst {true   false}<br>Routes the selected nets first, followed by all other nets.<br><i>Default</i> : false                                                                                         |
| -route_select_net_la         | yer_range {layer:layer   layer}<br>Routes the selected nets on the specified layer range.                                                                                                           |
| -route_soft_top_laye         | r_limit {true   false}<br>Specifies that the top routing limit is soft, if set to true.<br>Default: false                                                                                           |
| -route_stripe_center         | connect {true   false}<br>Connects to the center of the stripe only. Does not connect to<br>POWER and GROUND pins.<br><i>Default</i> : false                                                        |
| -route_stripe_follow         | y_pin_only {true   false}<br>Connects to the follow pin stripe only.<br><i>Default</i> : false                                                                                                      |
| -route_top_layer_lim         | Limits the top routing layer to the specified value. A value of 0 disables this argument. A value of n means the placer uses routing resources from layer 1 to layer n. <i>Default</i> : 0          |
| -route_use_range_rul         | e (obstruction   pin   obstruction+pin)<br>Specifies the clearance distance used for spacing rule checks<br>using one or more of: pin, obstruction, or obstruction+pin.<br>Default: obstruction+pin |
| -straighten_net <i>net</i> _ | _name_list<br>Straightens the selected nets specified by net_name_list.<br>Default: [ ]                                                                                                             |

| -timing_driven {true | <ul> <li>false}</li> <li>Turns on timing-driven routing when set to true. To perform timing-driven routing, the router decides the order in which to route the constrained nets based on their timing criticality, and routes them accordingly. The most timing-critical nets are routed first to achieve the shortest routes.</li> </ul>                                                                      |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | The router modifies its routing priorities as appropriate during the routing process. For example, if the router places a net low on the priority list to start, but later realizes that the net must be routed more directly to meet timing constraints, it will reroute the net. The router also considers the layer RC values when determining how to route the timing-critical nets. <i>Default</i> : true |
| -timing_net_percenta | age_delta [0 to 100]<br>Specifies the percentage change in the timing-critical nets.<br>Default: 0                                                                                                                                                                                                                                                                                                             |
| -use_auto_ggrid {tru | ue   false}<br>Uses Wroute's default auto tune settings, if set to true. If<br>false, uses the PKS smaller ggrid size.<br>Default: true                                                                                                                                                                                                                                                                        |
| -use_max_xy_spacing  | ${true   false}$<br>Uses the maximum values of x and y for spacing checks.<br>Default: false                                                                                                                                                                                                                                                                                                                   |
| -version             | Checks the version number and build information for routing.<br>This option only works after a gate-level netlist is loaded.                                                                                                                                                                                                                                                                                   |

## Example

do\_route -timing\_driven true -ggrid\_mode align

#### do\_wroute

```
do_wroute [-antenna_method] [-antenna_sum_gate_area] [-froute_allow_port_short]
     [-froute_antenna_cell_pass] [-froute_antenna_top_layer_limit integer_value]
     [-froute_auto_save_interval] [-froute_auto_stop]
     [-froute fix antenna pass integer value] [-froute manufacturing grid]
     [-froute_on_grid_only] [-froute_on_grid_via_threshold]
     [-froute_optimization] [-froute_pin_enclose_wire {true | false}]
     [-froute_prefer_on_grid] [-froute_runtime_limit value]
     [-froute_search_repair] [-froute_taper_distance]
     [-froute_taper_pin_selection {ruleBased | inputOnly | all}]
     [-froute_use_max_x_y_spacing]
     [-froute use range rule {pin | obstruction | pin+obstruction}]
     [-froute_xtalk_threshold integer_value]
     [-groute_discourage_planar_routing {true | false}] [-groute_ggrid_mode]
     [-groute_incremental] [-include filename ...] [-input_db_name filename]
     [-input def name {filename | "list of files"}] [-input eco {true | false}]
     [-input_gcf_constraints {filename | "list_of_files"}]
     [-input_gcf_timing_libraries {filename | "list_of_files"}]
     [-input_ldef_comment_char] [-input_lef_name {filename | "list_of_files"}]
     [-log_file filename] [-no_license_sharing] [-output_db_name filename]
     [-output_def_name filename] [-processor] [-route_area]
     [-route_bottom_layer_limit] [-route_chip_assembly_mode {true | false}]
     [-route final] [-route global] [-route modify preroute pass]
     [-route_select_net {netname | "list_of_nets"}]
     [-route_select_net_first {true | false}]
     [-route_select_net_layer_range {bottom_layer | "bottom_layer:top_layer"}]
     [-route soft top layer limit {true | false}] [-route straighten net [~]
     {netName | "list_of_files" | < filename | "fileName"}]</pre>
     [-route_stripe_center_connect {true | false}]
     [-route_top_layer_limit integer_value] [-timing_driven_routing]
     [-timing_fall_transition] [-timing_net_percentage_delta]
     [-timing_rise_transition] [-timing_use_est_cap]
     [-xtalk_fix_net {netName | "list_of_files" | < filename}]
     [-xtalk_rule "class_a [|class_b] ... + class_a [|class_b] ... [,class_a
     [|class_b] ... + class_a [|class_b] ...] ..."]
     [-xtalk_rule_threshold threshold]
```

Starts Wroute to do a final routing on the design. Wroute will not generate its own log file. All log messages will be channeled into pks\_shell output and also saved in pks\_shell.log or the file you specify with the -log\_file option.

# Important

You must specify one of the following options, otherwise the do\_wroute\_eco command will error out:

- -input\_db\_name
- -input\_def\_name

The do\_wroute command automatically calls <u>read\_wdb</u> after finishing routing. The read\_wdb messages are written to the log file as a Groute call from ULTRA PLACER.

The wroute executable is typically found on the UNIX search PATH or can be set using the following global command:

set\_global pks\_wroute\_exe path/wroute

If the <u>pks wroute exe</u> global is not set or set to a null string, the following message appears:

"wroute: on the search PATH will be used."

If the wroute executable is not on the UNIX search PATH, the command will error out.

The do\_wroute command will signal a warning if the do\_route command version and wroute command version are not a known match. A similar warning will be issued if the WDB version written by the do\_route command does not match with the WDB version expected by the wroute command. These are for error checking and do not indicate actual mismatches. You are responsible for making sure that the WDB file you pass to the do\_wroute command is compatible (do\_route version 72 and wroute version 35 is a known match).

The do\_wroute command supports all Wroute options with a changed name style. The rule of thumb is: all letters in the do\_wroute option name appear as they do in the Wroute option name but in lower case. Precede all capital letters in the original name with a '\_' in the new name. For example:

| Wroute Option Name | do_wroute Option Name |
|--------------------|-----------------------|
| routeSelectNet     | -route_select_net     |
| outputDbName       | -output_db_name       |
| AntennaMethod      | -antenna_method       |

All option values are the same as they appear in Wroute. For example:

| Wroute Option Value   | do_wroute <b>Option Value</b> |
|-----------------------|-------------------------------|
| TRUE or true          | TRUE OF true                  |
| FALSE <b>OF</b> false | FALSE <b>Or</b> false         |
| 0.25                  | 0.25                          |

| Wroute Option Value | do_wroute Option Value |
|---------------------|------------------------|
| "clk*,net1,net2"    | "clk*,net1,net2"       |
| "file1 file2"       | "file1 file2"          |
| obstruction+pin     | obstruction+pin        |

Currently, this is the only mechanism to run Wroute through PKS. Until REF files are supported, PKS can not transfer global routing automatically through pks\_shell to Wroute.

#### **Options and Arguments**

For more details, refer to the Ultra Router Reference available with the Silicon Ensemble documentation set.

| -antenna_method      | Maps to the Silicon Ensemble Verify. A environment variable.                                                                 | ntenna.Method          |
|----------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------|
| -antenna_sum_gate_ar | rea<br>Maps to the Silicon Ensemble<br>Verify.Antenna.SumGateArea envir                                                      | onment variable.       |
| -froute_allow_port_s | Maps to the Silicon Ensemble WRoute.A<br>environment variable.                                                               | llow.Port.Shorts       |
| -froute_antenna_cell | pass<br>Maps to the Silicon Ensemble WRoute.A<br>environment variable.                                                       | ntenna.Cell.Pass       |
| -froute_antenna_top_ | _layer_limit <i>integer_value</i><br>Starts adding antenna diode cells if proce<br>remain after layer hopping reaches the sp |                        |
| -froute_auto_save_in | Maps to the Silicon Ensemble WRoute.A<br>environment variable.                                                               | utoSave.Interval       |
| -froute_auto_stop    | Maps to the Silicon Ensemble WRoute. A environment variable.                                                                 | uto.Stop               |
| December 2003        | 537                                                                                                                          | Product Version 5.0.13 |

| -froute_fix_antenna_ | pass <i>integer</i><br>Maps to the Silicon Ensemble WRoute.Fix.AntennaPass<br>environment variable.                                                                          |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -froute_manufacturin | g_grid<br>Maps to the Silicon Ensemble<br>FRoute.Manufacturing.XGrid environment variable.                                                                                   |
| -froute_on_grid_only | Maps to the Silicon Ensemble Wroute.OnGrid.Via.Only environment variable.                                                                                                    |
| -froute_on_grid_via_ | threshold<br>Maps to the Silicon Ensemble<br>WRoute.OnGrid.Via.Threshold environment variable.                                                                               |
| -froute_optimization | Maps to the Silicon Ensemble WRoute.Optimization environment variable.                                                                                                       |
| -froute_pin_enclose_ | wire {true   false}<br>Specifies whether to force the router to connect to a pin if it<br>encloses a wire or connect to the center of a wire if it is wider than<br>the pin. |
| -froute_prefer_on_gr | id<br>Maps to the Silicon Ensemble WRoute.Prefer.OnGrid<br>environment variable.                                                                                             |
| -froute_runtime_limi | t value<br>Maps to the Silicon Ensemble WRoute.RunTimeLimit<br>environment variable. Units in seconds.                                                                       |
| -froute_search_repai | r<br>Maps to the Silicon Ensemble WRoute.SearchRepair<br>environment variable.                                                                                               |
| -froute_taper_distan | ce<br>Maps to the Silicon Ensemble WRoute.Taper.Distance<br>environment variable.                                                                                            |
| -froute_taper_pin_se | lection {ruleBased   inputOnly   all}<br>Specifies which wires the router tapers.                                                                                            |

| -froute_use_max_x_y_       | _spacing<br>Maps to the Silicon Ensemble Rule.ClearanceMeasure<br>environment variable.                                                                                                                                                                                                                                                                            |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -froute_use_range_ru       | le {pin   obstruction   pin+obstruction}<br>Lets you use the spacing rule that is defined in the LEF file.                                                                                                                                                                                                                                                         |
| -froute_xtalk_thresh       | Specifies the maximum length for parallel wire segments. If the router finds parallel wire segments that exceed the specified length, it attempts to space out the wires by one additional track within a global routing cell (gcell) to avoid crosstalk. If the gcell does not have enough room, the router completes the routing without the additional spacing. |
| -groute_discourage_p       | <pre>blanar_routing {true   false} Specifies whether to penalize routing over blocks when only one routing layer is available. Planar routing (routing on one layer) increases the possibility that wires will cross.</pre>                                                                                                                                        |
| -groute_ggrid_mode         | Maps to the Silicon Ensemble WRoute.GGridMode environment variable.                                                                                                                                                                                                                                                                                                |
| -groute_incremental        | Maps to the Silicon Ensemble WRoute.Incremental.Global environment variable.                                                                                                                                                                                                                                                                                       |
| -include <i>filename</i> . | <br>Lets you use secondary configuration files for the router, so you<br>can include options in additional files. You can have up to ten<br>nesting levels of options.                                                                                                                                                                                             |
| -input_db_name file        | name<br>Specifies the database directory. Maps to the Silicon Ensemble<br>WRoute.Input.DbName environment variable.                                                                                                                                                                                                                                                |
| -input_def_name {fil       | eName   "list_of_files"} Specifies the name of the DEE file to be input to the router                                                                                                                                                                                                                                                                              |

Specifies the name of the DEF file to be input to the router.

| -input_eco {true   f      | Makes the router more error tolerant by allowing it to delete<br>problematic nets and rerouting the affected nets. Examples of<br>problematic nets are nets with loops and nets for which the router<br>cannot extract connectivity.                                               |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -input_gcf_constrain      | Its {fileName   "list_of_files"}<br>Specifies the general constraint format (GCF) constraint file or<br>files. You use GCF files to define system-level constraints (SLCs)<br>and timing libraries. You can use the same GCF file for the<br>constraints and the timing libraries. |
| -input_gcf_timing_li      | braries {fileName   "list_of_files"}<br>Specifies the GCF file or files containing the timing libraries. This<br>option is required to run timing-driven routing.                                                                                                                  |
| -input_ldef_comment_      | char<br>Maps to the Silicon Ensemble Input.Comment.Delimiter<br>environment variable.                                                                                                                                                                                              |
| -input_lef_name {fii      | <pre>leName   "list_of_files" } Specifies the name or names of the LEF files to be used. Maps to the Silicon Ensemble WRoute.Addition.LefName environment variable.</pre>                                                                                                          |
| -log_file <i>filename</i> | Specifies the name to use for the Wroute log file.                                                                                                                                                                                                                                 |
| -no_license_sharing       | Runs Wroute version 34 or older, which does not take license token from PKS and will checkout its own license.                                                                                                                                                                     |
| -output_db_name file      | Specifies the directory to use for the output database. Maps to the Silicon Ensemble WRoute.Output.DbName environment variable.                                                                                                                                                    |
|                           | <b>Note</b> : If you specify this option with no filename, the tool will error out. If you omit this option, no database file will be written out.                                                                                                                                 |

| -output_def_name fil | ename<br>Specifies the name to use for the output DEF file. Maps to the<br>Silicon Ensemble WRoute.Output.DefName environment<br>variable.                                                                                                                                                                                                                                                               |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | <b>Note</b> : If you specify this option with no filename, the tool will error out. If you omit this option, no DEF file will be written out.                                                                                                                                                                                                                                                            |
|                      | <b>Note</b> : By default, do_wroute writes the output file in the DEF version of the file you originally loaded, or DEF version 5.4, whichever is the newer version.                                                                                                                                                                                                                                     |
| -processor           | Maps to the Silicon Ensemble WRoute.Processor environment variable.                                                                                                                                                                                                                                                                                                                                      |
| -route_area          | Maps to the Silicon Ensemble WRoute.Route.Area environment variable.                                                                                                                                                                                                                                                                                                                                     |
| -route_bottom_layer_ | limit<br>Maps to the Silicon Ensemble WRoute.BottomLayer.Limit<br>environment variable.                                                                                                                                                                                                                                                                                                                  |
| -route_chip_assembly | <u>Specifies whether to scan the design to determine the necessity for chip-assembly routing and changes heuristics during detailed routing, depending on the percentage of the area of the design that is covered by blocks, rings, or pads. In chip-assembly mode, the router runs an order of magnitude faster than in no-chip-assembly mode at the expense of slightly degraded routing quality.</u> |
| -route_final         | Maps to the Silicon Ensemble Wroute.Final environment variable.                                                                                                                                                                                                                                                                                                                                          |
| -route_final (TRUE)  | Maps to the Silicon Ensemble WRoute.Incremental.Final environment variable.                                                                                                                                                                                                                                                                                                                              |

| -route_global        | Maps to the Silicon Ensemble WRoute.Global environment variable.                                                                                                                                                                     |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -route_modify_prerou | ute_pass<br>Maps to the Silicon Ensemble<br>WRoute.Modify.PreroutePass environment variable.                                                                                                                                         |
| -route_select_net {r | <pre>metname   "list_of_nets"} Maps to the Silicon Ensemble WRoute.SelectNets environment variable.</pre>                                                                                                                            |
| -route_select_net_fi | <pre>.rst {true   false} Maps to the Silicon Ensemble WRoute.SelectNet.First environment variable.</pre>                                                                                                                             |
| -route_select_net_la | <pre>syer_range {bottom_layer   "bottom_layer:top_layer"} Specifies a layer range for selected nets if all nets are being routed. You can specify a bottom layer for routing the selected nets or both a bottom and top layer.</pre> |
| -route_soft_top_laye | er_limit {true   false}<br>Specifies whether to allow routing on layers higher than the one<br>set by routeTopLayerLimit.                                                                                                            |
| -route_straighten_ne | et [~] {netName   "list_of_nets"   "< fileName"  <br>" fileName" }<br>Deletes specified nets in a fully routed design and reroutes them<br>as straight as possible.                                                                  |
| -route_stripe_center | Connect {true   false}<br>Controls whether the router connects to the center of wide<br>stripes only, not to power or ground pins.                                                                                                   |
| -route_top_layer_lim | nit <i>integer_value</i><br>Maps to the Silicon Ensemble WRoute.TopLayer.Limit<br>environment variable.                                                                                                                              |
| -timing_driven_routi | .ng<br>Maps to the Silicon Ensemble WRoute.Timing.Driven<br>environment variable.                                                                                                                                                    |

PKS Commands

| -timing_fall_transit         | tion<br>Maps to the Silicon Ensemble<br>WRoute.Timing.Fall.Transition environment variable.                                                                                                                                                                                                                                         |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -timing_net_percenta         | age_delta<br><b>Maps to the Silicon Ensemble</b><br>WRoute.Timing.Net.Percentage.Delta environment<br>variable.                                                                                                                                                                                                                     |
| -timing_rise_transit         | tion<br>Maps to the Silicon Ensemble<br>WRoute.Timing.Rise.Transition environment variable.                                                                                                                                                                                                                                         |
| -timing_use_est_cap          | Maps to the Silicon Ensemble WRoute.Timing.Use.Est.Cap environment variable.                                                                                                                                                                                                                                                        |
| -xtalk_fix_net { <i>net1</i> | <pre>Name   "list_of_nets"   &lt; fileName } Performs postroute crosstalk fixing on selected nets by pushing adjacent routing aside. Use this option on a fully routed database during final routing only.</pre>                                                                                                                    |
| -xtalk_rule " <i>class_</i>  | a [ class_b] + class_a [ class_b]<br>[,class_a [ class_b] + class_a [ class_b]<br>]"<br>Specifies the interaction rules for crosstalk classes. The default<br>crosstalk class for all nets is 0. Cadence recommends you use<br>xtalkRule "0+0" if you need to minimize crosstalk.<br>Default: false (Crosstalk class for all nets.) |
| -xtalk_rule_threshol         | d threshold<br>Specifies the wire-length threshold for nets to be affected by the<br>class interaction rule for crosstalk.                                                                                                                                                                                                          |

### Examples

Refer to the Ultra Router Reference available with the Silicon Ensemble documentation set.

#### **Additional Information**

read\_wdb

#### write wdb

#### do\_wroute\_eco

```
do_wroute_eco -input_db_name filename [-antenna_method] [-antenna_sum_gate_area]
     [-froute_allow_port_short] [-froute_antenna_cell_pass]
     [-froute_antenna_top_layer_limit integer_value]
     [-froute auto save interval] [-froute auto stop] [-froute fix antenna pass]
     [-froute manufacturing grid] [-froute on grid only]
     [-froute_on_grid_via_threshold] [-froute_optimization]
     [-froute_pin_enclose_wire {true | false}] [-froute_prefer_on_grid]
     [-froute_runtime_limit] [-froute_search_repair] [-froute_taper_distance]
     [-froute_taper_pin_selection {ruleBased | inputOnly | all}]
     [-froute_use_max_x_y_spacing]
     [-froute use range rule {pin | obstruction | pin+obstruction}]
     [-froute_xtalk_threshold integer_value]
     [-groute_discourage_planar_routing {TRUE | FALSE}] [-groute_ggrid_mode]
     [-groute_incremental] [-include filename ...]
     [-input def name {filename | "list of files"}] [-input eco {TRUE | FALSE}]
     [-input_gcf_constraints {filename | "list_of_files"}]
     [-input_gcf_timing_libraries {filename | "list_of_files"}]
     [-input_ldef_comment_char] [-input_lef_name] [-log_file filename]
     [-no_license_sharing] [-output_db_name filename]
     [-output_def_name filename ] [-processor] [-route_area]
     [-route_bottom_layer_limit] [-route_chip_assembly_mode {TRUE | FALSE}]
     [-route final] [-route global] [-route modify preroute pass]
     [-route_select_net] [-route_select_net_first]
     [-route_select_net_layer_range] [-route_soft_top_layer_limit {TRUE | FALSE}]
     [-route_straighten_net [~] {netName | "list_of_files" | "< filename"|
     " fileName"}] [-route stripe center connect {TRUE | FALSE}]
     [-route top layer limit] [-timing driven routing] [-timing fall transition]
     [-timing_net_percentage_delta] [-timing_rise_transition]
     [-timing_use_est_cap]
     [-xtalk_fix_net { netName | "list_of_files" | < filename }]
     [-xtalk_rule "class_a [|class_b] ... + class_a [|class_b] ... [,class_a
     [|class_b] ... + class_a [|class_b] ...] ..."]
     [-xtalk rule threshold threshold]
```

Makes the router more error tolerant by allowing it to delete problematic nets and reroute the affected nets. Examples of problematic nets are nets with loops and nets for which the router cannot extract connectivity. Also runs global routing in incremental mode on an existing database. During incremental global routing, the router deletes and globally reroutes nets with violations. This command is similar to the following do\_wroute command:

do\_wroute -input\_eco true -groute\_incremental true

See <u>do wroute</u> on page 535 for more information.

## Important

You must use the <code>-input\_db\_name</code> option to specify an input file, otherwise the <code>do\_wroute</code> command will error out.

The do\_wroute\_eco command automatically calls <u>read\_wdb</u> after finishing routing. The read\_wdb messages are written to the log file as a Groute call from ULTRA PLACER.

The wroute executable is typically found on the UNIX search PATH, or can be set using the following global command:

set\_global pks\_wroute\_exe path/wroute

If the <u>pks wroute exe</u> global is not set or set to a null string, the following message appears:

"wroute: on the search PATH will be used."

If the wroute executable is not on the UNIX search PATH, the command will error out.

#### **Options and Arguments**

For more details, refer to the *Ultra Router Reference* available with the Silicon Ensemble documentation set.

-antenna\_method

Maps to the Silicon Ensemble Verify.Antenna.Method environment variable.

-antenna\_sum\_gate\_area

Maps to the Silicon Ensemble

Verify.Antenna.SumGateArea environment variable.

-froute\_allow\_port\_short

Maps to the Silicon Ensemble WRoute.Allow.Port.Shorts environment variable.

-froute\_antenna\_cell\_pass

Maps to the Silicon Ensemble WRoute.Antenna.Cell.Pass environment variable.

-froute\_antenna\_top\_layer\_limit integer Starts adding antenna diode cells if process antenna violations remain after layer hopping reaches the specified layer.

-froute\_auto\_save\_interval

Maps to the Silicon Ensemble WRoute.AutoSave.Interval environment variable.

-froute\_auto\_stop Maps to the Silicon Ensemble WRoute.Auto.Stop environment variable. -froute\_fix\_antenna\_pass integer Maps to the Silicon Ensemble WRoute.Fix.AntennaPass environment variable. -froute\_manufacturing\_grid Maps to the Silicon Ensemble FRoute.Manufacturing.XGrid environment variable. -froute\_on\_grid\_only Maps to the Silicon Ensemble Wroute.OnGrid.Via.Only environment variable. -froute\_on\_grid\_via\_threshold Maps to the Silicon Ensemble WRoute.OnGrid.Via.Threshold environment variable. -froute optimization Maps to the Silicon Ensemble WRoute.Optimization environment variable. -froute\_pin\_enclose\_wire {true | false} Specifies whether to force the router to connect to a pin if it encloses a wire or connect to the center of a wire if it is wider than the pin. -froute prefer on grid Maps to the Silicon Ensemble WRoute.Prefer.OnGrid environment variable. -froute\_runtime\_limit value Maps to the Silicon Ensemble WRoute.RunTimeLimit environment variable. Units are in seconds. -froute\_search\_repair Maps to the Silicon Ensemble WRoute.SearchRepair environment variable.

| -froute_taper_distar       | Maps to the Silicon Ensemble WRoute.Taper.Distance environment variable.                                                                                                                                                                                                                                                                                           |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -froute_taper_pin_se       | election {ruleBased   inputOnly   all}<br>Specifies which wires the router tapers.                                                                                                                                                                                                                                                                                 |
| -froute_use_max_x_y_       | spacing<br>Maps to the Silicon Ensemble Rule.ClearanceMeasure<br>environment variable.                                                                                                                                                                                                                                                                             |
| -froute_use_range_ru       | ale {pin   obstruction   pin+obstruction}<br>Lets you use the spacing rule that is defined in the LEF file.                                                                                                                                                                                                                                                        |
| -froute_xtalk_thresh       | Specifies the maximum length for parallel wire segments. If the router finds parallel wire segments that exceed the specified length, it attempts to space out the wires by one additional track within a global routing cell (gcell) to avoid crosstalk. If the gcell does not have enough room, the router completes the routing without the additional spacing. |
| -groute_discourage_p       | Delanar_routing {true   false}<br>Specifies whether to penalize routing over blocks when only one<br>routing layer is available. Planar routing (routing on one layer)<br>increases the possibility that wires will cross.                                                                                                                                         |
| -groute_ggrid_mode         | Maps to the Silicon Ensemble WRoute.GGridMode environment variable.                                                                                                                                                                                                                                                                                                |
| -groute_incremental        | Maps to the Silicon Ensemble WRoute.Incremental.Global environment variable.                                                                                                                                                                                                                                                                                       |
| -include <i>filename</i> . | <br>Lets you use secondary configuration files for the router so you<br>can include options in additional files. You can have up to ten<br>nesting levels of options.                                                                                                                                                                                              |

| -input_db_name dired      | Specifies the database directory. Maps to the Silicon Ensemble<br>WRoute.Input.DbName environment variable. This option is<br>required.                                                                                                                                        |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -input_def_name {fil      | eName   "list_of_files"}<br>Specifies the name of the DEF file to be input to the router.                                                                                                                                                                                      |
| -input_eco {true   f      | Makes the router more error tolerant by allowing it to delete<br>problematic nets and rerouting the affected nets. Examples of<br>problematic nets are nets with loops and nets for which the router<br>cannot extract connectivity.                                           |
| -input_gcf_constrain      | Its {fileName   "list_of_files"}<br>Specifies the general constraint format (GCF) constraint file or<br>files. Use GCF files to define system-level constraints (SLCs)<br>and timing libraries. You can use the same GCF file for the<br>constraints and the timing libraries. |
| -input_gcf_timing_li      | <pre>braries {fileName   "list_of_files"} Specifies the GCF file or files containing the timing libraries. This option is required to run timing-driven routing.</pre>                                                                                                         |
| -input_ldef_comment_      | _char<br>Maps to the Silicon Ensemble Input.Comment.Delimiter<br>environment variable.                                                                                                                                                                                         |
| -input_lef_name {fil      | <pre>lename   "list_of_files" } Maps to the Silicon Ensemble WRoute.Addition.LefName environment variable.</pre>                                                                                                                                                               |
| -log_file <i>filename</i> | Dumps the Wroute log file.                                                                                                                                                                                                                                                     |
| -no_license_sharing       | Runs Wroute version 34 or older, which does not take license token from PKS and will checkout its own license.                                                                                                                                                                 |

| -output_db_name file | Specifies the directory to use for the output database. Maps to the Silicon Ensemble WRoute.Output.DbName environment variable.                                                                                                                                                                                                                                                                                                              |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | <b>Note</b> : If you specify this option with no filename, the tool will error out. If you omit this option, no database file will be written out.                                                                                                                                                                                                                                                                                           |
| -output_def_name fil | ename<br>Specifies the name to use for the output DEF file. Maps to the<br>Silicon Ensemble WRoute.Output.DefName environment<br>variable.                                                                                                                                                                                                                                                                                                   |
|                      | <b>Note</b> : If you specify this option with no filename, the tool will error out. If you omit this option, no DEF file will be written out.                                                                                                                                                                                                                                                                                                |
|                      | <b>Note</b> : By default, do_wroute writes the output file in the DEF version of the file you originally loaded, or DEF version 5.4, whichever is the newer version.                                                                                                                                                                                                                                                                         |
| -processor           | Maps to the Silicon Ensemble WRoute.Processor environment variable.                                                                                                                                                                                                                                                                                                                                                                          |
| -route_area          | Maps to the Silicon Ensemble WRoute.Route.Area environment variable.                                                                                                                                                                                                                                                                                                                                                                         |
| -route_bottom_layer_ | <pre>limit Maps to the Silicon Ensemble WRoute.BottomLayer.Limit environment variable.</pre>                                                                                                                                                                                                                                                                                                                                                 |
| -route_chip_assembly | _mode {true   false}<br>Specifies whether to scan the design to determine the necessity<br>for chip-assembly routing and changes heuristics during detailed<br>routing, depending on the percentage of the area of the design<br>that is covered by blocks, rings, or pads. In chip-assembly mode,<br>the router runs an order of magnitude faster than in no-chip-<br>assembly mode at the expense of slightly degraded routing<br>quality. |

| -route_final         | Maps to the Silicon Ensemble Wroute.Final environment variable.                                                                                                                                                                      |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -route_final         | Maps to the Silicon Ensemble WRoute.Incremental.Final environment variable.                                                                                                                                                          |
| -route_global        | Maps to the Silicon Ensemble WRoute.Incremental.Final environment variable.                                                                                                                                                          |
| -route_modify_prerou | te_pass<br>Maps to the Silicon Ensemble<br>WRoute.Modify.PreroutePass environment variable.                                                                                                                                          |
| -route_select_net {n | <pre>metname   "list_of_nets"} Maps to the Silicon Ensemble WRoute.SelectNets environment variable.</pre>                                                                                                                            |
| -route_select_net_fi | <pre>rst {true   false} Maps to the Silicon Ensemble WRoute.SelectNet.First environment variable.</pre>                                                                                                                              |
| -route_select_net_la | <pre>syer_range {bottom_layer   "bottom_layer:top_layer"} Specifies a layer range for selected nets if all nets are being routed. You can specify a bottom layer for routing the selected nets or both a bottom and top layer.</pre> |
| -route_soft_top_laye | r_limit {true   false}<br>Specifies whether to allow routing on layers higher than the one<br>set by routeTopLayerLimit.                                                                                                             |
| -route_straighten_ne | t [~] {netName   "list_of_nets"   "< fileName"  <br>" fileName" }<br>Deletes specified nets in a fully routed design and reroutes them<br>as straight as possible.                                                                   |
| -route_stripe_center | _connect {true   false}<br>Controls whether the router connects to the center of wide<br>stripes only, not to power or ground pins.                                                                                                  |

| -route_top_layer_lim         | it <i>integer</i><br>Maps to the Silicon Ensemble WRoute.TopLayer.Limit<br>environment variable.                                                                                                                                                                                                      |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -timing_driven_routi         | ng<br>Maps to the Silicon Ensemble WRoute.Timing.Driven<br>environment variable.                                                                                                                                                                                                                      |
| -timing_fall_transit         | ion<br>Maps to the Silicon Ensemble<br>WRoute.Timing.Fall.Transition environment variable.                                                                                                                                                                                                            |
| -timing_net_percenta         | ge_delta<br>Maps to the Silicon Ensemble<br>WRoute.Timing.Net.Percentage.Delta environment<br>variable.                                                                                                                                                                                               |
| -timing_rise_transit         | ion<br>Maps to the Silicon Ensemble<br>WRoute.Timing.Rise.Transition environment variable.                                                                                                                                                                                                            |
| -timing_use_est_cap          | Maps to the Silicon Ensemble WRoute.Timing.Use.Est.Cap environment variable.                                                                                                                                                                                                                          |
| -xtalk_fix_net { <i>netN</i> | <pre>Iame   "list_of_nets"   &lt; fileName } Performs postroute crosstalk fixing on selected nets by pushing adjacent routing aside. Use this option on a fully routed database during final routing only.</pre>                                                                                      |
|                              | <pre>a [ class_b] + class_a [ class_b]<br/>[,class_a [ class_b] + class_a [ class_b]<br/>]"<br/>Specifies the interaction rules for crosstalk classes. Cadence<br/>recommends you use xtalkRule "0+0" if you need to<br/>minimize crosstalk.<br/>Default: false (Crosstalk class for all nets.)</pre> |
| -xtalk_rule_threshol         | d threshold<br>Specifies the wire-length threshold for nets to be affected by the                                                                                                                                                                                                                     |

class interaction rule for crosstalk.

## Examples

Refer to the Ultra Router Reference available with the Silicon Ensemble documentation set.

#### **Additional Information**

read wdb

write wdb

## do\_xform\_tcorr\_eco

do\_xform\_tcorr\_eco [-opt\_passes num] [-fix\_design\_rule] [-reclaim\_area]

## Important

This command will be removed in the next full release of the software. Use the do\_optimize -legalize\_only option to legalize the placement of the design.

Performs one pass of placement spreading and QP-eco followed by a loop of <code>opt\_passes</code> iterations of TC/QP-eco

```
where the TC command is do_xform_timing_correction
-quick -incremental -resize
-dont_fix_design_rules -dont_reclaim_area
```

This command is typically used as a cleanup step after obtaining the results from do\_optimize. It results in a legal placement of the design.

## **Options and Arguments**

| -fix_design_rule        | Turns on fixing design rules during timing correction.           |
|-------------------------|------------------------------------------------------------------|
| -opt_passes <num></num> | Defines the number of optimization passes.<br><i>Default</i> : 1 |
| -reclaim_area           | Turns on reclaim area during timing correction.                  |

## Examples

The following command performs only legalization on the design:

do\_xform\_tcorr\_eco -opt\_passes 0

The following command performs legalization and reoptimization including area reclaiming on the design:

do\_xform\_tcorr\_eco -opt\_passes 1 -reclaim\_area

## generate\_supply\_rails\_on\_rows

generate\_supply\_rails\_on\_rows

Removes any existing supply rails on rows, then generates new rails over the rows.

#### **Related Information**

remove supply rails on rows

report supply rails on rows

set supply rails on rows

## get\_cluster

get\_cluster instance\_name\_or\_id

Returns the cluster immediately associated with the specified instance or ID.

#### **Options and Arguments**

inst\_name\_or\_id

Specifies the name of the instance or ID.

#### **Related Information**

- create physical cluster
- remove physical cluster

## get\_cluster\_contents

```
get_cluster_contents cluster_name [-hier] [-tcl_list]
      [-instances | -clusters | -physical_instances]
```

Returns the instances directly associated to a cluster or immediate subclusters.

#### **Options and Arguments**

| cluster_name | Specifies a hierarchical physical cluster name.                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -clusters    | Lists the cluster names of all subclusters (recursively if the -hier option is specified). Note that it does not descend into soft_block subclusters.                              |
| -hier        | Lists the instances that are contained with children subclusters that are of type region or group (similarly for a list of subclusters).                                           |
| -instances   | Lists all instances that are directly associated with that cluster<br>and with clusters below if -hier is specified. Note that it does<br>not descend into soft_block subclusters. |
| -tcl_list    | Returns the report as a list.                                                                                                                                                      |

#### **Examples**

- The following command provides a list of the immediate subclusters of the root cluster: get\_cluster\_contents / -clusters
- The following command provides a list of all clusters defined in a design:

```
Proc getAllClusters {cluster_name} {//pseudo-code only. Not strictly legal Tcl
Set cc [get_cluster_contents cluster_name -hier -clusters]
If [get_cluster_physical_info $cc .eq. soft_block]
GetAllClusters $cc
Puts "$cc"
}
getAllClusters /
```

## **Related Information**

get cluster physical info

## get\_cluster\_names

get\_cluster\_names [-children] [-root]

Returns the name of either the root cluster, the children, or both. This command works with the current top timing module.

#### **Options and Arguments**

-children

Specifies the name of the cluster's children.

-root

Specifies the name of the root cluster.

#### **Related Information**

set top timing module

## get\_cluster\_physical\_info

```
get_cluster_physical_info cluster_name [-tcl_list] [-soft_block]
    [-associated_instances] [-placed] [-unplaced_top] [-origin] [-bbox]
    [-utilization] [-max_utilization] [-row_utilization] [-max_half_perim]
    [-max_x_perim] [-max_y_perim] [-allow_place_overlap] [-allow_route_overlap]
```

Returns a Tcl list of known attributes on the cluster, such as type, location, and so on.

#### **Options and Arguments**

cluster\_name

Specifies the name of the cluster you want information about.

#### Example

get\_cluster location

#### **Related Information**

get\_cluster

## get\_current\_cluster

get\_current\_cluster

Lets you locate where you are in the cluster hierarchy. When traversing through a hierarchy you may forget where you are, this command returns the name of the current cluster.

## get\_current\_congestion

get\_current\_congestion

Returns a measure of the congestion in the design (expressed as a percentage) for horizontal and vertical routes. The first number reports congestion in horizontal routes. The second number reports congestion in vertical routes.

The reported numbers represent the average number of excess routing tracks required per bin, expressed as a percentage of bin routing supply. Mathematically, the values reported are as follows:

congestion/supply \* 100

where congestion equals the total number of all tracks in excess of supply in congested bins, and supply equals the total number of tracks available in all bins.

The calculations for horizontal and vertical routing are done separately.

## get\_current\_utilization

get\_current\_utilization

Returns the current standard cell row utilization of a design by dividing the current total standard cell area by the effective sites in the design computed after accounting for all.

## get\_ground\_net

get\_ground\_net

Returns the name of the ground net that was set using the set\_ground\_net command.

#### **Related Information**

get power net

set ground net

set power net

## get\_library\_layer\_offset

get\_library\_layer\_offset layername

Returns the offset value for a given routing layer (specified in the physical library). Only routing layers may have offsets, so the layername is the name of a routing layer. The offset value is in user units (similar to LEF data).

Note: The offset value is retrieved from the database that stores physical library data.

## **Options and Arguments**

layername

Specifies the name of the routing layer.

#### **Related Information**

set library layer offset

## get\_logic\_0\_net

get\_logic\_0\_net

Gets the name of the tie low net used in  $write_def$  to dump the connectivity associated with the tie lows.

## **Related Information**

get logic 1 net

## get\_logic\_1\_net

get\_logic\_1\_net

Gets the name of the tie high net used in  $write_def$  to dump the connectivity associated with the tie high.

#### **Related Information**

get logic 0 net

## get\_min\_porosity\_for\_over\_block\_routing

get\_min\_porosity\_for\_over\_block\_routing

Returns the current value set by set\_min\_porosity\_for\_over\_block\_routing

#### **Related Information**

set min porosity for over block routing

## get\_min\_wire\_length

get\_min\_wire\_length

Gets the current value of the minimum wire length variable.

#### **Related Information**

set min wire length

## get\_physical\_info

```
get_physical_info [{-instance | -pin | -net} {object_name | FNPid}] [-bbox]
    [-center] [-dbunits] [-def_name] [-def_properties] [-direction] [-halo]
    [-hperimeter] [-ipin_name name] [-layer_usage_table] [-lef_multiplier]
    [-length] [-location] [-ndr_rule] [-orientation] [-direction] [-type] [-size]
    [-state] [-table] [-use name] [-vias]
```

Queries the physical information for a specified object.

Note: If no arguments are specified, all information is returned for the specified object.

All outputs of get\_physical\_info are in HêP units, not database units.

## **Options and Arguments**

| -bbox           | Returns the specified object's bounding box.                                                                                                                                                                                                                                      |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -center         | Returns the specified object's center ( $x$ , $y$ coordinates). Note that the -net argument is not available with this argument.                                                                                                                                                  |
| -dbunits        | Specifies that the output be in database units.                                                                                                                                                                                                                                   |
| -def_name       | Returns the specified object's DEF name as it would appear in<br>the DEF file. One application would be to associate a net<br>appearing in a timing critical path with a net name in the DEF file.<br>The returned name conforms to DEF syntax with respect to<br>escaping rules. |
| -def_properties | Returns all the DEF properties of the pin, instance, or net.                                                                                                                                                                                                                      |
| -direction      | Returns the direction (input, output, feedthrough, or none) of the signal flow through a physical pin. Note that this argument is used only with the -pin argument.                                                                                                               |
| -halo           | Returns the left, right, bottom, and top halos of the physical.                                                                                                                                                                                                                   |

|                        | instance. Note that this argument is used only with the -instance argument.                                                                                                                                                                      |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -hperimeter            | Returns the half perimeter of the specified physical net.                                                                                                                                                                                        |
| {-instance   -pin      | -net} {object_name   FNPid}<br>Identifies the physical instance, physical pin, or physical net<br>specified by object_name. FNPid specifies logical objects.<br>object_name is interpreted non-hierarchically in the current<br>cluster context. |
| -ipin_name <i>name</i> | Identifies an instance pin specified by name. Use this argument in conjunction with the [-instance object name   FNPid] argument.                                                                                                                |
| -layer_usage_table     | Returns the layer usage table information for the specified physical net.                                                                                                                                                                        |
| -lef_multiplier        | Returns the LEF multiplier information for the specified physical net.                                                                                                                                                                           |
| -length                | Returns the wire length of the specified physical net. If routed, it will return the length based on the route.                                                                                                                                  |
| -location <i>loc</i>   | Returns the location of a pin, instance, or instance pin.                                                                                                                                                                                        |
| -ndr_rule              | Returns the NDR rules information for the specified physical net.                                                                                                                                                                                |
| -orientation           | Returns the specified object's orientation in DEF format (N, S, W, E, FW, FE, FS, FN). Note that the $-net$ argument is not available with this argument.                                                                                        |
| -size                  | Returns the specified object's width and height $(x, y)$ coordinates). Note that -net is not available with this argument.                                                                                                                       |

| -state    | Returns the specified object's placement state. Note that -net is not available with this argument.                                                                                                                           |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -table    | Outputs in ASCII table format.                                                                                                                                                                                                |
| -type     | Returns the physical pin type (special route or not). Note that this argument is used only with the -pin argument.                                                                                                            |
| -use name | Returns the DEF_USE for the pin or net (such as SIGNAL, CLOCK, and so on).                                                                                                                                                    |
| -vias     | Returns the number of vias for the specified physical net. If the<br>net is not routed, this number will come from the LUT and Steiner<br>estimation. If it is routed, it will come from the actual vial count in<br>the net. |

## Examples

- The following command returns the location of instance I1, if find is successful: get\_physical\_info -instance [find -instance I1] -location {20 30}
- The following command returns the location of instance pin I1/A: get\_physical\_info -instance [find -instance I1] -ipin\_name A -location {25, 34}
- The following command returns the location of the FILLER1 instance if found in the current cluster context:

```
get_physical_info -instance FILLER1 -location {35, 40}
```

## **Related Information**

set\_physical\_info

## get\_pin\_location

get\_pin\_location pin\_name [-side] [-index]

Gets the side, the index, or both assigned to the *pin\_name*.

#### **Options and Arguments**

-index

| - IIIdex | Displays the index of the pin.                                    |
|----------|-------------------------------------------------------------------|
| pin_name | Specifies the name of the pin whose side and index are displayed. |
| -side    | Displays the side assigned to the pin.                            |

#### Examples

- The following command displays the side and the index assigned to the clk pin: get\_pin\_location clk
- The following command displays the side assigned to the clk pin: get\_pin\_location clk -side

## **Related Information**

set pin location

## get\_power\_net

get\_power\_net

Returns the name of the power net that was set using the set\_power\_net command.

#### **Related Information**

set power net

get ground net

set ground net

## get\_route\_availability

get\_route\_availability -layer layername

Provides the raw routing layer percentage that is used by the congestion analysis engine after considering preroutes. The default value is 100% for each routing layer.

#### **Options and Arguments**

layername

Specifies the name of the routing layer.

#### Example

The following command returns the raw routing layer (metal4) percentage used by the congestion analysis engine after considering preroutes:

get\_route\_availability -layer metal4

#### **Related Information**

set\_route\_availability

## get\_special\_netpins

get\_special\_netpins -type { power | ground }

Gets a list of the special pins in the current module that are of the type specified by the -type argument.

## **Options and Arguments**

-type {power | ground)

Determines the special pins type. The special pins type is defined as either power or ground.

#### **Related Information**

set\_special\_netpin

## get\_steiner\_capacitance

get\_steiner\_capacitance list\_of\_net\_name\_or\_id [-min]

Gets the total steiner wire capacitance of the specified nets. If more than one net is passed, the capacitances are returned as the sum of the capacitances of the individual nets. If a net is listed more than once, the capacitance is added for each occurrence of the net in the list.

**Note:** There are no -horizontal or -vertical arguments.

The resultant capacitance does not include pin capacitance, only wire capacitance. You can get the pin capacitance using the <u>get timing</u> or <u>report net</u> commands.

#### **Options and Arguments**

-min

Reports the minimum capacitance value.

#### **Related Information**

get\_steiner\_length

get steiner resistance

get timing

<u>report\_net</u>

# get\_steiner\_channel\_width

get\_steiner\_channel\_width

Returns the current value (the default value is 0, which means set\_steiner\_channel\_width is off).

## **Related Information**

set steiner channel width

# get\_steiner\_length

get\_steiner\_length [-horizontal|-vertical] list\_of\_nets

Reports the sum of the steiner wire lengths (in microns) for all nets specified in *list\_of\_nets*.

## **Options and Arguments**

-horizontal

|              | Reports the sum of the horizontal lengths (in microns) for the given net(s).                                              |
|--------------|---------------------------------------------------------------------------------------------------------------------------|
| list_of_nets | Specifies the name of the network using either the full hierarchical name of a net(s) or an ID (wildcards are supported). |
| -vertical    | Reports the sum of the vertical lengths (in microns) for the given net(s).                                                |

## get\_steiner\_resistance

get\_steiner\_resistance list\_of\_net\_name\_or\_id [-min]

Gets the total steiner wire resistance of the specified nets. If more than one net is passed, the resistances are returned as the sum of the resistances of the individual nets. If a net is listed more than once, the resistance is added for each occurrence of the net in the list.

Note: There are no -horizontal or -vertical arguments.

## **Options and Arguments**

-min

Reports the minimum resistance value.

## **Related Information**

get steiner capacitance

get steiner length

get\_timing

<u>report net</u>

# modify\_physical\_cluster

```
modify_physical_cluster -name cluster_name
    [-add_instance list_of_inst_names_or_ids]
    [-allow_place_overlap {true | false}] [-allow_route_overlap {true | false}]
    {[-bbox {lx ly ux uy}] | [-utilization float] [-aspect_ratio float] |
    [-width float] [-height float]} [-location {lx ly}]
    [-remove_instance list_of_names_or_ids] [-type {soft_block | region}]
    [-unplaced {true | false}]
```

Modifies an existing physical cluster created by the create\_physical\_cluster command. Note that this command can only be used on an existing cluster and invalidates appropriate blockage maps and timing.

## **Options and Arguments**

```
-add_instance list_of_inst_names_or_ids
                           Adds instances to the physical cluster. The command will error if
                          the addition of instances invalidates the soft cluster containment
                           rules (containingSOFTCLUSTER). If the addition of instances
                           is successful, and the cluster does not have a -bbox
                           specification and is unplaced, the estimated -bbox is modified
                           to reflect the new contained cell area.
-allow_place_overlap {true | false}
                           Allows the parent cluster to place over any placeable areas in the
                           physical cluster. Note that it does not place over any overlap
                           layer obstacles created on the cluster. If false is selected
                           (default), the cluster is completely blocked for all placement at
                           the parent level, even if overlap blockages are defined.
-allow_route_overlap {true | false}
                           Allows the parent cluster to route over any routable areas in the
                           physical cluster. Note that it does not route over any overlap layer
                          obstacles created on the cluster. If false is selected (default),
                          the cluster is completely blocked for all routing at the parent level,
                           even if overlap blockages are defined.
-bbox {lx ly ux uy} | -utilization float -aspect_ratio float |
                           -width float -height float
                           Use one of three methods (below) to modify the shape of the
                           physical cluster.
```

|                            | -bbox $\{lx \ ly \ ux \ uy\}$<br>Modifies the shape and location of the cluster using the four<br>coordinates $\{lx \ ly \ ux \ uy\}$ . All coordinates are assumed to be<br>absolute. Using this argument will make the cluster PLACED.<br>Note that you must type the curly braces in the syntax.                                                                                                |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | -utilization <i>float</i> -aspect_ratio <i>float</i><br>Modifies the bounding box by specifying the -utilization<br>(0-100) and -aspect_ratio (>0). For this to be useful, the<br>cluster should also be associated with instances.                                                                                                                                                                |
|                            | Note that the -utilization percentage is the <i>target</i> utilization for the cluster. Whenever the utilization percentage is reset this way, a new bounding box will be derived based on the current logical cell area.                                                                                                                                                                          |
|                            | The placement information (if applicable) of any contained<br>instances will be maintained. The available row area is estimated<br>based on row spacing rules of the containing soft cluster. No<br>estimation blockages are considered.                                                                                                                                                           |
|                            | -width float -height float<br>Modifies the width and height of the bounding box.                                                                                                                                                                                                                                                                                                                   |
| -location { <i>lx ly</i> } | Specifies the location of the lower-left corner of the cluster using the $lx$ and $ly$ coordinates. Note that you must type the curly braces in the syntax. Using this argument will make the cluster PLACED.                                                                                                                                                                                      |
| -name cluster_name         | Specifies the name of the subcluster at the current cluster level.                                                                                                                                                                                                                                                                                                                                 |
| -remove_instance lis       | st_of_names_or_ids<br>Removes instances from a physical cluster. The command will<br>error if the removal of instances invalidates the soft cluster<br>containment rules (containingSOFTCLUSTER). If the removal<br>of instances is successful, and the cluster does not have a<br>-bbox specification and is unplaced, the estimated -bbox is<br>modified to reflect the new contained cell area. |
| -type {soft_block          | region}<br>Defines the type of cluster you want to create. Note that if you                                                                                                                                                                                                                                                                                                                        |

request a -type soft\_block and more than one hierarchical instance is specified, the command will error out. If a cluster currently tagged as a soft\_block cluster is changed to a region cluster (soft block), routing information may be lost. This occurs because routes are held on a per soft-cluster level basis; when a non-soft cluster becomes a soft-cluster, the routes are split into two components, resulting in the routes being destroyed.

-unplaced {true | false}

Changes the placement status of the cluster. When the cluster is changed from PLACED to UNPLACED, the location of the cluster and all of its contents will remain unchanged. If true, sets the UNPLACEDTOP variable of a currently placed cluster to itself (also sets any placed sub clusters to their appropriate values). In other words, the parent cluster rows can now be placed over the cluster even if it has been set to -allow\_place\_overlap false. If set to false, will make an unplaced cluster placed.

## Examples

modify\_physical\_cluster -name a1 -type region
modify\_physical\_cluster -name A1 -allow\_overlap true

## **Related Information**

create\_physical\_cluster

# pks\_shell

```
pks_shell [-64] [[-f] filename] [-cmdfile command_filename]
      [-logfile log_filename] [-cdsdocd {on | off}] [-queue] [-expire] [-version]
      [-help] [-continue] [-no_init] [-set var=value ...] [-which] [-gui]
      [-display machine:0] [-geometry intxint+int+int] [-fullscreen] [-large]
      [-limit] [-colormap colormap_file]
```

Starts the Cadence Physically Knowledgeable Synthesis (PKS) tool. For more detail on starting pks\_shell, refer to <u>Before You Begin</u> in the PKS User Guide.

## **Options and Arguments**

| -64                        | Starts a 64-bit pks_shell session. Default is 32 bit.                                                                                                                                                                                                                                                                                   |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -cdsdocd {on   off}        | Enables or disables the use of browser-based documentation for pks_shell help. When set to on, the full documentation set is available from the <i>Help</i> button in the GUI. When set to off, only the syntax is displayed in the command line. The default is on when running in GUI mode and off when running in command line mode. |
| -cmdfile <i>command_fi</i> | <i>lename</i><br>Specifies the name of the command file.<br>Default: pks_shell.cmd                                                                                                                                                                                                                                                      |
| -colormap                  | Specifies the color map file.                                                                                                                                                                                                                                                                                                           |
| -continue                  | Specifies to not exit after an error in Tcl script file.                                                                                                                                                                                                                                                                                |
| -display machine:0         | Specifies the system display to use.                                                                                                                                                                                                                                                                                                    |
| -expire                    | Displays the expiration date of the license.                                                                                                                                                                                                                                                                                            |
| -f filename                | Specifies the name of the Tcl script file to source at startup. You can use <i>filename</i> without specifying the <i>-f</i> .                                                                                                                                                                                                          |

| -fullscree        | n                            | Uses entire screen for the pks_shell.                                                                                                                                                                                                                                                                                                                                      |
|-------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -geometry         | int <b>x</b> int <b>+</b> ir | Sets the initial size and position of the GUI main screen window.<br>Where <i>width</i> and <i>height</i> are in pixels. And <i>xoff</i> and <i>yoff</i> are the number of pixels from the corner; a negative value is measured from the bottom or right corners, and a positive value is measured from the top or left corners. No spaces are allowed between the values. |
|                   |                              | For example: -geometry 800x400+10-30 means create a window 800 by 400 pixels with its left edge offset 10 pixels from the left edge of the screen and its bottom edge offset 30 pixels from the bottom of the screen                                                                                                                                                       |
|                   |                              | Valid only in GUI mode.                                                                                                                                                                                                                                                                                                                                                    |
| -gui              |                              | Starts the graphical user interface (GUI) mode                                                                                                                                                                                                                                                                                                                             |
| -help             |                              | Prints usage message for this command.                                                                                                                                                                                                                                                                                                                                     |
| -large            |                              | Increases the memory limit above 2GB for the process running pks_shell if the memory is available.                                                                                                                                                                                                                                                                         |
| -limit            |                              | Prints the current data size limit and memory allocation limit for the machine on which the software will run.                                                                                                                                                                                                                                                             |
| -logfile <i>l</i> | og_filena                    | me<br>Specifies the name of the log file.<br>Default: pks_shell.log                                                                                                                                                                                                                                                                                                        |
| -no_init          |                              | Disables sourcing of ~/.ambit/.acshrc                                                                                                                                                                                                                                                                                                                                      |
| -queue            |                              | Waits for a license if none is available.                                                                                                                                                                                                                                                                                                                                  |

| -set var=value | Initializes a Tcl variable.                              |
|----------------|----------------------------------------------------------|
| -version       | Displays version of this pks_shell.                      |
| -which         | Displays the full path name of the pks_shell executable. |

## Example

The following command starts the PKS graphical user interface and saves the session log in  $cpu_design.log$ :

pks\_shell -gui -logfile cpu\_design.log

## **Related Information**

<u>check\_option</u>

## prune\_routes

prune\_routes [-keep\_top percent\_value]

Removes the routes for a given percentage of nets.

#### **Options and Arguments**

-keep\_top float Sorts the nets in your design according to the difference between the maximum source-to-sink distance from Steiner routes and real routes. The routes are retained for the top float percent of nets (those with the largest difference). The routes for all of the remaining nets will be deleted. Pruning some of the nets' routes allows PKS to perform more optimization tasks on the retained routes.

The specified percentage value (float), can be between 0 and 100. The default is 0.

# read\_cap\_table

read\_cap\_table filename

Replaces LEF capacitance values with values computed from the specified cap table file. Use this command after all LEF files have been read in (that is, after the read\_lef and/or read\_lef\_update commands) but prior to any optimization.

LEF supports AreaCap and EdgeCap per unit length on a per layer basis. The cap table provides coupling and area cap for various spacings between same-layer routes. Based on this data, PKS recalibrates the LEF EdgeCap and AreaCap values assuming there is a specific probability (70%, 25%, or 5%) of coupling happening to a route one, two, or three tracks away. For layer widths not the same as those in the cap table, a linear interpolation is performed (especially for NonDefaultRule specifications).

A layer name can be either the same as that used in the LEF or in the format "Mn" or "mn", where n is an integer corresponding to the layer order number in the LEF.

A basic cap table consists of several sections of cap information. Each section is for one layer and one particular width and must have the following format:

```
<lr><layer name>width(um) space(um) Ctot(Ff/um) Cc(Ff/um) Carea(Ff/um) Cfrg(Ff/um)......data lines (one data line for one space)...
```

The table can contain multiple sections (different widths) for the same layer, but for the table to be usable, there must be at least one section for each routing layer.

# Important

The basic section of the cap table must start with a line containing just the keyword BEGIN\_BASIC and end with a line containing just the keyword END\_BASIC. Everything before BEGIN\_BASIC and after END\_BASIC will be ignored.

# **Options and Arguments**

filename

Specifies the name of the cap table file.

## **Related Information**

read\_lef

read lef update

read\_cap\_table\_update

# read\_cap\_table\_update

read\_cap\_table\_update

Revaluates edge capacitance and reset layer capacitance, and derives a new unit capacitance to be used in any subsequent RC extraction.

The new unit capacitance is computed after the routes have been read in. The distribution of routes on the layers is analyzed, and the distribution profile (the percentages of two adjacent routes at 1-pitch, 2-pitch, and 3-pitch spacings) is derived using a bin map method. An average profile per layer is then derived from the bin values. This average profile is used together with a capacitance table to revaluate edge capacitance and reset layer capacitance per unit length.

## **Related Information**

read\_lef

read\_lef\_update

read cap table

# read\_change\_file

read\_change\_file change\_file

Reads antenna change information from the *change\_file* into the pks\_shell. These are netlist changes that result from inserting antenna diodes into the netlist during detail routing.

## **Options and Arguments**

change\_file

Specifies the change file that contains the antenna change information.

# read\_def

```
read_def [-do_not_strip_top_level_delimiter] [-hier_delimiter char]
    [-ignore_dist_cells] [-ignore_pwrgnd_pads] [-no_region]
    [-ignore_cover] {-scan_only | -ignore_scan} filename
```

Reads a Design Exchange Format (DEF) file and reads in cell placement and IO placement information, as well as final routes from the DEF. All other information in the DEF file is ignored.

**Note:** The database is modified when a DEF file is loaded.

The following applies when read\_def is used with a Scan command:

For a chain containing flip-flops driven by an internal clock domain, the tool will first try to match a scan\_data\_port command with -clk argument that matches the internal clock domain pin. If no match is found, then a second match will be made with the "root" clock pin (top level clock pin driving the internal clock signal).

The DEF reader must be enhanced to parse and optionally store the scanDEF section contained within a full DEF file. The default behavior is to both parse and store the scanDEF section, unless the read\_def command was issued with the -ignore\_scan argument. In this situation, the scanDEF section will be parsed by the reader but not stored to a data structure.

Additionally, the DEF reader must also be enhanced to read a standalone scanDEF file. For example:

```
read_verilog structuralNetlist
do_build_generic
read_def full.def
read_def -ignore_scan full.def
read_def -scan_only scan.def
```

The scan chain configuration parsed and stored from the scanDEF file, will take precedence over any BuildGates test synthesis specific configuration commands including:

```
set_number_of_scan_chains
set_max_scan_chain_length
set_dft_compatible_clock_domain
set_dont_touch_scan
```

In the event that any of the above commands have been entered into the shell prior to or after creating the scanDEF data structure, a WARNING message will be returned to the user. For example:

Example 1:

```
set_number_of_scan_chains 2
read_def -scan_only scanDEF.def
```

WARNING Scan chain configuration established through scanDEF format. ... Ignoring command: set\_number\_of\_scan\_chains

#### Example 2:

read\_def -scan\_only scanDEF.def
set\_number\_of\_scan\_chains 2

WARNING Scan chain configuration established through scanDEF format.... Ignoring command: set\_number\_of\_scan\_chains

## **Options and Arguments**

| -do_not_strip_top_le        | Vel_delimiter<br>Forces the DEF reader to ignore the top-level delimiter character<br>(if it exists in the input DEF) in situations where the Verilog is a<br>flat Verilog and has the delimiter as a part of the name.           |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | Example:<br>The flat Verilog name is: /a/b/c<br>The DEF name is: /a/b/c                                                                                                                                                           |
|                             | In the example above, the Verilog name is a flat name; therefore<br>read_def should not strip the first / character. By default,<br>read_def strips the top-level delimiter to find the instance<br>internal to the PKS database. |
| filename                    | Specifies the name of the file to be read.                                                                                                                                                                                        |
| -hier_delimiter <i>char</i> | Specifies the delimiter character to be used with instance and pin names. The default value is /.                                                                                                                                 |
| -ignore_cover               | Forces the read_def to ignore cover macros.                                                                                                                                                                                       |
| -ignore_dist_cells          | Forces the read_def to ignore filler cells when reading the input def file.                                                                                                                                                       |
| -ignore_pwrgnd_pads         | Forces the read_def to ignore physical only pads, such as power and ground pads.                                                                                                                                                  |
|                             |                                                                                                                                                                                                                                   |

| -ignore_scan | Causes the scan chains section to be excluded from the DEF output.                                                 |
|--------------|--------------------------------------------------------------------------------------------------------------------|
| -no_region   | Forces read_def to Ignore all region-related information (region definition and region reference) in the DEF file. |
| -scan_only   | Excludes all write_def outputs except the scan chains section.                                                     |

## Examples

■ The following command reads design cell placement information and also reads the IOs from the DEF file (DesignFile.def):

read\_def DesignFile.def

■ The following command designates the / character as the hierarchy delimiter for instance and pin names in the DEF file (temp.def):

read\_def -hier\_delimiter / temp.def

## **Related Information**

write\_def

# read\_gns

read\_gns [-hier] -gns\_view view\_name -gns\_lib lib\_name -gns\_tech tech\_lib\_name

# Important

The Genesis database is no longer supported. This command will be removed in a future release.

Updates the PKS physical data structure from a Genesis database (placement, floorplan, detailed routes, and global routes).

The read\_gns command does not make any change to the Genesis database.

Changes to the PKS database depend on the presence or absence of the -hier argument:

- With the -hier argument, the entire hierarchy, with the exception of any hard blocks, is updated from the Genesis database.
- Without the -hier argument, only the current module is updated in the PKS database

**Note:** The read\_gns command only updates a PKS database, it does not create one.

## **Options and Arguments**

| -hier                      | Reads a design that contains a physical hierarchy.                |
|----------------------------|-------------------------------------------------------------------|
| -gns_lib <i>lib_name</i>   | Specifies which Genesis library the command should use.           |
| -gns_tech tech_lib_n       | ame<br>Specifies which technology library the command should use. |
| -gns_view <i>view_name</i> | Specifies which Genesis view the command should use.              |

## read\_layer\_usages

read\_layer\_usages filename



This command performs operations similar to those found in other commands. If this command is used, the following commands are disabled and will have no effect:

- □ <u>set\_lef\_multiplier</u>
- □ <u>set layer usages table</u>
- □ <u>set net physical attribute</u>

Reads the layer usages table that contains wire length range definitions. See the <u>*PKS User*</u> <u>*Guide*</u> for more information about layer usages tables.

Using this command changes the default layer usages table (both clock and non-clock data) and changes all capacitance values.

#### **Options and Arguments**

filename

Specifies the name of the wire length usage table file.

## Example

read\_layer\_usages usage.txt

## **Related Information**

create layer usages table

set layer usages table

set net physical attribute

write layer usages

# read\_lef

read\_lef [-comment\_char comment\_char] [-min min\_lef\_filename] filename

Reads in the physical library data contained in the LEF file. The LEF file can be read only once during each pks\_shell session, otherwise a warning is issued.

## **Options and Arguments**

-comment\_char comment\_char Comments out the text following the *comment\_char* on the same line. You may comment out whole lines if needed. The default comment\_char is #. filename Specifies the name of the LEF file. -min min lef filename Defines all sets of min RC values as well as any subsets of them. You can use this command argument as often as needed. Each subsequent command will append a new set of min RC values or will reset the min RC values. Specifying this argument reads only the min LEF RC data. The RC data will be read only for those layers, vias, nondefault layers, or nondefault vias that have already been read by the read\_lef or read lef update commands using the -min option. All other data from *min\_lef\_filename* will be ignored. **Note**: The read\_lef\_update -min command can not be used in conjunction with the set\_net\_physical\_attribute command.

## Examples

- The following command reads the physical data from the abc.lef file: read\_lef abc.lef
- The following command reads the physical data from the amc.lef file, designating the @ symbol as a comment character:

```
read_lef amc.lef -comment_char @
```

## **Related Information**

read lef update

# read\_lef\_update

read\_lef\_update [-comment\_char comment\_char] [-min min\_lef\_filename] filename

Reads in the physical library data contained in the LEF file and adds this data to the data read in by the previous read\_lef operation. This command can only be used after the read\_lef command is issued.

**Note:** This command does not overwrite or update any library data read in by previous read\_lef and read\_lef\_update operations. It only adds new data. If you wish to update capacitance values, see <u>read\_cap\_table</u> on page 587.

## **Options and Arguments**

```
-comment_char comment_char
```

Comments out the text following the *comment\_char* on the same line. You may comment out whole lines if needed. The default *comment\_char* is #.

**Note**: The comment character used in this command may differ from the one used with the read\_lef or other read\_lef\_update commands. The comment character should be implicitly defined in each read\_lef\_update command, otherwise the comment character defined in a previous read\_lef or read\_lef\_update command is used.

filename

Specifies the name of the LEF file.

-min min\_lef\_filename

Defines or redefines all sets of min RC values as well as any subsets of them. You can use this command argument as often as needed. Each subsequent command will append a new set of min RC values or will reset the min RC values.

Specifying this argument reads only the min LEF RC data. The RC data will be read only for those layers, vias, nondefault layers, or nondefault vias that have already been read by the read\_lef or read\_lef\_update commands. All other data from min\_lef\_filename will be ignored.

**Note**: Do not use the read\_lef\_update -min command after you have issued the set\_net\_physical\_attribute command.

## Example

The following command reads the physical data from the amc\_macro.lef file and appends this data to the data read in by the previous read\_lef operation. During the read operation all \$ symbols are designated as comment characters:

read\_lef\_update amc\_macro.lef -command\_char \$

#### **Related Information**

read\_lef

# read\_pdef

```
read_pdef pdef_file_name [-flow] [-Release Status] [-pdef_version version_tag]
    [-use_name_keyword] [-ieee_location] [-print_all_messages] [-incremental]
    [-xoffset x_offset [-logical_prefix logical_prefix]
    [-instance instance_name_or_id]
```

Reads a PDEF file conforming to the V2.0 syntax. Additional constructs from the IEEE-P1481 syntax include:

- Support for RECT, ROW\_ORIENT, ORIGIN, and CONTENTS\_LOCATION attributes on clusters.
- Support for PIN construct and LOC attributes for pins.
- Support for WireLoad attributes.

Note: The database is modified when a PDEF file is loaded.

## **Options and Arguments**

| -flow                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | Maintains file integrity between the ADB and PDEF files. Use this argument after loading an ADB file. If the PDEF file contains CELL information, this information must correspond to instances in the ADB file at the time the command is issued. For example, if you run the optimize command first, it may change the netlist and therefore potentially invalidate the CELL information.                                                                      |
| -ieee_location        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                       | Uses the IEEE 1481-1999 (also referred to as IEEE or 3.0)<br>location definition instead of the PDEFVERSION 2.0 location<br>definition found in the PDEF file. Note that the PDEFVERSION<br>2.0 location definition positions cells in the lower left-hand<br>corner. Refer to IEEE 1481-1999 specifications for a definition of<br>IEEE locations. This argument overrides the PDEFVERSION<br>specification in the PDEF file and the<br>-pdef_version argument. |
| pdef_file_name        | Specifies the name of the source PDEF file.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -pdef_version version | on tag                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                       | Uses the PDEFVERSION specified by <i>version_tag</i> instead of the PDEFVERSION tag specified in the PDEF file. For example, if                                                                                                                                                                                                                                                                                                                                  |

|                        | the PDEF file contains a PDEFVERSION tag of 2.0, this argument enables you to use the 3.0 version (and vice-versa). Note that the original PDEFVERSION tag in the PDEF file will remain untouched. The specified <i>version_tag</i> value can be 2.0, or 3.0 (also referred to as IEEE or IEEE 1481-1999). |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -Release <i>Status</i> |                                                                                                                                                                                                                                                                                                            |
|                        | Sets the design state to a <i>placed</i> status if there is any CELL LOC<br>information in the PDEF file. Any subsequent use of the<br>do_optimize command is launched in the PKS mode. If you<br>don't want to use this mode, reload the design (minus the<br>read_pdef command).                         |
| -use_name_keyword      |                                                                                                                                                                                                                                                                                                            |
|                        | Uses the Name keyword structure characteristically associated<br>with PDEFVERSION 2.0. This argument overrides the<br>PDEFVERSION specification in the PDEF file and the<br>-pdef_version argument.                                                                                                        |

## Example

read\_pdef pdef\_file\_name -flow -Release Status

## **Related Information**

write pdef

# read\_wdb

read\_wdb [-rspf\_only {true | false}] wdb\_name

Reads routes and netlist changes (antenna diodes) from the .wdb file.

You can do two things with this information:

- 1. Keep the routes inside PKS for further use, for example, to write\_adb to save routes in ADB, to do a timing analysis based on routed parasitics, or to do a post-route IPO based on routing segments.
- 2. Do not keep the routes, for example to save memory, but extract the RC information and annotate it into the pks\_shell for timing analysis. The extracted RC information can also be saved in the form of a reduced standard parasitic format (RSPF) file.

## **Options and Arguments**

-rspf\_only {true | false}

Extracts and annotates RSPF information.

wdb\_name

Specifies the name of the wroute database (WDB).

## **Related Information**

write wdb

## remove\_blockage

```
remove_blockage {[{x y}] | [-bbox {lx ly ux uy}]} [-layer list_of_layernames]
    [-instance name_or_id] [-type {placement_only | routing_only | soft_block |
    regular}] [-all]
```

Removes a blockage type created with the create\_blockage command. The exact arguments must be given to remove a specified block.

## **Options and Arguments**

-all

Removes all the blockages.

-instance name\_or\_id

Removes the blockage associated with any instance of CLASS BLOCK in the design specified by name\_or\_id.

-layer list\_of\_layernames Removes blockages only on the specified layers.

## **Examples**

remove\_blockage {10 10}
remove\_blockage -layer METAL1
remove\_blockage -all

## **Related Information**

create blockage

report\_blockage

## remove\_physical\_cluster

remove\_physical\_cluster -name cluster\_name

Removes a physical cluster created by the create\_physical\_cluster command. *cluster\_name* is interpreted as a hierarchical cluster name. Any instances that were associated to the removed cluster are now associated to the parent cluster. If the removed cluster is a soft\_block, all routing information is removed from that cluster. Note that you cannot remove the root cluster.

## **Options and Arguments**

-name cluster\_name

Specifies the name of the physical cluster being removed.

## **Related Information**

create physical cluster

## remove\_physical\_connection

```
remove_physical_connection -net net_name_or_id [-cluster_pin cluster_pin_list]
      [-physical_pin physical_pin_list]
```

Removes true physical pins created by the add\_physical\_connection command.

Note: Wildcard connectivity cannot be removed.

## **Options and Arguments**

-cluster\_pin*cluster\_pin\_list* Defines the cluster pin names in a current cluster or a direct soft\_block sub-cluster.

-net physical\_netname Specifies the name of a physical net in the current cluster context.

-physical\_pinphysical\_pin\_list

Defines a set of specific physical cell instance pins to which the physical net is connected to.

## Example

The following command removes net  $n_{310}$  from the design:

remove\_physical\_connection -net n\_310

## **Related Information**

add\_physical\_connection

## remove\_physical\_instance

remove\_physical\_instance instance\_name

Removes the physical instance created by the create\_physical\_instance command.

## **Options and Arguments**

name

Specifies the name of the physical object (non-hierarchical) that is searched for in the current\_cluster context.

#### **Related Information**

create physical instance

# remove\_physical\_net

remove\_physical\_net net\_name

Removes the physical net created by the create\_physical\_net command.

## **Options and Arguments**

net\_name

Specifies the name of the physical object (non-hierarchical) that is searched for in the current\_cluster context.

#### **Related Information**

create physical net

# remove\_physical\_pin

remove\_physical\_pin name

Removes the physical pin created by the create\_physical\_pin command.

## **Options and Arguments**

name

Specifies the name of the physical object (non-hierarchical) that is searched for in the current\_cluster context.

#### **Related Information**

create physical pin

## remove\_placement\_area

remove\_placement\_area [-by\_name name] [-by\_position {x y}] [-all]

Removes a specified placement area.

Note: Using this command can cause significant timing changes in ECO due to unplaceable areas.

## **Options and Arguments**

| -all                     | Removes all placement areas.                                                                                                                                     |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -by_name                 | Removes a placement area based on its name.                                                                                                                      |
| -by_position $\{x \ y\}$ | Removes a placement area based on its location specified by the $x$ , $y$ coordinate pairs used. Note that you must type the curly braces in the command syntax. |
| name                     | Specifies the name of the placement area                                                                                                                         |

Specifies the name of the placement area.

## **Examples**

```
remove_placement_area -by_name a1
remove_placement_area -by_position [3524. 2480.]
remove_placement_area -all
```

## **Related Information**

create placement area

report\_placement\_area

# remove\_supply\_rails\_on\_rows

remove\_supply\_rails\_on\_rows

Removes any supply rails that are lying on rows.

#### **Related Information**

generate supply rails on rows

report supply rails on rows

set supply rails on rows

# report\_block\_halo

report\_block\_halo list\_of\_instance\_names

Reports the block halo that has been set around all of the macro blocks in the design. If no block halo is set, the default is reported.

## **Options and Arguments**

*list\_of\_instance\_names* Specifies the name of the instance being checked.

## Example

report\_block\_halo blockA/i\_10

## **Related Information**

set block halo

# report\_blockage

report\_blockage [-instance name\_or\_id] [-type {placement\_only | routing\_only |
 soft\_block | regular}]

Reports the blockage specifications created with the create\_blockage command. The exact arguments must be given to report on a specified block. If no arguments are specified, all blockages are reported in the ASCII table.

## **Options and Arguments**

-instance name\_or\_id Reports the blockage specifications of any instance of CLASS BLOCK in the design specified by name\_or\_id.

## Example

The following example assumes you created the blockages using the following commands:

```
create_blockage -bbox {0 0 266.50 284.54} -type routing_only -instance I2/u1_pgcore/fifo/
gfx_fram_i/ram_64_32
create_blockage -bbox {0 0 129.56 446.08} -type routing_only -instance I2/u1_pgcore/clut/rd_clut/
ram_64_32
```

The following command displays the report below:

the report\_blockage

| +<br>  Type | bBox                                               | Layer_blocked | +<br>  Instance_name                                                         |
|-------------|----------------------------------------------------|---------------|------------------------------------------------------------------------------|
|             | 0.00 0.00 266.50 284.54<br>0.00 0.00 129.56 446.08 |               | I2ul_pgcore/fifo/gfx_fram_i/ram_64_32<br>I2/ul_pgcore/clut/rd_clut/ram_64_32 |

**Note:** The Instance\_name entries in the report contain full hierarchical paths to eliminate any confusion.

## **Related Information**

create\_blockage

remove blockage

## report\_cluster

report\_cluster cluster\_name [-tcl\_list]

Reports the following design information:

- Number of components, nets, pins, physical instances, physical nets, physical pins
- Number of core instances (fixed/placed/unplaced)
- Number of block instances (fixed/placed/unplaced)
- Number of cover cells
- Number of clusters (region/soft)
- Number of sites / core instance size
- Average row utilization
- Number of power specifications

## **Options and Arguments**

-tcl\_list

Reports a Tcl list of the design information.

#### Example

The following command reports on cluster C1 and outputs the information in a Tcl list: report\_cluster C1 -tcl\_list

# report\_floorplan\_parameters

report\_floorplan\_parameters [-tcl\_list]

Reports information about the floorplan. To change and control these parameters, use the set\_floorplan\_parameters command.

#### **Options and Arguments**

-tcl\_list

Reports a Tcl list of floorplan parameters.

#### Example

The following is a typical output file for the report\_floorplan\_parameters command:

| +                               |          | +       |
|---------------------------------|----------|---------|
| FloorplanParameter              | Value    | Source  |
| -bbox initial <lx></lx>         | 0.000    | Derived |
| -bbox initial <ly></ly>         | 0.000    | Derived |
| -bbox_initial <ux></ux>         | 750.400  | Derived |
| -bbox_initial <uy></uy>         | 748.000  | Derived |
| -bbox_start <lx></lx>           | 0.000    | Default |
| -bbox_start <ly></ly>           | 0.000    | Default |
| -bbox_start <ux></ux>           | 750.400  | Default |
| -bbox_start <uy></uy>           | 748.000  | Default |
| -lr_io_to_core_distance <l></l> | 4.800    | Default |
| -lr_io_to_core_distance <r></r> | 4.800    | Default |
| -tb_io_to_core_distance <b></b> | 6.000    | Default |
| -tb_io_to_core_distance <t></t> | 6.000    | Default |
| -aspect_ratio_initial           | 1.000    | User    |
| -fixed_floorplan                | true     | Default |
| -height_initial                 | 600.000  | Default |
| -width_initial                  | 400.000  | Default |
| -max_height                     | -        | Default |
| -max_width                      | -        | Default |
| -row_utilization_initial        | 70.018%  | Derived |
| -row_utilization_current        | 70.011%  | Derived |
| -max_row_utilization            | 90.000%  | Default |
| -max_local_row_utilization      | 100.000% | Default |
| -row_spacing                    | 0.000    | Default |
| -abut_row_pairs                 | false    | Default |
| -flip_alternate_rows            | false    | Default |
| -lr_block_halo                  | 0.000    | Default |
| -tb_block_halo                  | 0.000    | Default |
| -top_layer_limit                | 5        | Default |
| -bottom_layer_limit             | 1        | Default |
| +                               |          | +       |

## **Related Information**

do initialize floorplan

set floorplan parameters

## report\_grow\_parameters

report\_grow\_parameters

Reports information about how the design is to grow. To change and control these parameters, use the set\_grow\_parameters command.

## Example

The following shows a typical output file for the report\_grow\_parameters command:

| Grow Parameter                                                                                 | Value                                                               | Source                                              |
|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------|
| -grow_origin<br>-max_left_offset<br>-max_bottom_offset<br>-max_right_offset<br>-max_top_offset | $ \begin{array}{c} 1r\\ 100.000\\ 0.000\\ 2147483.750 \end{array} $ | Derived<br>Default<br>Default<br>Default<br>Default |

## **Related Information**

set grow parameters

# report\_net\_distribution

report\_net\_distribution [-tcl\_list]

Reports information on signal nets:

- Number of term nets (0/1/2/3/4/5/6/7/8/9/10-19/20-29/30-39/40-49/50-99/>=100)
- Average terms per net
- Total number of nets
- Total number of nets with route information
- Total number of unplaced nets
- Total wirelength of all fully placed nets (horizontal/vertical)

## **Options and Arguments**

-tcl\_list

Reports a Tcl list of the signal net information.

## report\_net\_rc

report\_net\_rc [-net net\_name\_or\_id\_list] [-tcl\_list]

Reports the following resistance and capacitance values for nets:

- *NetName*—the name of the specified net(s).
- *Steiner R*/*C*—the pure steiner calculated values independent of any route data.
- *SteinerLeng H*/*V*—the horizontal and vertical wirelength values.

All information is generated from the current top timing module. Use the do\_push command to collect data at the sub levels.

The reported net capacitance is in two parts: Ignore Route and With Route. For a placed netlist the Ignore Route and With Route capacitances are same. For a routed netlist, the Ignore Route part has steiner based net length capacitance, and the With Route part has routed net length capacitance.

**Note:** This command reports the capacitance of the net only, not input pins. The reported net capacitance is based on PKS extraction only, and is independent of the standard parasitic values read in through read\_spf and read\_spef.

#### **Options and Arguments**

| -net list_of_nets | Specifies the name of the nets you are reporting on.                                                                                                                                                                                               |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | <b>Note</b> : The list of nets you provide must include the top level of<br>any net for which you want a report. If you are not sure whether<br>one of the nets in your list belongs to a logically lower level net,<br>use the following command: |
|                   | report_net_rc -net [get_physical_info -def_name netname]                                                                                                                                                                                           |
| -tcl_list         | Reports a Tcl list of the resistance and capacitance values.                                                                                                                                                                                       |

## Example

#### The following command generates the report below:

report\_net\_rc -net [find -net fmyx\_w\_fbys\_1\*]

|                                                                                                                                                                                                                     |                                                                                                                                            | Ignore                                                                                                                                                                         | Route                                                                                                                                   |                                                                                                                                    |                                                                                                                                                          | With F                                                                                                                                | Route                                                                                                                                   |                                                                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                     |                                                                                                                                            | RC                                                                                                                                                                             | Leng                                                                                                                                    | gth                                                                                                                                |                                                                                                                                                          | RC                                                                                                                                    | Len                                                                                                                                     | gth                                                                                                                                            |
| NetName                                                                                                                                                                                                             | R                                                                                                                                          | С                                                                                                                                                                              | (н)                                                                                                                                     | (V)                                                                                                                                | R                                                                                                                                                        | С                                                                                                                                     | (н)                                                                                                                                     | i (v)                                                                                                                                          |
| fmyx_w_fbys_1<br>fmyx_w_fbys_10<br>fmyx_w_fbys_11<br>fmyx_w_fbys_11<br>fmyx_w_fbys_13<br>fmyx_w_fbys_13<br>fmyx_w_fbys_14<br>fmyx_w_fbys_15<br>fmyx_w_fbys_16<br>fmyx_w_fbys_18<br>fmyx_w_fbys_18<br>fmyx_w_fbys_19 | 646.01526<br>460.57712<br>502.02869<br>571.04242<br>381.87839<br>441.82913<br>420.7468<br>315.18405<br>431.91675<br>597.97314<br>341.48364 | 0.4069874<br>0.2679894<br>0.2679894<br>0.30004334<br>0.34186554<br>0.23812148<br>0.27537292<br>0.26710063<br>0.18819347<br>0.28434074<br>0.26434074<br>0.36327013<br>0.2199838 | 953.77301<br>525.58398<br>525.58398<br>715.10498<br>934.06799<br>654.495<br>743.78497<br>570.51801<br>573.802<br>599.13599<br>779.63898 | 789.005<br>616.52899<br>570.35999<br>536.927<br>370.31201<br>440.64401<br>570.29303<br>239.14<br>614.87201<br>772.11798<br>246.211 | 817.95959<br>649.78772<br>649.78772<br>747.94464<br>734.40808<br>509.46411<br>738.41486<br>533.51868<br>450.31918<br>581.57349<br>831.82684<br>434.00464 | 0.58929509<br>0.30598477<br>0.40084186<br>0.43712389<br>0.23627302<br>0.52558601<br>0.285997<br>0.2295174<br>0.29739299<br>0.65578598 | 900.34698<br>498.849<br>726.73297<br>922.75299<br>621.84003<br>623.37598<br>523.45398<br>590.54199<br>565.70203<br>941.67499<br>763.573 | 1704.109<br>804.0139<br>985.8679<br>985.8679<br>962.6480<br>1802.6480<br>1690.954<br>618.7089<br>412.4299<br>1718.1160<br>2006.908<br>331.5759 |

## report\_overlap

report\_overlap [-detail] [-snap]

Reports number of overlapping instances in the design.

#### **Options and Arguments**

-detail

Prints a detailed report, including the x and y co-ordinates for the overlapping instances.

-snap

Snaps to the grid before checking for overlaps.

#### Example

■ The following example shows a sample report:

> report\_overlap -detail

# report\_physical\_library

report\_physical\_library [-tcl\_list]

Reports on LEF data:

- Unit Rh, Rv, Ch, Cv
- Number of layers (name/direction/routing)
- Number of vias (regular/nonregular)
- Number of NDRs, LUTs, LEFmultipliers
- Number of LUTs

## **Options and Arguments**

-tcl\_list

Reports a Tcl list of the LEF data.

# report\_placement\_area

report\_placement\_area

Lists all of the placement areas in the database. Placement areas with no names will contain a question mark (?) in the name string.

## Example

The following is an example of the output generated by the <code>report\_placement\_area</code> command:

| + |      |          |         |         | +      | H  |
|---|------|----------|---------|---------|--------|----|
|   | Name | lx       | ly      | ux      | uy     |    |
|   | a1   | -1066.41 | -481.00 | 1066.00 | 770.80 |    |
|   |      |          |         |         |        | Γ. |

## **Related Information**

create\_placement\_area

remove placement area

## report\_preroute\_parameters

report\_preroute\_parameters [-tcl\_list]

Provides you with a report to view the preroute parameters that have been set.

#### **Options and Arguments**

-tcl\_list

Reports the Tcl list preroute parameters.

#### **Related Information**

set preroute parameters

# report\_supply\_rails\_on\_rows

report\_supply\_rails\_on\_rows

Outputs the supply rail specifications currently being used. Among other things, the output will indicate whether the specifications were derived automatically from the LEF library, or were input by the user through the set\_supply\_rails\_on\_rows command.

#### **Related Information**

generate supply rails on rows

remove supply rails on rows

set supply rails on rows

# report\_unplaced

report\_unplaced [-instances] [-clusters | -physical\_instances | -all]

Reports instance and cluster information.

#### **Options and Arguments**

-clusters

Reports unplaced clusters.

-instances

Reports any unplaced block instances and fixed standard cell instances.

#### Example

The following command provides a report of unplaced clusters and instances in your design: report\_unplaced -instances -clusters

## reset\_dont\_move

reset\_dont\_move instance\_list

Removes the attribute placed on an instance(s) by the set\_dont\_move command.

#### **Options and Arguments**

instance\_list

Lists the hierarchical names (wildcards accepted) or object IDs of the instance(s).

#### **Related Information**

set dont move

## reset\_net\_physical\_attribute

```
reset_net_physical_attribute [-layer_usages_table] [-lef_multiplier]
    [-non_default_rule] {[-non_clock_tree_nets] | [-clock_tree_nets] | [-all] |
    [-net list_of_nets]} [-shieldNet] [-use]
```

Resets the method of capacitance and resistance (RC) calculation set by a set\_net\_physical\_attribute command.

The options for this command are similar to those for the <u>set net physical attribute</u> command. Please see that command for detailed descriptions of each option.

There are three ways to change the RC calculation for a net:

- -layer\_usages\_table
- -lef\_multiplier
- -non\_default\_rule

There are four ways to apply changes to a design:

- ∎ -all
- -clock\_tree\_nets
- -net
- -non\_clock\_tree\_nets

If you use the -net option, each net from the specified list of nets corresponding properties defining the way of RC calculation set for the net earlier will be ignored and current default properties will be used.

If you use the <code>-non\_clock\_tree\_nets</code>, <code>-clock\_tree\_nets</code>, or <code>-all</code> option, then the corresponding current default properties defining the method of RC calculation (<code>-layer\_usages\_table</code>, <code>-lef\_multiplier</code>, or <code>-non\_default\_rule</code>) will be ignored and initial default properties generated by the tool will be used.

#### **Options and Arguments**

See <u>set net physical attribute</u> on page 655 for details on the options and arguments for this command.

## Examples

■ The following command specifies that the current default LUT will be used for RC calculation for net m\_clk.

reset\_net\_physical\_attribute -layer\_usages\_table -net m\_clk

The following command specifies that the initial default LUT generated by the tool will be used for RC calculation for all nets.

set\_net\_physical\_attribute -layer\_usages\_table LUT1 -al

#### **Related Information**

set net physical attribute

## set\_block\_halo

set\_block\_halo instName [-left lval] [-right rval] [-top tval] [-bottom bval]

Defines the region around a macro reserved for routing. This command internally creates placement areas which cause the rows to adhere to the block halo. This only applies values for macro cells as specified in the LEF file. This is an overriding value; this value is in affect even if the global defaults are changed. This only affects optimization space and should not result in a timing change. This also affects placement resources.

The options -right, -left, -top, and -bottom refer to the original rotation of the block as specified in the LEF and not as it appears on the screen. For example, if a block is rotated 180 degrees and you specify set\_block\_halo block\_inst\_name -top 10 then the halo actually appears on the bottom side of the block in the placement.

**Note:** Specifying block halos will snip rows in the database for all macros which have at least one non-zero halo value.

#### **Options and Arguments**

| -bottom <i>bval</i> | Defines the halo distance on the bottom side. The default value is <i>0</i> . |
|---------------------|-------------------------------------------------------------------------------|
| instName            | Specifies the name of the instance.                                           |
| -left <i>lval</i>   | Defines the halo distance on the left side. The default value is 0.           |
| -right rval         | Defines the halo distance on the right side. The default value is 0.          |
| -top tval           | Defines the halo distance on the top side. The default value is 0.            |

#### Example

set\_block\_halo top/block/macroInst -left 10 -right 10 -top 25 -bottom 30

#### **Related Information**

report\_block\_halo

December 2003

# set\_block\_rc\_rule

```
set_block_rc_rule {-instance blockInst_or_id | -all_blocks}
        {-auto | -lut LUTname}
```

Applies a separate layer usages table (LUT) for over-block-routing to all routing segments that route through a block instance.

## **Options and Arguments**

| -all_blocks         | Specifies that the LUT will be used for all over block routing<br>whenever it occurs. Note that the use of this argument does not<br>override any specific instance assignment done previously.                                                                                                                                                                                                        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -auto               | Performs automatic LUT characterization. Specifies that the system will automatically customize block specific LUTs by analyzing the obstacle description and normalizing the block LUT table to reflect the actual layer availability.                                                                                                                                                                |
|                     | Note that auto LUT characterization for a specific net is only<br>done at the LEF description level. It does not consider any<br>instance specific blockages, such as the blockages created with<br>the create_blockage command. In other words, the block<br>LUT for all occurrences of a certain macro will be the same. You<br>can override this by loading custom LUTs on a per instance<br>basis. |
| -instance blockInst | _or_id<br>Identifies the name of the block instance or id that the LUT is<br>being applied to.                                                                                                                                                                                                                                                                                                         |
| -lut LUTname        | Identifies the name of the LUT you are referencing. The<br>LUTname must be the table name of a previously read in LUT definition.                                                                                                                                                                                                                                                                      |

#### Example

set\_block\_rc\_rule -all\_blocks -auto

## **Related Information**

set global auto block rc rule

## set\_current\_cluster

set\_current\_cluster [-name cluster\_name | cluster\_name]

Changes the root cluster (provided by default) to the cluster specified by -name hier\_cluster\_name. Use this command prior to using any existing floorplan related command, such as commands for setting floorplan spec, creating a blockage, creating placement areas, and so on. You can also use this command to define the cluster to directly contain physical instances or for querying physical instance information, as well as for new commands for creating and modifying cluster definitions from the command line. Note that any cluster name that starts with a / will be considered an absolute path; where / is used to refer to the root physical cluster. Any cluster name that does not start with a / will be considered to be specified in the context of the current active cluster. The tool uses / as the default cluster hierarchy separator.

**Note:** Changing the current cluster will have no effect on batch commands, including placement, routing, and optimization. The command is intended for interactive editing or for querying commands only. Also note that changing the current cluster does not change the current module.

#### **Options and Arguments**

-name cluster\_name

Sets the new cluster name (specified by  $cluster_name$ ) as the current cluster. Use / as a hierarchy divider, use  $\$ to escape the hierarchy divider, and use  $\ \$ as a backquote.

#### Example

The following command specifies cluster C3 as the current cluster:

set\_current\_cluster -name C3

## set\_default\_core\_site

set\_default\_core\_site core\_site\_name

By default, when your library has multiple core sites, PKS chooses the one referred to by the greatest number of standard cells in the library. Use this command to specify a particular core site to use as the default.

## **Options and Arguments**

*core\_site\_name* The name of the core site you want to set as default.

## set\_dont\_move

set\_dont\_move instance\_list

Identifies the instances that will not be moved during optimization. The instances will not be moved, but can be deleted or resized in-place unless you also assert a set\_dont\_modify on them. The instances are written out with the +FIXED attribute in the DEF file. This property is not an attribute and can not be viewed by the get\_info or get\_physical\_info commands. This property is preserved in an ADB file.

**Note:** The recommended usage is to use this command after the related instances have already been placed using do\_place, or after reading the PDEF or DEF file.

To remove the attribute on an instance, use the reset\_dont\_move *instance\_list* command.

#### **Options and Arguments**

instance\_list

Lists the hierarchical names (wildcards accepted) or object IDs of the instance(s).

#### Example

set\_dont\_move blockA/i\_10 blockB/i\_40

#### **Related Information**

reset dont move

get physical info

## set\_floorplan\_parameters

```
set_floorplan_parameters [-abut_row_pairs] -no_abut_row_pairs]
[-aspect_ratio_initial float] [-bbox_initial float float float float]
[-by_tracks] [-fixed_floorplan | -no_fixed_floorplan]
[-flip_alternate_rows | -no_flip_alternate_rows] [-height_initial float]
[-lr_io_to_core_distance {float | float float}]
[-tb_io_to_core_distance {float | float float}] [-lr_block_halo float]
[-tb_block_halo float] [-max_height float] [-max_row_utilization float]
[-max_local_row_utilization float][-max_width float] [-report_only]
[-route_top_layer_limit value] [-route_bottom_layer_limit value]
```

Sets floorplan specification parameters for the root cluster.

#### **Options and Arguments**

| -abut_row_pairs      |                                                                                                                                                                                                                                                                                             |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Keeps flipped row pairs together. Used with the                                                                                                                                                                                                                                             |
|                      | flip_alternate_rows command.                                                                                                                                                                                                                                                                |
|                      |                                                                                                                                                                                                                                                                                             |
| -aspect_ratio_initia | 1                                                                                                                                                                                                                                                                                           |
|                      | Defines the aspect ratio for the initial floorplan. This is used in conjunction with row_utilization,                                                                                                                                                                                       |
|                      | io_to_core_distance, and row_spacing to determine the initial floorplan. Note that the aspect ratio = width/height.                                                                                                                                                                         |
| -bbox_initial        |                                                                                                                                                                                                                                                                                             |
| 2201_1110101         | Defines the initial bounding box of the design. It defines which<br>bounding box to use when the design is initially converted into a<br><i>placed</i> state. If specified, the other parameters in this block are<br>not used: aspect_ratio_initial, height_initial, and<br>width_initial. |
| -by_tracks           |                                                                                                                                                                                                                                                                                             |
|                      | Indicates that the io_to_core_distance, row_spacing, lr_block_halo, and tb_block_halo values are to be interpreted in terms of tracks of the lowest routing layer in each direction.                                                                                                        |
| -flip_alternate_rows |                                                                                                                                                                                                                                                                                             |
| <u>_</u>             | Causes every other row to be oriented opposite the one preceding it (such as: North, flipped South, North, flipped South, and so on).                                                                                                                                                       |

| -height_initial      | Defines the height of the initial floorplan. Given<br>row_utilization_initial, io_to_core_distance, and<br>row_spacing, the width of the design is calculated.                                                                                                                                                                   |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -lr_block_halo       | Defines the amount of block halo on the left/right sides. The default value is <i>0</i> .                                                                                                                                                                                                                                        |
| -lr_io_to_core_dista | Defines the left and right io-to-core distance. The io-to-core distance is the distance between the die box of a given edge and the rows that are used for the core cell placement. The default value is 6 metal pitches using the lowest vertical routing layer.                                                                |
| -max_height          | Defines the maximum height that the design can grow. Sets the limit of growth for a particular floorplan.                                                                                                                                                                                                                        |
| -max_local_row_utili | Controls the amount of row area that is made available in each local bin (region) for PKS optimization. PKS optimization will not accept any moves that would cause the local utilization to increase beyond this target. Normally this is set to 100% which means that all the bin's row area is made available to optimization |
|                      | <b>Note</b> : Some part of the row area could be subtracted if the bin is deemed to be congested. That is, a certain number (X) of the available sites could be unusable due to routing congestion. If the bin is not congested, X will be zero. If the bin is very congested, X can be as high as the total number of sites.    |
|                      | For example, if there are 100 sites in a bin, optimization can place up to 100-X sites instances in that bin. If, however, you set -max_local_row_utilization to 95, then optimization can place only 95-X sites.                                                                                                                |
|                      | For designs with very low utilization, setting this option to a<br>number between 90 and 100 may help ensure that the design<br>has no local routing congestion and that it can be easily<br>legalized.                                                                                                                          |

| -max_row_utilization | Defines the maximum row utilization allowed. This is a constraint<br>that the tool will attempt to maintain during optimization. If the<br>maximum row utilization is exceeded, a "grow" on the design is                                                                                                                                                                                                                                                                              |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -max_width           | attempted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                      | Defines the maximum width that the design can grow. Sets the limit of growth for a particular floorplan.                                                                                                                                                                                                                                                                                                                                                                               |
| -report_only         | Reports the set and derived values if those arguments are<br>issued. Will not change any of the specification parameters in the<br>database. Recommended if you are unsure of the relationships<br>between values.                                                                                                                                                                                                                                                                     |
| -route_top_layer_lim | it <i>value</i> and -route_bottom_layer_limit <i>value</i><br>Limits the top or bottom routing layer to the specified value.<br>Takes an integer value from 1 to the number of all routing layers.<br>This value is stored per cluster and effects the cluster and all<br>child clusters which can inherit this value.                                                                                                                                                                 |
|                      | Using these arguments causes a timing reset and creates a new layer usages table (LUT). For example, in a 6-layer technology, if bottom = 2 and top = 5, a new LUT is created that does not use M1 and M6. The new LUT will be used on the cluster and for all nets associated with the cluster (on macro blocks, a LUT specific to each macro is derived based on this new cluster LUT and used on all macros of the same cell). These arguments have no affect on user-defined LUTs. |
|                      | Causes the route availability on unused layers to be set to 0.<br>Routing blockages on unused layers will have no affect.                                                                                                                                                                                                                                                                                                                                                              |
|                      | Added to the do_route option list automatically so when global route is called it uses the proper layers (such as -route_top_layer_limit and                                                                                                                                                                                                                                                                                                                                           |
|                      | -route_bottom_layer_limit). A layer limit explicitly added<br>to the do_route option list will override what is set as a floorplan<br>parameter.                                                                                                                                                                                                                                                                                                                                       |

|                      | <b>Note</b> : A sub cluster, if without a layer limit set by set_floorplan_parameter, will inherit the layer limit from the closest parent cluster which has the layer limit set this way.                                                                                                 |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -row_spacing         | Defines the space between the rows created in the core. The rows start in the lower left of the core area and are stepped by the core site height plus the row_spacing. The last row is at least the io-to-core distance from the upper right, but may be more than this minimum distance. |
| -row_utilization_ini | tial<br>Defines the row utilization used when creating the initial<br>floorplan. The final utilization may be different depending on the<br>optimizations done, but it will never be more than the<br>max_row_utilization.                                                                 |
| -tb_block_halo       | Defines the amount of block halo on the top/bottom sides. The default value is 0.                                                                                                                                                                                                          |
| -tb_io_to_core_dista | Defines the top and bottom io-to-core distance. The io-to-core distance is the distance between the die box of a given edge and the rows that are used for the core cell placement.                                                                                                        |
| -width_initial       | Defines the width of the initial floorplan. Given<br>row_utilization_initial, io_to_core_distance, and<br>row_spacing, the height of the design is calculated.                                                                                                                             |

## **Related Information**

do initialize floorplan

report floorplan parameters

# set\_ground\_net

set\_ground\_net

Sets the ground net to be used to connect tie-low connections for a specific cluster. This command operates on the current area cluster.

#### **Related Information**

get ground net

get power net

set power net

## set\_grow\_anchors

```
set_grow_anchors [-horizontal { left | right } ] [-instance anchor_name]
      [-vertical { top | bottom }] [ list_of_macro_names ]
```

Supplements the set\_floorplan\_parameters command to enforce certain patterns of the post-grow motion of hard macros. The set\_grow\_parameters and set\_pin\_status commands also support grow functionality.

Note: This command only affects hard macros. It does not affect clusters.

## **Options and Arguments**

| -horizontal {left  | <pre>  right } Freezes the macro in the horizontal direction so that its left or right side distance to the bounding box remains unchanged (or changes minimally to avoid overlap with any external blockage).</pre> |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance anchor_r | lame                                                                                                                                                                                                                 |
|                    | Sets a macro name (specified by <i>anchor_name</i> ) as an anchor so every satellite macro specified by the                                                                                                          |
|                    | list_of_macro_names will move in sync with the anchor. In                                                                                                                                                            |

other words, the relative position(s) between the anchor and the satellite macro(s) remains unchanged. Note that if *list\_of\_macro\_names* is omitted, all macros (except the anchor) are considered satellite macros.

list\_of\_macro\_names

Specifies the name of the macro(s) being affected. Note that if *list\_of\_macro\_names* is omitted, all macros are affected by the specified argument.

-vertical {top | bottom}

Freezes the macro in the vertical direction so that its top or bottom side distance to the bounding box remains unchanged (or changes minimally to avoid overlap with any external blockage).

## Example

The following command freezes the macro in the horizontal direction so that its left side distance to the bounding box remains unchanged (or changes minimally to avoid overlap with any external blockage):

set\_grow\_anchors -horizontal left

## **Related Information**

set floorplan parameters

set grow parameters

set pin status

## set\_grow\_parameters

```
set_grow_parameters [-max_box {lx ly ux uy}] [-max_bottom_offset value]
    [-max_left_offset value] [-max_right_offset value]
    [-max_top_offset value] [-max_offsets {bottom_offset left_offset
    right_offset top_offset}] [-origin {ll | lr | ul | ur | cc}]
    [-start_box {lx ly ux uy}]
```

Supplements the set\_floorplan\_parameters command to set the maximum offsets for growing the specified root cluster. The set\_grow\_anchors and set\_pin\_status commands also support grow functionality.

## **Options and Arguments**

```
-max_bottom_offset value
                          Sets the bottom offset to its maximum allowed growth. This
                          enables you to set an individual offset value in microns.
-max_box {lx ly ux uy}
                          Specifies the maximum size a bounding box can grow.
                          lx = lower x coordinate
                          l_{Y} = lower y coordinate
                          ux = upper x coordinate
                          uy= upper y coordinate
                          Note that you must type the curly braces in the command syntax.
-max_left_offset value
                          Sets the left offset to its maximum allowed growth. This enables
                          you to set an individual offset value in microns.
-max_offsets {bottom_offset left_offset right_offset top_offset}
                          Specifies the maximum allowed growth in each direction from the
                          initial bounding box of the cluster. All offsets must be specified.
                          Units in microns. Note that you must type the curly braces in the
                          command syntax.
-max right offset value
                          Sets the right offset to its maximum allowed growth. This enables
                          you to set an individual offset value in microns.
-max_top_offset value
                          Sets the top offset to its maximum allowed growth. This enables
                          you to set an individual offset value in microns.
```

```
-origin {ll | lr | ul | ur | cc}
Specifies a fixed corner for the cluster. Note that setting an origin
sets two max_offsets, which cannot be overridden. For example:
origin ll sets max_left_offset=0 and
max_bottom_offset=0.
-start_box {lx ly ux uy}
Specifies the initial bounding box of the sub cluster you want to
grow. If not specified, it assumes that the cluster bounding box is
the same as that of the whole chip (die box). To check the initial
die box dimensions of the top-level cluster, use the
set_floorplan_parameters -initial_bbox command.
Note that you must type the curly braces in the command syntax.
```

## Examples

The following command specifies the maximum size the bounding box can grow in the specified x and y directions:

set\_grow\_parameters -max\_box {lx ly ux uy}

■ The following command specifies the initial size of the subcluster's bounding box:

set\_grow\_parameters -start\_box {700 0 1200 500}

The following command specifies the lower right corner as the fixed corner for the cluster:

```
set_grow_parameters -origin lr
```

The following command sets the left offset to a maximum growth of 100 (microns): set\_grow\_parameters -max\_left\_offset 100

#### **Related Information**

set floorplan parameters

set grow anchors

set pin status

## set\_layer\_usages\_table

set\_layer\_usages\_table -name table\_name filename

# Important

This command performs operations similar to those found in other commands. If this command is used, the <u>read layer usages</u> command is disabled and will have no effect.

Reads named layer usages tables. This command is used to load tables for use by set\_net\_physical\_attribute.

The layer usages table specifies how nets will be routed by specifying what percentage of each wire will be routed on each layer. See <u>Appendix A</u> of the PKS User Guide for more information about layer usages tables.

## **Options and Arguments**

```
-name table_name filename
```

Loads tables for use by the set\_net\_physical\_attribute command. The data is read from the file specified and a *table\_name* is generated and associated with the layer usages table that was read. The *table\_name* is used as an argument for the set\_net\_physical\_attribute command, for example: set\_net\_physical\_attribute -layer\_usages\_table table\_name -all. The *table\_name* can not be overwritten. If *table\_name* already exists, an error message is issued and the data is ignored.

## Example

The following command loads the specified table from the layer usages table (*LUT1*) that was read in. The resulting table is used by the set\_net\_physical\_attribute command.

set\_layer\_usages\_table -name Table1 LUT1

#### **Related Information**

create layer usages table

set net physical attribute

write layer usages

# set\_lef\_multiplier

```
set_lef_multiplier -name multiplier_name [-layer layer_name]
     [-capacitance c] [-edge_capacitance e] [-resistance r] [-via_resistance v]
```

# Important

If this command is used, the <u>read layer usages</u> command is disabled and will have no effect:

Specifies a multiplier to be used in conjunction with the capacitance and resistance values in the LEF file.

More than one layer can be associated with each multiplier (specified by the -name option). You must issue separate commands for each layer to be associated with a particular multiplier.

You can specify more than one set of resistance and capacitance multipliers for a layer by using different multiplier names.

**Note:** If you issue a set\_lef\_multiplier command with a layer and data that have already been specified, the data are overwritten.

## **Options and Arguments**

| -capacitance c             | Specifies a float value, $c$ , that the capacitance for the specified layer will be multiplied by.                                                                                                                                                                                                                                                                                       |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -edge_capacitance <i>e</i> | Defines a float value, <i>e</i> , that the edge capacitance for the specified layer will be multiplied by.                                                                                                                                                                                                                                                                               |
| -layer <i>layer_name</i>   | Defines the layer that the multipliers will be applied to. This is an optional field. If this argument is omitted, multiplier values specified by -capacitance, -edge_capacitance, and -resistance will be applied to all routing layers. The multiplier value specified by -via_resistance will also be applied to all routing layers, with the exception of the highest routing layer. |
| -name <i>multiplier_n</i>  | ame<br>Defines how the multiplier will be referenced by<br>set_net_physical_attribute. This is a required option.                                                                                                                                                                                                                                                                        |

| -resistance r     | Defines a float value, $r$ , that the resistance for the specified layer will be multiplied by.                                                                                                                                 |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -via_resistance v | Defines a float value $v$ , that the via_resistance for the specified lower layer will be multiplied by.                                                                                                                        |
|                   | This option applies to the via with the layer specified by the -layer option as the lower layer. If applied to the top layer, an error message is generated and the layer will not be associated with the specified multiplier. |

## Example

The following command defines <code>mult1\_table</code> as the multiplier name that will be used with the <code>set\_net\_physical\_attribute</code> command.

set\_lef\_multiplier -name mult1\_table

#### **Related Information**

set net physical attribute

# set\_library\_layer\_offset

set\_library\_layer\_offset layername offset\_value

Sets the offset value for a given routing layer. Only routing layers may have offsets, so *layername* is the name of the routing layer.

**Note:** The *offset\_value* is stored in the database that stores physical library data.

#### **Options and Arguments**

| layername    | Specifies the name of the routing layer.                                                          |
|--------------|---------------------------------------------------------------------------------------------------|
| offset_value | Defines the <i>offset value</i> for a given routing layer is in user units (similar to LEF data). |

#### **Related Information**

get library layer offset

## set\_logic\_0\_net

set\_logic\_0\_net net\_name

Sets the net name associated with the pins that are tied low in the design.

**Note:** If a design contains multiple ground and power nets, you must use this command to specify one of the nets as the default logic0 net.

### **Options and Arguments**

net\_name

Specifies the name of the net.

## **Related Information**

set logic 1 net

## set\_logic\_1\_net

set\_logic\_1\_net net\_name

Sets the net name associated with the pins that are tied high in the design.

**Note:** If a design contains multiple ground and power nets, you must use this command to specify one of the nets as the default logic1 net.

### **Options and Arguments**

net\_name

Specifies the name of the net.

## **Related Information**

set\_logic\_0\_net

## set\_min\_porosity\_for\_over\_block\_routing

set\_min\_porosity\_for\_over\_block\_routing val

Defines the minimum porosity (min-porosity) a block must have to enable the Steiner router to route over blocks when performing routing estimation. When a LEF description of a block is read into PKS, the porosity is automatically calculated from the metal geometries defined in the LEF for that block. The porosity is calculated as the total unblocked track length divided by the total track length, and is calculated in both the horizontal and vertical directions. When PKS performs Steiner routing, it will route over a block if the min-porosity value is less than both the horizontal and the vertical porosity for that block (see examples below).

#### **Options and Arguments**

val

Defines the percentage of routable tracks (0-100). The default value is set to the minimum of 1/Nh or 1/Nv, where Nh and Nv are the number of horizontal and vertical routing layers in the design.

#### Examples

In the following example, a design uses five layers of metal and contains a block with layers 1-3 completely obstructed. Odd layers are horizontal and even layers are vertical.

PKS calculates the horizontal porosity to be 33.3%:

Metall porosity: 0% Metal3 porosity: 0% Metal5 porosity: 100% Total horizontal porosity = (0 + 0 + 100) / 300 = 33.3%

PKS calculates the vertical porosity to be 50%:

Metal2 porosity: 0% Metal4 porosity: 100% Total vertical porosity = (0 + 100)/200 = 50%

For this block to be considered for over-the-block routing by the Steiner router, you must set the minimum porosity value to be less than or equal to 33.3%:

set\_min\_porosity\_for\_over\_block\_routing 33

In this next example, consider the same design, but with the block completely obstructed in layers 1-4.

PKS calculates the horizontal porosity to be 33.3% (same as above).

PKS calculates the vertical porosity to be 0%:

```
Metal2 porosity: 0%
Metal4 porosity: 0%
Total vertical porosity = 0%
```

For this block to be considered for over-the-block routing by the Steiner router, you must set the min-porosity value to 0:

set\_min\_porosity\_for\_over\_block\_routing 0

**Note:** If your design contains both of the blocks mentioned above and you set the minporosity value to 30, the Steiner router will route over the first block (example 1), and go around the second block (example 2). When the steiner router routes over a block, it does not look at how many nets have been routed over. If it has determined that this block can be routed over, then all nets will route over it. It isn't until the global routing phase that the tool can determine which nets will go over a block and which will go around it.

### **Related Information**

get min porosity for over block routing

## set\_min\_RC\_multipliers

set\_min\_RC\_multipliers [-res float] [-cap float] [-edge\_cap float]

Enables you to reset RC values uniformly for all layers, vias, nondefault layers, and nondefault vias. You can use this command as often as needed. Each subsequent command will reset the min RC values.

## **Options and Arguments**

| -cap float      | Specifies the multiplier to be used with capacitance values.      |
|-----------------|-------------------------------------------------------------------|
| -edge_cap float | Specifies the multiplier to be used with edge-capacitance values. |
| -res float      | Specifies the multiplier to be used with resistance values.       |

## set\_min\_wire\_length

set\_min\_wire\_length value

Sets the minimum wire length value used during optimization. In other words, if a net length is calculated to be less than this value, for timing (RC calculation) purposes its wire length is treated as <value>. The intention is to build a minimum tolerance for cell movements (such as overlap removal) later on without altering achieved timing. Units are in microns.

#### **Options and Arguments**

value

Specifies the minimum wire length value.

#### Example

The following command sets the minimum wire length to 20 microns for use during optimization:

set\_min\_wire\_length 20

#### **Related Information**

get min wire length

## set\_net\_physical\_attribute

```
set_net_physical_attribute [-layer_usages_table table_name]
    [-lef_multiplier multiplier_name] [-non_default_rule rule_name]
    {[-non_clock_tree_nets] | [-clock_tree_nets] | [-all] | [-net list_of_nets]}
    [-shieldNet list_of_special_net_names] [-use type]
```

## /Important

This command performs operations similar to those found in other commands. If this command is used, the <u>read layer usages</u> command is disabled and will have no effect.

Changes the way capacitance and resistance (RC) are calculated for a specific net or class of nets.

There are three ways to change the RC calculation for a net:

- -layer\_usages\_table
- -lef\_multiplier
- -non\_default\_rule

There are four ways to apply the changes to a design:

- ∎ -all
- -clock\_tree\_nets
- -net
- -non\_clock\_tree\_nets

**Note:** If one of the four arguments above is not selected, this command is ignored. If more than one argument is selected, only one argument will be used and in the priority listed above.

#### **Options and Arguments**

| -all             | Loads the default settings for -clock_tree_nets and -non_clock_tree_nets. Does not overwrite information previously set with the -net argument. |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| -clock_tree_nets | Loads the default settings for clock tree nets. Overwrites information previously set with the <pre>-clock_tree_nets</pre>                      |

|                      | argument or with the -all argument for clock tree nets. Does<br>not overwrite information previously set with the -net argument,<br>-non_clock_tree_nets argument, or -all argument for non<br>clock tree nets.                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -layer_usages_table  | <pre>table_name Defines the percentages of each metal layer used to calculate the composite resistance and capacitance for each routing direction (can also differ based on wire length). Applies the table_name to the nets specified. The table_name must already be defined using the set_layer_usages_table command. A layer_usages_table may not be changed once it is created; a new named table must be created if needed.</pre>                                                                                                                                                              |
| -lef_multiplier mult | iplier name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ici_muicipiici muic  | Scales the values in the LEF file which impacts all resistance and capacitance values for the PKS session. Applies the <i>multiplier_name</i> to the nets specified. The <i>multiplier_name</i> must already be defined using the set_lef_multiplier command. LEF multipliers may be changed after they are applied. The change will take effect as soon as the <i>multiplier_name</i> is changed. Note that you must use this argument with the <i>-all</i> argument, otherwise an error message is issued and the command will not be executed. It is not supported with a net or a group of nets. |
| -net list_of_nets    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                      | Applies only to the supplied list of nets. Overwrites information previously set with the <pre>-all, -net, -clock_tree_nets, or <pre>-non_clock_tree_nets</pre> arguments.</pre>                                                                                                                                                                                                                                                                                                                                                                                                                     |
| -non_clock_tree_nets | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | Loads the default settings for non clock tree nets. Overwrites<br>information previously set with the <code>-non_clock_tree_nets</code><br>argument or with the <code>-all</code> argument for non clock tree nets.<br>Does not overwrite information previously set with the <code>-net</code><br>argument, <code>-clock_tree_nets</code> argument, or <code>-all</code> argument<br>for clock tree nets.                                                                                                                                                                                           |
| -non_default_rule ru | le_name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                      | Applies the named rule to the nets specified. The named rule                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Applies the named rule to the nets specified. The named rule must be specified in the LEF file.

| -shieldNet list_of_s | special net names                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5                    | Defines the shielding net for each net specified by<br><i>list_of_special_net_names</i> or the <i>list_of_nets</i><br>defined by the -net argument. Each net name in the list must<br>correspond to a special net that already exists in the design. If<br>not, a warning message is issued and the command will fail. This<br>argument must be used in conjunction with the -net argument,<br>otherwise an error message is issued and the command will not<br>be executed. |
| -use {clock   signa  | <pre>1   power   ground   tieoff   analog   scan<br/>  reset   data}<br/>Defines the net(s) usage. The valid net types are clock,<br/>signal, power, ground, tieoff, analog, scan, reset, and<br/>data. Note that you must use this argument with the -net<br/>argument, otherwise an error message is issued and the<br/>command will not be executed.</pre>                                                                                                                |

#### **Examples**

set\_net\_physical\_attribute -layer\_usages\_table BASE -lef\_multiplier ONE -all set\_net\_physical\_attribute -layer\_usages\_table CLOCK -clock\_tree\_nets set\_net\_physical\_attribute -non\_default\_rule WIDE\_WIRE\_1 -net CLK\_PLL -use clock set\_net\_physical\_attribute -lef\_multiplier ONEp5 -layer\_usages\_table T1 -non\_default\_rule DOUBLE\_WIDTH -all

| Group          | layer_usages_table | lef_multiplier | non_default_rule |
|----------------|--------------------|----------------|------------------|
|                |                    |                |                  |
| CLK_PLL        | CLOCK              | ONE            | WIDE_WIRE_1      |
| clock_tree_net | s CLOCK            | ONE            | WIDE_WIRE_2      |
| non_clock_tree | BASE               | ONE            |                  |

#### This result is exactly the same as using:

```
set_net_physical_attribute -layer_usages_table BASE -lef_multiplier ONE -all
set_net_physical_attribute -layer_usages_table CLOCK -non_default_rule WIDE_WIRE_2
-clock_tree_nets
set_net_physical_attribute -non_default_rule WIDE_WIRE_1 -net CLK_PLL
```

#### **Related Information**

#### reset net physical attribute

create\_blockage

set min porosity for over block routing

set steiner mode

## set\_physical\_info

```
set_physical_info [ [-instance | -pin] object_name | FNPid] [-ipin_name name]
    [-location loc] [-ll | -ur | -lr | -ul] [-type {special | no_special}] [-state
    {unplaced | placed | fixed | cover}]
    [-orientation {N | S | W | E | FE | FW | FS | FN}] [-use name]
```

Indicates whether a certain pin (timing or physical) needs to be connected by a special router or by Wroute. By default all timing pins are "regular" in nature. All pins of a physical net are special in nature.

If you specify an argument that does not pertain to an object, the command will skip it. If no arguments are given, an error or warning will result.

```
Note: To add physical information to nets, use the add_physical_connection command, which also allows a setting for special | no_special.
```

## **Options and Arguments:**

| [-instance   -pin]       | <pre>object_name   FNPid] Identifies a physical instance or physical pin specified by object_name. FNPid specifies logical objects.</pre>                                               |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-ipin_name name]        | Identifies an instance pin specified by name. Use this argument in conjunction with the [-instance object_name   FNPid] argument.                                                       |
| [-ll   -ur   -lr         | <ul> <li>-ul]</li> <li>Specifies the location coordinates of the instance footprint on the die (lower left, upper right, lower right, or upper left).</li> <li>Default: -11.</li> </ul> |
| [-location loc]          | Specifies the location of the pin or instance.                                                                                                                                          |
| [-orientation $\{N \mid$ | S   W   E   FE   FW   FS   FN}]<br>Specifies the orientation of a pin or instance.                                                                                                      |
| [-state {unplaced        | placed   fixed   cover}]<br>Specifies the state of a pin or instance.                                                                                                                   |
| [-type {special   n      | o_special } ]<br>Specifies the type of pin or instance.                                                                                                                                 |

[-use name]

Identifies the pin being used specified by name.

#### **Related Commands**

get physical info

add\_physical\_connection

## set\_physical\_instance

set\_physical\_instance [-xpos x] [-ypos y] [-xtrans xt] [-ytrans yt] instance

Sets the absolute or relative position of an instance, such as the location and orientation. Note that the object must be placed or this command has no effect on the design.

### **Options and Arguments**

| -xpos x    | Sets the absolute x position of the instance.             |
|------------|-----------------------------------------------------------|
| -xtrans xt | Translates the instance on the x-axis by the $xt$ amount. |
| -ypos y    | Sets the absolute y position of the instance.             |
| -ytrans yt | Translates the instance on the y-axis by the $yt$ amount. |

## Example

set\_physical\_instance -xpos 10 i\_1

## **Related Information**

get physical info

## set\_pin\_location

```
set_pin_location pin_name {[-side side] [-index number] | [-location location]
       [-layer layername] [-box {lx | ly | ux | uy}]}
```

Sets one or more of the following: pin side, pin index, pin layer, pin location, or pin geometry.

### **Options and Arguments**

| -box {lx   ly   ux      | uy}<br>Defines the geometry for the pin.                                                                                                                                                |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -index                  | Defines the relative index for the pin on the side it has been assigned. Any number greater than 1. This is specified along with the <code>-side</code> argument.                       |
| -layer <i>layername</i> | Defines the layer of where the pin is placed.                                                                                                                                           |
| -location {x y}         | Defines the location for the pin. This is mandatory but cannot be used in conjunction with the -side argument.                                                                          |
| pin_name                | Specifies the name of the pin whose side has to be set.                                                                                                                                 |
| -side                   | Defines the side that the pin is assigned. Can be one of the following: {left   right   bottom   top}. This is mandatory but cannot be used in conjunction with the -location argument. |

#### Examples

■ The following command sets the location of the clk pin to the left side of the die and sets the relative order to be the last pin on the respective side:

set\_pin\_location clk -side left

■ The following command sets the location of the clk pin to the left side of the die and also sets the relative order to be the 19th pin on the left side:

```
set_pin_location clk -side left -index 19
```

The following command sets the pin geometry to be a rectangular box with origin {0,0} and height and width 100 relative to the pin location:

set\_pin\_location clk -box {0 0 100 100}

- The following command sets the pin location to {10000, 20999}: set\_pin\_location clk -location {10000 20999}
- The following command sets the pin location in the M1 layer: set\_pin\_location clk -layer M1

### **Related Information**

get pin location

## set\_pin\_status

set\_pin\_status [-index] [-side {left | right | bottom | top}]
 [-state {fixed | cover}] [pin\_names\_or\_ids]

Supplements the set\_floorplan\_parameters command to force specified pins to obey certain rules during grow. If no *pin\_names\_or\_ids* are specified, all pins are chosen. The set\_grow\_anchors and set\_grow\_parameters commands also support grow functionality.

#### **Options and Arguments**

| -index               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Indicates that the pins are specified by numerical IDs, which are<br>their track IDs (before grow). Note that this argument is not<br>needed if the pins are specified by numerical IDs in relative rank<br>order along the side, from the bottom to top on the left and right<br>sides and from the left to right on the bottom and top sides.                                                                                                                                                                                                   |
| pin_names_or_ids     | Specifies the name or numerical ID of the cluster pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| -side {left   right  | bottom   top}<br>Applies only when the pins are specified by numerical IDs. It<br>selects only the pins (specified by <i>pin_names_or_ids</i> ) on<br>the specified side of the box. If no <i>pin_names_or_ids</i> are<br>specified, all of the pins on the specified side of the box are<br>chosen. Note that this argument is not needed if the pins are<br>specified by numerical IDs in relative rank order along the side,<br>from the bottom to top on the left and right sides, and from the<br>left to right on the bottom and top sides. |
| -state {fixed   cove | r }<br>Specifies that the pin is to move only along the same track that it<br>occupied before grow (fixed) or that the pin is to stay at the<br>same location (cover).                                                                                                                                                                                                                                                                                                                                                                            |

## Example

The following command specifies that the sixth pin on the left side is set to fixed:

set\_pin\_status -state fixed -side left 6

## **Related Information**

- set floorplan parameters
- set grow anchors
- set grow parameters

#### set\_power\_net

set\_power\_net

Sets the power net to be used to connect tie-high connections for a specific cluster. This command operates on the current area cluster.

#### **Related Information**

get power net

get\_ground\_net

set ground net

### set\_power\_stripe\_spec

```
set_power_stripe_spec -direction {vertical|horizontal} -layer name -width W
  [-start_from SF] [-stop_from EF] [-number_stripes NS] [-stripe_spacing SP]
  [-net_spacing DS] [-net_name name1 name2...] [-delete_def_routes]
```

Lets you generate power stripes for one or several power nets. This command describes the rules of how to generate power stripes; it does not describe the power stripes themselves. This command is useful when modeling PG related blockages for congestion with grow on.

More than one set\_power\_stripe\_spec command may be issued in one session. It will not check the intersect of power stripes defined by different commands. Creating power stripes with this command will not prevent the design from growing.

#### **Options and Arguments**

| -delete_def_routes   | Deletes the power stripes that were created based on the DEF information that if there are power stripes created based on the information from DEF, they should be deleted before creating power stripes.                                                                                |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -direction {vertical | <pre>  horizontal } Defines the direction of the power stripe(s). This argument is mandatory.</pre>                                                                                                                                                                                      |
| -layer name          | Defines the power stripe(s) layer name. This argument is mandatory.                                                                                                                                                                                                                      |
| -net_name name1 name | <ul> <li>2</li> <li>Defines the list of net names of where to create power stripes. At least one net name should be specified.</li> </ul>                                                                                                                                                |
| -net_spacing DS      | Defines the distance between power stripes of the two<br>neighboring nets in the list of net names. This argument is<br>mandatory if you create power stripes for more than one net. If<br>this argument is not defined, only power stripes for the first net in<br>the list is created. |
| -number_stripes NS   | Defines how many power stripes to create. If there is not enough space to create $NS$ stripes, than the maximum number of stripes                                                                                                                                                        |

|                    | fitting into the space defined by <i>SF</i> and <i>EF</i> is created. The default value is 1. If <i>NS</i> is not defined, the tool creates as many stripes as possible to fill space defined by start_from and stop_from parameters.                                                                                                         |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -start_from SF     | Defines the distance to the middle of the first power stripe from<br>the left side of the row bounding box (identifies where to start<br>creating the power stripes). If start_from and/or stop_from<br>are not defined, the default value of 100 microns is used. Zero is<br>a valid value for these two parameters.                         |
| -stop_from EF      | Defines the distance to the middle of the last power stripe from<br>the right side of the row bounding box (identifies where to stop<br>creating power stripes). The default value is 0.                                                                                                                                                      |
| -stripe_spacing SP | Defines the distance between the power stripes. This argument<br>is mandatory if you are creating more than one power stripe. If<br><i>SP</i> is not defined, the default value of 200 microns is used. If <i>SP</i><br>is zero, only one stripe is created (the value of the<br>number_stripes parameter is ignored if it is more than one). |
| -width W           | Defines the width of the power stripe. This argument is mandatory.                                                                                                                                                                                                                                                                            |

## Example

The following command sets the direction of the power stripes in the vertical direction on layer M3 with a width of 3:

set\_power\_stripe\_spec -direction vertical -layer M3 -width 10

### set\_preroute\_parameters

```
set_preroute_parameters [-min_place_obstacle_size float]
   [-min_route_obstacle_size float]
   [-place_obstacle_layers {layName1 layName2 ..}]
   [-route_obstacle_layers {layName1 layName2 ..}]
   [-use_pads_for_place_obstacles {0|1}] [-use_pads_for_route_obstacles {0|1}]
   [-halo_hor halo_width] [-halo_ver halo_width]
```

Sets a placement blockage (rows will be cut) if an obstacle exists in any of the specified place\_obstacle\_layers, and is at least of min\_place\_obstacle\_size.

It can also set a routing blockage (steiner router detours around it) if an obstacle exists in all of the specified route\_obstacle\_layers, and is at least of min\_route\_size.

If your design has area pads and you wish to affect placement/routing, set the use\_pads\_for\* variables.

If you wish to use halos, use the -halo\_hor and -halo\_ver options.

#### **Options and Arguments**

| -halo_hor halo_widt                   | h                                                                   |
|---------------------------------------|---------------------------------------------------------------------|
|                                       | Allows you to specify horizontal halos around pre-route             |
|                                       | obstructions.                                                       |
|                                       | Default: 0                                                          |
|                                       |                                                                     |
| -halo_ver halo_width                  | 2                                                                   |
|                                       | Allows you to specify vertical halos around pre-route               |
|                                       | obstructions.                                                       |
|                                       | Default: 0                                                          |
|                                       |                                                                     |
| -min_place_obstacle_size <i>float</i> |                                                                     |
|                                       | Sets the minimum size of a pre-route or blockage that will be       |
|                                       | seen as a placement obstruction. Default is 6 metal1 pitches.       |
|                                       |                                                                     |
| -min_route_obstacle_                  | size float                                                          |
|                                       | Identifies the minimum size of a pre-route or blockage that will be |
|                                       | seen as a routing obstruction. Default is 6 metal1 pitches.         |
|                                       |                                                                     |
| -place_obstacle_laye                  | rs {layName1 layName2}                                              |
|                                       | Specifies the list of layers to be seen as placement obstructions.  |
|                                       | Default is the lowest two routing layers.                           |
|                                       |                                                                     |

 -route\_obstacle\_layers {layName1 layName2 ..} Identifies the list of layers that will be seen as routing obstructions. The default requires that all layers must be in an area for the area to be considered a routing obstruction.
 -use\_pads\_for\_place\_obstacles <0 | 1> Tells PKS to use pads (IO or Area) as placement obstacles. The default is 1 (true).
 -use\_pads\_for\_route\_obstacles <0 | 1> Talla PKS to use pade (IO or Area) as routing blackares. The

Tells PKS to use pads (IO or Area) as routing blockages. The default is 1 (true).

## set\_route\_availability

set\_route\_availability -layer layername val

Sets the raw routing layer percentage that is used by the congestion analysis engine after considering preroutes. Note that setting this value only has an effect during the congestion analysis within PKS. This value is not used as a guide for do\_route.

## **Options and Arguments**

layername

Specifies the name of the routing layer.

val

Sets the routing layer percentage that is used by the congestion analysis engine after considering preroutes.

#### Example

The following command makes 20% of the routing layer (metal4) available to the congestion analysis engine after considering preroutes (which means 80% of the routing layer is occupied by preroutes):

set\_route\_availability -layer metal4 20

## **Related Information**

get\_route\_availability

## set\_special\_netpin

```
set_special_netpin -type {power | ground} list_of_pin_names
```

Assigns a list of pin names to a special pin connected to a special net of the same name.

## **Options and Arguments**

list\_of\_pin\_names
Specifies the name of a list of pins separated by spaces.
-type power | ground
Defines the special pin type. The type options are power or
ground.

#### Example

set\_special\_netpin -type ground list\_of\_pin\_names

#### **Related Information**

get special netpins

## set\_steiner\_channel\_width

set\_steiner\_channel\_width float

Enhances the steiner router block avoidance by detouring preferably along sides of the macro that are free of routing obstructions within the specified distance. Timing will be reset if the number is set to a different value.

## **Options and Arguments**

float

#### Example

The following command sets the Steiner channel width to 20:

set\_steiner\_channel\_width 20

### **Related Information**

get steiner channel width

### set\_steiner\_mode

set\_steiner\_mode  $\{0 \mid 1 \mid 2\}$ 

Provides three Steiner-routing algorithms to control the Steiner routing functionality in your design. The mode should be set at the beginning of your script.

**Note:** Care should be taken when using this command. It is recommended that you evaluate each mode on your complex floorplan to obtain the optimal results.

### **Options and Arguments**

set\_steiner\_mode 0 (wirelength)

In this mode, the Steiner router attempts to connect all pins, minimizing the total wirelength.

**Note**: This mode is fast and more than adequate for most designs.



The figure above shows that minimizing the Steiner tree is not always the optimal choice. Assume s (Fig. 1) moves slightly to the left (Fig. 2), the resulting tree in Fig. 2 is in fact optimal from a wirelength perspective, but the delay to pin D has become significantly worse. Care must be taken when using  $set\_steiner\_mode~0$ .

set\_steiner\_mode 1

This mode is a hybrid of Steiner modes 0 and 2 and is not recommended. Note that this mode will be obsolete in the next full release of the software.

#### set\_steiner\_mode 2 (wiredelay)

Invokes a new timing-conscious Steiner router. When connecting sinks, it tries to balance minimizing the total wirelength versus minimizing the maximum distance between the source and the farthest sink.

**Note**: Use this command if your design is very timing critical or has many large complex routing obstacles or is highly utilized. This mode is less susceptible to small cell perturbations that cause larger delays owing to a daisy-chain effect that can occur when using Steiner mode 0.



In the figure above, assume s (Fig. 1) moves slightly to the left (Fig. 2), the resulting tree in Fig. 2 is optimal from a wirelength perspective, and also minimizes the distance between s (source) and the farthest sink.

## set\_supply\_rails\_on\_rows

Sets the specifications for the power and ground rails that run through the cell rows. If this command is not used, the specifications are automatically extracted from the LEF library. The supply rail specifications are used during routing congestion analysis to account for routing resources occupied by the supply rails.

#### **Options and Arguments**

| -derived  | Indicates that the supply rail specifications are to be derived<br>automatically from the LEF library. If this argument is given, all<br>existing supply rail specifications are deleted. |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -layer    | Provides the name of the layer that the rail lies on.                                                                                                                                     |
| -location | Provides the location of the center line of the rail from the bottom (horizontal rows) or left side (vertical rows) of each cell.                                                         |
| -supply   | Provides the use of the rail.                                                                                                                                                             |
| -width    | Provides the width of the rail.                                                                                                                                                           |

#### **Examples**

set\_supply\_rails\_on\_rows -location 9.7 -width 0.2 -layer metal1 -supply power set\_supply\_rails\_on\_rows -derived

#### **Related Information**

generate supply rails on rows

remove supply rails on rows

report supply rails on rows

## vbg\_pks\_display\_ilist

vbg\_pks\_display\_ilist -add instance\_name\_list

Displays in the Graphical User Interface (GUI) the instances specified in *instance\_name\_list*. Specifically, the desired instances are displayed in the Physical Browser of the GUI. This command is useful for debugging.

## **Options and Arguments**

-add

Adds instances to the Physical Browser in the Graphical User Interface.

instance\_name\_list

Specifies the instances that are to be displayed.

#### Examples

- The following command displays the instances returned by the find command: vbg\_pks\_display\_ilist [get\_names [find -inst \*53]]
- The following command shows how the empty display list below returns the display mode to its default view:

vbg\_pks\_display\_ilist {}

## vbg\_pks\_group\_delete

vbg\_pks\_group\_delete {group\_name | all}

Removes highlights from the objects specified in the DEF group\_name within the Graphical User Interface (GUI). Specifically, the DEF objects will be de-highlighted from the PKS viewer of the GUI.

## **Options and Arguments**

all

Specified that all previously specified DEF groups be removed from the highlight list.

group\_name

The DEF group name to be de-highlighted.

## vbg\_pks\_group\_display

vbg\_pks\_group\_display group\_name color

Highlights all objects specified in the DEF group\_name with the specified color within the Graphical User Interface (GUI). Specifically, the highlighted DEF objects appear in the PKS viewer of the GUI.

## **Options and Arguments**

color

Designates color for highlighting objects. If *color* is not specified, then the default color is used.

group\_name

Specifies the DEF group to be highlighted.

## write\_def

```
write_def [-placement {all | cell | io}] [-netlist] [-hier_delimiter char]
    [top_level_delimiter] [-no_pin_placement] [-number_of_groups num]
    [-cells_per_group num] [-scan_only | -include_scan]
    [-computed_rows] [-no_regions] [-version {5.3 | 5.4}] filename
```

Writes a Design Exchange Format (DEF) view of the current module when physical cell placement information is known for the design. The default operation provides cell placement coordinates, IO pin placement information, and netlist information. It will also write routes read into PKS out to the DEF file. The output is determined by setting the desired command arguments.

When handling designs with mixed pins and pads, the write\_def command will output placement information for all pins not associated with pads. For pins with associated pads, the placement information will not be output in the DEF file.

### **Options and Arguments**

| -computed_rows              | Writes the computed rows in PKS to a DEF.                                                                          |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------|
| filename                    | Specifies the name of the DEF file.                                                                                |
| -hier_delimiter <i>char</i> | Defines the character that is used as the delimiter for the hierarchical names.                                    |
|                             | Default: /                                                                                                         |
| -netlist                    | Outputs cell placement and netlist information for all nets connecting the cells.                                  |
| -no_regions                 | Does not output any region-related information (region definition and region reference) in the DEF file.           |
| -placement {all   ce        | 11   io}<br>Outputs the $x, y$ coordinates for all cell and IO pins, cells only, or<br>IO pins only in the design. |

-scan\_only | -include\_scan

#### -scan\_only

Excludes all write\_def outputs except the scan chains section.

#### -include\_scan

Dumps the scanDEF data to DEF file when write\_def is used with -include\_scan.

-top\_level\_delimiter

Controls whether the delimiter for the top-level hierarchy is used in the DEF file. The default value is false. If true, the delimiter character used is based on the -hier\_delimiter argument.

```
-version {5.3 | 5.4}
```

Writes out a 5.3 or 5.4 DEF file. By default, the DEF writer writes out information in the 5.5 syntax. Using this argument enables you to get a 5.3 or 5.4 DEF file for use with flows that cannot handle the newer 5.5 syntax. However, some information may be lost in the process for constructs not supported in 5.3 and 5.4.

#### Examples

The following command writes all DEF information to the full.def file:

write\_def full.def

The following command writes the cell and IO placement information to the DesignName.def file:

write\_def -placement all DesignName.def

■ The following command writes the cell and IO placement information and all netlist information in the design to the DesignName.def file:

```
write_def -netlist DesignName.def
```

#### **Related Information**

read\_def

## write\_gns

write\_gns -hier -placement {io | cells | all} -gns\_view view\_name -gns\_lib lib\_name -gns\_tech tech\_lib\_name [-create\_gns\_lib]

# Important

The Genesis database is no longer supported. This command will be removed in a future release.

Writes a PKS design to a Genesis database. The write\_gns command does not make any changes to the PKS database. It does make changes to the Genesis database depending on the presence or absence of the -hier argument:

- With the -hier argument, a view (view\_name) is created for the top level of the design and any lower-level clusters, with the exceptions of hard blocks. The Genesis view for the top level instantiates the second level. The second level view instantiates the third level, and so forth. Hard blocks are always represented by abstract views and cannot be modified.
- Without the -hier argument, a view (view\_name) is created for the top level of the design. Abstract views (using a LEF model description) are created for any second-level soft blocks. The Genesis view for the top level instantiates any second-level soft blocks. Second-level soft blocks cannot be modified, but their placement can be changed within the top level.

Note: If the Genesis view already exists, it is overwritten.

#### **Options and Arguments**

| -create_gns_lib                                                                    | Calls the write_gns_lib command as follows:                                 |
|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
|                                                                                    | write_gns_lib -gns_library lib -gns_techlib<br>techLib -gns_lib_path ./lib  |
| -gns_lib <i>lib_name</i>                                                           | Specifies the Genesis library to which the command should write the design. |
| -gns_tech tech_lib_name Specifies which technology library the command should use. |                                                                             |

| -gns_view view_name  | Specifies the name to use for the Genesis view.                                                               |
|----------------------|---------------------------------------------------------------------------------------------------------------|
| -hier                | Creates Genesis views for all levels of a hierarchical design.                                                |
| -placement {io cells | $ all\}$<br>Outputs the x, y coordinates for all cell and IO pins, cells only, or IO pins only in the design. |

## write\_gns\_lib

write\_gns\_lib -gns\_library lib\_name -gns\_techlib tech\_lib\_name
 -gns\_lib\_path lib\_path

# Important

The Genesis database is no longer supported. This command will be removed in a future release.

Creates the Genesis standard cells libraries and the associated technology file and writes them to the Genesis database.

## **Options and Arguments**

-gns\_lib lib\_name

Specifies the Genesis library to which the command should write the design.

-gns\_lib\_path lib\_path

Specifies the path the command should use.

-gns\_tech tech\_lib\_name

Specifies which technology library the command should use.

# write\_layer\_usages

write\_layer\_usages [-autoLUT] [-name table\_name] filename

Lets you write out the layer usages tables stored in the system. If the -name argument is used, only the named table is written into the specified *filename*. If the -name argument is not used, all loaded layer usages tables are written out. Note that this does not include the initial default LUTs. Use this command anytime after issuing the read\_layer\_usages command.

#### **Options and Arguments**

| -autoLUT         |                                                                                                                                                                                |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Dumps automatically generated LUTs (such as those used for over_block_routing).<br>Note: Cadence recommends that you use these tables for informational purposes only.         |
| filename         | Specifies the name of the file that will contain the layer and contact usages information.                                                                                     |
| -name table_name | States that only the specified table data is written to the specified $filename$ . If not used, all loaded tables and default values are written to the specified $filename$ . |

#### **Related Information**

create layer usages table

read\_layer\_usages

set layer usages table

set net physical attribute

# write\_pdef

```
write_pdef pdf_file_name [-bbox_rect]
    [-location_ieee_1481] [-proprietary_avant_location]
    [-cluster hier_cluster_name] [-version version_tag]
    [-divider hierarchy_divider_char]
    [-pin_delimiter pin_delimiter_char]
    [-bus_delimiter bus_prefix_delimiter_char buf_suffix_delimiter_char] [-
    distance_unit distance_unit]
    [-resistance_unit resistance_unit]
    [-capacitance_unit capacitance_unit] [-computed_rows]
    [-instance instance_name_or_id] [-max_depth depth]
    [-max_soft_block_depth depth] [-xoffset x_offset] [-yoffset y_offset]
```

**Note:** The global pdef\_style can be STANDARD or IBM. The default is STANDARD.

Writes a PDEF file conforming to v2.0 syntax. Additional constructs from the IEEE-P1481 syntax include:

- Support for RECT, ROW\_ORIENT, ORIGIN, and CONTENTS\_LOCATION attributes on clusters.
- Support for PIN constructs and LOC attributes for pins.
- Support for WireLoad attributes.

#### **Options and Arguments**

```
-bbox_rect

Represents the cluster bounding box in RECT construct. Default

is to represent the cluster bounding box in X_BOUNDS and

Y_BOUNDS constructs.

-capacitance_unit unit

Sets the capacitance unit (specified by unit) in the output

PDEF file.

-cluster hier_cluster_name

Writes out a soft block cluster specified by

hier_cluster_name. Example:

write_pdef -cluster /clusterA /clusterB

depth

O means unlimited.

Default: unlimited if -instance is not specified; 1 level of

soft_block_depth is specified using the -instance option.
```

# Command Reference for BuildGates Synthesis and Cadence PKS PKS Commands

| -distance_unit <i>unit</i>  | Sets the distance unit (specified by $unit$ ) in the output PDEF file.                                                                                           |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -location_ieee_1481         | Represents the object orientation and location defined by IEEE 1481-1998. The default value is to represent object orientation and location defined by PDEF 2.0. |
| pdef_filename               | Specifies the name of the PDEF file.                                                                                                                             |
| -proprietary_avant_l        | ocation<br>Specific to Avant! customers only. Represents the object<br>orientation and location.                                                                 |
| -resistance_unit <i>uni</i> | t<br>Sets the resistance unit (specified by <i>unit</i> ) in the output PDEF<br>file.                                                                            |
| -version                    | Supports versions: ieee, IEEE, and IEEE 1481-1999 in addition to all previously supported versions.                                                              |
| -xoffset float              | Adds coordinates to instance and pin locations, and x boundaries and RECT of clusters.                                                                           |
| -yoffset float              | Adds coordinates to instance and pin locations, and y boundaries and RECT of clusters.                                                                           |

## Example

write\_pdef pdef file name

# write\_wdb

write\_wdb wdb\_name

Writes the wroute database (WDB) to *wdb\_name*. This command writes LEF, netlist, placement, and final route (if applicable) information to the .wdb file.

This command is typically used as follows:

- 1. Write the .wdb file using the write\_wdb command after final routing your design.
- 2. Read the .wdb file into PKS using the read\_wdb command.
- 3. Perform in-place optimization (IPO).
- 4. Pass the optimization changes and previously stored final route data to a .wdb file using the write\_wdb command.
- 5. Use the .wdb file to do an incremental global and final route of your design.

#### **Options and Arguments**

wdb\_name

Specifies the name of the .wdb file.

#### **Related Information**

read\_wdb

# **Test Synthesis Commands**

This chapter describes the commands that you can use with the test synthesis tool.

- <u>check dft rules</u> on page 692
- <u>display scan chains</u> on page 695
- <u>do\_remove\_scan\_order\_data</u> on page 697
- <u>do xform connect scan</u> on page 698
- <u>do xform fix dft violations</u> on page 704
- <u>do xform insert shadow dft</u> on page 706
- <u>do xform insert testpoint</u> on page 712
- <u>get dft config mode</u> on page 716
- get scan chain info on page 717
- <u>read scan order file</u> on page 720
- <u>remove\_dft\_assertions</u> on page 722
- report dft assertions on page 726
- <u>report dft registers</u> on page 728
- <u>reset\_dft\_compatible\_clock\_domains</u> on page 731
- reset dft fix violations on page 732
- reset dft internal clock domain on page 733
- <u>reset\_dft\_transparent</u> on page 734
- <u>reset dont scan</u> on page 736
- <u>reset dont touch scan</u> on page 737
- <u>reset must scan</u> on page 738
- <u>reset scan data</u> on page 739

- <u>reset\_test\_mode\_setup</u> on page 740
- <u>set dft clock waveform</u> on page 741
- <u>set dft compatible clock domains</u> on page 743
- <u>set\_dft\_compatible\_chains</u> on page 747
- set dft fix violations on page 749
- <u>set dft internal clock domain</u> on page 752
- <u>set\_dft\_lockup\_element</u> on page 754
- <u>set dft transparent</u> on page 755
- <u>set\_dont\_scan</u> on page 757
- <u>set\_dont\_touch\_scan</u> on page 758
- <u>set lssd aux clock</u> on page 759
- <u>set lssd scan clock a</u> on page 760
- <u>set lssd scan\_clock\_b</u> on page 761
- <u>set max scan chain length</u> on page 762
- <u>set must scan</u> on page 765
- <u>set\_number\_of\_scan\_chains</u> on page 767
- <u>set scan chain</u> on page 770
- <u>set scan chain segment</u> on page 772
- <u>set\_scan\_data</u> on page 775
- <u>set scan equivalent</u> on page 779
- <u>set scan mode</u> on page 780
- <u>set\_scan\_style</u> on page 782
- <u>set test mode setup</u> on page 783
- <u>set test scan clock</u> on page 785
- <u>write atpg info</u> on page 786
- <u>write scan order file</u> on page 787

# check\_dft\_rules

```
check_dft_rules [> file_name | >> file_name]
    [-disable_clock_check]
```

Checks DFT rules for each flip-flop in the design. The flip-flops that pass check\_dft\_rules check are later automatically mapped to scan flip-flops and included in a scan chain during scan connection. The flip-flops that fail check\_dft\_rules are excluded from scan chains.

This command can be run on a generic database, structural database, or on mixed generic/structural designs.

The DFT rule violations which this command checks for are listed in <u>Table 6-1</u> on page 693. To maximize fault coverage, you should try to fix any DFT rule violations so that all flip-flops can be included in a scan chain. To better understand the costs and benefits of fixing DFT rule violations, see the section <u>Avoiding DFT Rule Violations</u> in the <u>Test Synthesis for</u> BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS) manual.

DFT assertions which are used by check\_dft\_rules are:

- set\_scan\_mode
- set\_scan\_style (*Default*: muxscan)
- set\_must\_scan
- set\_dont\_scan
- set\_test\_mode\_setup
- set\_dft\_internal\_clock\_domain
- set\_dft\_transparent
- set\_global dft\_enable\_combinational\_loop\_check
- set\_global dft\_enable\_race\_condition

# Important

You should run check\_dft\_rules whenever you make changes to the above assertions except for set\_scan\_mode. Otherwise, the changes are not propagated through the design.

Any error messages produced by check\_dft\_rules gives the RTL file name and line number at which the DFT violation occurred. If you are working in the GUI, you can triple-click

the error message itself to view that section of RTL code. You can fix the violation by editing the RTL code directly in the window.

This command has no effect on the design database.

| DFT Rule Violation                               | Check for Violation With                                       |
|--------------------------------------------------|----------------------------------------------------------------|
| Combinational feedback loops                     | <pre>set_global dft_enable_combinational_loop_check true</pre> |
|                                                  | check_dft_rules                                                |
| Race conditions                                  | <pre>set_global dft_enable_race_condition_check true</pre>     |
|                                                  | check_dft_rules                                                |
| Uncontrollable<br>asynchronous signals           | check_dft_rules                                                |
| Gated clocks and derived clocks                  | check_dft_rules                                                |
| Register's clock port<br>connected to tied lines | check_dft_rules                                                |
| Multiple sequential<br>control functions         | check_dft_rules                                                |
| Clocks feeding data path                         | Not checked                                                    |
| Bus conflicts or floating conditions             | Not checked                                                    |

#### **Options and Arguments**

If a file name is specified, then the output report is printed in the specified file.

```
-disable_clock_check
Prevents DET from checking for clock violations. Clock viol
```

Prevents DFT from checking for clock violations. Clock violations can prevent the tool from looking at and reporting other violations.

> file\_name

Creates or overwrites the specified file.

>> file\_name

Appends to the specified file.

### Example

Before checking the DFT rules in the design in the following example, scan\_en is specified as the name of the input port that activates scan mode and the active polarity for the enable signal is set to active-high. The output of check\_dft\_rules is redirected to file TDRCS.

set\_scan\_mode scan\_en 1
check\_dft\_rules > ./TDRCs

#### **Related Information**

report dft assertions

<u>report dft registers</u>

# display\_scan\_chains

display\_scan\_chains [-pks] [-chain n] [module\_name]

Displays the scan chains in the schematic viewer following test synthesis. This command is run on a scan-mapped netlist which was configured on chain mode. You should open the schematic viewer to the appropriate module prior to invoking this command.

If you want to display the scan chains for the current module, you can use the following Tcl command:

display\_scan\_chains [get\_names[get\_current\_module]]

You can traverse the hierarchy in the schematic viewer by clicking on a module instance. Repeat the Tcl command to view the scan chains for the newly displayed module.

The display\_scan\_chains command has no effect on the design database.

#### **Options and Arguments**

| -chain <i>n</i> | Displays only the specified scan chain. <i>n</i> corresponds to a chain number.<br><i>Default</i> : All scan chains                    |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------|
| module_name     | Specifies the name of the module whose scan chains you want to display.                                                                |
|                 | Default: Current module Note: The module_name argument is ignored when you also specify the -pks argument because the PKS window shows |
| -pks            | only the flattened top level design.<br>Displays the scan chain in the PKS window. The design must be                                  |
|                 | placed before using this option.<br>Default: Schematic viewer                                                                          |

#### **Examples**

The following command displays the scan chain 2 in module mymod in the schematic viewer:

display\_scan\_chains mymod - chain 2

■ The following command displays all scan chains in the current module in the schematic viewer:

display\_scan\_chains [get\_names [get\_current\_module]]

### do\_remove\_scan\_order\_data

do\_remove\_scan\_order\_data

Removes explicit scan order data stored after reading the scan-order file (using the command <u>read scan order file</u>) or SCANCHAINS section of the DEF file (using the command read\_def -scan\_only). This is necessary if you want to allow the scan configuration function to freely assign chains according to overall scan constraints instead of by explicit order from the above sources.

This command (do\_remove\_scan\_order\_data) is not needed to remove scan-order data after a connection cycle if read from the scan-order file. This is done automatically by the connection function.

**Note:** DEF file scan order data is *not* deleted automatically in this way, however, and will be retained by the system until deleted by this command (or by do\_remove\_design).

#### Examples

The following commands remove the scan order data that were stored after reading the new.scan\_order scan\_order file:

```
read_scan_order_file new.scan_order
do_remove_scan_order_data
```

The following commands removes the annotated scanDEF data after the reordering and connection cycle:

```
read_def -scan_only scan.def
do_place
do_xform_connect_scan -pks
do_remove_scan_order_data
```

#### **Related Information**

do remove design

<u>do\_xform\_connect\_scan</u>

get dft config mode

read def -scan only

read\_scan\_order\_file

# do\_xform\_connect\_scan

do\_xform\_connect\_scan [-scan\_file file\_name] [-pks] [-preserve\_config]

Configures and connects scan flip-flops into scan chains. The command works at the set\_current\_module level and all lower hierarchies referred to in the current module. The design must be mapped to the target library before connecting scan chains in a design.

There are two methods of getting to scan-equivalent flip-flops:

- If starting with a generic netlist, all flip-flops that pass DFT rule checking are converted to scan flip-flops by the technology mapper, and are connected up into scan chains when the connection engine is run in chain mode.
- If starting with a structural netlist that is mapped to basic D-flops, all flip-flops that pass DFT rule checking are converted to scan-equivalent flops and connected up into scan chains when the connection engine is run in chain mode.

# Important

The remapping is restricted to an **unplaced** design. If the design is placed, only those flip-flops that were mapped to scan flip-flops —by a do\_xform\_connect\_scan command—prior to placement are connected in scan chains.

The flip-flops that do not pass DFT rule checking are automatically excluded from scan chains. The flip-flops in the lower module hierarchies are also automatically reconfigured and connected, unless the lower module has been attributed with a dont\_modify or dont\_touch\_scan using commands set\_dont\_modify or set\_dont\_touch\_scan, respectively. The scan style used for scan flip-flops is controlled by the set\_scan\_style command.

Default: Scan style is muxscan.

DFT assertions or commands which are used by do\_xform\_connect\_scan are:

- set\_scan\_mode
- check\_dft\_rules
- set\_scan\_data
- set\_number\_of\_scan\_chains
- set\_max\_scan\_chain\_length
- set\_dft\_compatible\_clock\_domains
- set\_dont\_touch\_scan

- set\_dont\_modify [find -module]
- read\_def -scan\_only
- read\_scan\_order\_file
- set\_global dft\_scan\_path\_connect
- set\_global dft\_scan\_enable\_connect
- set\_global dft\_scan\_output\_pref
- set\_global dft\_scan\_avoid\_control\_buffering
- set\_global dft\_allow\_scan\_path\_inv
- set\_global dft\_min\_scan\_wire\_length
- set\_global dft\_scan\_port\_name\_prefix

#### **Scan Configuration**

When creating a configuration, all scan flip-flops are first configured into different chains based on the DFT assertions, such as

- Maximum scan chain length
- Number of scan chains
- Sets of compatible clock domains (when mixing different clock domains in a single chain in mux scan style)
- Fixed scan segments (that is, scan segments belonging to modules marked dont\_modify or dont\_touch\_scan).

In the absence of specifying any of the above test assertions, the connection engine will create a single scan chain for each clock domain and clock phase identified by check\_dft\_rules. If the user reads in a specific scan chain configuration (using read\_scan\_order\_file or read\_def -scan\_only), then the user-specified configuration is applied during chain synthesis.

To analyze and maintain the existing scan chain configuration of a structural netlist by PKS reordering, the scan connection engine must be run using the <code>-preserve\_config</code> option.

The -preserve\_config option is used in conjunction with the -pks option which instructs the connection engine to perform placement-based PKS reordering. Both options require a PKS license.

When using the -pks option, the placement information about scan flip-flops is used to configure the chains to minimize wire length due to routing the scan data shift path. The design must be placed before -pks option can be used in scan connection.

If scan chains contain multi-input gates on the scan path, then set the DFT global variable: set\_global dft\_stop\_analysis\_at\_complex\_logic prior to running the scan
connection engine.

#### Scan Data Connection

Scan flip-flops are connected up according to the global setting on the dft\_scan\_path\_connect global variable, which can be one of the following:

- chain—connects scan flip-flops in chain mode
- tieback—ties scan-in of a flip-flop to its own scan-out pin
- floating—leaves the scan-in of flip-flop unconnected.

#### *Default*: chain

Under chain mode, the following two additional globals control how the chains will be connected.

- dft\_scan\_output\_pref—controls whether to use normal or inverted output (Q or Q-bar) of scan flip-flop for scan connection. The possible settings are:
  - non\_inv—uses non-inverted (Q) output
  - □ min\_load—uses the output with least load.

Default: min\_load

- dft\_allow\_scan path\_inv—controls if inverters should be inserted in scan path to compensate for logic inversion when connecting from inverted output or to inverted scan-input. The possible settings are:
  - on—inversion in scan path is allowed.
  - off—inversion in scan path is not allowed. When connecting from inverted output (Qbar) or to inverted scan-input, an inverter will be inserted to compensate for logic inversion on the data path.

#### Default: on

Under chain mode, the chains get connected to the specified scan-in and scan-out pins (using set\_scan\_data command). If the scan-out of a chain is shared with a functional

output pin, a multiplexor, controlled by the scan-enable signal, is inserted to share the pin between functional output and scan output. For more information, refer to -sharedout option in the <u>set scan data</u> command.

In mux scan style, if scan flip-flops triggered by different edges of a clock or by different clock domains are to be connected in the same chain having specified the set\_dft\_compatible\_clock\_domains assertion, then lock-up latches would be automatically inserted to prevent clock-skew problems.

#### **Scan Control Connection**

When creating a scan chain configuration, the scan mode signal (scan-enable signal) is connected according to the setting of global variable dft\_scan\_enable\_connect. The allowed settings are:

- on—Connect scan-enable pin of flip-flop to the specified scan-enable signal.
- tieoff—Connect scan-enable pin of flip-flop to its inactive value (power/ground).
- floating—Leave scan-enable unconnected.

#### Default: on

If you do not specify scan mode pin (using set\_scan\_mode command) or an adequate number of scan data pins (using set\_scan\_data command), then scan synthesis will create new pins at the "current module" to drive scan mode and scan data nets.

The name prefix for these pins can be controlled with the following command: set\_global dft\_scan\_port\_name\_prefix.

#### *Default*: BG\_scan

When importing a structural netlist which had previously undergone test synthesis, the scan mode network will be preserved when the connection engine is run with the -preserve\_config option in PKS mode.

#### **Options and Arguments**

-pks

Orders and connects each chain according to the proximity of flip-flops and the placement information from the PKS tool. Optionally, the user may specify the DFT global variable dft\_min\_scan\_wire\_length prior to invoking PKS reordering. This global instructs PKS to connect successive registers along a scan chain according to a minimum wire length distance specified by the user which helps in minimizing hold time violations along the scan chain path.

**Note:** The -pks option requires a Cadence® Physically Knowledgeable Synthesis (PKS) software license. The design must be placed before performing placement-based scan chain ordering using the do\_place command. The units of distance are specified in units consistent with the LEF file (typically microns). *Default*: 0

-preserve\_config

Preserves the analyzed configuration of existing scan chains in scan mapped netlists during PKS-based scan reordering (-pks option). Any additional configuration assertions that you specify, such as set\_number\_of\_scan\_chains or set\_max\_scan\_chain\_length, and TDRC data (output of check\_dft\_rules) are ignored. The -preserve\_config option is the default mode used by the do\_place -scan\_reorder command.

-scan\_file file\_name

Specifies the output file name for the scan order file. *Default*: Generates the flat scan order file: *top\_module.scan.flat* 

#### Examples

■ The following commands create a configuration (two scan chains) prior to placement:

```
set_number_of_scan_chains 2
do_xform_conect_scan -scan_file ./SOF
```

The following commands create a configuration (based on the maximum scan chain length) after placement:

```
set_max_scan_chain_length
do_place
do xform connect scan
```

The following commands order and connect the chains based on placement information using PKS while preserving the existing configuration:

```
do_place
set_global dft_min_scan_wire_length 5.0
do_xform_connect_scan -pks -preserve_config
```

do\_xform\_connect\_scan

#### **Related Information**

<u>check\_dft\_rules</u>

<u>do place</u>

write\_scan\_order\_file

# do\_xform\_fix\_dft\_violations

```
do_xform_fix_dft_violations
  [-preview | -dont_check_dft_rules]
  [> file_name | >> file_name]
```

Automatically fixes all asynchronous set and reset violations that you have specified to fix via the <u>set dft fix violations</u> command. Any violation without a user-specified assertion is skipped.

Unless -preview is specified, this command transforms the DFT-fix assertions into actual netlist modifications. Consequently, after its successful execution, any existing DFT-fix assertions are cleared. This avoids re-applying a DFT fix more than once to a particular violation. In addition, the DFT-rule checker is automatically invoked after fixing the violations, unless -dont\_check\_dft\_rules is specified. This allows the tagging of the fixed flip-flops as being feasible for scan insertion.

If you use do\_xform\_fix\_dft\_violations with the -dont\_check\_dft\_rules option, you must eventually run check\_dft\_rules before running scan connection with the do\_xform\_connect\_scan command to include all scannable flip-flops in scan chains.

**Note:** Currently, only DFT violations related to asynchronous set and reset are fixed. Clock violations cannot be fixed yet.

#### **Options and Arguments**

| -dont_check_dft_rule | 29                                                                                                                                                                                                                                                                                                                               |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Prevents do_xform_fix_dft_violations from checking<br>DFT rules immediately after fixing the violations. You can use this<br>option if you do not want to fix all violations at once and you want<br>to use the DFT rule violation information, such as violation<br>codes, provided by a previous execution of check_dft_rules. |
| > file_name          | Directs he report generated by the command to the specified file.<br>If the file does not exist, it is created. If the specified file exist, it<br>will be overwritten.                                                                                                                                                          |
| >> file_name         | Appends the report generated by the command to the specified file.                                                                                                                                                                                                                                                               |

-preview

Displays the control points that will be inserted, but makes no modifications to the netlist.

#### Example

The following commands specify to fix the asynchronous reset violations on all instances with this type of violation using the test mode signal TM:

**Note:** The report indicates the number of violation points, such as flip-flop pins, and not the number of violations reported when running check\_dft\_rules.

#### **Related Information**

<u>check\_dft\_rules</u>

reset dft fix violations

<u>set dft fix violations</u>

<u>Tasks for Automatic Fixing of the Design Rule Violations</u> in *Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS*.

# do\_xform\_insert\_shadow\_dft

```
do_xform_insert_shadow_dft -around instance
  [-share | -bypass] [-sharing_groups groups]
  [-inputs ports] [-outputs ports]
  [-exclude ports | -only ports] [-test_mode signal]
  [-test_clock clock [-rise|-fall]] [-preview]
```

Allows to insert two basic types of DFT shadow logic around a particular instance: bypass and scannable logic (see Figure 6-1 on page 709 and Figure 6-2 on page 710 for simple examples). The insertion of scannable logic requires three steps (two steps more than when you insert bypass logic):

- Insertion of the DFT shadow logic (performed by this command)
- Mapping the DFT shadow flip-flops to scannable flip-flops
- Connecting the scan-chains

Each shadow logic flip-flop can implement one control point and one observation point at the same time (see Figure 6-2 on page 710).

In general, sharing results in smaller gate count, but this not always translates into smaller area. If the points to observe and control are close, sharing them in a same flip-flop will give smaller area and less routing. However, if the points are far away, the additional routing and congestion result in an overall worse solution. Because deciding which points to share is not straightforward, the default behavior is not to share them. Choosing to insert bypass logic implicitly assumes sharing.

If you want to share observation and control points, either using *-share or -bypass*, the following sharing criteria are observed:

- If you specified -sharing\_groups, the specified inputs and outputs are grouped together as indicated
- For the remaining inputs and outputs that are not listed with sharing\_groups, the first input will share the flip-flop with or be connected to the first output, the second input with the second output, and so on. The order is that specified in the HDL interface declaration.

#### **Options and Arguments**

-around instance

Specifies the instance around which the DFT shadow logic must be inserted. Specify either a hierarchical instance name or an object identifier.

| -bypass               | Implements bypass logic instead of observation and control points. If you specify this option, you must balance the number of inputs and outputs.                                              |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -exclude <i>ports</i> | Prevents the specified ports from being considered for shadow logic insertion. Specify either port names or port identifiers.                                                                  |
| -inputs <i>ports</i>  | Specifies the bidirectional ports of the untestable module that must be considered as inputs.                                                                                                  |
|                       | Use this option when the instance specified by the -around option is a black box and, hence, all its interface ports are assumed to be bidirectional.                                          |
| -only ports           | Restricts the ports to be considered for shadow logic insertion to<br>the specified ports. Specify either port names or port identifiers.                                                      |
| -outputs ports        | Specifies the bidirectional ports of the untestable module that<br>must be considered as outputs. Specify either port names or port<br>identifiers.                                            |
|                       | Use this option when the instance specified by the -around option is a black box and, hence, all its interface ports are assumed to be bidirectional.                                          |
| -preview              | Shows the potential changes, without making any modifications to the netlist.                                                                                                                  |
| -rise   -fall         | Specifies the edge of the <pre>-test_clock</pre> that is active during test mode operation. These options are only valid in conjunction with <pre>-test_clock.</pre> Default: <pre>-rise</pre> |
| -share                | Shares shadow flip-flops for control and observation points.                                                                                                                                   |

| -sharing_groups grou     | Specifies the inputs and outputs that must share an observation<br>and control point. Each group can have multiple input pins and<br>multiple output pins. Format the groups as follows:                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | $\{\{input_i output_i\} \}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                          | Separate the pins by spaces and enclose each group by braces ({}). If you have more than one group, you must enclose the list of groups by braces or double quotes.                                                                                                                                                                                                                                                                                                                                                                                                        |
|                          | The inputs of a group are applied to an XOR. Groups with multiple outputs result in the insertion of one multiplexer per output.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          | <b>Note</b> : If you use the $-bypass$ option, each group must have at least one input and one output. Otherwise, the number of inputs or outputs can be equal or larger than zero.                                                                                                                                                                                                                                                                                                                                                                                        |
| -test_clock <i>clock</i> | Specifies the signal that drives the clock pin of the flip-flops<br>implementing the scannable observation points. If you do not<br>specify this option, the tool issues a warning and connects the<br>flip-flops to the first available clock domain.                                                                                                                                                                                                                                                                                                                     |
| -test_mode <i>signal</i> | Specifies the signal to use to control the multiplexers after the controlling points. Specify either a previously declared test-mode signal, a top-level port or a hierarchical pin. If the signal does not exist, a warning message will be issued. This option is not (necessarily) related to the test-mode signal used at a later stage by the scan-chain connection engine. scan-mode signal may later on be connected to the observation points. That test-mode (or scan-mode) signal might or might not be the same as the one specified by this -test_mode option. |

#### Examples

In the following example, the logic before the ATPG-untestable module is not observable and the logic after it is not controllable. Following is the Verilog input code for the ATPG-untestable module and its instantiation:

```
output o1,o2,o3;
...
Untestable U1 (.i1(n_1), .i2(n_2), .o1(n_3), .o2(n_4), .o3(n_5));
...
```

In the following example, bypass logic is used to make the two inputs observable and the three outputs controllable. The first command pairs input i1 to output o1, and input i2 to output o3 (skipping o2). The second command pairs input i1 and output o2. The result is shown in Figure <u>6-1</u> (b).

```
do_xform_insert_shadow_dft -around U1 -test_mode TM -bypass -exclude o2
do_xform_insert_shadow_dft -around U1 -test_mode TM -bypass -only {i1 o2}
```

#### Figure 6-1 Insertion of Bypass DFT Shadow Logic



■ The following example uses scannable registers and shares shadow flip-flops for control and observation points. Figure <u>6-2(a)</u> shows that i1 and o1, and i2 and o2 share the shadow flip-flop. In total, 3 flip-flops are needed.

do\_xform\_insert\_shadow\_dft -around U1 -test\_mode TM -test\_clock CK -share



#### Figure 6-2 Inserting Scannable DFT Shadow Logic

■ The following command uses scannable registers but does not share the shadow flip-flops for control and observation points. As a result, five flip-flops are needed.

do\_xform\_insert\_shadow\_dft -around U1 -test\_mode TM -test\_clock CK

Figure 6-2(b) shows the result.

■ The following command uses scannable registers, shares shadow flip-flops for control and observation points, and controls which pins share a flip-flop. More specifically, i1 and o2 share a flip-flop, and i2 and o1. In addition, no control point is inserted for the net driven by U1/o3.

```
do_xform_insert_shadow_dft -around U1 -test_mode TM -test_clock CK \
        -exclude o3 -share -sharing_groups {{i1 o2} {i2 o1}}
```

#### **Related Information**

Inserting DFT Shadow Logic in the Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS manual.

# do\_xform\_insert\_testpoint

```
do_xform_insert_testpoint -location lsignal
   [-input | -output]
   [-observe_scan -test_clock clock [-rise|-fall]]
   [-control_0 | -control_1 | -control csignal
   |-control_scan -test_clock clock [-rise|-fall]]
   -test_mode tsignal [-preview]
```

Allows you to manually specify a control or observation test point to be added to the design. Control test points always require the specification of a test-mode signal. Test points that use scannable flip-flops to observe or control a node always require a test-clock signal.

If you insert a control or observation scan flip-flop, you need to run <u>check dft rules</u> to validate the control signals. You also need to run the scan connection engine to connect the flip-flops to a scan chain.

#### **Options and Arguments**

| -control_0              | Inserts a constant value 0 at the specified location when the signal specified by -test_mode is active.                                                              |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -control_1              | Inserts a constant value 1 at the specified location when the signal specified by -test_mode is active.                                                              |
| -control <i>csignal</i> | Inserts an arbitrary node, <i>csignal</i> , at the specified location when the signal specified by -test_mode is active.                                             |
| -control_scan           | Inserts a scan flip-flop to force a particular value at the specified location during test mode operation. The scan flip-flop is connected to a scan chain later on. |
|                         | <b>Note</b> : This option requires you to specify the -test_clock option                                                                                             |
| -input                  | Specifies that the signal specified with -location should be considered as an input.                                                                                 |

| -location <i>lsignal</i> |                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Specifies the location of the control point or observation point.<br>Specify an existing hierarchical pin name or an I/O (boundary<br>port at the top or a lower level. For observation test points, the<br>pin can be an input or output pin. For control test points, the<br>result is different depending on the direction of the location. See<br>the <u>Examples</u> on page 714. |
|                          | <b>Note</b> : If you specify a bidirectional pin, no logic will be inserted unless you specify the direction of the pin.                                                                                                                                                                                                                                                               |
| -observe_scan            | Inserts a scan flip-flop to observe the specified location. The scan flip-flop is connected to a scan chain later on.                                                                                                                                                                                                                                                                  |
|                          | <b>Note</b> : This option requires you to specify the -test_clock option                                                                                                                                                                                                                                                                                                               |
| -output                  | Specifies that the signal specified with -location should be considered as an output.                                                                                                                                                                                                                                                                                                  |
| -preview                 | Shows the potential changes, without making any modifications to the netlist.                                                                                                                                                                                                                                                                                                          |
| -rise   -fall            | Specifies the edge of the <pre>-test_clock</pre> that is active during test mode operation. These options are only valid in conjunction with <pre>-test_clock. Default: <pre>-rise</pre></pre>                                                                                                                                                                                         |
|                          | <b>Note</b> : You must use the same clock edge for both the control scan and the observe scan.                                                                                                                                                                                                                                                                                         |
| -test_clock <i>clock</i> | Specifies the signal that drives the clock pin of the inserted scan<br>flip-flops during test mode operation. This option is required<br>when you specify either -control_scan or -observe_scan                                                                                                                                                                                        |
|                          | <b>Note</b> : You must use the same clock signal for both the control scan and the observe scan.                                                                                                                                                                                                                                                                                       |

-test\_mode *tsignal* 

Specifies the signal that allows controlling or observing the specified location point. Specify either a previously declared test-mode or scan-mode signal, a top-level port, or a hierarchical pin. If *tsignal* does not exist, a warning message is issued.

#### Examples

Consider a net with multiple sinks. If the location signal is specified on an output pin, the test point is inserted at the beginning of the fork. If the location is specified on an input pin, the test point is inserted in such a way that only the end of the fork is controllable. Both situations are illustrated in Figure 6-3 on page 714.

#### Figure 6-3 Location of Test point Insertion Depends on Type of Used Pin

Circuit before test point insertion.



Control-0 test point inserted at the output of instance x



Control-0 test point inserted at the input of instance Z



- The following command inserts a control-0 test point at hierarchical pin X/out: do\_xform\_insert\_testpoint -location X/out -test\_mode TM -control\_0
- The following command inserts a control-1 test point at hierarchical pin X/out: do\_xform\_insert\_testpoint -location X/out -test\_mode TM -control\_1

#### Command Reference for BuildGates Synthesis and Cadence PKS Test Synthesis Commands

- The following command inserts a control signal csignal at hierarchical pin X/out: do\_xform\_insert\_testpoint -location X/out -test\_mode TM -control csignal
- The following command inserts a scannable observation test point, using CLK to drive: do\_xform\_insert\_testpoint -location X/out -test\_clock CLK -observe\_scan
- The following command inserts a control-1 and scannable observation point:

do\_xform\_insert\_testpoint -location X/out -test\_mode TM \
-test\_clock CLK -control\_1 -observe\_scan

The following command inserts a scannable control point:

do\_xform\_insert\_testpoint -location X/out -test\_mode TM \
-test\_clock CLK -control\_scan

The following command inserts a scannable control and observation test point:

```
do_xform_insert_testpoint -location X/out -test_mode TM \
-test_clock CLK -control_scan -observe_scan
```

#### **Related Information**

<u>check dft rules</u>

<u>do\_xform\_connect\_scan</u>

<u>do optimize</u>

<u>Types of Test Points</u> in the Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS manual.

# get\_dft\_config\_mode

get\_dft\_config\_mode

Returns the configuration mode established in the design database. The following keywords are returned:

- scandef—Indicates connection engine is using scanDEF data (from read\_def command).
- scanorder—Indicates connection engine is using scan order file data (from read\_scan\_order\_file command).
- normal—Normal BG configuration mode enabled (none of the above modes are active).

#### **Related Information**

do remove scan order data

<u>read\_def</u>

<u>read scan order file</u>

# get\_scan\_chain\_info

```
get_scan_chain_info [-test_setup | -scan_setup
      -count | -enable | -clock [scan_chain_index]
      -length [scan_chain_index]
     -in [scan_chain_index]
     -out [scan_chain_index] ] [-name]
```

Returns the information on scan chains in "current module" configured in a design database which has undergone test synthesis. This command is also used by the write atpg info command to generate an ATPG interface file.

#### **Options and Arguments**

| -clock scan_chain_i | ndex                                                                                                                                                                                      |                                                        |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
|                     | Gets the pin ID of the system clock p<br>and its active edge. The active edge i<br>edge, 1 for positive edge. If the -name<br>command returns the pin name rathe                          | s reported as 0 for negative<br>ne option is used, the |
|                     | Valid values for <i>scan_chain_ind</i><br>number of scan chains.<br><i>Default</i> : 1                                                                                                    | ex are 1 through the                                   |
| -count              | Gets the total number of scan chains                                                                                                                                                      | S.                                                     |
| -enable             |                                                                                                                                                                                           |                                                        |
|                     | Gets the scan-enable pin ID and its a option is used, the command returns the ID.                                                                                                         |                                                        |
| -in scan_chain_inde | ex                                                                                                                                                                                        |                                                        |
|                     | Gets the pin ID of the scan input port<br>values for <i>scan_chain_index</i> ar<br>scan chains. If the <i>-name</i> option is u<br>the pin name rather than the ID.<br><i>Default</i> : 1 | re 1 through the number of                             |
| -length scan_chain_ | index                                                                                                                                                                                     |                                                        |
| 5                   | Gets the length of the specified chain<br>scan_chain_index are 1 throug<br>chains.<br>Default: 1                                                                                          |                                                        |
| December 2003       | 717                                                                                                                                                                                       | Product Version 5.0.13                                 |

| -name               | Returns name of what you are looking for instead of pin ID.                                                                                                                                                                                                                |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -out scan_chain_ind | Gets the pin ID of the scan output port of the specified chain.<br>Valid values for <i>scan_chain_index</i> are 1 through the<br>number of scan chains. If the <i>-</i> name option is used, the<br>command returns the pin name rather than the ID.<br><i>Default</i> : 1 |
| -scan_setup         | Returns a list of sublists, where each sublist consists of a port ID and its active value that is set during the scan-shift cycle of the test mode.                                                                                                                        |
| -test_setup         | Returns a list of sublists, where each sublist consists of a port ID<br>and its active level that needs to be set during test mode<br>(throughout the test session). If the -name option is used, the<br>command returns the pin name rather than the ID.                  |

#### Examples

The following command returns the number of scan chains (including scan chain segments) configured in the design:

get\_scan\_chain\_info -count

■ The following commands return the length along scan chain 1:

```
get_scan_chain_info -length 1
set clockNameChain2 [lindex [get_scan_chain_info -clock 2 -name] 0]
set clockLogicValueChain2 [lindex [get_scan_chain_info -clock 2 -name] 1]
```

The following command returns sen as the input port for the test mode signal and 1 as the value assigned to the test mode signal during the scan\_shift cycle of test mode:

```
set_test_mode_setup sen 1 -scan_shift
Info: Test mode for module `test' set to sen=1 during scan shift only.
get_scan_chain_info -scan_setup -name
```

# **Related Information**

<u>do xform connect scan</u>

<u>write\_atpg\_info</u>

# read\_scan\_order\_file

#### read\_scan\_order\_file file\_name

Reads a scan order data file and initializes the scan order chain configuration in the design database. The scan order file controls the configuration and specific ordering of instances and scan chains throughout the hierarchy. In this mode, all other scan configuration assertions, such as set\_number\_of\_scan\_chains and set\_max\_scan\_chain\_length will be ignored.

The test synthesis tool creates a scan order data file when you run the do\_xform\_connect\_scan, do\_optimize, or write\_scan\_order\_file commands. *Default*: The file type is written in flat format using the file name *top\_module*.scan.flat.

You can create or edit a scan order data file and define the order in which registers are to be connected along the scan chains by using the read\_scan\_order\_file command.

If the connection engine is run with the -pks flag, PKS reordering of the flops will also occur. Scan Order File (SOF) data is automatically removed after a connection cycle.

#### **Options and Arguments**

*file\_name* Specifies the name of the scan order data file.

#### **Examples**

■ The following commands first read in scan order data file new.scan\_order, then configure and connect the scan flip-flops into scan chains before placement:

read\_scan\_order\_file new.scan\_order
do\_xform\_connect\_scan

The following commands read in scan order data file new.scan\_order, place the design, then configure, connect and reorder the scan chains. After the reordering, the scan order file data is removed.

```
read_scan_order_file new.scan_order
do_place
do_xform_connect_scan -pks
```

#### **Related Information**

do remove scan order data

do\_xform\_connect\_scan

get dft config mode

write\_scan\_order\_file

# remove\_dft\_assertions

```
remove_dft_assertions [-all] [-check_dft_rules_data]
  [-compatible_chains] [-compatible_clock_domains]
  [-config_constraints] [-configuration_constraints]
  [-dft_fix_violations] [-dft_transparent]
  [-dont_scan] [-dont_touch_scan] [-lockup_element]
  [-internal_clock_domains]
  [-must_scan] [-scan_chain] [-scan_chain_segment]
  [-scan_data_io] [-scan_mode] [-test_mode_setup]
```

Allows the user to selectively remove all or any of the DFT assertions specified on the design database.

# **Options and Arguments**

| -all                 | Removes all DFT assertions.                                                                                                                                             |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -check_dft_rules_dat | a<br>Removes DFT rule check data generated by the<br>check_dft_rules command.                                                                                           |
| -compatible_chains   | Removes all scan chain groupings set using the set_dft_compatible_chains command.                                                                                       |
| -compatible_clock_dc | mains<br>Removes the -compatible_clock_domain assertion set by<br>set_dft_compatible_clock_domains.                                                                     |
| -config_constraints  | Removes configuration constraints related to chain length and number of scan chains as set by <pre>set_max_chain_length</pre> and <pre>set_number_of_scan_chains.</pre> |
| -configuration_const | raints<br>Works the same as -config_constraints above.                                                                                                                  |
| -dft_fix_violations  | Removes all DFT assertions set with set_dft_fix_violations.                                                                                                             |

| -dft_transparent     | <b>Removes the</b> -dft_transparent <b>assertion set by</b> set_dft_transparent.                                                                                                                                                                                          |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -dont_scan           | Removes the -dont_scan assertion set by set_dont_scan.                                                                                                                                                                                                                    |
| -dont_touch_scan     | Removes the -dont_touch_scan assertion set by set_dont_touch_scan.                                                                                                                                                                                                        |
| -internal_clock_doma | ins<br>Removes the -internal_clock_domains assertion set by<br>set_dft_internal_clock_domain.                                                                                                                                                                             |
| -lockup_element      | Removes the -lockup_element assertion set by the set_dft_lockup_element command.                                                                                                                                                                                          |
| -must_scan           | Removes the -must_scan assertion set by set_must_scan.                                                                                                                                                                                                                    |
| -scan_chain          | Removes the -scan_chain assertions set by the <pre>set_scan_chain command. For consistency, it also removes all segments declared by the set_scan_chain_segment command.</pre>                                                                                            |
| -scan_chain_segment  | Removes the -scan_chain_segment assertion set by set_scan_chain_segment command. It also removes the -scan_chain assertions set by the set_scan_chain command, as the assertions in the set_scan_chain command refer to the segments specified by set_scan_chain_segment. |
| -scan_data_io        | Removes the -scan_data_io assertion set by set_scan_data.                                                                                                                                                                                                                 |
| -scan_mode           | Removes the -scan_mode signal assertion set by set_scan_mode.                                                                                                                                                                                                             |

-test\_mode\_setup

Removes the -test\_mode\_setup attributes set by set\_test\_mode\_setup.

In previous releases (with the exception of configuration assertions set\_number\_of\_scan\_chains and set\_max\_scan\_chain\_length, or set\_scan\_mode), the remaining DFT assertions could be selectively removed using the following commands:

```
reset_dft_compatible_clock_domains
reset_dft_transparent
reset_dont_scan
reset_dont_touch_scan
reset_dft_internal_clock_domain
reset_must_scan
reset_scan_data
reset_test_mode_setup
```

## Example

The following commands remove configuration constraints related to the number of scan chains set by set\_number\_of\_scan\_chains:

set\_number\_of\_scan\_chains 5
report\_dft\_assertions
remove\_dft\_assertions -config\_constraints

# **Related Information**

<u>check\_dft\_rules</u>

set dft compatible chains

set dft compatible clock domains

<u>set\_dft\_fix\_violations</u>

<u>set dft internal clock domain</u>

<u>set dft lockup element</u>

set\_dft\_transparent

<u>set\_dont\_scan</u>

- set dont touch scan
- set max scan chain length
- <u>set must scan</u>
- <u>set\_number\_of\_scan\_chains</u>
- <u>set\_scan\_chain</u>
- <u>set scan chain segment</u>
- <u>set\_scan\_data</u>
- <u>set\_scan\_mode</u>
- set test mode setup

# report\_dft\_assertions

```
report_dft_assertions
  [-module {module_id | module_name}]
  [> file_name | >> file_name]
```

Displays the current settings of the DFT assertions and configuration constraints. When you do not use the *-module* option, report\_dft\_assertion displays the DFT assertions for the current module and all the modules below it, and it gives a report of the current settings.

## **Options and Arguments**

| >file_name         | Creates or overwrites the specified file.                                                         |
|--------------------|---------------------------------------------------------------------------------------------------|
| >> file_name       | Appends to the specified file.                                                                    |
| -module {module_id | <pre>module_name } Reports DFT assertions for the specified module. Default: Current module</pre> |

# Examples

The following commands fix the asynchronous set and reset violations on instances R1 and R2 using the test mode signal TM. and then reports the current settings of the DFT assertions and configuration constraints for the current module:

The following commands specify the input port for the test mode signal and the input port that activates scan mode before reporting the current settings of the DFT assertions and configuration constraints for the module top:

```
set_current_module top
set_test_mode_setup u_jtag/test_mode_out 1
set_scan_mode u_jtag/scan_enable 1
report_dft_assertions
Info: Scan mode for module `top' set to `u_jtag/scan_enable = 1'
```

#### **Related Information**

- set dft compatible clock domains
- set dft compatible chains
- <u>set\_dft\_fix\_violations</u>
- set dft internal clock domain
- set dft transparent
- <u>set\_dont\_scan</u>
- set dont touch scan
- <u>set lssd aux clock</u>
- <u>set\_lssd\_scan\_clock\_a</u>
- <u>set\_lssd\_scan\_clock\_b</u>
- set max scan chain length
- <u>set\_must\_scan</u>
- <u>set number of scan chains</u>
- <u>set scan chain</u>
- <u>set\_scan\_chain\_segment</u>
- <u>set\_scan\_data</u>
- <u>set scan mode</u>
- <u>set\_scan\_style</u>
- set test mode setup
- set test scan clock

# report\_dft\_registers

```
report_dft_registers [-scan] [-non_scan] [-latch]
    [> file_name | >> file_name]
```

Reports whether all register instances are scanned or non-scanned, and the clock domain in which they exist. Use this command after running check\_dft\_rules.

- For scannable registers, it reports the clock domain.
- For non-scannable registers, it indicates the reason for their exclusion from scan (that is, the DFT rule that was violated).

You can request information about only the scannable registers or only the non-scannable registers.

Non-scannable latch instances can be reported using the *-latch* option.

Additionally, the report\_dft\_registers command reports the mapping/scan status of all register instances in the design. The following status flags apply:

<mapped to invalid scan register>

Scan style of registers does not match scan style specified using  $set\_scan\_style$  command.

<unmapped register>

Not yet mapped to a register from the target technology library.

<mapped to non-scan register>

Will be converted to scan equivalent register, if the register passes the DFT rule checking. The conversion of the register to its scan equivalent flop occurs when the scan chain configuration is being created in the design.

■ <mapped (for-DFT) to scan register>

Mapped to scan register from the target technology library

■ <mapped (NOT-for-DFT) to scan register>

Mapped to scan register but likely to be mapped to scan for functional logic purposes rather than for DFT. This status flag could also be obtained, if the user did not identify all scan mode signals and/or their correct active logic value specified using the set\_scan\_mode assertion.

#### **Options and Arguments**

| > file_name  | Creates or overwrites the specified file.                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| >> file_name | Appends to the specified file.                                                                                                                                          |
| -latch       | Includes latches in the report.<br><i>Default</i> : The latches are excluded from the report since the tool does not perform scan insertion on level-sensitive latches. |
| -non_scan    | Reports only the non-scan registers.                                                                                                                                    |
| -scan        | Reports only the scan registers.                                                                                                                                        |

## Example

The following commands report the scan registers.

```
check_dft_rules
report_dft_registers -scan
        Scan register instances:
        ireq req 4 -> [clock-domain 0] <unmapped register>
    ireg_reg_3 -> [clock-domain 0] <unmapped register>
    ireq req 5 -> [clock-domain 0] <unmapped register>
    ireg_reg_2 -> [clock-domain 0] <unmapped_register>
    ireg_reg_1 -> [clock-domain 0] <unmapped_register>
    submod2i/creg_reg_4 -> [clock-domain 0] <unmapped_register>
    submod2i/creg_reg_3
                                 -> [clock-domain 0] <unmapped_register>
                                 -> [clock-domain 0] <unmapped_register>
    submod2i/creg_reg_2
                                 -> [clock-domain 0] <unmapped register>
    submod2i/creg_reg_1
    submod2i/bottom2i/breg reg 0
                                         -> [clock-domain 0] <unmapped register>
                                         -> [clock-domain 0] <unmapped_register>
    submod2i/bottom2i/breg_reg_1
    submod2i/bottom2i/breg reg 2
                                         -> [clock-domain 0] <unmapped register>
    submod2i/bottom2i/breg_reg_3
                                         -> [clock-domain 0] <unmapped_register>
    submod2i/bottom2i/breg_reg_4
                                         -> [clock-domain 0] <unmapped_register>
    submod2i/bottom2i/breg_reg_5
                                         -> [clock-domain 0] <unmapped_register>
    submod2i/bottom2i/breg reg 6
                                         -> [clock-domain 0] <unmapped_register>
                                         -> [clock-domain 0] <unmapped_register>
    submod2i/bottom2i/areg_reg_0
    submod2i/bottom2i/areg_reg_1
                                         -> [clock-domain 0] <unmapped register>
    submod2i/bottom2i/areg_reg_2
                                         -> [clock-domain 0] <unmapped_register>
    submod2i/bottom2i/areg_reg_3
                                         -> [clock-domain 0] <unmapped_register>
   submod21/bottom21/areg_reg_3-> [clock-domain 0] ulmapped_register>submod2i/bottom2i/areg_reg_5-> [clock-domain 0] unmapped_register>submod2i/bottom2i/areg_reg_6-> [clock-domain 0] unmapped_register>
    submodli/do_reg_0 -> [clock-domain 0] <mapped (for-DFT) to scan register>
```

submodli/do\_reg\_1 -> [clock-domain 0] <mapped (for-DFT) to scan register> submodli/do\_reg\_2 -> [clock-domain 0] <mapped (for-DFT) to scan register> submodli/do\_reg\_3 -> [clock-domain 0] <mapped (for-DFT) to scan register> submodli/do\_reg\_4 -> [clock-domain 0] <mapped (for-DFT) to scan register> submodli/do\_reg\_5 -> [clock-domain 0] <mapped (for-DFT) to scan register> submodli/do\_reg\_6 -> [clock-domain 0] <mapped (for-DFT) to scan register> Info: Total Scannable register count: 30 <DFT-340>.

#### **Related Information**

30

check dft rules

# reset\_dft\_compatible\_clock\_domains

```
reset_dft_compatible_clock_domains
```

Removes all the previous settings of the set\_dft\_compatible\_clock\_domains assertion.

You need to specify this command before you connect the scan chains in order to prevent the connection engine from creating chains with merged domains.

# Examples

Reconfigure without domain merging.

The following commands remove all the previous settings of the set\_dft\_compatible\_clock\_domains assertion, report the current settings of the DFT assertions and configuration constraints for the current module, and reconfigure the scan chains before placement:

```
reset_dft_compatible_clock_domains
report_dft_assertions
do_xform_connect_scan
```

The following commands first place the design, then removes all the previous settings of the set\_dft\_compatible\_clock\_domains assertion before connecting the scan chains:

```
do_place
reset_dft_compatible_clock_domains
do_xform_connect_scan -pks
```

# **Related Information**

do xform connect scan

remove dft assertions -compatible\_clock\_domains

report dft assertions

<u>set\_dft\_compatible\_clock\_domains</u>

# reset\_dft\_fix\_violations

```
reset_dft_fix_violations [-async_set | -async_reset]
    [-clock] [-all | -instance instance_list]
```

Reverses the effects of <u>set dft fix violations</u> on the specified instances.

#### **Options and Arguments**

-all

| all                         | Removes the specified type assertions from all the instances that have them.                                                                                                                |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -async_reset                | Removes the asynchronous reset violation assertions—<br>associated with the specified instances—from the list of<br>violations to be fixed.                                                 |
| -async_set                  | Removes the asynchronous set violation assertions associated— with the specified instances—from the list of violations to be fixed.                                                         |
| -clock                      | Removes the clock violation assertions—associated with the specified instances—from the list of violations to be fixed.                                                                     |
| -instance <i>instance</i> _ | Jist<br>Specifies the instances from which to remove the assertions. You<br>can identify the instances using either their hierarchical instance<br>names or their object identifiers (IDs). |

#### **Related Information**

<u>set dft fix violations</u>

<u>Tasks for Automatic Fixing of the Design Rule Violations</u> in the *Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS* manual.

# reset\_dft\_internal\_clock\_domain

```
reset_dft_internal_clock_domain
    { hier_pin_id | hier_pin_name }
```

Removes a previous setting of an internal clock as a separate DFT domain, previously set with the <u>set dft internal clock domain</u> assertion.

Clocks are specified cumulatively with the set\_dft\_internal\_clock\_domain
assertion. To remove any of the previous settings, use the
reset\_dft\_internal\_clock\_domain command. This data applies to the
current module.

Before connecting the scan chains, you need to rerun check\_dft\_rules in order to propagate the changes through the circuit.

## **Options and Arguments**

hier\_pin\_id Specifies an existing instance output pin identifier (ID). hier\_pin\_name Specifies an existing hierarchical instance output pin name.

# Example

The following commands remove the clock domain that was first created for internal clock ul/out:

set\_dft\_internal\_clock\_domain ul/out
reset\_dft\_internal\_clock\_domain ul/out

# **Related Information**

<u>check dft rules</u>

remove dft assertions -internal\_clock\_domains

report\_dft\_assertions

<u>set dft internal clock domain</u>

# reset\_dft\_transparent

```
reset_dft_transparent
  [-module { module_id | module_name }]
  -instance { instance_id | instance_name }
   { output_port_id | output_port_name} [-all]
```

Removes the virtual connectivity information specified for a black box module previously defined with the set\_dft\_transparent assertion.

You need to rerun check\_dft\_rules before you connect the scan chains in order to propagate the changes through the circuit.

## **Options and Arguments**

| -all                | Specifies that you want to remove the connectivity data for all modules and instances that were previous set using the set_dft_transparent assertion.                                                      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance {instance | _id   instance_name}<br>output_port_id   output_port_name<br>Specifies the instance and its output port for which you want to<br>remove the connectivity data.                                             |
| -module {module_id  | <pre>module_name } Specifies the module for the instance that you want to reset when you specify an instance name. You do not need to specify the module for an instance ID. Default: Current module</pre> |

# Example

The following commands remove the virtual connectivity information that was specified for black box instance pll\_ins and output port Out:

reset\_dft\_transparent -instance pll\_ins Out
check\_dft\_rules



Black color (black box) indicates a <code>set\_dft\_transparent</code> assertion has been specified across the I/O pins of the <code>pll\_ins</code> instance.

# **Related Information**

<u>check\_dft\_rules</u>

remove dft assertions -dft\_transparent

<u>report dft assertions</u>

<u>set dft\_transparent</u>

# reset\_dont\_scan

reset\_dont\_scan [-module {module\_id | module\_name}]
 [-instance {list\_of\_inst\_id | list\_of\_inst\_name}]

Reverses the effect of the set\_dont\_scan assertion.

You need to rerun check\_dft\_rules before you connect the scan chain in order to propagate the changes through the circuit.

## **Options and Arguments**

| -instance {list_of_ | <pre>inst_id   list_of_inst_name } Specifies one or more instances that you want to reset. All registers in the instance hierarchy that pass DFT rule checking are included in the scan chain.</pre> |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -module {module_id  | <pre>module_name } Specifies the module that you want to reset. All registers in the module hierarchy that pass DFT rule checking are included in the scan chain.</pre>                              |

# Examples

The following commands remove the set\_dont\_scan assertion from instance clk\_div\_reg, report the current settings of the DFT assertions and configuration constraints, then propagate the changes:

```
reset_dont_scan -instance clk_div_reg
report_dft_assertions
check_dft_rules
```

■ The following commands remove the set\_dont\_scan assertion from module lower1, then propagate the changes:

```
reset_dont_scan -module lower1
check_dft_rules
```

# **Related Information**

<u>check\_dft\_rules</u>

remove dft assertions -dont\_scan

report dft assertions

<u>set\_dont\_scan</u>

December 2003

# reset\_dont\_touch\_scan

reset\_dont\_touch\_scan [module\_id | module\_name]

Reverses the effect of the set\_dont\_touch\_scan assertion. This assertion must be set prior to running the scan connection engine.

After this assertion is issued, the connection engine may modify and reconfigure existing scan chains inside the module in subsequent scan connection runs (<u>do xform connect scan</u>).

#### **Options and Arguments**

| module_id   | Specifies the identifier (ID) of the module that you want to reset. |
|-------------|---------------------------------------------------------------------|
| module_name | Specifies the name of the module that you want to reset.            |

#### Example

The following commands remove the dont\_touch\_scan assertion from module submod1 before running the connection engine:

reset\_dont\_touch\_scan submod1 Info: module 'submod1' cleared of DONT\_TOUCH\_SCAN mode. report\_dft\_assertions > ./DFTAssert do\_xform\_connect\_scan

#### **Related Information**

do xform connect scan

remove\_dft\_assertions -dont\_touch\_scan

report dft assertions

<u>set dont touch scan</u>

## reset\_must\_scan

```
reset_must_scan
[-instance {list_of_register_instance_id |
    list_of_register_instance_name}]
```

Reverses the effect of the set\_must\_scan assertion.

You need to rerun check\_dft\_rules before you connect the scan chain in order to propagate the changes through the circuit.

#### **Options and Arguments**

-instance {list\_of\_register\_instance\_id | list\_of\_instance\_name} Specifies one or more instances that you want to reset. All registers in the instance hierarchy that pass DFT rule checking are included in the scan chain.

#### Example

The following commands remove the set\_must\_scan assertion from instances u1/regA and u2/regB, then propagate the changes through the circuit:

```
reset_must_scan -instance u1/regA u2/regB
check_dft_rules
```

#### **Related Information**

<u>check dft rules</u>

remove dft assertions -must\_scan

report dft assertions

<u>set must scan</u>

# reset\_scan\_data

```
reset_scan_data
    [-clock { clock_port_id | clock_port_name }]
```

Removes the scan data port assertions from the top-level module. The tool assigns default names or propagates the names applied at the current module (if specified) using the set\_scan\_data command.

**Note:** You need to specify the reset\_scan\_data command before you connect the scan chains.

## **Options and Arguments**

```
-clock {clock_port_id | clock_port_name}
Specifies the clock port ID or name of a top-level port, or an
internal clock domain point set using the set_scan_data
command.
```

#### Example

The following example resets all scan data port assertions:

reset\_scan\_data

# **Related Information**

<u>do\_xform\_connect\_scan</u>

remove\_dft\_assertions -scan\_data\_io

report dft assertions

<u>set\_scan\_data</u>

# reset\_test\_mode\_setup

```
reset_test_mode_setup
    {input_port_id | input_port_name }
```

Reverses the effect of a previous set\_test\_mode\_setup assertion.

You need to rerun check\_dft\_rules before you connect the scan chain in order to propagate the changes through the circuit.

#### **Options and Arguments**

| input_port_id   | Specifies an input port identifier (id) for the test mode signal. |
|-----------------|-------------------------------------------------------------------|
| input_port_name | Specifies an input port name for the test mode signal.            |

#### **Examples**

The following commands reset the value for the test mode signal associated with input port xyz, then propagate the changes through the circuit:

```
set_top_timing_module top
set_test_mode_setup xyz 1
reset_test_mode_setup xyz
Info: Module 'top' cleared of test mode 'xyz = 1' during entire test session.
set_test_mode_setup xyz 0
check_dft_rules
```

# **Related Information**

remove dft assertions -test\_mode\_setup

<u>report dft assertions</u>

set test mode setup

# set\_dft\_clock\_waveform

set\_dft\_clock\_waveform [RTZ|RT1]

Controls how the DFT clock waveforms are applied to all top-level DFT clock signals. The DFT rules checker and the scan configuration and connection engines will use this information to mix compatible clock edges in the proper order to minimize the number of lockup elements.

You must use this command prior to running check\_dft\_rules for it to be effective. *Default*: RTZ

#### **Options and Arguments**

RT1

RTZ

Specifies that for all clocks, the negative (falling) edge occurs first when applying the clock signals to the design. As a result the tool will connect the positive edge-triggered flip-flops before connecting the negative edge-triggered flip-flops to avoid insertion of a lockup element in the scan chains.

Specifies that for all clocks, the positive (rising) edge occurs first when applying the clock signals to the design. As a result the tool will connect the negative edge-triggered flip-flops before connecting the positive edge-triggered flip-flops to avoid insertion of a lockup element in the scan chains.

#### Example

■ The following example shows you where to use the set\_dft\_clock\_waveform command in a flow that creates a scan chain configuration.

```
#specify the test setup
set_global dft_scan_avoid_control_buffering
set_scan_mode
set_scan_data
set_dft_clock_waveform
# run the DFT rule checks and report the registers
check_dft_rules
report_dft_registers > DFTregs
# optimize the design (map to scan flops and create the chains)
# uncomment compatible clock domains assertion if domain merging is desired.
# set_dft_compatible_clock_domains
do_optimize
...
```

For examples of where to use the set\_dft\_clock\_waveform command in flows that analyze pre-existing scan chains, refer to <u>Reordering Scan Chains on an Imported</u> <u>Netlist with Preconfigured Scan Chain Architecture</u> in the *Test Synthesis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)* manual.

# **Related Information**

<u>check dft rules</u>

<u>do\_xform\_connect\_scan</u>

set dft compatible clock domains

# set\_dft\_compatible\_clock\_domains

```
set_dft_compatible_clock_domains
    [-all | -all_rise | -all_fall | list_of_clocks
    |-same_edge | -same_clock | -same_root]
```

Specifies the compatible clock domains whose affected scan flip-flops can be merged into a single scan chain using lockup latches in between.

*Default*: No clock domains (including different phases of the same clock) are assumed compatible.

You need to specify this command before you create a scan chain configuration using the do\_xform\_connect\_scan command.

#### **Options and Arguments**

Any command-line option, or a *list\_of\_clocks*, should be specified as:

| -all           | Specifies that all clocks are compatible. This setting supersedes all prior invocations of this command. |
|----------------|----------------------------------------------------------------------------------------------------------|
| -all_rise      | Specifies that all rising-edge clock domains are compatible.                                             |
| -all_fall      | Specifies that all falling-edge clock domains are compatible.                                            |
| list_of_clocks | Specifies the clock domain. A clock domain can be specified as follows: <i>clock</i> [-rise   -fall]     |
|                | clock should be an existing top level clock port name, hierarchical clock pin, or clock identifier.      |
|                | -rise denotes rising edge.                                                                               |
|                | -fall denotes falling edge.                                                                              |
|                | When no edge is specified, both domains are assumed to be compatible, if present.                        |

| -same_clock | Specifies that both edges of each clock are compatible. For example, if both edges of clocks A and B are present (four domains total), this is equivalent to the following commands: |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <pre>set_dft_compatible_clock_domains A set_dft_compatible_clock_domains B</pre>                                                                                                     |
| -same_edge  | Specifies that all clock domains of the same edge are compatible.                                                                                                                    |
| -same_root  | Causes all clocks/phases with the same root domain to be grouped together.                                                                                                           |

The settings of  $set_dft_compatible_clock_domains$  are cumulative. If clock domains A and B are specified as compatible, and subsequently B and C are set compatible, then clocks A, B, and C are compatible.

Use the reset\_dft\_compatible\_clock\_domains command to remove all prior compatibility settings.

# Examples

For the following examples, consider the schematic shown in Figure <u>6-6</u>. The design has 7 clock domains.



#### Figure 6-4 Schematic for the set\_dft\_compatible\_clock\_domains Examples

**Note:** Use the set\_dft\_internal\_clock\_domain command to identify domains 2, 3, 5, and 6.

- The following command declares that clock domains 2 and 5 can be merged: set\_dft\_compatible\_clock\_domains A1/X -fall B1/X -rise.
- The following command declares that clock domains 2 and 3 (both edges of A1/X) can be merged:

set\_dft\_compatible\_clock\_domains A1/X

The following command declares that clock domains 0 and 1 can be merged. No edge is specified; include both.

set\_dft\_compatible\_clock\_domains Aclk

The following command takes no action (same as default since only one edge specified for Bclk). To group all clocks with Bclk as the root (only), you would need to specify them explicitly, such as Bclk B1/X B1/Y.

set\_dft\_compatible\_clock\_domains Bclk

■ The following command groups clock domains (0, 1) and (2, 3). Only alternate phases when present for specific clocks, Aclk and Al/X in this case—are grouped together.

```
set_dft_compatible_clock_domains -sameclock
```

■ The following command groups clock domains (0, 1, 2, 3) and (4, 5, 6):

set\_dft\_compatible\_clock\_domains -sameroot

■ The following example uses the cumulative effect of successive commands. As a result, the following groups are created: (0, 1) and (2, 3, 4).

set\_dft\_compatible\_clock\_domains -sameclock
set\_dft\_compatible\_clock\_domains A1/X -rise Bclk

- The following command declares that clock domains 0, 3, 4, 5, and 6 are compatible: set dft compatible clock domains -allrise
- The following command declares that clock domains 1 and 2 are compatible: set\_dft\_compatible\_clock\_domains -allfall
- The following command creates two groups of compatible clock domains: (0, 3, 4, 5, 6) and (1,2):

set\_dft\_compatible\_clock\_domains -sameedge

#### **Related Information**

do xform connect scan

remove\_dft\_assertions -compatible\_clock\_domains

report dft assertions

reset dft compatible clock domains

set\_dft\_internal\_clock\_domain

# set\_dft\_compatible\_chains

```
set_dft_compatible_chains [-partition name]
        {-all | chain_name1 chain_name2...}
```

Designates a set of scan chains in the scanDEF file as compatible swap candidates in placement-based reordering. When chains within a group are reordered or repartitioned, FLOATING and ORDERED segments can be swapped between them, but the original maximum sequential length of the chains in the group is retained.

**Note:** The number of chain elements may exceed the sequential length for any given chain because not all elements are required to be sequential.

Each use of this command defines a group of chains whose elements are swappable, allowing multiple groups of two or more chains to be defined. Chains may only be members of a single group, so references to chains previously-defined in other groups are ignored.

Chain groups defined with this command as swappable remain that way until removing them with remove\_dft\_assertions -compatible\_chains or until the DEF scan data itself is removed using do\_remove\_scan\_order\_data.

**Note:** You must have a Cadence PKS license to use this functionality.

# **Options and Arguments**

| -all                   | Specifies that all chains comprise a single group.                                                                                                                                   |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| chain_name1 chain_     | name2<br>Specifies the names of the chains—as defined in the scanDEF<br>file—that you want to designate as compatible swap candidates.<br>You must specify at least two chain names. |
| -partition <i>name</i> | Names the specific chain group. If you do not specify this option, a group name is given by default, such as group_n.                                                                |

# Examples

■ The following commands designate scan chains CLK\_FB\_F1, CLK\_FB\_F2, and CLK\_FB\_F3 (defined in the scan.def file) as compatible swap candidates, then assign the chains to group group\_1:

```
read_def -scan_only scan.def
set_dft_compatible_chains CLK_FB_F1 CLK_FB_F2 CLK_FB_F3
```

■ The following commands designate scan chains CLK\_FB\_F1, CLK\_FB\_F2, and CLK\_FB\_F3 (defined in the scan.def file) as compatible swap candidates, then assign the chains to group foo2:

```
read_def -scan_only scan.def
set_dft_compatible_chains -partition foo2 CLK_FB_F1 CLK_FB_F2 CLK_FB_F3
```

## **Related Information**

do remove scan order data

<u>do xform connect scan</u>

read def -scan\_only

remove dft assertions

# set\_dft\_fix\_violations

```
set_dft_fix_violations
   [-async_set] [-async_reset] [-async_set_reset]
   -test_mode signal [-control signal]
   { -all | -instance instance_list}
   [{-clock|-observe_scan} -test_clock clock [-rise|-fall]]
```

Specifies which DFT rule violations must be fixed and how to fix them. DFT rule violations are detected by the check\_dft\_rules command. You must run the <u>do\_xform\_fix\_dft\_violations</u> command to actually fix the violations.

**Note:** Currently only DFT violations related to asynchronous set and reset can be fixed. Clock violations cannot be fixed yet.

To fix asynchronous set or reset violations, you need to specify a test-mode or scan-mode signal. Using a scan-mode signal makes it only controllable during the scan-shift operation. These signals can be either a previously specified test-mode or scan-mode signal or any existing port or hierarchical pin. If you use a hierarchical pin, a user-defined instance pin or flip-flop pin is preferred, because some design optimizations can change combinational logic.

Warning messages are issued whenever a strange assignment occurs. For example, when specifying instance names that do not have the particular violation to be fixed.

# **Options and Arguments**

| -all             | Applies the assertion to all flip-flops that have the type of violation specified.                                                  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| -async_reset     | Fixes the asynchronous reset violations on either all instances, or just the instances specified with the -instance option.         |
| -async_set       | Fixes the asynchronous set violations on either all instances, or just the instances specified with the -instance option.           |
| -async_set_reset | Fixes the asynchronous set and reset violations on either all instances, or just the instances specified with the -instance option. |

| -clock                   | Fixes the clock violations on either all instances, or just the instances specified with the -instance option.                                                                                                                                       |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | <b>Note</b> : This option requires you to specify the -test_clock option and cannot be used together with the -observe_scan option.                                                                                                                  |
| -control <i>signal</i>   | Specifies to fix violations by inserting control-variable test points rather than control-0 or control-1 test points. You must specify the <i>signal</i> value to be used during test mode using the set_test_mode_setup command.                    |
| -instance instance_      | <ul><li>list</li><li>Specifies the instances to which you want to apply the assertion.</li><li>You can identify the instances using either their hierarchical instance names or their object identifiers (IDs).</li></ul>                            |
| -observe_scan            | Inserts a scan flip-flop to observe the specified location. The scan flip-flop is connected to a scan chain later on.                                                                                                                                |
|                          | <b>Note</b> : This option requires you to specify the -test_clock option and cannot be used together with the -clock option.                                                                                                                         |
| -rise   -fall            | Specifies the edge of the -test_clock that is active during test mode operation. These options are only valid in conjunction with -test_clock.<br>Default: -rise                                                                                     |
| -test_clock <i>clock</i> | Specifies the test-mode clock signal used for fixing clock rule violations and also the signal that drives the clock pin of the inserted scan flip-flops during test mode operation. A warning is issued if the clock signal is not a primary input. |
| -test_mode <i>signal</i> | Specifies the particular signal to fix the violation. Specify either a previously declared test-mode or scan-mode signal, a top-level port, or a hierarchical pin. If you do not specify a <i>signal</i> , a warning message is issued.              |

#### Examples

The following commands fix all asynchronous set and reset violations by using test mode signal TM active high:

```
set_test_mode_setup TM 1
set_dft_fix_violation -async_set -async_reset -test_mode TM -all
```

■ The following commands fix the clock rule violation caused by the gating of the clock pin of flip-flop B (see in Figure 6-5 on page 751 (a)).

```
set_test_mode_setup TM 1
set_dft_fix_violations -instance B -clock -test_mode TM -test_clock CLK
do_xform_fix_violations
```

The result is shown in Figure 6-5 on page 751 (b).

## Figure 6-5 Fixing a Clock Violation



#### **Related Information**

do xform fix dft violations

reset dft fix violations

<u>Avoiding DFT Rule Violations</u> in the Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS manual.

Tasks for Automatic Fixing of the Design Rule Violations in the Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS manual.

# set\_dft\_internal\_clock\_domain

```
set_dft_internal_clock_domain
    { hier_pin_id | hier_pin_name }
```

Allows you to treat all the flip-flops driven by the specified pin as a separate domain for scan insertion purposes if there are different internal clock domains logically connected to the same clock input port in test mode.

This means that such flip-flops will be kept together on the same scan chain(s), and will be separated if necessary from other compatible domains on the same chain by lockup latches (see the -sameroot option for set dft compatible clock domains on page 743).

Such flip-flops must pass all DFT rules, including clock rules such that those flip-flops' clock ports can be driven by a primary input under test mode conditions.

# Important

This command must be specified prior to issuing the check\_dft\_rules command.

Clocks are specified cumulatively by the set\_dft\_internal\_clock\_domain command. To remove any of the previous settings, use the reset\_dft\_internal\_clock\_domain command. This data applies to the current module.

# **Options and Arguments**

| hier_pin_id   | Specifies an existing instance output pin identifier (ID).   |
|---------------|--------------------------------------------------------------|
| hier_pin_name | Specifies an existing hierarchical instance output pin name. |

# Example

The following commands add a new clock domain for the internal clock nodes U1/OUT and U2/OUT. Consider the schematic shown in Figure 6-6 on page 753.

```
set_dft_internal_clock_domain U1/OUT
set_dft_internal_clock_domain U2/OUT
check_dft_rules
Info: Partitioning registers for scan based on clock domain. <DFT-325>
    Clock Domain 0 from pin 'clock' (Pos Edge)<Internal Pin: 'U1/OUT'> has 2 f/f
    Clock Domain 1 from pin 'clock' (Pos Edge)<Internal Pin: 'U2/OUT'> has 2 f/f
```



# Figure 6-6 Schematic for set\_dft\_internal\_clock\_domain Example

# **Related Information**

#### <u>check\_dft\_rules</u>

remove dft\_assertions -internal\_clock\_domains

report dft assertions

<u>reset\_dft\_internal\_clock\_domain</u>

set dft compatible clock domains

# set\_dft\_lockup\_element

set\_dft\_lockup\_element instance

Identifies the specified instance as a lockup-element in an existing chain. This is required for lockup flip-flop elements, and is not necessary for lockup latches.

Currently, if you read in a design that has lockup flip-flops in the chain that were inserted by a third-party tool or even by PKS but in a different terminal session, DFT cannot recognize the element automatically, because it looks no different from a non-scan flip-flop feeding the scan-in pin of a scan flip-flop. Therefore, you must identify the lockup flip-flop so it can be correctly traced.

DFT can recognize lockup latches in chains, whether inserted by PKS or a third-party tool. DFT can also recognize lockup flip-flops if they are inserted by PKS and you stay in the same BG shell.

# **Options and Arguments**

instance

Specifies an instance as a lockup-element in an existing chain.

# Example

The following command identifies instance i\_57 as a lockup flip-flop:

set\_dft\_lockup\_element top/u2/i\_57

# **Related Information**

remove dft assertions -lockup\_element

# set\_dft\_transparent

```
set_dft_transparent
```

```
-module {module_id | module_name}
[-instance {instance_id | instance_name}]
-from {input_port_id | input_port_name} [-invert]
{output_port_id | output_port_name}
```

Specifies the logical connectivity within a black box module, from an input port to an output port. Otherwise, when your design has black box modules, the check\_dft\_rules command cannot detect whether a direct path exists from a primary input to the flip-flop's clock pin, set pins, or reset pins of the module, and it reports a DFT violation.



This command should be used only for black box modules, or cellrefs for which a function definition has not been defined in the technology library. This command should not be used to propagate scan chain analysis data.

# **Options and Arguments**

| -from {input_port_i        | d   input_port_name }<br>Specifies an input port that is on a direct path through the module<br>or instance. Specify the input port using its name or identifier<br>(ID).                                         |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance {instance        | <pre>_id   instance_name } Specifies the black box instance for which you want to specify the connectivity.</pre>                                                                                                 |
| -invert                    | Specifies that the path is inverted.<br><i>Default</i> : The set_dft_transparent command assumes that<br>the path represents a direct connection.                                                                 |
| -module { <i>module_id</i> | <pre>module_name } Specifies the black box module for the instance that you want to set, when you specify an instance name. You do not need to specify a module for an instance ID. Default: Current module</pre> |
| {output_port_id   o        | output_port_name } Specifies an output port that is on a direct path through the                                                                                                                                  |

module or instance. Specify the output port using its name or identifier (ID).

# Example

The following commands specify the functional connectivity between input port In and output port Out of black box instance pll\_ins, then propagate the changes:

set\_dft\_transparent -instance [find -hier -instance pll\_ins] -from In Out check\_dft\_rules



Black color (black box) indicates a set\_dft\_transparent assertion has been specified across the I/O pins of the pll\_ins instance. The black box module has no function.

# **Related Information**

<u>check\_dft\_rules</u>

remove dft assertions -dft\_transparent

report dft assertions

<u>reset\_dft\_transparent</u>

# set\_dont\_scan

```
set_dont_scan [-module {module_id | module_name}]
    [[-instance] {list_of_inst_id | list_of_inst_name}]
```

Excludes from the scan chain all of the registers in the specified module or instance hierarchy. Use this command before or after uniquification of your design.

*Default*: The test synthesis tool tries to include all registers that pass DFT rule checking in the scan chain.

This command determines whether a register is included in the scan chain, so it affects the wiring of the scan chain. This command can affect the area of the design because any registers excluded from the scan chain could be mapped to smaller, non-scannable cells.

Run  $check\_dft\_rules$  before you connect the scan chain in order to propagate the changes through the circuit.

#### **Options and Arguments**

-instance {list\_of\_inst\_id | list\_of\_inst\_names}
Excludes all registers in the specified instance hierarchy from the
scan chain.
-module {module\_id | module\_name}
Excludes all registers in the specified module hierarchy from the
scan chain.

#### Example

The following commands exclude registers 75939, 75027, and 77859 from the scan chain, then propagate the changes through the circuit:

```
set_dont_scan 75939 75027 77859
check_dft_rules
```

#### **Related Information**

<u>check\_dft\_rules</u>

<u>reset dont scan</u>

remove\_dft\_assertions -dont\_scan

report dft assertions

# set\_dont\_touch\_scan

set\_dont\_touch\_scan [module\_id | module\_name]

Prevents modification or reconfiguring of existing scan chains inside the specified module (a scan-specific equivalent to set\_dont\_modify on the module). All existing scan chains in the indicated module are analyzed for suitability and compatibility with scan chains being constructed from the top level and are connected accordingly. Any existing module chain containing a flip-flop that violates DFT rules will be excluded from connection to outer (top level) chains.

This command must be specified prior to running the scan connection engine.

#### **Options and Arguments**

| module_id   | Specifies the ID of the module that you want to leave unchanged.   |
|-------------|--------------------------------------------------------------------|
| module_name | Specifies the name of the module that you want to leave unchanged. |

#### Example

The following commands prevent modification of the scan chains in module submod1:

set\_dont\_touch\_scan submod1
Info: Module 'submod1' set to DONT\_TOUCH\_SCAN mode.
do\_xform\_connect\_scan

#### **Related Information**

do xform connect scan

remove dft assertions -dont touch scan

report dft assertions

reset dont touch scan

# set\_lssd\_aux\_clock

set\_lssd\_aux\_clock { clk\_pin\_name | clk\_pin\_id }

Sets the auxiliary clock pin for aux\_clocked\_lssd scan style. In the aux\_clocked\_lssd scan style, a regular edge-triggered D flip-flop is replaced by an aux\_clocked\_lssd scan cell that has one edge triggered System Clock input and level-sensitive scan clocks, scan\_clock\_a, scan\_clock\_b and aux\_clock.

The clock active edge is assumed to be rising-edge, where applicable. This command overrides any previous command setting specified, and applies to the current module.

**Note:** You must specify this command along with aux\_clock\_lssd in the <u>set scan style</u> command before running check\_dft\_rules.

#### **Options and Arguments**

| clk_pin_id   | Specifies the identifier (ID) of a top-level input port or of an output pin on an instance.                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk_pin_name | Specifies the name of a top-level input port or the hierarchical name of an output pin on an instance. If the specified top-level pin does not exist, an input pin with that name is created. |

#### Example

The following command specifies <code>aux\_test\_clock</code> as the auxiliary clock pin for <code>aux\_clocked\_lssd</code> scan style:

set\_lssd\_aux\_clock aux\_test\_clock

#### **Related Information**

<u>check dft rules</u>

report\_dft\_assertions

<u>set lssd scan clock a</u>

set lssd scan clock b

<u>set\_scan\_style</u> aux\_clock\_lssd

# set\_lssd\_scan\_clock\_a

```
set_lssd_scan_clock_a
    { clk_pin_name | clk_pin_id }
```

Sets the LSSD scan\_clock\_a pin for clocked\_lssd or aux\_clocked\_lssd scan style. In the clocked LSSD scan style, a regular edge-triggered D flip-flop is replaced by a clocked\_lssd scan cell that has one edge triggered System Clock input and level-sensitive scan clocks, scan\_clock\_a and scan\_clock\_b.

The *clock* active edge is assumed to be rising-edge, where applicable. This command overrides any previous command setting specified, and applies to the current module.

**Note:** You must specify this command along with the appropriate scan style using the <u>set scan style</u> command before running check\_dft\_rules.

#### **Options and Arguments**

| clk_pin_id   | Specifies the identifier (ID) of a top-level input port or of an output pin on an instance.                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk_pin_name | Specifies the name of a top-level input port or the hierarchical name of an output pin on an instance. If the specified top-level pin does not exist, an input pin with that name is created. |

#### Example

The following command specifies clockA as the LSSD scan\_clock\_a pin for clocked\_lssd or aux\_clocked\_lssd scan style:

set\_lssd\_scan\_clock\_a clockA

#### **Related Information**

```
<u>check_dft_rules</u>
```

report dft assertions

```
<u>set lssd scan clock b</u>
```

```
set scan style {clocked_lssd | aux_clock_lssd}
```

# set\_lssd\_scan\_clock\_b

```
set_lssd_scan_clock_b
{ clk_pin_name | clk_pin_id }
```

Sets the LSSD scan\_clock\_b pin for clocked\_lssd or aux\_clocked\_lssd scan style. In the clocked\_lssd scan style, a regular edge-triggered D flip-flop is replaced by a clocked LSSD scan cell that has one edge triggered System Clock input and level-sensitive scan clocks, scan\_clock\_a and scan\_clock\_b.

The *clock* active edge is assumed to be rising-edge, where applicable. This command overrides any previous command setting specified, and applies to the current module.

**Note:** You must specify this command along with the appropriate scan style using the <u>set scan style</u> command before running check\_dft\_rules.

#### **Options and Arguments**

| clk_pin_id   | Specifies the identifier (ID) of a top-level input port or of an output pin on an instance.                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk_pin_name | Specifies the name of a top-level input port or the hierarchical name of an output pin on an instance. If the specified top-level pin does not exist, an input pin with that name is created. |

#### Example

The following command specifies clockB as the LSSD scan\_clock\_b pin for clocked\_lssd or aux\_clocked\_lssd scan style:

set\_lssd\_scan\_clock\_b clockB

#### **Related Information**

```
<u>check_dft_rules</u>
```

report dft assertions

```
<u>set lssd scan clock a</u>
```

```
set scan style {clocked_lssd | aux_clock_lssd}
```

# set\_max\_scan\_chain\_length

```
set_max_scan_chain_length
    [-clock clock_name [-rise | -fall]]
    max_chain_length [-priority]
```

Specifies the maximum length of any scan chain in the current module. If necessary, the test synthesis tool creates additional scan chains to keep each scan chain at or below the required maximum length.

Default: There is no limit to the maximum length of a scan chain.

The -priority option specifies that this (maximum chain length) constraint takes precedence over set\_number\_of\_scan\_chains constraint when both are specified.

The -clock option allows the maximum chain length constraint to be applied to a specific clock domain or domain group (see the <u>set\_dft\_compatible\_clock\_domains</u> command). Such domain-specific max-length constraints always take precedence over non-specific constraints (either set\_max\_scan\_chain\_length or set\_number\_of\_scan\_chains), and may be combined with them to provide more detailed control over the scan configuration created. Also, the -priority option can be used with domain-specific forms of each command to specify which limit takes precedence. Warnings will be issued when constraint inconsistencies are specified (or inadvertently created).

**Note:** Applying a set\_max\_scan\_chain\_length constraint overrides chain balancing that would occur under a set\_number\_of\_scan\_chains constraint. This means that when a max length limit is applied within each domain group, the chains are packed to capacity, with the last chain created in each group getting the residual amount.

When the maximum length for a scan chain is exceeded by the length of an existing chain inside a set\_dont\_modify or set\_dont\_touch\_scan module, a warning is issued and the dont\_touch chain will be placed in a top level chain by itself.

For the recommended use model for this command, see <u>Test Synthesis for BuildGates</u> <u>Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)</u>.

#### **Options and Arguments**

```
-clock clock_name [-rise | -fall]
```

Specifies a clock domain, or clock domain group for which the maximum length chain constraint applies (only). Specifying any member of a compatible clock domain group constitutes setting the constraint for the entire group. For example, if clocks A, B, and C are specified as compatible, specifying the option -clock A means that the length maximum applies to all chains

|                  | formed with registers in domains A, B, and C. Maximum limits specified with this -clock option take precedence over similar commands with no -clock option.                                                                                                                                                                                                                                   |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| max_chain_length |                                                                                                                                                                                                                                                                                                                                                                                               |
|                  | Specifies the maximum number of registers allowed in a scan chain.                                                                                                                                                                                                                                                                                                                            |
| -priority        | Specifies that the maximum length constraint specified takes<br>precedence over the set_number_of_scan_chains limit<br>when both commands have been specified (including with or<br>without -clock options). A warning is issued whenever the<br>non-priority limit is exceeded in order to enforce the priority limit.<br><i>Default</i> : The set_number_of_scan_chains limit has priority. |

#### Examples

For the following examples, consider a design with 20 registers in clock domain clkA, and 30 registers in clock domain clkB.

The following command limits the maximum chain length to 20. As a result, all registers in domain clkA are included in one chain, because it satisfies the limit of 20. Registers in clkB are assigned to two chains, one with length 20 and the other with length10:

set\_max\_scan\_chain\_length 20

The following commands limit the maximum chain length to 20 and the number of chains to 4. Because the number of chains constraint has priority (by default), clock domain clkA gets two chains of 10 registers each, and clock domain clkB gets two chains of 15 each:

```
set_max_scan_chain_length 20
set_number_of_scan_chains 4
```

■ The following commands are similar to those in the previous example (same scan configuration created). However, in this case warnings are issued for clock domain clkB, because its two chains exceed the soft maximum chain limit of 10:

```
set_max_scan_chain_length 10
set_number_of_scan_chains 4
```

The following commands give priority to the maximum length constraint. As a result, clock domain clkA has two chains (10 each), while clock domain clkB has 3 chains. A warning is issued since 5 total chains exceeds the soft number-of-chains limit of 4.

```
set_max_scan_chain_length 10 -priority
set_number_of_scan_chains 4
```

The following command sets the maximum length constraint specifically for clock domain clkA, resulting in two chains of length 7 and one of length 6, respectively. Clock domain clkB gets a single chain of length 30, since no constraint was specified for it.

```
set_max_scan_chain_length -clock clkA 7
```

■ The following commands specify domain-specific constraints for clkA. Because the specific number-of-chains limit for clkA has default priority, two balanced chains of length 10 are created. A warning will be issued because the soft limit of 7 is exceeded.

```
set_max_scan_chain_length -clock clkA 7
set_number_of_scan_chains -clock clkA 2
```

The following commands specify that the maximum chain length for clock domain clkB is 8, while the overall number of scan chains is limited to 6. As a result, four chains of length 8, 8, 8, and 6, respectively are created in clock domain clkB, while clock domain clkB gets the two remaining chains (to satisfy the overall limit of six) of length 10 each:

```
set_max_scan_chain_length -clock clkB 8
set_number_of_scan_chains 6
```

■ The following commands limit the chain length for clock domain clkB to 8, and the chain length for the other domains to 5. As a result, four chains of length 8, 8, 8, and 6, respectively are created in clock domain clkB, while four chains of length 5, are created for clock domain clkA:

```
set_max_scan_chain_length -clock clkB 8
set_max_scan_chain_length 5
```

# **Related Information**

remove dft assertions [-config\_constraints]

```
remove_dft_assertions [-configuration_constraints]
```

```
set dft compatible clock domains
```

```
set number of scan chains
```

# set\_must\_scan

```
set_must_scan
  [-clock {clock_port_id | clock_port_name}]
  [-rise | -fall] {list_of_register_instance_id |
    list_of_register_instance_name}
```

Forces a register to be included in a scan chain, even if the register does not pass all DFT rules. If the register fails the clock controllability rule check, you must also specify the clock domain to which the register belongs.

You must run check\_dft\_rules before you connect the scan chain in order to propagate the effects of this command.



When you use this command, some flip-flops that do not pass DFT rules may get placed in scan chains. As a result, the scan shifting operation may fail in simulation and on the tester. Please use this command rarely, and only when you understand the implications of its use.

# **Options and Arguments**

| -clock { <i>clock_port_</i> | _id   clock_port_name }<br>Specifies the clock domain to which the register belongs. The<br>clock_port_id or clock_port_name must be the top<br>timing module's clock port. You use this option only if the register<br>fails the clock controllability rule. |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| list_of_register_i          | nstance_id<br>Specifies a list of identifiers (IDs) of the register instances that<br>you want to include in the scan chain.                                                                                                                                  |
| list_of_register_i          | nstance_name<br>Specifies the hierarchical names of register instances that you<br>want to include in the scan chain.                                                                                                                                         |
| -rise   -fall               | Specifies the clock edge of the clock domain, when you also specify the -clock option.<br>Default: -rise                                                                                                                                                      |

# Example

The following commands force registers u1, u3, and  $my_submodule/u7$  to be included in a scan chain for the specified clock domain, then propagate the change:

set\_must\_scan -clock ck -rise ul u3 my\_submodule/u7
check\_dft\_rules

#### **Related Information**

<u>check\_dft\_rules</u>

remove\_dft\_assertions -must\_scan

report dft assertions

<u>reset must scan</u>

# set\_number\_of\_scan\_chains

```
set_number_of_scan_chains
    [-clock clock_name [-rise | -fall]]
    chain_count [-priority]
```

Specifies the number of scan chains to be created for the current module.

*Default*: Only one chain is created for each clock domain or compatible domain group (see <u>set\_dft\_compatible\_clock\_domains</u> command).

When this constraint is used to create multiple chains, an attempt is made to distribute registers from each domain or domain-group evenly (balance) across chains within that group, and apportion the number of chains across all applicable groups to meet the constraint in a way that minimizes differences in chain length as much as possible. For example, if a domain clk1 had 30 registers, and clk2 had 40 registers, a number-of-chains limit of 4 would result in clk1 domain getting two chains of length 15, and clk2 domain would have two chains of length 20.

The -clock option allows a number-of-chains constraint to be applied to a specific domain or domain group. This domain-specific form of the command always take precedence over non-specific ones, such that they can be combined to provide more detailed control over the scan configuration. When combined, the tool will attempt to meet the domain-specific constraint first, and then meet the non-specific one (see examples). Appropriate warnings are generated when this is not possible.

The -priority option allows you to specify that the limit being set takes precedence over a currently active max-chain-length constraint (set using set\_max\_scan\_chain\_length command). This is normally not needed unless the prior set\_max\_scan\_chain\_length command had itself used a -priority option, as it is the default for set\_number\_of\_scan\_chains.

For the recommended use model for this command, see <u>Test Synthesis for BuildGates</u> <u>Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)</u>.

#### **Options and Arguments**

| chain_count              | Specifies the number of scan chains desired.<br><i>Default</i> : One scan chain for each clock domain or domain group.                           |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| -clock <i>clock_name</i> | [-rise   -fall]<br>Specifies a clock domain for which the current limit applies<br>(only). If the clock domain named is a member of a compatible |

|           | domain group, the setting is applied to the whole group. For<br>example, if clocks A, B, and C are specified as compatible,<br>specifying the option -clock A means that the number of<br>chains applies to all chains formed with registers in domains A,<br>B, and C. Commands specified with this option take precedence<br>over commands without the option.                                                                                                                      |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -priority | Specifies that the number-of-chains being set takes precedence<br>over any max-chain-length limit currently active. Since this is the<br>default for the set_number_of_scan_chains command, it is<br>not needed unless you need to switch back from a prior<br>set_max_scan_chain_length priority setting. This option<br>can also be used similarly with domain-specific command forms<br>(-clock options) to control the configuration within a specific<br>domain or domain group. |

#### Examples

For the examples below, consider a design with 20 registers in clkA domain, and 30 registers in clkB.

The following command limits the overall number of chains to 4. As a result, the tool creates two chains of length 10 for domain clkA, and two chains of length 15 for domain clkB:

```
set_number_of_scan_chains 4
```

■ The following commands limit the maximum chain length to 20 and the number of chains to 4. Because by default the number of chains constraint has priority, the tool creates two chains of length10 for clock domain clkA, and two chains of length15 for clock domain clkB. So the additional set\_max\_scan\_chain\_length constraint has no effect:

```
set_number_of_scan_chains 4
set_max_scan_chain_length 20
```

■ The following commands are similar to those in the previous example (same scan configuration created). However, in this case tool issues warnings for clock domain clkB, because its two chains exceed the soft maximum chain limit of 10:

```
set_number_of_scan_chains 4
set_max_scan_chain_length 10
```

■ The following command limits the number of chains for clock domain clkB to 3. As a result, one chain of length 30 is created for clock domain clkA (default, since no other length constraint was specified). Clock domain clkB gets three chains of length10 each:

```
set_number_of_scan_chains -clock clkB 3
```

The following commands limit the maximum chain length for clock domain clkB to 7, and the maximum number of scan chains for clock domain clkB to 6. As a result, the tool creates five chains of length 7, 7, 7, 7, and 2, respectively for clock domain clkB. Because the length constraint has priority, a warning is issued, since this exceeds the number-of-chains for this domain. Clock domain clkA is not constrained, and gets one chain of length 20.

```
set_max_scan_chain_length -clock clkB 7 -priority
set_number_of_scan_chains -clock clkB 4
```

■ The following commands limit the maximum chain length for clock domain clkB to 8, and the overall number of scan chains to 6. As a result, the tool creates four chains of length 8, 8, 8, and 6, respectively for clock domain clkB, and two chains of length10 each for clock domain clkA (to satisfy the overall limit of six):

```
set_max_scan_chain_length -clock clkB 8
set_number_of_scan_chains 6
```

The following commands limit the number of chains for clock domain clkB to 4, and the overall number of scan chains to 6. As a result, the tool creates four chains of length 7, 7, 8, and 8, respectively for clock domain clkB, and two chains of length 10 for clock domain clkA to satisfy the overall limit of 6:

```
set_number_of_scan_chains -clock clkB 4
set_number_of_scan_chains 6
```

# **Related Information**

remove dft assertions [-config\_constraints]

remove\_dft\_assertions [-configuration\_constraints]

set dft compatible clock domains

<u>set max scan chain length</u>

# set\_scan\_chain

set\_scan\_chain

{ -head head\_segment\_name | -tail tail\_segment\_name | -head head\_segment\_name -tail tail\_segment\_name }

Constrains segments previously defined with the set\_scan\_chain\_segment command to be configured to specific chain positions.

Specific scan segments can be required to appear at the beginning (first shift-in position or *head*), or end (first shift-out position or *tail*) of a scan-chain. Also, both options can be used in the same command to specify when a head and tail must be placed in the same chain. Head and tail segments will always be inserted in chains with compatible domains (see set\_dft\_compatible\_clock\_domains). Head and tail segments applied to the same chain must themselves have compatible domains also.

#### Notes

- 1. You cannot use this command with the existing Scan Order File (SOF) (read\_scan\_order\_file) or scanDEF file (read\_def -scan\_only or write\_def) modes of configuration.
- 2. PKS scan-chain reordering treats defined segments as freely movable within chains (as a contiguous unit), unless you further constrain them with the set\_scan\_chain command. In this case, PKS ignores them in reordering.

#### **Options and Arguments**

-head head\_segment\_name

Specifies a segment (an ordered set of scan registers) that must be placed at the head of a scan chain. The segment must have been previously defined with set\_scan\_chain\_segment.

-tail tail\_segment\_name

Specifies a segment (an ordered set of scan registers) that must be placed at the tail of a scan chain. The segment must have been previously defined with set\_scan\_chain\_segment.

# Examples

The following commands define a segment S1 guaranteed to be kept at the head of a chain:

```
set_scan_chain_segment -name S1 \
        {C1/R_reg_0 C1/R_reg_1 C2/CC1/R_reg_3 C2/CC1/R_reg_0 C1/R_reg_2}
set_scan_chain -head S1
```

The following commands define a segment S1 guaranteed to be kept at the tail of a chain:

```
set_scan_chain_segment -name S1 \
        {C1/R_reg_0 C1/R_reg_1 C2/CC1/R_reg_3 C2/CC1/R_reg_0 C1/R_reg_2}
set_scan_chain -tail S1
```

■ The following commands define a pair of segments (S1 and S2) guaranteed to be kept at the head and tail of one chain:

#### **Related Information**

remove dft assertions -scan\_chain

report dft assertions

<u>set\_scan\_chain\_segment</u>

<u>Using Head and Tail Chain Constraints during Scan Chain Configuration and Scan Chain</u> <u>Reordering with PKS</u> in the *Test Synthesis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)* manual.

# set\_scan\_chain\_segment

```
set_scan_chain_segment
    {-from hier_pin_name -to hier_pin_name
    | [-name segment] instance_list }
```

This assertion has the following purposes:

■ The -from -to specification identifies lower-level scan chain segments embedded in the hierarchy of the current module. This identification is used to correctly connect the embedded scan chains segments in a block that might have been marked as dont\_modify or dont\_touch\_scan for example in the bottom-up flow.

This identification is essential, if the tool can not distinguish the true scan-out pin of an embedded scan chain segment from a functional connection, or if the chain segment contains a terminal lockup element.

Scan analysis uses this information as a hint to identify and trace the scan chain segments in the embedded module from its sdi to sdo pins, for connection of the segments into the top level chains.

■ The second specification (-name segment instance\_list) defines a collection of scan registers to be treated as a chain segment for scan configuration purposes.

You can define multiple segments using multiple invocations of this command; one segment is defined per command invocation.

You can later reference such segments in a set\_scan\_chain command to further constrain them and place them at the head or tail of a configured chain:

When the scan configuration is created from scratch (no pre-existing chains), DFT places the defined segments in scan-chains with consistent or compatible domains.

When pre-existing chains are present, and the *preserve configuration* mode is used, DFT places the elements of each segment on the chain where the first element appeared originally. For more information, refer to the <u>Running the Scan Connection Engine in</u> <u>preserve config Mode</u> section in the *Test Synthesis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)* manual.

#### Notes:

- □ A scan element cannot be included in more than one segment.
- You cannot use this command with the existing Scan Order File (SOF) or scanDEF file modes of configuration.

PKS scan-chain reordering treats segments defined with this assertion as freely movable within chains (as a contiguous unit), unless you further constrained them with the set\_scan\_chain command. In this case, PKS ignores them in reordering.

#### **Options and Arguments**

| -from <i>hier_pin_name</i> | Specifies the start pin for the scan chain segment. Specify the hierarchical name of the pin.                                                                                                                                                                                                                                        |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| instance_list              | Specifies the instances in the order they should appear in the scan chain (in shift order, that is, left-most corresponds to first bit shifted-in).                                                                                                                                                                                  |
|                            | The instances must be scannable registers and must belong to<br>the same clock domain, otherwise the segment is ignored. Do<br>not specify scan registers that are contained in<br>dont_touch_scan or dont_modify modules or they will be<br>ignored. Specify either the hierarchical instance names or the<br>instance identifiers. |
| -name <i>segment</i>       | Defines a name for the segment that you can use to reference for the set_scan_chain command (head/tail specifications), and related diagnostics.                                                                                                                                                                                     |
| -to hier_pin_name          | Specifies the end pin for the scan chain segment. Specify the hierarchical name of the pin.                                                                                                                                                                                                                                          |

#### Examples

■ The following command identifies a scan chain segment that starts at pin mod1/si and ends at pin mod1/so:

set\_scan\_chain\_segment -from mod1/si -to mod1/so

The following commands define a segment S1 guaranteed to be kept at the head of a chain:

```
set_scan_chain_segment -name S1 \
    {C1/R_reg_0 C1/R_reg_1 C2/CC1/R_reg_3 C2/CC1/R_reg_0 C1/R_reg_2}
set_scan_chain -head S1
```

The following commands define a segment S1 guaranteed to be kept at the tail of a chain:

```
set_scan_chain_segment -name S1 \
        {C1/R_reg_0 C1/R_reg_1 C2/CC1/R_reg_3 C2/CC1/R_reg_0 C1/R_reg_2}
set_scan_chain -tail S1
```

The following commands define a pair of segments (S1 and S2) guaranteed to be kept at the head and tail of one chain:

The following commands define two segments (S1 and S2) to be arbitrarily assigned to chains (instances are fixed relative to each other, but the segments are not required to be at the head or tail of any chain). Segment S3 must however appear at a tail of a chain.

```
set_scan_chain_segment -name S1 \
        {C1/R_reg_0 C1/R_reg_1 C2/CC1/R_reg_3 C2/CC1/R_reg_0 C1/R_reg_2}
set_scan_chain_segment -name S2 \
        {C3/CCC2/CC0/R_reg_0 C3/CCC2/CC0/R_reg_1}
set_scan_chain_segment -name S3 {C3/CCC1/R_reg_0 C3/CCC2/CC1/R_reg_3}
set_scan_chain -tail S3
```

#### **Related Information**

<u>do\_xform\_connect\_scan</u>

remove dft assertions -scan\_chain\_segment

report dft assertions

<u>set\_scan\_chain</u>

set\_global <u>dft insert terminal lockup element</u>

Inserting Terminal Data Lockup Latches at the End of the Scan Chain in Test Synthesis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)

<u>Using Head and Tail Chain Constraints during Scan Chain Configuration and Scan Chain</u> <u>Reordering</u> with PKS in *Test Synthesis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)* 

# set\_scan\_data

```
set_scan_data [-clock [clock [-rise | -fall]]]
    scan_in scan_out [-shared_out]
    [-enable scan_enable]
```

Specifies the names for the input and output scan data ports, as well as the following:

- Name for a port that the test synthesis tool creates
- Clock domain with which you want to associate the specified port names

If you want to use vectored ports for the scan data input and output ports, the scan data input and output ports must have the same bit widths. In this case the set\_scan\_data command is applied to each bit of the vectored ports.

Do not use set\_scan\_data during preliminary synthesis runs (that is, on lower-level modules). Let the test synthesis tool use default names for the scan data ports. In higher-level synthesis runs, the tool discards information that you have set with this command during previous synthesis runs.

Use the set\_scan\_data command during the final synthesis run of the entire design (when the tool connects the scan chains), to specify the desired scan data port names for each clock domain.

If a clock domain has multiple scan chains, you can invoke this command multiple times to give a different name to each scan chain data port. Otherwise, the tool uses the scan data ports specified without the -clock option or create default ports for the extra chains.

If you use the same port names for two different clock domains, the tool uses the port name for the clock domain specified first, and ignores the second invocation. For example:

```
set_scan_data -clock cka -fall sdia sdoa
set_scan_data -clock ckb -rise sdia sdoa *This assertion ignored*
```

If you do not use this command, the scan connection function creates or reuses the default scan port names which are derived from the setting of the dft\_scan\_port\_name\_prefix global. The settings from the set\_scan\_data command are cumulative, and apply to the current module set. To undo these settings, use the remove\_dft\_assertions -scan\_data\_io command.

If you want to create a configuration in a design database, specify the set\_scan\_data command prior to running the connection engine.

If you reorder scan chains in a scan-mapped structural netlist, specify the set\_scan\_data command prior to performing PKS reordering.

For more information on naming conventions see <u>Naming Scan-Data Ports</u> in *Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS*.

# **Options and Arguments**

```
-clock [clock [-rise | -fall]]
                           Specifies the clock domain. For a chain containing flip-flops
                           driven by an internal clock domain, the tool first tries to match a
                           scan_data_port command with the -clock option that
                           matches the internal clock domain pin. If no match is found, then
                           a second match will be made with the root clock pin (top level
                           clock pin driving the internal clock signal).
-enable scan_enable {name | hiername | ID}
                           Designates a chain-specific scan-enable port/pin for the
                           muxscan scan style. If you specify this option, you must use the
                           set scan mode command to specify the active polarity of the
                           scan-enable signal.
                           name must be a top-level port, if it exists. If not, the port will be
                           created.
                           hiername must be an existing instance output pin (can be
                           non-uniquified).
                           ID must be the ID of an existing top level input port, or uniquified
                           instance output pin.
scan_in {name | hiername | ID}
                           Specifies the scan data input.
                           name should be top-level port/pin name, if it exists. If not, the
                           port will be created.
                           hiername must be the name of an existing instance output pin
                           (can be non-uniquified).
                           ID can be the ID of an existing top level input port, or hierarchical
                           instance output pin (must be uniquified).
                           If you want to use a vectored scan data input port, the scan data
                           input port must exist in the netlist and its bit width must
                           correspond to the bit width of the specified scan data output port.
```

|                    | If the vectored port does not exist in the netlist, you can create it using the <u>create port</u> command.                                                                                                                                                                                                    |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| scan_out {name   h | iername   ID}<br>Specifies the scan data output.                                                                                                                                                                                                                                                               |
|                    | name should be top level port/pin name, if it exists. If not, the port will be created.                                                                                                                                                                                                                        |
|                    | hiername must be the name of an existing instance input pin (can be non-uniquified).                                                                                                                                                                                                                           |
|                    | <i>ID</i> can be the ID of an existing top level output port, or hierarchical instance input pin (must be uniquified).                                                                                                                                                                                         |
|                    | If you want to use a vectored scan data output port, the scan data output port must exist in the netlist and its bit width must correspond to the bit width of the specified scan data input port. If the vectored port does not exist in the netlist, you can create it using the <u>create port</u> command. |
| -shared_out        | Specifies that the output port must be shared with a functional port using a mux.                                                                                                                                                                                                                              |

#### Examples

The following command specifies sdia and sdoa as scan data input and output ports for clock domain cka (falling edge):

```
set_scan_data -clock cka -fall sdia sdoa
```

■ The following command specifies sin and sout as scan data input and output ports for all clock domains. If sin and sout are existing vectored ports with bit width 4, DFT associates sin[1] with sout[1], sin[2] with sout[2], sin[3] with sout[3], and sin[4] with sout[4].

set\_scan\_data sin sout

# **Related Information**

#### <u>check\_dft\_rules</u>

<u>dft scan port name prefix</u>global

report dft assertions

<u>remove dft\_assertions</u> -scan\_data\_io

set number of scan chains

set\_scan\_mode

<u>write scan order file</u>

<u>Naming Scan-Data Ports</u> in the *Design for Test (DFT) Using BuildGates Synthesis and Cadence PKS* manual.

# set\_scan\_equivalent

set\_scan\_equivalent non\_scan\_cell scan\_cell

Controls the scan-equivalent cell type that is used during the initial conversion of a non-scan flip-flop to a scan flop.

Initially, the specified scan-equivalent cell should match in functionality with the non-scan cell for the system mode operation. For example clock, set/reset, enable, data and so on. Later during optimization, the cell type can be replaced with a different scan instance to better meet timing and area constraints.

You can change the order of the arguments, because the tool automatically figures out which of the two cells is the scan cell and which one is the non-scan cell.

**Note:** You can also specify this information using the scan\_equivalent construct for the non-scan cell in the TLF library.

#### **Options and Arguments**

| non_scan_cell | Specifies the name of a non-scan cell. |
|---------------|----------------------------------------|
| scan_cell     | Specifies the name of a scan cell.     |

#### Example

The following command specifies that cell SCANREGD can be used in the conversion of cell REGD. The tool figures out that REGD is the non-scan cell and that SCANREGD is the scan cell.

set\_scan\_equivalent REGD SCANREGD

# set\_scan\_mode

set\_scan\_mode [-default] scan\_enable {0 | 1}

Specifies the name of the input port that activates scan mode (scan shifting), and whether it is active-high (1) or active-low (0). A separate input port to activate scan mode is required by the muxed (muxscan) scan style. If you do not call this command, the tool creates a default port name using set\_global dft\_scan\_port\_name\_prefix, which defaults to BG\_scan\_enable.

If the port already exists, you must ensure that any logic connected to the port is not needed in system mode. If the named port does not already exist, the test synthesis tool adds the scan mode port to the netlist when you call do\_xform\_connect\_scan

This assertion is propagated to all (lower-level) child modules.

#### **Options and Arguments**

| {0   1}     | Sets the active polarity desired for the scan enable signal.                                                                                                                                           |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -default    | Indicates that the <i>scan_enable</i> specified is the default shift control for all scan chains. To specify chain-specific shift control pins, use -enable option in set_scan_data command. Optional. |
| scan_enable | Designates the port/pin used to control scan-shifting for the muxscan scan style. Follow the form:                                                                                                     |
|             | {name   hiername   ID}.                                                                                                                                                                                |
|             | name should be a top level input port, if it exists. If not, it will be created.                                                                                                                       |
|             | <i>hiername</i> must be an existing instance output pin name (can be non-uniquified).                                                                                                                  |
|             | <i>ID</i> must be the ID of an existing top level input port or internal instance output pin (but must be uniquified).                                                                                 |

# Examples

■ The following command specifies that input port scan\_enable activates scan mode when the applied scan enable signal is active high:

set\_scan\_mode scan\_enable 1

■ The following command specifies that pin jtag\_instance/SE activates scan mode when the signal is active high:

set\_scan\_mode jtag\_instance/SE 1

#### **Related Information**

<u>check dft rules</u>

<u>report\_dft\_assertions</u>

remove dft assertions -scan\_mode

<u>set scan data</u>

<u>set\_scan\_style</u>

# set\_scan\_style

set\_scan\_style [mux\_scan | clocked\_scan | clocked\_lssd | aux\_clocked\_lssd]

Selects a scan style for the current module and all child modules. Currently, the test synthesis tool supports the muxed scan style, muxscan, clocked\_scan, clocked\_lssd, and aux\_clocked\_lssd.

You must set the appropriate scan style before running check\_dft\_rules since the DFT rules varies with different scan styles. If no scan style is set, the tool assumes muxscan style by default.

#### **Options and Arguments**

| aux_clocked_lssd | Specifies the auxiliary scan style, using these commands:                 |
|------------------|---------------------------------------------------------------------------|
|                  | <pre>set_lssd_aux_clock set_lssd_scan_clock_a set_lssd_scan_clock_b</pre> |
| clocked_lssd     | Specifies the clocked lssd scan style, using these commands:              |
|                  | set_lssd_scan_clock_a<br>set_lssd_scan_clock_b                            |
| clocked_scan     | Specifies clocked scan style, using this command:                         |
|                  | set_test_scan_clock                                                       |
| muxscan          | Specifies the muxed scan style.                                           |

#### **Related Information**

<u>check\_dft\_rules</u>

report dft assertions

<u>Muxed Scan Style</u> in the Test Synthesis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS) manual.

# set\_test\_mode\_setup

```
set_test_mode_setup { input_port_id | input_port_name }
    { 0 | 1 } -scan_shift
    [-clock { clock_pin_name | clock_pin_id }]
```

Specifies the input port and constant value that is assigned during a test session. The test signal is asserted for the entire test session, unless you specify <code>-scan\_shift</code> in which case it is assumed to be asserted only during the <code>scan\_shift</code> cycle of test mode.

The  $check\_dft\_rules$  command ensures that this signal exists when checking for DFT rule violations.

#### **Options and Arguments**

| 0   1                       | Specifies the value for the test mode signal.                                                                                                                                                                                |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |                                                                                                                                                                                                                              |
| -clock { <i>clock_pin_n</i> | ame   clock_pin_id}<br>Specifies that during low-power synthesis this test mode be used<br>to bypass low-power clock gating logic for flip-flops clocked by<br>the identified clock pin.                                     |
| input_port_id               | Specifies the input port identifier (ID) for the test mode signal.                                                                                                                                                           |
| input_port_name             | Specifies the input port name for the test mode signal.                                                                                                                                                                      |
| -scan_shift                 | Specifies that you want to assert the test signal only during the scan shift cycle of test mode. If you do not specify this option, the test signal is asserted for the entire test session, including the scan shift cycle. |
|                             | Use this option for the test-mode setup of asynchronous signals, to keep them constant only during shifting of scan chains, and not during the capture stage of test application.                                            |

#### Examples

The following commands specify that the active high value of test signal u\_jtag/test\_mode is asserted for the entire session, while the active high value of test signal reset\_L is asserted during the scan shift cycle only:

```
set_test_mode_setup u_jtag/test_mode 1
set_test_mode -scan_shift reset_L 1
check_dft_rules
```

■ The following commands specify that the active high value of test signal scan\_en is asserted during the scan shift cycle, then propagates the change:

```
set_test_mode_setup scan_en -scan_shift 1
check_dft_rules
```

#### **Related Information**

check\_dft\_rules

remove dft assertions -test\_mode\_setup

<u>report dft assertions</u>

reset\_test\_mode\_setup

# set\_test\_scan\_clock

set\_test\_scan\_clock { clk\_pin\_name | clk\_pin\_id }

Sets the scan\_clock pin for clocked\_scan style.

You must specify this command along with the clocked\_scan style (using the <u>set\_scan\_style</u> command) before running check\_dft\_rules.

#### **Options and Arguments**

| clk_pin_id   | Specifies the identifier (ID) of a top-level input port or of an output pin on an instance.                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk_pin_name | Specifies the name of a top-level input port or the hierarchical name of an output pin on an instance. If the specified top-level pin does not exist, an input pin with that name is created. |

#### Example

The following commands specify clockA as the scan\_clock pin for the clocked\_scan scan style.

set\_scan\_style clocked\_scan
set\_test\_scan\_clock clockA

#### **Related Information**

<u>check\_dft\_rules</u>

report dft assertions

<u>set\_scan\_style</u> clocked\_scan

# write\_atpg\_info

write\_atpg\_info [-mentor | -syntest | -logicvision | -stil]

Creates an interface file containing the scan chain information in a format readable by the designated third-party ATPG tool. The third-party ATPG tool uses this interface file to generate appropriate test patterns. The file extension given to this interface file is determined by the selected third-party tool.

The interface file is useful only to the third-party tool if the test synthesis tool has connected the scan chain. Therefore, you should use this command only if the test synthesis tool connects the scan chains; that is, if you have set the dft\_scan\_path\_connect global variable to chain.

The test synthesis tool does not currently add information about asynchronous controls or test mode ports to the interface file. If needed, you must add this information manually.

**Note:** You can also use the get\_scan\_chain\_info command to get all necessary information about scan chains and generate necessary data for any ATPG tool.

#### **Options and Arguments**

| -logicvision | Creates an interface file in the format used by the Logic Vision ATPG tool. File generated: top_module.LV                                  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| -mentor      | Creates an interface file in the format used by Mentor Graphics<br>ATPG tool. Files generated:<br>top_module.testproc<br>top_module.dofile |
| -stil        | Creates an interface file in the IEEE Standard Test Interface Language (STIL) format (IEEE format 1450). File generated: top_module.stil   |
| -syntest     | Creates an interface file in the format used by Syntest<br>Technologies ATPG tool. File generated:<br>top_module.dft                       |

# write\_scan\_order\_file

```
write_scan_order_file [-hier | -flat]
    [-verbosity {1 | 2 | 3}] filename
```

Generates a scan order file containing the scan chain information in the format specified. *Default*: A flat order file is created using the default file name: set\_current\_module\_name.scan.flat.

#### **Options and Arguments**

| -hier <i>filename</i> | Creates a hierarchical scan order file, organized by the modules with the design hierarchy.                                                                             |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -flat <i>filename</i> |                                                                                                                                                                         |
|                       | Creates a flat scan order file, which contains a list of the complete scan chain in the top level module that uses full hierarchical path names, down to each register. |
| -verbosity            |                                                                                                                                                                         |
|                       | Sets the verbosity level where 1 = least verbose and 3 = most verbose.<br>Default: Off (0)                                                                              |

#### Examples

- The following command writes a hierarchical scan order file named init.scan\_order: write\_scan\_order\_file -hier init.scan\_order
- The following command writes a flat scan order file named ./SO1. By setting the verbosity level to 1, the number of messages generated is reduced to the minimum.

```
write_scan_order_file -flat -verbosity 1 ./S01
```

#### **Related Information**

<u>read\_scan\_order\_file</u>

# 7

# Common Timing Engine (CTE) Commands

This chapter contains information about the Common Timing Engine (CTE) commands used in timing analysis, as well as general information that applies to various commands:

- <u>Path Exception Priorities</u> on page 797
- <u>Bidirectional Pin Defaults</u> on page 799
- <u>Command Descriptions</u> on page 802
  - □ <u>check\_timing</u> on page 803
  - <u>create mp constraint arc</u> on page 810
  - □ <u>create mp delay arc</u> on page 813
  - □ <u>create mp\_drive\_type</u> on page 816
  - □ <u>create mp load type</u> on page 818
  - □ <u>create mp model</u> on page 819
  - □ <u>create mp\_path\_type</u> on page 820
  - □ <u>create mp port</u> on page 822
  - □ <u>do analyze crosstalk</u> on page 824
  - □ <u>do\_cppr\_analysis</u> on page 830
  - □ <u>do derive context</u> on page 832
  - □ <u>do extract model</u> on page 834
  - □ <u>do\_signalstorm</u> on page 841
  - □ <u>do time budget</u> on page 845
  - □ <u>do xform timing correction</u> on page 849

- □ <u>get capacitance unit</u> on page 850
- □ <u>get cell drive</u> on page 851
- □ <u>get cell pin load</u> on page 853
- □ <u>get\_clock</u> on page 855
- □ <u>get clock propagation</u> on page 857
- □ <u>get clock source</u> on page 858
- □ <u>get\_constant\_for\_timing</u> on page 859
- □ <u>get dcl calculation mode</u> on page 861
- □ <u>get dcl functional mode</u> on page 862
- □ <u>get\_dcl\_functional\_mode\_array</u> on page 863
- □ <u>get dcl level</u> on page 864
- □ <u>get derived clock</u> on page 865
- □ <u>get\_drive\_pin</u> on page 866
- □ <u>get fanin</u> on page 868
- □ <u>get fanout</u> on page 870
- □ <u>get\_flow\_compatible\_mode</u> on page 872
- □ <u>get load pin</u> on page 873
- □ <u>get module worst slack</u> on page 876
- □ <u>get operating conditions</u> on page 877
- **get operating parameter** on page 878
- □ <u>get operating voltage</u> on page 880
- □ <u>get propagated clock</u> on page 881
- □ <u>get scale delays</u> on page 883
- □ <u>get slack</u> on page 885
- □ get slew thresholds on page 887
- □ <u>get tech info</u> on page 888
- □ <u>get time borrow limit</u> on page 895

- □ <u>get\_time\_unit</u> on page 896
- □ get timing on page 897
- □ get top timing module on page 901
- □ <u>libcompile</u> on page 902
- □ <u>load dcl rule</u> on page 903
- □ <u>read alf</u> on page 904
- □ <u>read\_ctlf</u> on page 907
- □ <u>read\_dc\_script</u> on page 908
- □ <u>read\_dotlib</u> on page 911
- □ <u>read\_irdrop</u> on page 914
- □ <u>read library update</u> on page 915
- □ <u>read\_ola</u> on page 918
- □ <u>read\_rrf</u> on page 920
- □ <u>read sdf</u> on page 922
- □ <u>read spef</u> on page 929
- □ <u>read spf</u> on page 931
- □ <u>read\_stamp</u> on page 933
- □ <u>read\_tlf</u> on page 935
- □ <u>remove\_assertions</u> on page 938
- □ <u>report analysis coverage</u> on page 944
- □ <u>report annotated check</u> on page 948
- □ <u>report\_annotations</u> on page 950
- □ <u>report cell instance</u> on page 953
- report cell instance timing on page 958
- □ report clocks on page 959
- □ report fanin on page 964
- □ <u>report\_fanout</u> on page 966

- □ <u>report\_functional\_mode</u> on page 968
- □ <u>report inactive arcs</u> on page 969
- □ <u>report library</u> on page 972
- □ <u>report net</u> on page 975
- □ <u>report path exceptions</u> on page 978
- □ report path groups on page 981
- □ <u>report path\_group\_timing</u> on page 982
- □ <u>report poles residues</u> on page 983
- □ <u>report ports</u> on page 985
- □ <u>report\_timing</u> on page 990
- □ <u>reset capacitance limit</u> on page 1013
- □ reset capacitance unit on page 1015
- □ <u>reset\_clock\_gating\_check</u> on page 1016
- □ reset clock info change on page 1018
- <u>reset clock insertion delay</u> on page 1020
- □ <u>reset\_clock\_root</u> on page 1022
- □ reset clock uncertainty on page 1024
- □ reset constant for timing on page 1027
- □ <u>reset\_dcl\_calculation\_mode</u> on page 1028
- □ <u>reset dcl functional mode</u> on page 1029
- □ <u>reset dcl level</u> on page 1030
- □ <u>reset\_default\_slew\_time</u> on page 1031
- □ <u>reset disable cell timing</u> on page 1032
- □ <u>reset disable clock gating check</u> on page 1034
- □ <u>reset\_disable\_timing</u> on page 1035
- □ <u>reset drive cell</u> on page 1037
- □ <u>reset drive resistance</u> on page 1039

- □ <u>reset external delay</u> on page 1041
- □ <u>reset fanout load</u> on page 1043
- □ reset fanout load limit on page 1044
- □ <u>reset\_feedback\_loop\_snipped\_arcs</u> on page 1045
- □ <u>reset functional mode</u> on page 1046
- □ <u>reset generated clock</u> on page 1047
- □ <u>reset\_ideal\_net</u> on page 1048
- □ <u>reset input delay</u> on page 1049
- □ reset num external sinks on page 1051
- <u>reset\_num\_external\_sources</u> on page 1052
- reset operating condition on page 1053
- reset operating parameter on page 1055
- □ <u>reset\_operating\_voltage</u> on page 1056
- □ reset path exception on page 1057
- □ <u>reset path group</u> on page 1063
- □ <u>reset\_port\_capacitance</u> on page 1066
- □ <u>reset port capacitance limit</u> on page 1067
- □ reset port wire load on page 1068
- □ <u>reset\_propagated\_clock</u> on page 1069
- □ reset scale delays on page 1071
- □ <u>reset slew limit</u> on page 1073
- □ <u>reset\_slew\_thresholds</u> on page 1074
- □ <u>reset slew time</u> on page 1075
- □ <u>reset slew time limit</u> on page 1077
- □ <u>reset\_tech\_info</u> on page 1078
- <u>reset time borrow limit</u> on page 1085
- □ <u>reset time unit</u> on page 1086

- □ <u>reset\_wire\_capacitance</u> on page 1087
- □ <u>reset wire load</u> on page 1088
- □ <u>reset wire load mode</u> on page 1089
- □ <u>reset\_wire\_load\_selection\_table</u> on page 1090
- reset wire resistance on page 1091
- □ <u>save mp model</u> on page 1092
- □ <u>set\_annotated\_check</u> on page 1094
- □ <u>set annotated delay</u> on page 1096
- □ <u>set capacitance limit</u> on page 1100
- □ <u>set\_capacitance\_unit</u> on page 1103
- □ set case analysis on page 1104
- □ <u>set cell pin load</u> on page 1106
- □ <u>set\_clock</u> on page 1108
- □ <u>set clock arrival time</u> on page 1111
- □ <u>set clock gating check</u> on page 1112
- □ <u>set\_clock\_info\_change</u> on page 1116
- □ <u>set clock insertion\_delay</u> on page 1120
- □ <u>set clock propagation</u> on page 1124
- □ <u>set clock required time</u> on page 1126
- □ <u>set clock root</u> on page 1127
- □ <u>set clock transition</u> on page 1129
- □ <u>set\_clock\_uncertainty</u> on page 1130
- □ <u>set constant for timing</u> on page 1134
- □ <u>set cycle addition</u> on page 1136
- □ <u>set\_data\_arrival\_time</u> on page 1143
- □ <u>set data required time</u> on page 1144
- □ <u>set dcl calculation mode</u> on page 1145

- □ <u>set\_dcl\_functional\_mode</u> on page 1146
- □ <u>set\_dcl\_level</u> on page 1147
- □ <u>set default slew time</u> on page 1148
- □ <u>set\_disable\_cell\_timing</u> on page 1149
- □ <u>set disable clock gating check</u> on page 1151
- □ set disable timing on page 1153
- □ <u>set\_drive\_cell</u> on page 1156
- □ <u>set drive resistance</u> on page 1163
- □ set external delay on page 1167
- □ <u>set\_false\_path</u> on page 1172
- □ <u>set fanout load limit</u> on page 1179
- □ <u>set flow compatible mode</u> on page 1180
- □ <u>set\_functional\_mode</u> on page 1183
- □ <u>set generated clock</u> on page 1184
- □ set ideal net on page 1191
- □ <u>set input delay</u> on page 1193
- □ set max delay on page 1196
- □ <u>set min delay</u> on page 1197
- □ <u>set mp\_area</u> on page 1198
- □ <u>set mp global parameter</u> on page 1199
- □ set mp max fanout limit on page 1201
- □ <u>set mp min fanout limit</u> on page 1202
- □ <u>set mp port drive</u> on page 1203
- □ <u>set mp port load</u> on page 1205
- □ <u>set mp port max capacitance</u> on page 1207
- <u>set mp port max transition</u> on page 1209
- <u>set mp port min capacitance</u> on page 1211

- <u>set mp\_port\_min\_transition</u> on page 1213
- □ <u>set mp technology</u> on page 1215
- □ <u>set num external sinks</u> on page 1217
- □ <u>set\_num\_external\_sources</u> on page 1218
- □ <u>set operating conditions</u> on page 1219
- □ <u>set operating parameter</u> on page 1226
- □ <u>set\_operating\_voltage</u> on page 1228
- □ <u>set path delay constraint</u> on page 1230
- □ <u>set path group</u> on page 1235
- □ <u>set port capacitance</u> on page 1238
- □ <u>set port capacitance limit</u> on page 1240
- □ <u>set port wire load</u> on page 1242
- □ <u>set\_propagated\_clock</u> on page 1244
- □ set scale delays on page 1246
- □ <u>set slew limit</u> on page 1248
- □ <u>set\_slew\_thresholds</u> on page 1249
- □ <u>set slew time</u> on page 1251
- □ <u>set slew time limit</u> on page 1253
- □ set tech info on page 1255
- □ <u>set time borrow limit</u> on page 1263
- □ <u>set time unit</u> on page 1265
- □ <u>set top timing module</u> on page 1267
- □ <u>set wire capacitance</u> on page 1269
- □ <u>set wire load</u> on page 1271
- □ <u>set\_wire\_load\_mode</u> on page 1274
- <u>set wire load selection table</u> on page 1275
- □ <u>set wire resistance</u> on page 1276

- □ <u>unload\_dcl\_rule</u> on page 1277
- □ <u>write assertions</u> on page 1278
- □ <u>write constraints</u> on page 1280
- □ <u>write\_gcf\_assertions</u> on page 1282
- write library assertions on page 1284
- □ <u>write rspf</u> on page 1285
- □ <u>write\_sdc</u> on page 1286
- □ <u>write sdf</u> on page 1288
- □ <u>write spf</u> on page 1295
- □ <u>write timing windows</u> on page 1296

# Path Exception Priorities

The following are the path exception priorities if a path in the design matches more than one path exception:

- 1. <u>set\_false\_path</u>
- 2. set path delay constraint
- 3. <u>set\_cycle\_addition</u>.

If there is more than one exception of a given type, for example the set\_cycle\_addition command, the path exception that is more specific has higher priority. A path exception is more specific if it specifies a longer path than the other. For example, the -from -to options would have priority over the -from option.

If the path has the same number of reference points:

- -from option has priority over the -to option
- -to option has priority over the -through option
- -clock\_from option has priority over the -clock\_to option

**Note:** To check for ignored path exceptions, use the <code>report\_path\_constraints</code> command.

Table 7-1 shows the priorities for path exceptions applied to the same path. See also <u>"Examples of Path Exception Priorities"</u> on page 798.

| Table 7-1 | Path | Exception | Priorities |
|-----------|------|-----------|------------|
|-----------|------|-----------|------------|

| Priority     | Path Exception                                                                                                    |
|--------------|-------------------------------------------------------------------------------------------------------------------|
| 1. (Highest) | set_false_path                                                                                                    |
| 2.           | <pre>set_path_delay_constraint -from pin_list</pre>                                                               |
| 3.           | <pre>set_path_delay_constraint -to pin_list</pre>                                                                 |
| 4.           | set_path_delay_constraint -through <i>pin_list</i><br>(The greatest number of throughs has the highest priority.) |
| 5.           | <pre>set_path_delay_constraint -clock_from clkwave_name</pre>                                                     |
| 6.           | <pre>set_path_delay_constraint -clock_to clkwave_name</pre>                                                       |

| Priority     | Path Exception                                                                                                                 |
|--------------|--------------------------------------------------------------------------------------------------------------------------------|
| 7.           | set_path_delay_constraint<br>(The most constraining adjustment has the higher priority over less<br>constraining adjustments.) |
| 8.           | <pre>set_cycle_addition -from pin_list</pre>                                                                                   |
| 9.           | <pre>set_cycle_addition -to pin_list</pre>                                                                                     |
| 10.          | <pre>set_cycle_addition -through pin_list</pre>                                                                                |
| 11.          | <pre>set_cycle_addition -clock_from clkwave_name</pre>                                                                         |
| 12.          | <pre>set_cycle_addition -clock_to clkwave_name</pre>                                                                           |
| 13. (Lowest) | set_cycle_addition<br>(The most constraining adjustment has the higher priority over less<br>constraining adjustments.)        |

#### Table 7-1 Path Exception Priorities

#### **Examples of Path Exception Priorities**

The following are examples of the path exception priorities for a path starting at A, going through B, and ending with C. The pairs of examples are ordered such that the highest priority constraint in one pair has precedence over the highest priority constraint in the next pair.

■ In the following pair of constraints, the false path overrides the cycle addition for the path from A through B to C. For all other paths from A, the cycle addition applies.

```
set_false_path -from A -through B -to C
set_cycle_addition -from A 1
```

■ In the following pair, the first constraint is applied (two cycles added) because the -from option has priority over the -to option.

```
set_cycle_addition -from A 2
set_cycle_addition -to C 1
```

■ In the following pair, the first constraint is applied (two cycles added) because it specifies a -through pin as well as a -to pin.

```
set_cycle_addition -through A -to B 2
set_cycle_addition -to B 1
```

■ In the following pair, the first constraint is applied (two cycles added) because the -clock\_from option has precedence over the -clock\_to option.

```
set_cycle_addition -clock_from CLKA 2
set_cycle_addition -clock_to CLKB 1
```

In this pair of path exceptions, one cycle is added because it is the most constraining value.

```
set_cycle_addition -from A 1
set_cycle_addition -from A 2
```

# **Bidirectional Pin Defaults**

Bidirectional pins have both an input pin and an output pin type. This section explains the default pin type that the system uses for bidirectional pins.

## **Defaults for Path Exceptions and Timing Reports**

Table 7-2 shows the defaults for bidirectional pins used in path exceptions and timing reports.

| Pin Type           | -from            | -through            | -to            |
|--------------------|------------------|---------------------|----------------|
| Primary ports      | bidi_input_from  | bidi_input_through  | bidi_output_to |
| Hierarchical ports | bidi_input_from  | bidi_input_through  | bidi_output_to |
| Instance pins      | bidi_output_from | bidi_output_through | bidi_input_to  |
| Blackbox pins      | bidi_output_from | bidi_output_through | bidi_input_to  |

Table 7-2 Bidirectional Pin Type Defaults for Path Exceptions

⊂∰\_ Tip

Override the default by specifying these options:

```
[-bidi_input_from | -bidi_output_from]
[-bidi_input_through | -bidi_output_through]
[-bidi_input_to | -bidi_output_to]
```

For more information, see the following:

- <u>report\_timing</u> on page 990
- <u>set disable timing</u> on page 1153 and <u>reset disable timing</u> on page 1035
- <u>set false path</u> on page 1172
- <u>set path delay constraint</u> on page 1230
- <u>set\_cycle\_addition</u> on page 1136

- <u>reset\_path\_exception</u> on page 1057
- Path Exception Priorities on page 797

## **Defaults for Pin (or Port) Assertions**

Table 7-3 defines the pin and port types that are used in Table 7-4.

| Pin Type                | Туре 1 | Type 2 |
|-------------------------|--------|--------|
| Blackbox pins           | out    | in     |
| Instance pins           | out    | in     |
| Netlist (primary) ports | in     | out    |
| Hierarchical ports      | in     | out    |

#### Table 7-4 Bidirectional Pin Type Defaults

| Pin or Port Constraint           | Туре | Hierarchical Port |
|----------------------------------|------|-------------------|
| set external delay               | 2    | ignored           |
| <u>set clock insertion delay</u> | 1    | ignored           |
| <u>set_generated_clock</u>       | 1    | used              |
| <u>set clock info change</u>     | 1    | used              |
| <u>set slew time</u>             | 1    | ignored           |
| <u>set drive cell</u>            | 1    | ignored           |
| <u>set drive resistance</u>      | 1    | ignored           |
| path exception (from)            | 1    | used              |
| path exception (through)         | 1    | used              |
| path exception (to)              | 2    | used              |

## **Defaults for Port Assertions**

Table 7-5 defines the port types that are used in Table 7-6.

Table 7-5 Bidirectional Port Type Definitions

| Pin Type                | Туре 1 | Туре 2 |
|-------------------------|--------|--------|
| Netlist (primary) ports | in     | out    |
| Hierarchical ports      | in     | out    |

Table 7-6 Bidirectional Port Type Defaults

| Port Constraint                   | Туре | Hierarchical Port |
|-----------------------------------|------|-------------------|
| set_fanout_load_limit             | 2    | ignored           |
| <u>set_fanout_load_limit</u>      | 2    | ignored           |
| <u>set_num_external_sources</u>   | 2    | ignored           |
| <u>set_num_external_sinks</u>     | 2    | ignored           |
| <u>set_port_capacitance</u>       | 2    | ignored           |
| <u>set_port_capacitance_limit</u> | 2    | ignored           |
| <u>set_port_wire_load</u>         | 2    | ignored           |
| <pre>set_slew_time_limit</pre>    | 2    | ignored           |

# **Command Descriptions**

This section contains descriptions of the commands used in the Common Timing Engine (CTE) for timing analysis.

# check\_timing

```
check_timing [-pins pin_list] [-type type_list] [-verbose]
   [-sort {pin | warning}] [-exclude_warning warning_list]
   [-early | -late] [-tcl_list] [-old] [{> | >> } file_name]
   Valid types are: clocks clock_clipping constant_collision endpoints inputs
   loops
```

Performs a variety of consistency and completeness checks on the timing constraints specified for a design. Use the check\_timing command after setting all constraints but before using the do\_optimize command or any CTE commands, such as report\_timing or get\_timing, to verify that the timing environment is complete and self-consistent.

The checks include arrival time and external delay (or required time) for each clock in a multiple clock system. In addition, clock connectivity and data connectivity are checked to make sure the clock or data is propagated as expected. Clock gating points are also reported. For more information about gated clock checks, see "Using Clock Gating" in the Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).

Use this command on generic or mapped netlists. The check\_timing command considers constants applied to a pin while reporting warnings.

# Important

Use the check\_timing command before using any commands for timing analysis. Warnings are displayed when problems occur. <u>Table 7-7</u> on page 806 lists the check\_timing warnings. For best results, rerun the check\_timing command after resolving each warning. Redirecting the output to a file is the quickest run method. For example: check\_timing *filename* 

# **Options and Arguments**

-early -late

Reports early or late timing inconsistencies. *Default*: The late timing inconsistencies are reported.

-exclude\_warning warning\_list

Disables reporting of the warnings specified in the *warning\_list*. The list of warnings and their descriptions is given in <u>Table 7-7</u> on page 806.

| Common Timing Engine (CTE) Commands |                                                                                                                                                                                                                                                                                                                                           |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| file_name                           | Specifies the name of the output file.<br><i>Default</i> : stdout                                                                                                                                                                                                                                                                         |  |
| -old                                | Reports in the 4.0 format.                                                                                                                                                                                                                                                                                                                |  |
| -pins <i>pin_list</i>               | Limits the checks to pins in the pin_list.                                                                                                                                                                                                                                                                                                |  |
| -sort {pin   warning                | Sorts the Timing Check Detail table by pin name or warning.                                                                                                                                                                                                                                                                               |  |
| -tcl_list                           | Reports the warnings in a Tcl list.                                                                                                                                                                                                                                                                                                       |  |
| -type type_list                     | Limits the checks to the specified type. <i>Default</i> : All check types are reported.                                                                                                                                                                                                                                                   |  |
|                                     | The valid types are as follows:                                                                                                                                                                                                                                                                                                           |  |
|                                     | clock_clipping<br>Warns when there is a problem with clock gating that can result<br>in clock clipping.                                                                                                                                                                                                                                   |  |
|                                     | clocks<br>Warns if no clock arrives at register clock pins, if data arrives on<br>a pin where a clock signal is expected, and if the master of a<br>generated clock is not driven by a clock source.                                                                                                                                      |  |
|                                     | <pre>constant_collision Warns when there is a constant collision on a net connected to the pin or if there is a contradiction on a pin. Constant collision occurs when a net is driven simultaneously by conflicting values and a constant contradiction occurs when a constant assertion on a pin conflicts with the driven value.</pre> |  |
|                                     | endpoints<br>For output ports, warns if no external delay (or required time)<br>assertion is applied to the port or if a specific (late/early rise/fall)<br>external delay (or required time) is missing. It also warns if an                                                                                                             |  |

external delay (or required time) assertion is applied with no clock information.

For all endpoints (output ports and register data pins), it warns if any incoming signal is unconstrained.

Also warns if a clock arrives where clock is not expected or if multiple signals arrive at an endpoint.

#### inputs

Issues warnings if no input delay (or arrival time) assertion is applied to an input port or if a specific (late/early rise/fall) input delay (or arrival time) is missing on that port.

Warns if an input delay (or arrival time) assertion is applied with no clock information.

Warns if no drive assertion is applied to an input port or if a specific (late/early rise/fall) drive assertion is missing on that port.

#### loops

Warns when a combinational loop is detected. Reports the loop and the arc used to break the loop. The -pin option is ignored in this case.

Also reports loops caused by generated clocks.

#### -verbose

Gives detailed information about the warnings. *Default* Gives a summary of how many warnings of each type exists.

**Note**: This option replaces the -detail option, which is obsolete.

# Warning Messages

Table 7-7 shows the check\_timing warning messages.

| Warning              | Description                                                                                    | Comments                                                                                                                                               |
|----------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| async_arr            | Input delay or arrival time<br>assertion with no clock<br>information<br>(asynchronous).       | Input delay or arrival time<br>assertion applied without the<br>-clock option. Do not mix an<br>asynchronous clock (@) with a<br>regular clock.        |
| async_ext            | External delay or required<br>time assertion with no<br>clock information<br>(asynchronous).   | External delay or required time<br>assertion is applied without the<br>-clock option. Do not mix an<br>asynchronous clock (@) with a<br>regular clock. |
| clock_but_data       | Clock signal found where data is expected.                                                     | See the <u>reset clock root</u><br>and <u>set generated clock</u> .                                                                                    |
| clock_clipping_gate  | Clock clipping possible<br>due to wrong gate type or<br>wrong trigger for data<br>input.       |                                                                                                                                                        |
| clock_clipping_freq  | Clock clipping possible<br>due to incompatible clock<br>signal and data signal<br>frequencies. |                                                                                                                                                        |
| clock_expected       | Clock not found where clock is expected.                                                       | Indicates that no clock signal is<br>defined at the clock pin.<br>Typically, accompanies<br>data_but_clock warnings.                                   |
|                      |                                                                                                | See the <u>set_clock_root</u> .                                                                                                                        |
| clock_not_propagated | Clock not propagated.                                                                          | Indicates that the clock is not<br>propagated further because it is<br>connected to a black box or<br>signal pin of a timing check.                    |
| const_collision      | Constant collision.                                                                            | <b>See</b><br><u>set constant for timing</u> .                                                                                                         |

Table 7-7 check\_timing Warning Messages

| Warning             | Description                                                                   | Comments                                                                                                                                    |
|---------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| const_contradiction | Constant contradiction.                                                       | See <u>set constant for timing</u> .                                                                                                        |
| data_but_clock      | Data signal found where clock is expected.                                    |                                                                                                                                             |
| data_gating_clock   | Data gating clock.                                                            | A warning that the clock is a gated clock.                                                                                                  |
| loop                | Timing loop found in the design.                                              | Indicates that there are timing<br>loops in the design. It also<br>includes loops caused by<br>generated clocks.                            |
| missing_arr         | Missing specific (rise/fall)<br>input delay or arrival time<br>assertion.     | Either a rise or fall input delay or arrival time assertion is applied and the other one is missing.                                        |
| missing_drive       | Missing specific (rise/fall) drive assertion.                                 | Either a rise or fall drive assertion is applied and the other one is missing.                                                              |
| missing_ext         | Missing specific (rise/fall)<br>external delay or required<br>time assertion. | Either rise or fall external delay<br>or required time assertion is<br>applied and the other one is<br>missing.                             |
| multiple_signal     | Multiple signals arriving at end points.                                      | Indicates that there are signals triggered by different clocks arriving at the pin.                                                         |
| no_drive            | No drive assertion.                                                           | See <u>set drive cell</u> and <u>set drive resistance</u>                                                                                   |
| no_ext              | No external delay or required time assertion.                                 | See <u>set external delay</u> .                                                                                                             |
| no_gen_clock_source | No clock source found for generated clock.                                    | Indicates that the source pin of<br>the clock generated by the<br><u>set generated clock</u><br>command is not driven by a<br>clock source. |

# Table 7-7 check\_timing Warning Messages , continued

| Warning            | Description                                                                                                      | Comments                                                                                                                                                                 |
|--------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| specific_async_arr | Specific (rise/fall) input<br>delay or arrival time<br>assertion with no clock<br>information<br>(asynchronous). | Either a rise or fall input delay or<br>arrival time assertion is applied<br>without the -clock option. Do<br>not mix an asynchronous clock<br>(@) with a regular clock. |
| specific_async_ext | Specific external delay or<br>required time assertion<br>with no clock information<br>(asynchronous).            | Either rise or fall external delay<br>or required time assertion is<br>applied without the -clock<br>option. Do not mix asynchronous<br>clock (@) with regular clock.    |
| uncons_signal      | Unconstrained signal arriving at end point.                                                                      | Signal arriving at an end point is<br>not constrained. Use the<br><u>set_external_delay</u><br>command to constrain it.                                                  |
| unmatched_req      | Unmatched required time assertion.                                                                               | Required time does not match any incoming signal. Check for bad constraints.                                                                                             |

#### Table 7-7 check\_timing Warning Messages , continued

## Examples

■ The following command displays the default summary report:

check\_timing

|                                            | TIMING CHECK SUMMARY                                                                                                                                                   |                          |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Warning                                    | Warning Description                                                                                                                                                    | Number<br>of<br>Warnings |
| clock_expected<br>loop<br>no_arr<br>no_ext | Clock not found where clock is expected<br>Timing loop found in the design<br>No input delay or arrival time assertion<br>No external delay or required time assertion | 2<br>1<br>6<br>1         |

■ The following command displays a specified type of warning using the -type option:

check\_timing -type loops

+----+
TIMING CHECK SUMMARY
Warning Warning Description Number
of

|      |                                 | Warnings |
|------|---------------------------------|----------|
| loop | Timing loop found in the design |          |

■ The following command provides more information about problems and prints a summary using the -detail option:

check\_timing -detail

|                                            | TIMING CHECK SUMMARY                                                                                                                                                   |                              |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Warning                                    | Warning Description                                                                                                                                                    | Number<br>  of<br>  Warnings |
| clock_expected<br>loop<br>no_arr<br>no_ext | Clock not found where clock is expected<br>Timing loop found in the design<br>No input delay or arrival time assertion<br>No external delay or required time assertion | 2<br>1<br>6<br>1             |

|                                                                         | TIMING CHECK DETAIL                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin                                                                     | Warning                                                                                                                                                                                                                                                                                                                                                                                                    |
| clk1<br>clk2<br>enable<br>ff1/CP<br>ff2/CP<br>in1<br>in2<br>in3<br>out1 | No input delay or arrival time assertion<br>No input delay or arrival time assertion<br>No input delay or arrival time assertion<br>Clock not found where clock is expected<br>Clock not found where clock is expected<br>No input delay or arrival time assertion<br>No input delay or arrival time assertion<br>No input delay or arrival time assertion<br>No external delay or required time assertion |

|              | ING CHECK | +<br>LOOP                 |
|--------------|-----------|---------------------------|
| Snipped Arcs |           | Timing<br>Loop<br>Details |
| From<br>Pin  | To Pin    |                           |
| g1/Z         | gl/A      | g1/A<br>g1/Z              |

# create\_mp\_constraint\_arc

```
create_mp_constraint_arc [-name constraint_name]
  [-setup | -hold | -recovery | -removal | -no_change_setup | -no_change_hold
  | -skew | -mpw | -period] [-from port_name_list] [-edge {rise | fall}]
  [-to port_name_list]
  [{-path_type path_type|-path_factor factor|-value extra_constraint_time}]
```

Specifies the value for a timing check. Most checks relate a transition on a clock input port to a transition on a data input port. The minimum pulse width (mpw) and period checks have only a clock pin.

The constraint arc starts with a base value found with the <u>set mp global parameter</u> command with a matching -param option. To this base constraint value, an internal delay is added. This delay is either given explicitly or from a path\_type.

### **Options and Arguments**

-edge

Specifies the edge of the clock, *rise* or *fall*, relevant to the timing check.

-from port\_name\_list

Specifies the name of the clock input port to use for the timing check.

The *port\_name\_list* argument can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the Using the Module Prototyper (MP) section of the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

| -name  | constraint_name                                       |
|--------|-------------------------------------------------------|
|        | Specifies the constraint arc name, which is not used. |
|        |                                                       |
| -hold  |                                                       |
| -11010 |                                                       |
|        | Specifies a hold constraint arc.                      |
|        |                                                       |
| -mpw   |                                                       |

Specifies a minimum pulse width constraint arc.

#### Command Reference for BuildGates Synthesis and Cadence PKS Common Timing Engine (CTE) Commands

| -no_change_hold            | Specifies a no_change_hold constraint arc.                                                                                                                 |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -no_change_setup           | Specifies a no_change_setup constraint arc.                                                                                                                |
| -path_factor factor        | Specifies a multiplicative factor for the path type.                                                                                                       |
| -path_type                 | e<br>Specifies the extra constraint time based on a path type. The<br>extra constraint time is the delay time from the path type times<br>the path factor. |
| -period                    | Specifies a period constraint arc.                                                                                                                         |
| -recovery                  | Specifies a recovery constraint arc.                                                                                                                       |
| -removal                   | Specifies a removal constraint arc.                                                                                                                        |
| -setup                     | Specifies a setup constraint arc.                                                                                                                          |
| -to port_name_list         | Specifies the input port name to use for the timing check. For slew arcs, this should be another clock. This argument is not used for mpw and period arcs. |
| -value <i>extra_constr</i> | aint_time<br>Specifies an explicit extra constraint time, which can be either a<br>single number or an SDF style triplet.                                  |

# Examples

■ The following command creates a hold constraint arc from cp to D. The base constraint value is set by the set\_mp\_global\_parameters. To that base, 2 is added as an extra constraint time:

create\_mp\_constraint\_arc -hold -from cp -to D -edge rise -value 2

■ The following command creates a setup constraint arc. The base constraint value is set by the set\_mp\_global\_parameters. To that base, an extra constraint time is added, which is found by multiplying the path delay of path1 by the path factor:

create\_mp\_constraint\_arc -setup -from cpn -to D -edge rise -path\_type path1
-path\_factor 2

#### **Related Information**

create mp path type

<u>set\_mp\_global\_parameter</u>

# create\_mp\_delay\_arc

```
create_mp_delay_arc [-name arc_name]
  [-from port_name_list]
  [-to port_name_list]
  [-edge {rise | fall}| {-set | -clear}]
  [-value delay_time] [-path_type path_type] [-path_factor factor]
```

Creates a delay arc. By default, it is a purely combinational delay arc from all input ports to all output ports.

All delay arcs created by the Module Prototyper (MP) are non-inverting except for the edge arcs.

The delay and slew tables for the arc are based on the tables implied by the <u>set mp port drive</u> command on the -to pin. An internal delay time is added to the delay table to create the delay table for the specific arc. This internal delay time can be found either by explicitly stating the time using the -value option or by using the path\_type option. In the later case, the delay associated with the path type is multiplied by the path factor.

Edge arcs also add the clk\_to\_output delay set by the <u>set mp global parameter</u> -param clk\_to\_output command.

If there are multiple calls to <u>create mp delay arc</u> for the same pair of from and to ports, the model will have multiple delay arcs between these ports.

## **Options and Arguments**

```
-edge {rise | fall}
```

Specifies the delay arc is either a rising edge or falling edge arc. The from ports for this arc must be clock pins.

-from port\_name\_list

Specifies the name of the input port or ports. These ports must be either input or inout pins. Edge arcs must have clock pins as the from pin. If this option is not specified, then delays arcs will come from all appropriate ports.

The port\_name\_list variable can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of

|                            | the Timing Analysis for BuildGates Synthesis and Cadence<br>Physically Knowledgeable Synthesis (PKS).                                                                                                                                      |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -name arc_name             | Specifies an optional name for the from-to arc to which the delay applies. The arc name can be specified but is not used.                                                                                                                  |
| -path_type <i>path_typ</i> | e<br>Specifies the path type to be used for the delay. The default for<br>path factor is 1. The name of the basic path, <i>path_type</i> , must<br>be previously defined using the <u>create mp path type</u><br>command.                  |
| -path_factor factor        | Specifies the delay based on the path type multiplier by a factor.<br>The default for the path factor is 1.                                                                                                                                |
| -set   -clear              | Specifies that the delay arc is an asynchronous set or clear arc.<br>The -set option creates a set asynchronous delay path. This<br>arc will have a SET QUALIFIER if stored in a TLF file or a<br>timing_type of preset in a Liberty file. |
|                            | The -clear option creates a clear asynchronous delay path.<br>This arc will have a CLEAR QUALIFIER if stored in a TLF file or<br>a timing_type of clear in a Liberty file.                                                                 |
| -toport_name_list          | Specifies the name of the output port or ports, which must be an output or an inout port. If this option is not specified, delays will be created to all output and inout ports.                                                           |
| -value <i>delay_time</i>   | Specifies the internal delay as an explicit value, which can be either be a single number or an SDF style triplet.                                                                                                                         |

## Examples

■ The following command creates a delay arc from port cp to Q. It is a rising edge arc and has a constant delay of 2 for the minimum corner and 3 for the maximum corner (there is no typical corner for this prototype, otherwise the typ value must be provided):

create\_mp\_delay\_arc -from cp -edge rise -value 2::3 -to Q

■ The following command creates two delay arcs from port A to port Z and from port B to port Z. The delay and slew data is based on the driver type port Z was set to (if any). An extra delay is added, found by multiplying the path delay of path1 by 1:

create\_mp\_delay\_arc -from {A B} -path\_type path1 -path\_factor 1 -to Z

#### **Related Information**

<u>create\_mp\_path\_type</u>

<u>set mp global parameter</u>

# create\_mp\_drive\_type

```
create_mp_drive_type [-lib_cell cell_name][-input_pin pin_name]
      [-output_pin pin_name] drive_type_name
```

Specifies a drive type that describes a drive type that describes drives. The drive type can then be applied to an out or inout port using the <u>set mp port drive</u> command. All delay arcs to ports set to this drive type uses the reference delay arc as a base time. If the <u>inherit\_port\_limits</u> option was set to on using the <u>set mp technology</u> command, then any port limits on the reference's cell driver pin are copied to the driver port.

A delay arc is found in the reference arc for the matching cell name and pin names. If multiple arcs match, the first one is used. A capacitive load found for that arc is either given explicitly or based on the fanout count and the current Module Prototyper (MP) wire load table. A delay is then found for the output rising arc using that capacitance for the load and zero for all other axes. This delay is used whenever this path type is used.

The *pin\_name* variable is the name of a single pin the reference cell.

Bus names or bus ranges are not allowed. The current name space is used for special character escaping. See <u>Pin Names</u> in the "Using the Module Prototyper (MP)" section of the *Common Timing Engine* (*CTE*) User Guide.

## **Options and Arguments**

| drive_type_name            | Specifies the name for the drive type. The drive type is stored using this name,                                   |
|----------------------------|--------------------------------------------------------------------------------------------------------------------|
| -input_pin <i>pin_name</i> | Specifies the input pin for the arc. If missing, the first input or inout will be used.                            |
| -lib_cell <i>cell_name</i> | Specifies the cell in the library for which the logic type is defined.                                             |
| -output_pin pin_name       | Specifies the output pin for the arc. If this option is not specified, the first output or inout pin will be used. |

## Examples

■ The following command sets the drive1 drive type to the delay arc from cell INVX1's first input pin to the cell's first output pin:

create\_mp\_drive\_type drive1 -lib\_cell INVX1

■ The following command sets the drive2 drive type to the delay arc from pin A to pin Z in the reference cell INXV1:

create\_mp\_drive\_type drive2 -lib\_cell INVX1 -input\_pin A -output\_pin Z

#### **Related Information**

<u>create mp constraint arc</u>

<u>create\_mp\_delay\_arc</u>

# create\_mp\_load\_type

create\_mp\_load\_type [-lib\_cell cell\_name] [-input\_pin pin\_name] load\_type\_name

Specifies a load type that describes the load of a input or inout reference pin. The load type created by this command can be used with the set\_mp\_port\_load command where it is used to set the port's capacitance and optionally other port limits.

## **Options and Arguments**

| -input_pin <i>pin_name</i> | Specifies the input pin for the arc. If this option is not specified, the first input or inout will be used.                                                                                                                                                                                                                                   |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | The <i>pin_name</i> argument specifies the name of a single pin for<br>a reference cell. Bus names or bus ranges are not allowed.The<br>current name space is used for special character escaping. See_<br><u>Pin Names</u> in the "Using the Module Prototyper (MP)" section of<br>the <i>Common Timing Engine</i> ( <i>CTE</i> ) User Guide. |
| -lib_cell <i>cell_name</i> | Specifies the cell in the library for which the logic type is defined.                                                                                                                                                                                                                                                                         |
| load_type_name             | Specifies the name for the load type. The load type will be stored using this name.                                                                                                                                                                                                                                                            |

## Examples

■ The following command creates a load1 load type from the pin information on the first input or inout pin in the INVX1 reference cell:

create\_mp\_load\_type load1 -lib\_cell INVX1

■ The following command creates a load2 load type from the pin information on pin z in the INVX1 reference cell:

create\_mp\_load\_type load1 -lib\_cell INVX1 -input\_pin A -output\_pin Z

## **Related Information**

<u>set\_mp\_port\_load</u>

# create\_mp\_model

create\_mp\_model [-copy\_ports\_from\_module\_or\_inst\_name] cell\_name

Starts the definition of a new module prototype. The *cell\_name* will be the name for both the model cell and the library it is stored in. If the *-copy\_ports\_from* option is specified, the Module Prototyper (MP) will look at the current design to find a module or an instance with that name. If found, the model will be created with the same ports and names as in the design module or instance. The name and numbers of ports will then be fixed, but you can use the <u>create mp port</u> command to change the port type.

The create\_mp\_model command starts an MP edit session and the save\_mp\_model command ends the session. The prototype is visible only to MP commands until it is saved.

### **Options and Arguments**

cell\_name

Specifies the name of the module that is being prototyped. The same name will be used both as the name of the library containing the MP prototype, and the name of the prototype cell within the library.

-copy\_ports\_from\_module\_or\_inst\_name

Specifies a module or an instance in the current design whose port number and names the prototype model should match.

#### Examples

The following command creates a new MP prototype with no pins:

create\_mp\_model invert

■ The following command creates a new MP prototype, which has the same pin names and pin order as block5 in the current netlist:

create\_mp\_model -copy\_ports\_from block5 mp\_block5

## **Related Information**

<u>save\_mp\_model</u>

# create\_mp\_path\_type

```
create_mp_path_type [-lib_cell cell_name] [-input_pin pin_name]
    [-output_pin pin_name] [-fanout fanout_count | -capacitance cap]
    path_type_name
```

Specifies a basic path type that describes delays through one or more levels of combinational logic. The information in the command line is converted to a simple delay value (the delay time for different PVT corners may differ). The path type is referred to in the <u>create mp delay arc</u> and <u>create mp constraint arc</u> commands to refer to an additional delay time to be added to a delay or constraint time.

A delay arc is found in the reference arc for the matching cell name and pin names. If multiple arcs match, the first one is used. A capacitive load is found for that arc either given explicitly or based on the fanout count and the current Module Prototyper (MP) wire load table. A path delay is then found for the output rising arc using that capacitance for the load and zero for all other axes. This path delay is used whenever this path type is used to create an arc.

## **Options and Arguments**

| -capacitance <i>cap</i>    | Specifies an explicit load for the arc when calculating the delay for the path. It may either be a single number or an SDF style triplet.                                                                                                                                                                                       |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -fanout fanout_count       | A load is calculated using the fanout_count and the<br>wireload_model specified in the <u>set mp technology</u><br>command. This capacitance is used as the load for the delay arc<br>when calculating the delay of the path.                                                                                                   |
| -input_pin <i>pin_name</i> | Specifies the input pin for the arc. If missing, the first input or inout will be used.                                                                                                                                                                                                                                         |
|                            | The pin_name is the name of a single pin in the reference cell.<br>Bus names or bus ranges are not allowed. The current name<br>space is used for special character escaping. See <u>Pin Names</u> in<br>the "Using the Module Prototyper (MP)" section of the <i>Common</i><br><i>Timing Engine</i> ( <i>CTE</i> ) User Guide. |
| -lib_cell <i>cell_name</i> |                                                                                                                                                                                                                                                                                                                                 |

Specifies the cell in the library for which the logic type is defined.

| -output_pin pin_name | Constitution the output air for the area of this option is not enceified                                           |
|----------------------|--------------------------------------------------------------------------------------------------------------------|
|                      | Specifies the output pin for the arc. If this option is not specified, the first output or inout pin will be used. |
| path_type_name       |                                                                                                                    |
|                      | Specifies a name for the path type. The path type will be stored using this name.                                  |

### Examples

The following command creates a path type based on the delay arc between the first input and the first output pin in the INVX1 reference cell. The Module Prototyper's current wireload table is used to find a capacitance for a fanout of 5 and this load is used to calculate the path delay:

create\_mp\_path\_type path1 -lib\_cell INVX1 -fanout 5

■ The following command creates a path type based on the delay arc between pin A and pin Z in the INXV1 reference cell. The path delay is calculated using 0.09 as the load:

create\_mp\_path\_type path12 -lib\_cell INVX1 -input\_pin A -output\_pin Z -capacitance 0.09

#### **Related Information**

<u>create\_mp\_constraint\_arc</u>

<u>create mp delay arc</u>

# create\_mp\_port

create\_mp\_port [-type {input | -output | -inout | -clock}] port\_name\_list

Adds ports of the specified type to the prototype or changes the type of existing ports. How it is used depends on how the Module Prototype (MP) was created.

If the create\_mp\_model command used to start this MP session specified the -copy\_ports\_from option, then the port names and order are already set. The ports names cannot be changed. If the ports were copied from a Verilog or VHDL module, the port types are also set and this command is not necessary. However, if the ports were copied from a black box instance, the port types are set to inout and this command should be used to set the port types.

If the create\_mp\_model command used to start this MP session did not specify the -copy\_ports\_from option, then the create\_mp\_port command must be used to create all the ports. When you use this command, make sure that the connections to the pins of an instance are correct by order (rather than by name). To do this, you must issue the command in the same order in which the ports appear in the Verilog or VHDL definition of the module. Similarly, bus ports must be created using the bus port notation. The order of the indices (ascending or descending) must match that appearing in the Verilog or VHDL definition of the module.

# **Options and Arguments**

| port_name_list      | Specifies the name of the created or modified ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | The port_name_list argument can be either a single name<br>or a list of names in curly braces. Each name may be a simple<br>name, such as A, a bus element name, such as Data[3], a bus<br>name, such as Data, or a bus range, such as Data[3:6]. The<br>current name space is used for special character escaping. See<br><u>Port Names</u> in the "Using the Module Prototyper (MP)" section of<br>the <i>Timing Analysis for BuildGates Synthesis and Cadence</i><br><i>Physically Knowledgeable Synthesis (PKS).</i> |
| -type (input   -out | put   -inout   -clock)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

ype (input | -output | -inout | -clock)
Specifies the type of port to be added to the module prototype.

## Examples

■ The following command creates two input ports A and B in that order:

create\_mp\_port -type input { A B}

■ The following command creates a clock port named cp:

create\_mp\_port -type clock cp

The following command changes the pin type of a port previously created by copying from an existing inst5 black box in the current design:

create\_mp\_model -copy\_ports\_from inst5 inst5\_mp
create\_mp\_port -type input A

#### **Related Information**

<u>create mp model</u>

# do\_analyze\_crosstalk

```
do_analyze_crosstalk [-engine {xmc | celtic} [-coupling_file coupling_file]
    [-dont_read_coupling_file] [-config configfile] [-twf_based {net | pin}]
    [-no_timing] [-which] [-spef parasitics.spef] [-spf parasitics.spf]
    [-keep_inc sdf][-exefile exe_full_pathname] [-echo file_list]
    [-exename exe_filename] [-cdb cdb_filename] [-text] [-outprefix prefix]
```

Runs the crosstalk analyzer engine on input from RC extraction (HyperExtract) and produces a crosstalk repair file used by the do\_xform\_run\_repair\_file command or downstream tools. The engine is CeltIC or SE5.4 or the Crosstalk Magnitude Calculator (XMC) for SE5.3. This command supports the SE-PKS flow.

You cannot use the do\_analyze\_crosstalk command if you only have a license for Cadence PKS. You must have the appropriate licenses to run HyperExtract and Celtic or XMC. Run RC extraction on a fully routed design before you analyze crosstalk. For more information, see the *Synthesis Place and Route (SP&R) Flow Guide*.

If the Celtic license (FEATURE Celtic in license file) is not available, then the CTE do\_analyze\_crosstalk command asks CeltIC to check out the Envisia\_SE\_SI\_place\_route license. If the SESI license is not available, then CTE exits CeltIC. Otherwise, crosstalk analysis starts with the SESI license checked out.

# **Output Files**

When the  $do_analyze_crosstalk$  command completes successfully, it produces the following files in the run directory:

- xtalk.log Crosstalk analysis log file.
- xtalk.gcf Intermediate General Constraint Format (GCF) timing constraint file required for boundary timing, drive, and load information (XMC only).
- xtalk.twf Timing windows file generated by the do\_analyze\_crosstalk command. This is an internal handshake from PKS to the crosstalk analyzer only. You do not need to do anything with this file, the tools handle the handshake during each run.
- xtalk.incsdf Incremental Standard Delay Format (SDF) file containing the delay effects of the induced crosstalk. Unless the -no\_timing option is specified, this SDF is loaded when the crosstalk analysis is completed.

Additional files are produced for analysis and repair.

CeltIC produces the following files:

- xtalk.vg
- xtalk\_eco.html Repair file used with the do\_xform\_run\_repair\_file PKS command.
- xtalk\_noise\_html
- xtalk\_sens\_html
- celtic.tcl Tcl file containing the runtime commands to CeltIC. Specify this file in a later run using the -config option.

For information on what the files represent, see the <u>CeltIC User Guide</u>.

XMC produces the following files:

- xtalk.repair ASCII file containing the nets to be repaired due to crosstalk induced logic problem along with the method used for the repair. For example: ReduceNetC net1 0.5
- xtalk.rpt Output report file
- xtalk.err Crosstalk errors file

#### **Options and Arguments**

| -cdb <i>cdb_filename</i>  | Specifies a CeltIC-specific binary database file used for signal integrity (SI) analysis. The file, <i>cdb_filename</i> , is passed to wrap.celtic.pl.                                                                                                       |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | <b>Note:</b> Coupling files that are suffixed with .spf or .spef are automatically read in to CeltIC using the do_analyze_crosstalk command.                                                                                                                 |
| -config <i>configfile</i> | Specifies an optional configuration file for running CeltIC (or XMC). Recommended for advanced users only. Use this option to pass additional information or settings (CeltIC constraints) that CeltIC will take into account when doing crosstalk analysis. |
|                           | For information on CeltIC specific settings, see the <u>CeltIC User</u><br><u>Guide</u> .                                                                                                                                                                    |

| -coupling_file coupl | <pre>ing_file_list Specifies the input for CeltIC (or XMC) from HyperExtract. Required argument.</pre>                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | If you are using CeltIC, you can pass multiple coupling files in a<br>Tcl list. CeltIC can read cross-coupling information specified in<br>Standard Parasitic Format (SPF), Standard Parasitic Exchange<br>Format (SPEF), or HE-xcoup file format. The coupling files must<br>be in the same format. See <u>Examples</u> on page 829.                                                                                                                                          |
|                      | If you are using XMC, you cannot pass multiple coupling files.<br>XMC only accepts HE-xcoup file format, not SPF or SPEF.                                                                                                                                                                                                                                                                                                                                                      |
|                      | If the <i>coupling_file_list</i> contains files in SPF or SPEF<br>format, the do_analyze_crosstalk will read the<br><i>coupling_file_list</i> and take into account the RCs<br>specified in the file. When reading coupling files, coupling<br>capacitances will be treated as grounded capacitance.                                                                                                                                                                           |
| -dont_read_coupling_ | file                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -uont_reau_coupring_ | Does not read the file specified in the -coupling_file option.<br>Without this option, the do_analyze_crosstalk will read the<br>coupling_file_list. This option is useful when you want to<br>do timing analysis with parasitics being annotated before calling<br>the do_analyze_crosstalk command. In this case, you will<br>read the parasitics file, analyze the timing report, then use the<br>do_analyze_crosstalk command with the<br>-dont_read_coupling_file option. |
| -echo file_list      | Allows the do_analyze_crosstalk command to take ECHO or UDN files. The file names are passed to CeltIC.                                                                                                                                                                                                                                                                                                                                                                        |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| -engine xmc   celtic | Specifies the engine to use to compute crosstalk effects. Use xmc to specify the XMC engine. <i>Default</i> : celtic                                                                                                                                                                                                                                                                                                                                                           |
|                      | When using the celtic engine, CeltIC does not support the signal integrity (SI) analysis of two mixed corner-case timing libraries. For example:                                                                                                                                                                                                                                                                                                                               |

|                            | <pre>read_tlf -min \$rootDir/links/tsmc13_ff.tlf -max \$rootDir/links/tsmc13_ss.tlf -name tsmc13</pre>                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | CeltIC only supports the use of single corner-case timing libraries each time SI is performed.                                                                                                                                                                                                                                                                                                                                                                |
|                            | <b>Note:</b> Supply the proper license and executable for the crosstalk calculator you intend to use.                                                                                                                                                                                                                                                                                                                                                         |
| -exefile <i>exe_full_p</i> | athname<br>Specifies a non-default executable file using the complete path<br>name.<br>Default: The executable for XMC is <pre>xtalk_file</pre> and the<br>executable for CeltIC is <pre>wrap_celtic.pl</pre>                                                                                                                                                                                                                                                 |
| -exename <i>exe_filena</i> | me<br>Specifies a non-default executable file using only the file name.<br>CTE searches for the executable in your \$path.<br>Default: The executable for XMC is xtalk_file and the<br>executable for CeltIC is wrap_celtic.pl.                                                                                                                                                                                                                               |
| -keep_incsdf               | Preserves the incremental SDF file that is generated by CeltIC.                                                                                                                                                                                                                                                                                                                                                                                               |
| -no_timing                 | Prevents Celtic from doing incremental delay analysis so it will<br>not generate incremental SDF. If specified, Celtic completes<br>noise and glitch analysis.                                                                                                                                                                                                                                                                                                |
| -outprefix <i>prefix</i>   | Specifies a prefix for the output files. The default prefix of xtalk names the files as shown in <u>Output Files</u> on page 824. This is useful when you want to do multiple crosstalk analysis runs using different sets of data. For example, the results of the first run could have a prefix of xtalk1, and second run results a prefix of xtalk2. You can specify a directory name in the prefix, for example: /net/projects/mydesign/analysis1/xtalk1. |
| -spef \$path/parasiti      | cs.spef<br>Provides an alternative to using the read_spef command<br>before the do_analyze_crosstalk command. Reading net                                                                                                                                                                                                                                                                                                                                     |

|                       | parasitics data is a requirement before crosstalk analysis can be done.                                                                                                                                                                                                                            |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | <b>Note:</b> If the SPEF file contains cross-coupling information, you must pass the file to CeltIC using the <code>-coupling_file</code> option. Files that are passed to PKS using <code>-spef</code> option are not automatically passed to CeltIC unless they have suffix <code>.spef</code> . |
|                       | Timing windows produced for CeltIC crosstalk analysis are effected by the parasitics file. The tool treats cross-coupling capacitance in a parasitics file as grounded capacitance.                                                                                                                |
| -spf \$path/parasitic | s.spf<br>Provides an alternative to issuing the read_spf command<br>before the do_crosstalk_analysis command. Reading net<br>parasitics data is a requirement before crosstalk analysis can be<br>done.                                                                                            |
|                       | <b>Note:</b> If the SPF file contains cross-coupling information, pass the file to CeltIC using the <code>-coupling_file</code> option. Files that are passed to PKS using the <code>-spf</code> option are not automatically passed to CeltIC unless they have suffix <code>.spf</code> .         |
|                       | Timing windows produced for CeltIC crosstalk analysis are effected by the parasitics file. The tool treats cross-coupling capacitance in a parasitics file as grounded capacitance.                                                                                                                |
| -text                 | Specifies that output files are to be written out as text rather than HTML.                                                                                                                                                                                                                        |
| -twf_based net   pin  | Lets you choose between pin-based timing windows or net-based timing windows when running crosstalk analysis. <i>Default</i> : net                                                                                                                                                                 |
| -which                | Gives a message indicating which exe file is executed. This option is useful because do_analyze_crosstalk tries to find the executable in several different paths.                                                                                                                                 |

#### Examples

■ The following command shows the usage if the parasitics file has not been previously read by read\_spf:

do\_analyze\_crosstalk -coupling\_file routed.xcoup -spf routed.rspf

■ The following command shows how to use multiple SPEF files with CeltIC.

do\_analyze\_crosstalk -spef {parasit1.spef parasit2.spef} -coupling xcoup.spef

PKS reads in parasit1.spef and parasit2.spef before it computes timing windows. Since the coupling file xcoup.spef is suffixed with .spef, PKS also reads this before producing timing windows. However, the only parasitics file that is passed to CeltIC is the coupling file, xcoup.spef.

The following command reads in all parasitics files before it computes timing windows. All parasitics files are passed files to CeltIC:

do\_analyze\_crosstalk -coupling "parasit1.spef parasit2.spef xcoup.spef"

#### **Related Information**

#### Synthesis Place and Route (SP&R) Flow Guide

<u>CeltIC User Guide</u>

# do\_cppr\_analysis

do\_cppr\_analysis [-slack\_limit slack\_limit] [-critical] [-early | -late]

Removes delay pessimism from paths that have a portion of the clock network in common.

Removes both clock networks as well as clock source pessimism. Common path pessimism removal (CPPR) is the process of computing delay adjustments through a clock network and at clock source to remove the pessimism introduced at various checks. All timing checks compare a latest arriving signal against an earliest arriving signal. If both signals share a portion of the clock network, then a pessimism equal to the difference in late and early arrival times at nearest common pin, is introduced.

The results of this command are reflected in the reports generated by the report\_timing command.

For more information, see <u>Removing Common Path Pessimism</u>" in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

**Note:** Currently only simple clock trees are supported. If there are any parallel buffers or clock muxes, CPPR calculation stops with an error message.

### **Options and Arguments**

| -critical                  |                                                                                                                                                                                                                                   |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Stops the common path pessimism removal process at each<br>endpoint, as soon as the most critical path to that endpoint has<br>its pessimism removed. Use this option as an efficiency measure<br>to reduce CPU and memory usage. |
| -early   -late             | Specifies pessimism removal from either early or late data paths.                                                                                                                                                                 |
|                            | <i>Default</i> : The command removes pessimism from both early and late paths.                                                                                                                                                    |
| -slack_limit <i>slac</i> / | c limit                                                                                                                                                                                                                           |
| —                          | Removes clock pessimism only from paths whose slack is worse<br>than the specified slack limit. Use this option as an efficiency                                                                                                  |

measure to reduce CPU and memory usage.

### Example

The following command removes clock pessimism from paths whose slack is worse than the 3.2:

do\_cppr\_analysis -slack\_limit 3.2

#### **Related Information**

set global pvt\_early\_path

<u>set global pvt late path</u>

set operating conditions

### do\_derive\_context

do\_derive\_context [list\_of\_instances]

Builds the characteristics of the design from its environment constraints. A context-based optimization approach requires that constraints for lower level modules be derived from the higher level modules. This is one of the fundamental capabilities for performing top-down hierarchical synthesis. The constraints set at the top level of the design are pushed down the hierarchy so that each of the lower level modules are optimized using the correct set of constraints. Later, as the higher level modules are grouped together, the optimized modules are all connected correctly with respect to each other.



Use either the do\_time\_budget or do\_derive\_context command in CTE. For PKS, use the do\_push command instead. Budgeted constraints cannot be used in a third party tool.

The do\_derive\_context command derives the worst condition for modules among all the instances specified in the list of instances in a similar manner to that performed by the time budgeting procedure.

The context is derived by extracting three types of constraints from the surrounding environment of the instances in the instance list. The name of the instances can be hierarchical and are related to the current module:

■ Interface timing constraints

Includes timing information about clock definitions, arrival time on input ports, required time on output ports, and identification of multicycle and false paths.

Electrical constraints

Includes port capacitance and resistance, number of drivers, and load for every port of every instance.

■ Logic value constraints

Includes the logic constants that block timing analysis.

**Note:** The derived context information is stored in the database. Use the <u>write assertions</u> command to store the constraints in a file.

#### **Options and Arguments**

list\_of\_instances

Specifies the list of instance names for which the context is derived. The instance name can be specified by a hierarchical path name.

The instance name is relative to the current module.

If the instance list is not provided, the default is the current module.

The current module must be unique in the context of the top timing module. If not, run the do\_uniquely\_instantiate command.

#### Examples

```
do_derive_context [find -inst *]
do_derive_context blkA/xbar
```

### **Related Information**

See "<u>Using the do\_derive\_context Command with Backannotated Timing and RC</u> <u>Information</u>" in the Cadence Common Timing Engine (CTE) User Guide for information on how to buid the characteristics of the design from its environment constraints.

<u>do\_optimize</u>

<u>do uniquely instantiate</u>

do time budget

<u>write\_assertions</u>

# do\_extract\_model

```
do_extract_model [-lib_name lib_name] [-cell_name cell_name]
    [-clock_slews {clk_slew1 clk_slew2 ...}]
    [-input_slews {input_slew1 input_slew2 ...}]
    [-output_loads {output_load1 output_load2 ...}]
    [-precision integer] [-resolution float] [-tolerance float]
    [-unroll_loops] [-no_insertion_delay]
    [-keep_trigger_arcs] [-force] [-power] [-blackbox] [-blackbox_2d]
    [-verilog_shell_file filename]
    [-verilog_shell_module top_module_name] [-remove_boundard_parasitics]
    [-max_num_slews integer] [-max_num_loads integer] tlf_filename
```

Builds a Timing Library Format (TLF) model (*tlf\_filename*) and Liberty (.lib) format for the block specified by the set\_top\_timing\_module and set\_current\_module commands.

The model is extracted for the given input vectors, PVT conditions, input slews and load capacitance. If any one of these parameters change, then you must extract the model again.

- Tip

For model extraction, your design must be properly constrained. For example, no clock or data conflicts can be present. It is a good idea to use the <u>check timing</u> command and fix all errors prior to model extraction.

For information about the use model, the limitations, and example TLF and .lib output, see <u>Extracting the Timing Model</u> and <u>Writing Extracted Timing Models in Liberty Format</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

**Note:** After binding a model to an instance, use the <code>-check\_clocks</code> option with the <code>report\_timing</code> command to produce the same timing violations as the original netlist. The reason is that the model extractor moves timing checks associated with sequential elements to timing checks at port pins, usually clock pins. The <code>report\_timing</code> command <code>\_check\_clocks</code> option considers clock paths that end at the reference end of a timing check, as well as the paths that end at the signal end.

### **Options and Arguments**

-blackbox

Produces a TLF file for a black box model. These models can be used by tools that do not understand internal pins. Use black box models primarily in IP characterization, not in a top-down hierarchical design.

|                               | For more information, see <u>"Producing Blackbox Models"</u> in<br>Timing Analysis for BuildGates Synthesis and Cadence<br>Physically Knowledgeable Synthesis (PKS).                                                                                                                  |
|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -blackbox_2d                  | Transforms three dimensional tables to two dimensional tables<br>by fixing the capacitance at the secondary output to the current<br>value. This is necessary if extracted models are used by tools<br>that do not support three dimensional tables such as First<br>Encounter®.      |
| -cell_name <i>cell_nam</i>    | e<br>Specifies the cell name used in the TLF model.<br><i>Default</i> : The name of the module to be extracted.                                                                                                                                                                       |
| -clock_slews { <i>clk_s</i> . | <pre>lew1 clk_slew2} Specifies a range of slew values used at all clock pins. The list of values must be enclosed by curly braces. If this option is not specified, appropriate values are computed automatically by the model extractor.</pre>                                       |
| -force                        | Forces, for black box models, the model extraction to continue<br>even though the model extractor has detected assertions on<br>internal pins or hierarchical pins. Such assertions will not be<br>preserved on the model.                                                            |
|                               | For gray box models, the -force option, when used with the option -keep_trigger_arcs, forces the model extractor to preserve all clock and data signal conflicts that arise, because data signals arrive at pins where clock signals are expected. See the -keep_trigger_arcs option. |
|                               | <b>Note:</b> Do not use the -force option for gray box models unless the model extractor issues a warning message regarding too many data signals arriving at control input pins.                                                                                                     |
| - Tip                         |                                                                                                                                                                                                                                                                                       |

Instead of using the -force option, define the clocks properly prior to model extraction such that data and clock conflicts are minimized.

| -input_slews { <i>input</i> _ | <pre>_slew1 input_slew2} Specifies a range of slew values used at all input pins. Enclose the list of values with curly braces. If this option is not specified, appropriate values are computed automatically by the model extractor.</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -keep_trigger_arcs            | Models clock and data signal conflicts by preserving trigger arcs (arcs from clock pin to register or latch output pin) that arise because a data signal arrives at a pin where a clock signal is expected. This option only works for gray box models. For black box models, this option is ignored with a warning. This option is useful for characterizing incompletely constrained designs where clock definitions are incomplete or missing. Clocks can be defined after model extraction and this will yield timing results as if the clocks had been defined prior to model extractor expects clock definitions to be complete and removes relevant trigger arcs and timing checks if clock and data signal conflicts occur. This prevents data signals from propagating to clock paths. The drawback of this option is that the model size may increase significantly for a large number of clock and data conflicts. The model extractor will abort if the model size is expected to increase beyond a certain limit. Use the $-force$ option to force the model size. |
| -lib_name <i>lib_name</i>     | Specifies the library name used in the TLF model.<br>Write extracted timing models in the liberty format by specifying<br>the .lib file suffix. If you do not specify the file suffix, by default,<br>timing models are written out in the TLF format. See <u>Writing</u><br><u>Extracted Timing Models in Liberty Format</u> for details.<br><i>Default</i> : The name of the module to be extracted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| -max_num_loads integ          | Specifies the maximum number of output load values used for<br>delay arc characterization. A low value of 1 or 2 improves<br>runtime and memory usage but may significantly degrade model<br>accuracy. Use this option only if the model size or model<br>extraction time is critical.<br><i>Default</i> : 64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| -max_num_slews integ         | ger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              | Specifies the maximum number of input slews or clock slews<br>used for delay and check arc characterization. Specifying a low<br>value of 1 or 2 improves runtime and memory but may<br>significantly degrade model accuracy. Using the<br>-max_num_slews option has a larger impact on runtime and<br>memory than the -max_num_loads option. Use this option only<br>if the model size or the model extraction time is critical.<br><i>Default</i> : 64                                                            |
|                              | <b>Note</b> : The max slew and max loads options specify only the maximum limits on how many slew and load points are chosen. The tool will look at the gates connected to the input and output ports to come up with the number of points.                                                                                                                                                                                                                                                                         |
| -no_insertion_delay          | Suppresses writing insertion delays in the output TLF file.<br>Insertion delays characterize the embedded clock tree and are<br>used by clock tree generator. The model extractor determines<br>insertion delay by tracing combinational paths back to clock<br>source pins from register clock pins and latch enable pins. Using<br>the -no_insertion_delay option saves run time, but results<br>in a model without clock tree characterization.<br><i>Default</i> : The insertion delays are written out to TLF. |
| -output_loads { <i>outpu</i> | <pre>ut_load1 output_load2} Specifies a range of load values used at all output pins. Enclose the list of values by curly braces. If this option is not specified, appropriate values are computed automatically by the model extractor.</pre>                                                                                                                                                                                                                                                                      |
| -power                       | Produces a TLF file that includes a power model (see <u>Examples</u> on page 839). Low-Power Synthesis (LPS) provides a constant power number as the model for power analysis in the SE-PKS flow.                                                                                                                                                                                                                                                                                                                   |
|                              | This option requires the LPS feature.<br><i>Default</i> : No power model is included in the output.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| -precision <i>integer</i>    | Specifies the floating point precision used for the TLF model <i>Default</i> : 4                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Precision | Data Value in TLF |
|-----------|-------------------|
| 4         | 3.0089            |
| 3         | 3.009             |
| 2         | 3.01              |
| 1         | 3.0               |

For example, the floating point precision for 3.0089 can be changed as follows:

#### -remove\_boundary\_parasitics

|                          | Changes output port capacitances by removing the parasitic resistance (R_s and R_pi) at output port boundaries and asserting C1 and C2 as wire caps. A new set of external loads are then applied to characterize delays at output ports. The model extractor takes into account the possible change in external loading at the expense of losing RC net delay at boundary nets. See Figure 2-6: Time-Varying Thevenin-Equivalent Gate Delay Model in Common Timing Engine (CTE) User Guide. |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Useful when reduced parasitics data (RSPF) is present. Since<br>parasitics are reduced for only one set of output port<br>capacitances, the extracted model is valid only for the<br>capacitance values for which the reduction was done.                                                                                                                                                                                                                                                    |
|                          | <b>Note:</b> The boundary parasitics will not be restored after model extraction. This option is not needed for detailed parasitics data (DSPF), since a reduction is performed automatically for each new external output port capacitance.                                                                                                                                                                                                                                                 |
| -resolution <i>float</i> | Specifies the magnitude of delay difference in user units that can be ignored by the extractor. <i>Default</i> : 0.001                                                                                                                                                                                                                                                                                                                                                                       |
| tlf_filename             | Specifies the name of the TLF output file.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



Avoid problems with rebind by using the <code>-lib\_name</code> and <code>-cell\_name</code> options instead of using the default names.

-tolerance *float* 

Specifies the accuracy level of extractor in percent. For example, 5.0 represents a plus or a minus 5.0 percent allowable error in the extracted model. The higher the tolerance, the faster the extraction time. *Default*: 1.0

-unroll\_loops

Unrolls, for gray box models, self-loop setup/hold timing checks or direct clock-to-clock constraints by introducing dummy internal pins and zero-delay arcs. This is useful for timing analysis tools that do not understand self-loop constraints. For CTE, use the report\_timing -check\_clocks command to see violations associated with self-loop checks or direct clock-to-clock constraints.

This option is ignored if used with the -blackbox option because black box models have no internal pins.

```
-verilog_shell_file filename
```

Instructs the model extractor to generate a Verilog shell file that instantiates the TLF model. This option is useful for validating the model. Use the -verilog\_shell\_module option to specify the name of the top module in this Verilog file.

-verilog\_shell\_module top\_module\_name

Specifies the top module name of the Verilog shell file. *Default*: test\_shell

# Examples

■ The following command builds a TLF model (*tlf\_filename*) for the block:

do\_extract\_model min\_max.tlf

■ The following commands show a flow for generating the power model for instance foo, module foo\_m:

```
read_tlf lib.tlf
read_verilog netlist.v
```

```
do build generic
set_top_timing_module top
set_current_module top
source assertions
read_tcf netlist.tcf
do_derive_context foo
set top timing module foo m
set_current_module foo_m
do_extract_model -power -lib_name new.lib -cell_name new_cell
set_top_timing_module top
set_current_module top
read_tlf model.tlf
```

The following shows what the resulting TLF looks like (model contents deleted): 

```
Cell(new_cell
  Timing_Model(Model0
    . . .
  )
  Timing_Model(Model1
  )
  Cell_SPower(0.000732)
```

The following command creates the timing model for the test model cell belonging to the test\_lib library, and writes the model into the test.lib liberty file:

do\_extract\_model -cell\_name test\_model -library\_name test\_lib test.lib

If you do not specify the file suffix, by default, timing models are written out in the TLF format.

### **Related Information**

do derive context

do pull

)

do push

do\_rebind

do time budget

read tlf

set\_current\_module

set top timing module

# do\_signalstorm

```
do_signalstorm { -process process_name | -setup setupfile}
    { -dspf dspffile | -spef speffile | -parasitics parasiticsfile }
    [ -lib ecsm_library] [-include filelist] [-user_inlude_only]
    [-max_slew max_slew_limit] [-outprefix outprefix]
```

Lets you run SignalStorm<sup>TM</sup> for accurate delay calculation on gate and interconnect segments. The do\_signalstorm command takes your input and creates the default constraint and setup files necessary to run the SignalStorm tool.

**Note:** The do\_signalstorm command is a utility that runs the SignalStorm software with the necessary input files to generate an SDF file. This file is back-annotated to the BG/PKS run after it is generated. For information on how to use the utility or the input files needed to generate the SDF file, use the do\_signalstorm -help command after you load a design. Make sure the SignalStorm hierarchy and license file are present, the SIMPLEX ENV variables are set, and that signalstorm is part of the PATH ENV variable as follows:

```
SIMPLEX_HOME
SIMPLEX_VERSION
set path = (<path to bin directory of signalstorm> $path)
```

### **Options and Arguments**

| -dspf <i>dspffile</i>   -s | Spef speffile   -parasitics parasiticsfile<br>Specifies only one parasitic file, which covers the whole design.<br>The parasitic file can either be in dspf format, spef format, or a<br>compressed .gz file of either format. The do_signalstorm<br>command errors out if you specify more than one parasitics file. |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Use the -parasitics option if you prefer to let the do_signalstorm command detect the parasitics file and decide whether it is a spef or a dspf file.                                                                                                                                                                 |
| -include filelist          | Specifies a list of files to be included in the SignalStorm run.<br>Unless the -user_include_only option is used, the specified<br>files are included, in addition to the default constraint information<br>that the do_signalstorm command generates. The default<br>constraint information includes the following:  |
|                            | <ul> <li>Load of all output ports in the design</li> <li>Slew of all input ports in the design stretched to a 0-100 percent threshold</li> <li>Timing constraints that effect propagation of slews</li> </ul>                                                                                                         |

|                            | This option is only for advanced users.                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -lib <i>ecsm_library</i>   | Specifies the path to the ECSM library. This is a required option.<br>For information on how to create a ECSM library, see the "ECSM<br>Library Database" section in the <i>SignalStorm Manual</i> .                                                                                                                                                                                         |
| -max_slew max_slew_        | <pre>limit Writes out a outprefix.slew file that contains nets having a slew greater than the specified max_slew_limit.</pre>                                                                                                                                                                                                                                                                |
| -outprefix <i>outprefi</i> | x<br>Specifies the outprefix file name. If you do not specify this option,<br>the default outprefix is derived from the top module name and the<br>processed module name ID. There are four main files that are<br>generated as a result of running the do_signalstorm<br>command:                                                                                                           |
|                            | outprefix.cmd: The command file that the do_signalstorm command generates and uses to run the SignalStorm tool.                                                                                                                                                                                                                                                                              |
|                            | outprefix.log: The log file that contains error and warning messages displayed during the SignalStorm run.                                                                                                                                                                                                                                                                                   |
|                            | outprefix.sdf: The SDF file that SignalStorm generates.<br>This file is automatically back-annotated.                                                                                                                                                                                                                                                                                        |
|                            | outprefix.slew: The file that lists any part of the design, which exceeds the slew time specified in the <code>-max_slew</code> option.                                                                                                                                                                                                                                                      |
| -process process_na        | me                                                                                                                                                                                                                                                                                                                                                                                           |
|                            | Specifies the process name that has been characterized and<br>saved in the ECSM library for computing delay, which refers to a<br>specific process, voltage, and temperature parameter for timing<br>analysis. For information on how to create an ECSM library from<br>a .lib library, see "Generating the Library Database from<br>Synopsys .lib Files" in the <i>SignalStorm Manual</i> . |
|                            | Make sure you specify the process name that is related to the timing analysis setting used in other commands, such as the <u>timing analysis type</u> and the <u>pvt late path</u> globals,                                                                                                                                                                                                  |

|                         | and the <u>set operating conditions</u> command where you specify the process, voltage, and temperature values.                                                                                                                                                                                                                                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | For example, if in CTE you set the following commands:<br>set_global pvt_late_path max<br>set_global pvt_early_path min<br>set_global timing_analysis_type min-max<br>set_operating_condition -pvt min fast<br>set_operating_condition -pvt max slow                                                                                            |
|                         | When running the do_signalstorm command as follows:<br>do_signalstorm -process min_process:max_process<br>-dspf test.dspf -lib /lib/dtmf_chip.ipdb                                                                                                                                                                                              |
|                         | The process name that you specify for min_process, should be<br>the process name that you use to characterize the library<br>dtmf_chip.ipdb with a fast operating condition.<br>Consequently, the max_process setting should be the process<br>name that you use to characterize the library dtmf_chip.ipdb<br>with a slow operating condition. |
|                         | Various process names at which the ECSM library has been characterized are found in the library directory: <i>cell.design/</i> analysis/process.                                                                                                                                                                                                |
|                         | The do_signalstorm command errors out if the process name<br>you specify cannot be found in the ECSM library. When you want<br>to specify more than one process, separate each process with a<br>colon. For example, -process min:typ:max.                                                                                                      |
| -setup <i>setupfile</i> | Looks at the setupfile and uses the process name defined in the<br>set process setup command, which consequently ignores the<br>-process option if specified. If there are multiple set process<br>commands specified in the setupfile, the do_signalstorm<br>command chooses the last one.                                                     |
| -user_include_only      | Prevents the do_signalstorm command from creating the default constraints. See the -include option description for an explanation of what the default constraints contain. If this option is specified, the do_signalstorm command uses the list of                                                                                             |

include files in the order you specify. This option is for advanced users.

### Examples

■ The following command uses the technology.ipdb library at a single pvt corner, which the process name max refers to. The design and its connectivity is described in the spef file chip.spef.gz:

```
do_signalstorm -process "max" -spef "chip.spef.gz" -lib
"technology.ipdb"
```

■ The following command includes the user include file. Since the -user\_include\_only option is specified, the do\_signalstorm command will not generate the default constraints. The user include file captures information, such as slew and load at input and output ports in the design, as well as timing constraints that may effect the slew propagation.

```
do_signalstorm -process "max" -spef "chip.spef.gz" -lib "technology.ipdb"
-include "signalstorm.constraints" -user_include_only
```

■ The following command shows how to create your own setup file. The setup file must contain the "set process" setup command, which the do\_signalstorm command uses to decide which process name the delay needs to be computed.

do\_signalstorm -setup "top.setup" -spef "chip.spef.gz" -lib "technology.ipdb"

■ The following command shows how to run the do\_signalstorm command at multiple process names. The description of the -process option, shown in the above example, explains how the process names you choose should correspond to the settings used in CTE.

do\_signalstorm -process "min:max" -spef "chip.spef.gz" -lib "technology.ipdb"

# do\_time\_budget

do\_time\_budget [-top list\_of\_top\_instances] | [list\_of\_instances]

Generates realistic time estimates for the modules specified in the instance list. Time budgeting is the process of splitting the combinational delay requirements across module boundaries to allocate slack across all modules in a fair manner. The segments of paths entirely contained in the instance list are considered to be changeable, while all other paths are considered to be fixed.

Use either the do\_time\_budget or the do\_derive\_context command in CTE. For PKS, use the do\_push command instead. Budgeted constraints cannot be used in a third party tool.

Note: The following two paragraphs apply to PKS users only.

The do\_time\_budget command comes up with assertions to use for a block, assuming the block is run using wireloads. The PKS do\_push command, on the other hand, works around soft blocks. The PKS do\_push command does the budgeting assuming the block timing is completed using the physical information that is pushed (by default). The do\_time\_budget and do\_derive\_context commands do not push physical information to the budgeted block and therefore, will not capture your intent in a PKS session.

The budgeting results are slightly different between the do\_time\_budget (or do\_derive\_context) and the do\_push commands. This is because of a delay correction that the do\_push command does on the boundary arrival and required times based on the capacitance and delay calculated in the lower context. The correction is done so that design constraints and physical design characteristics match to the top level context.

The do\_time\_budget command does the following:

- Writes assertions on the instances in the database. Use the <u>write assertions</u> or the <u>write adb</u> command to save the result of time budgeting.
- Finds the worst constraints for a module from all those available (if the module is used in many contexts under the top timing module).
- Accepts the dont\_modify flags on instances and modules in the computation of constraints.

The reference of the hierarchical instances starts from the current module as specified by the <u>set\_current\_module</u> command. The current module must be unique in the scope of the

top timing module as set by the <u>set top timing module</u> command. See <u>Setting the</u> <u>Current Module</u> in the *Common Timing Engine (CTE) User Guide* for more information.

Note: The time budgeting algorithm handles both positive and negative slacks.

A "changeable" path or block is one that can be modified during synthesis to meet timing constraints, whereas a "fixed" one cannot be modified. Normally, you specify as fixed, the hard macros or other blocks that you do not want the optimizer to touch. There are two ways to specify such fixed blocks:

- Use the dont\_modify switch for such instances.
- Use the -top option only for blocks that can be modified.

If you issue the command without any options, for example, do\_time\_budget, then all instances (except those having the dont\_modify switch) are assumed to be changeable. BuildGates Synthesis creates budgets for all the instances.

If you want to create the budgets only for specific modules, use the following command:

do\_time\_budget {inst1 inst2 ...}

**Note:** The above command still assumes that all the instances except those marked dont\_modify are changeable.

If you want only a specific instance (inst1) to be changeable and all others fixed, use the following command:

do\_time\_budget -top inst1

### **Options and Arguments**

list\_of\_instances

Specifies a list of instances for time budgeting. The instances in the *instance\_list* must all be hierarchical entities. If the *instance\_list* is not specified, then the default is to generate budgets for all instances within the current module. The time budget assumes that only the delay arcs (paths) entirely within the specified instances can be optimized. The others are considered to be fixed.

Depending on the number of instances in the current module, omitting the instance list can result in long run times.

-top list\_of\_top\_instances

Creates a top timing module from which to start the synthesis.

The listed instances are considered part of the top context. Only those sub-designs that exist under the list of top instances are synthesized. The time budget assumes that only the delay arcs (paths) within and between the specified top instances can be optimized. The others are considered to be fixed. *Default:* Assumes that everything under the top timing module can be changed. Use the dont\_modify option for instances and modules to overrides this.

### Examples

■ The following command performs time budgeting on the instances x1, x2, and x3 for the circuit shown in Figure 7-1, assuming that all delay arcs contained within these instances are changeable and all others are fixed. The paths p2, p4, and p6 are changeable and the others are treated as fixed. This is because the top contains only p2, p4, and p6, while p1, p3, p5 are outside the boundaries of the top context.

do\_time\_budget -top {X1 X2 X3}

■ The following command assumes only paths in and between x1 and x2 instances to be changeable and x3 to be fixed. As a result, the time budgeting algorithm derives a new set of constraints since only the paths p2 and p4 are changeable while the others are fixed.

do\_time\_budget -top {X1 X2}



### Figure 7-1 do\_time\_budget Example

### **Related Information**

do derive context

<u>do push</u>

- set\_current\_module
- set\_dont\_modify
- set top timing module

# do\_xform\_timing\_correction

```
do_xform_timing_correction [-footprint] [-resize] [-upsize_only] [-buffer]
    [-clone] [-dont_modify_children]
    [-design_rule_only | {-no_design_rule | -dont_fix_design_rule}]
    [-min_hold | -fix_hold] [-no_pinswap | -pinswap_only] [-fix_clock_net]
    [-max_area float] [-quick] [-incremental][-critical_ratio float]
    [-critical_offset float] [-dont_reclaim_area | -minimize_area]
    [-change_limit integer] [-change_file filename]
```

# Important

This command is obsolete and will be removed in the next full release of the software. Use the do\_optimize <code>-effort low</code> and do\_xform\_fix\_hold commands for comparable results.

# get\_capacitance\_unit

get\_capacitance\_unit

Returns the session capacitance unit in picoFarads.

### Example

The following command returns the session capacitance unit:

```
get_capacitance_unit
1.0
```

### **Related Information**

set capacitance unit

reset\_capacitance\_unit

# get\_cell\_drive

```
get_cell_drive [-library library_name] [-cell cell_name ]
    [-from_pin from_pin_name] [-from_pin_rise] [-from_pin_fall]
    [-rise] [-fall] [-early | -late] [-pin pin_name]
```

Returns the resistance value at the specified output port of a cell in the library. For a library having nonlinear delay models, the returned value is the resistance as seen at the specified output pin if the output pin were to drive the input pin having the worst capacitance of the same cell. (In other words, the resistance is linear at the point as if the cell is driving itself.)

The returned value is a real (floating point) number. The units of resistance are the same as the units used in the technology library.

*Default*: The worst resistance found in rising, falling, from-pin rising, from-pin falling, early and late modes is returned.

### **Options and Arguments**

| -cell <i>cell_name</i>  | Specifies the name of the cell whose output port is specified by                                      |
|-------------------------|-------------------------------------------------------------------------------------------------------|
|                         | the -pin option.                                                                                      |
| -early   -late          | Returns the resistance corresponding to early (data hold check)                                       |
|                         | or late (data setup check) modes only.                                                                |
| -fall                   |                                                                                                       |
|                         | Returns the resistance corresponding to falling edge only.                                            |
| -from_pin_fall          | Returns the resistance corresponding to the falling signal at the                                     |
|                         | from pin only.                                                                                        |
| -from_pin from_pin_name |                                                                                                       |
|                         | Specifies the input port name as the starting point of the path for which the resistance is returned. |
| -from_pin_rise          |                                                                                                       |
|                         | Returns the resistance corresponding to the rising signal at the from pin only.                       |
| -library library_name   |                                                                                                       |
|                         | Specifies the name of the library where the cell can be found. <i>Default</i> : The target library.   |
|                         |                                                                                                       |

| -pin <i>pin_name</i> | Specifies the name of the output port whose resistance is returned. If there is more than one path terminating at the <i>pin_name</i> , the largest resistance seen among all paths is returned. |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -rise                | Returns the resistance corresponding to rising edge only.                                                                                                                                        |
|                      |                                                                                                                                                                                                  |

### Examples

get\_cell\_drive -cell BUFA -from\_pin A -pin Z
1.920189
get\_cell\_drive -cell BUFA -from\_pin A -from\_pin\_fall -pin Z
1.368688

### **Related Information**

get cell pin load

set global target technology

# get\_cell\_pin\_load

get\_cell\_pin\_load [-library library\_name] [-cell cell\_name] [-pin pin\_name]

Returns the value of the capacitive load at the specified pin of a cell in the library. The returned value is a real (floating point) number. The units of the load are the same as the units used in the library.

### **Options and Arguments**

| -cell <i>cell_name</i>     | Specifies the name of the cell whose pin is specified by the $-\texttt{pin}$ option.                                          |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| -library <i>library_na</i> | me<br>Specifies the name of the library where the cell can be found.<br>Default: The target library is searched for the cell. |
| -pin <i>pin_name</i>       | Specifies the name of the pin whose capacitive load is returned.                                                              |

### Example

■ The following command returns the value of the capacitive load of pin z of cell IV in the library. See the <u>set cell pin load</u> command for the related library cell description used for these examples.

get\_cell\_pin\_load -cell IV -pin z

■ The following command gets the capacitance values for pin A:

```
get_cell_pin_load -library cell_load_example -cell AN2 -pin A
0.042000
```

■ The following command gets the capacitance values for pin B:

```
get_cell_pin_load -library cell_load_example -cell AN2 -pin B
0.041000
```

An error message is returned if you are getting values for a pin that is not defined for a cell.

### **Related Information**

get\_cell\_drive

<u>set\_cell\_pin\_load</u>

set global target technology

# get\_clock

get\_clock [clock\_name] [-period | -waveform | -lead | -trail]

Returns the information of clocks defined in the database through the set\_clock or the set\_generated\_clock command.

- Tip

If you want information about a generated clock, you must run CTE first. This is because the generated clock waveforms are created by timing analysis. Without timing analysis, the system cannot report the name of the generated clock.

See <u>Specifying Clock Information</u> in the Common Timing Engine (CTE User Guide.

### **Options and Arguments**

| clock_name |                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | Returns information for the specified clock.<br><i>Default</i> : A list of all currently defined clocks is returned and all<br>other command line options are ignored. |
| -lead      | Returns the leading edge of the specified clock.                                                                                                                       |
| -period    | Returns the period of the specified clock.                                                                                                                             |
| -trail     | Returns the trailing edge of the specified clock.                                                                                                                      |
| -waveform  | Returns the waveform of the specified clock in the form of {lead, trail}.                                                                                              |

#### Examples

■ The following commands define the clock named CLOCK:

set\_clock CLK -period 10.0 -wave {0 5}
set\_clock\_root -clock CLK pinX

■ The following command gets clock-related information for CLK: get\_clock -period CLK 10.00000

■ The following commands get the name of all the defined clocks:

```
get_clock
CLK
```

The following commands define a generated clock:

```
set_generated_clock -name my_clock -from pinX -divide_by 2 pinY
get_clock
CLK
```

■ The following commands report only the ideal clock because you have not performed timing analysis yet. Use the report\_timing command followed by the get\_clock command:

```
report_timing
# report deleted
get_clock
CLK my_clock
get_clock -period my_clock
20.000000
```

■ Using the report\_clocks command with the -generated option runs analysis and reports the same information that is available with the get\_clock command except in a different format. See Examples for the report\_clocks command report format.

#### **Related Information**

get clock source

<u>report\_clocks</u>

<u>set\_clock</u>

set generated clock

# get\_clock\_propagation

get\_clock\_propagation

Returns the value of the clock propagation mode, ideal or propagated, associated with the current top timing module.

**Note:** Because this command returns the clock propagation mode associated with a design, load a design before using this command.

If the get\_clock\_propagation command returns an ideal clock propagation mode, use the get\_propagated\_clock to determine the status of individual clocks.

See <u>Setting the Clock Propagation Mode for Analysis</u> in the Common Timing Engine (CTE) User Guide for more information.

### Example

The following command returns the value of the clock propagation mode:

get\_clock\_propagation
ideal

### **Related Information**

get propagated clock

reset propagated clock

set clock propagation

set\_propagated\_clock

### get\_clock\_source

get\_clock\_source [-port\_only] clock\_name

Returns the list of clock names (sources) for the defined clock using the  $clock_name$  argument in the database. Also returns pins where a generated clock has been asserted. Specify the clock sources through the set\_clock\_root and set\_generated\_clock commands.

### **Options and Arguments**

| clock_name | Returns the clock sources (input ports or instance output pins) set on the named clock. If this option is omitted, all clock sources specified in the current database are returned. |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -port_only | Returns only the clock sources that are input ports.                                                                                                                                 |

#### Examples

- The following command defines the clock CLK: set\_clock CLK -period 4 -waveform {0 2}
- The following command defines the clock source clk\_in: set\_clock\_root -clock CLK clk\_in
- The following command gets the clock source for clock CLK: get\_clock\_source CLK clk\_in

### **Related Information**

<u>get\_clock</u>

get derived clock

<u>set clock</u>

<u>set\_clock\_root</u>

# get\_constant\_for\_timing

get\_constant\_for\_timing [-bidi\_input | -bidi\_output] pin\_name

Queries the design database for the state of the specified pin or the state propagated through the combinational logic cone to that pin. The returned value is 0 for logic 0, 1 for logic 1, or x if no constant has been set.

**Note:** Constants on hierarchical ports are not computed.

See <u>Setting Constant Values for Timing</u> in the *Common Timing Engine (CTE) User Guide* for more information.



The get\_constant\_for\_timing command returns the state for one pin only. If you want to know the state on all pins that have a constant set, use the -type constant option with the report\_port command. For example: report\_port -type constant. Use the -tcl\_list option to process the list in Tcl.

### **Options and Arguments**

| bidi_input   -bidi_output                                                           |    |
|-------------------------------------------------------------------------------------|----|
| Returns the constant that is set on the input or output part on bidirectional pins. | of |
| Default: Returns the constant on the input part.                                    |    |
|                                                                                     |    |

pin\_name

Specifies the name of the single pin to query for pin state. The pin must be an instance pin or primary IO port.

### Examples

The following command sets the value of the specified pin(s) to either a 1 or 0 for use by the timing engine:

```
set_constant_for_timing 0 J_block/zbuf0/A
```

The following command queries the design database for the state of the specified pin or the state propagated through the combinational logic cone to that pin:

```
get_constant_for_timing J_block/zbuf0/A
```

#### **Related Information**

<u>report ports</u>

reset constant for timing

set\_constant\_for\_timing

# get\_dcl\_calculation\_mode

get\_dcl\_calculation\_mode

Returns the current DCL calculation mode.

Calculation modes defined in the DCL library allow the vendor library developer to model three process conditions (best\_case, nominal\_case, and worst\_case) within one library. Choose the mode with the <u>set\_dcl\_calculation\_mode</u> command.

**Note:** Temperature, process multiplier, and voltage are set independently of the calculation mode using the <u>set operating parameter</u> command.

#### Example

The following command returns the current DCL calculation mode:

get\_dcl\_calculation\_mode
worst\_case

#### **Related Information**

get operating parameter

<u>load dcl rule</u>

set\_dcl\_calculation\_mode

set operating parameter

# get\_dcl\_functional\_mode

get\_dcl\_functional\_mode instance

Returns the current DCL functional mode on the specified hierarchical instance. The value returned is a Tcl list where the current functional mode group for the instance is the first element in the list, and the current functional mode value is the second element in the list.

Functional modes defined in a DCL library let the library developer model the timing arcs and timing checks for a technology cell in a variety of ways. For instance, a scan flip-flop could have functional modes defined for normal flip-flop behavior and for scan behavior where, for each mode, different timing arcs and checks are defined.

See <u>Using IEEE 1481 Delay and Power Calculation System (DPCS) Libraries</u> in the *Common Timing Engine (CTE) User Guide* for more information.

#### **Options and Arguments**

instance

Specifies the hierarchical instance for which the DCL functional mode needs to be obtained.

### Example

The following command shows that the current functional mode group for instance A1/B3/ C2 is latch\_type and the value is transparent:

get\_dcl\_functional\_mode A1/B3/C2
{latch\_type transparent}

### **Related Information**

get\_dcl\_functional\_mode\_array

<u>load dcl rule</u>

set dcl functional mode

# get\_dcl\_functional\_mode\_array

get\_dcl\_functional\_mode\_array [-cell cellname]

Returns the DCL functional mode array on the specified library cell. This array lists all of the functional modes available for the library cell by group. The array is returned as a hierarchical Tcl list.

Functional modes defined in a DCL library let the vendor library developer model the timing arcs and timing checks for a technology cell in a variety of ways. For instance, a scan flip-flop could have functional modes defined for normal flip-flop behavior and for scan behavior where, for each mode, different timing arcs and checks are defined.

### **Options and Arguments**

```
-cell cellname
```

Specifies the library cell for which the DCL functional mode array needs to be obtained.

### Example

The following command returns the DCL functional mode array on the specified library cell:

```
get_dcl_functional_mode_array -cell ram_8_8
```

```
{rw { read write}} {latch_type {latching transparent}}
```

### **Related Information**

<u>load dcl rule</u>

set dcl functional mode

# get\_dcl\_level

get\_dcl\_level [-perfLevel]

Returns the current performance level used in DCL based delay and slew calculations.

DCL supports two performance levels for delay calculation. One performance level targets faster run time with less accurate timing, while the other targets more accurate timing with slower run time.

Refer to the DCM library vendor documentation for information about the characteristics of each performance level in their library and whether or not they are both supported. Use the faster performance in terms of run time for initial synthesis. For final timing correction, use the more accurate level.

#### **Options and Arguments**

-perfLevel

Returns the current performance level.

**Note:** The DCL standard contains other types of levels which, if supported in the future, are accessible via other arguments. These other types include temperatureScope, voltageScope, functionalModeScope, and wireloadModelScope.

#### Example

The following command returns the current performance level used in DCL based delay and slew calculations:

```
get_dcl_level -perfLevel
1
```

### **Related Information**

<u>load dcl rule</u>

<u>set\_dcl\_level</u>

# get\_derived\_clock

get\_derived\_clock [-full\_path\_name] [instance\_path\_or\_id]

Reports the derived clock sources for all sequential instances or for the specified instance.

**Note:** This command is not related to the set\_derived\_clock command.

The derived clocks are found by traversing backwards from the clock pin of sequential instances until reaching an output of a non-single-input-single-output combinational instance, or a sequential output (divided clock, for example), or a primary input port.

**Note:** If the clock: true attribute is not present in the library, the input pin on a RAM/ROM with setup/hold timing check is also treated as clock pin.

# **Options and Arguments**

-full\_path\_name

Returns a list of full path names for derived clocks. If this option is not specified, pin object identifiers are returned.

instance\_path\_or\_id

Specifies a sequential instance by path or object identifier. If no *instance\_path\_or\_id* is specified, derived clocks for all sequential instances (ff and latch) are reported.

# Example

The following command reports the derived clock sources for all sequential instances or for the specified instance:

```
get_derived_clock -full_path_name
TCLK3
COREP_P2/BEP_P2/I14P/Q
COREP_P2/BEP_P2/I25P/Q
CS
```

# **Related Information**

set clock info change

# get\_drive\_pin

get\_drive\_pin [-hierarchical] [-full\_path\_name] net\_path\_or\_id

Returns a list of drive pins that drive a given net within the current module.

**Note:** For multiple driver situations, the get\_drive\_pin command returns a list of pin identifiers.

# **Options and Arguments**

| -full_path_name | Returns the full path name for the drive pin, rather than the pin object identifier. <i>Default</i> : Object identifiers are returned. |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------|
| -hierarchical   | Enables traversal across a hierarchy if the given net crosses a hierarchy boundary.                                                    |
| net_path_or_id  | Specifies the net for which you want to know the driver pin.<br>Specify the net by the full path name or the object ID.                |

# Example

The following command shows how to get names for the circuit shown in Figure 7-2:

```
get_names [get_drive_pin [find -net w00]]
out
get_drive_pin -full_path_name w00
I block/out
```

# Figure 7-2 get\_drive\_pin Example

I\_block J\_block

# **Related Information**

<u>get\_load\_pin</u>

# get\_fanin

```
get_fanin [-level integer] [-tristate] [-sequential] [-hierarchical]
      [-full_path_name] list_of_pin_path_or_id
```

Returns a Tcl list of all begin points (output pins and input ports) in the fanin cone.

Use the  $\mbox{-tristate}$  and  $\mbox{-sequential}$  options for finer control of the gate type to be included in the fanin cone.

The command can take a hierarchical path name as well as a pin object identifier. Specifying a hierarchical name is useful when a module is not uniquely instantiated.

# **Options and Arguments**

| -full_path_name    | Returns the hierarchical path name for the starting points, starting from the current module. <i>Default</i> : Pin object identifiers are returned. |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| -hierarchical      | Lets you search cross hierarchy boundaries.<br><i>Default</i> : Search stops at input ports and returns the port as the starting point.             |
| -level integer     | Limits the search to the number of logic levels specified.                                                                                          |
| list_of_pin_path_o | r_id<br>Starts the fanin cone search from the specified Tcl list of pins or<br>ports specified by path names or object identifiers.                 |
| -sequential        | Includes sequential cells in the fanin path. <i>Default</i> : Sequential cells are excluded.                                                        |
| -tristate          | Includes tristate cells in the fanin path. <i>Default</i> : Tristates are excluded.                                                                 |

# Examples

The following command returns a Tcl list of all begin points (output pins and input ports) in the fanin cone:

```
get_fanin -hierarchical -full_path_name out*
J_block/C_reg/Q J_block/D_reg/Q
```

■ The following Tcl script iterates over all the begin points of the fanin cone of net req:

```
foreach i [get_fanin [find -net req]] {
puts "Found fanin [get_names $i]"
}
```

#### **Related Information**

get fanout

<u>do\_extract\_fanin</u>

# get\_fanout

```
get_fanout [-level integer] [-tristate] [-sequential] [-hierarchical]
        [-full_path_name] list_of_pin_path_or_id
```

Returns a Tcl list of all endpoints (input pins and output ports) in the fanout cone.

The  $\mbox{-tristate}$  and  $\mbox{-sequential}$  options give you finer control of the gate type to be included in the fanout cone.

The command can take a hierarchical path name as well as pin object identifier. Specifying a hierarchical name is useful when a module is not uniquely instantiated.

#### **Options and Arguments**

| -full_path_name    | Returns the hierarchical path name for the starting points, starting from the current module. <i>Default</i> : The pin object identifiers are returned. |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| -hierarchical      | Searches cross hierarchy boundaries.<br><i>Default</i> : Search stops at output ports and returns the port as the ending point.                         |
| -level integer     | Limits the search to the number of logic levels specified.                                                                                              |
| list_of_pin_path_o | r_id<br>Starts the fanout cone search from the specified Tcl list of pins<br>or ports specified by path names or object identifiers.                    |
| -sequential        | Includes sequential cells in the fanout path. <i>Default</i> : Sequential cells are excluded.                                                           |
| -tristate          | Includes tristate cells in the fanout path. <i>Default</i> : Tristates are excluded.                                                                    |

# Examples

■ The following command returns the names of endpoints of the fanout cone of any ports whose names begin with characters in:

```
get_fanout -full_path_name [find -port in*]
```

■ The following Tcl script Iterates over all the endpoints of the fanout cone of net req:

```
foreach i [get_fanout [find -net req]] {
    puts "Found fanout[get_names $i]"
}
```

#### **Related Information**

<u>get\_fanin</u>

- do extract fanin
- do extract\_fanout

# get\_flow\_compatible\_mode

get\_flow\_compatible\_mode

Returns the constraint interpretation mode, CTE or Synopsys PrimeTime style, for timing analysis.

# **Related Information**

set flow compatible mode

# get\_load\_pin

get\_load\_pin [-hierarchical] [-full\_path\_name] net\_path\_or\_id

Returns a list of load (sink) pins for the given net within the current module and in the sub-modules.

**Note:** For multiple load situations the get\_load\_pin command returns a list of pin identifiers.

# **Options and Arguments**

| -full_path_name | Returns a list of full path names of load (sink) pins. <i>Default</i> : The object identifiers are returned.          |
|-----------------|-----------------------------------------------------------------------------------------------------------------------|
| -hierarchical   | Traverses the design hierarchy when the given net connects to an output port.                                         |
| net_path_or_id  | Specifies the net for which you want to know the load pin. Specify the net using the full path name or the object ID. |

# Examples

The following command returns a list of load (sink) pins for the given net within the current module and in the sub-modules as shown in Figure 7-3.

```
get_load_pin -full_path_name [find -net out]
out
```

If you do not use the-hierarchical option, only the sink pins of the net in the current module are listed as IDs.

Use the -full\_path\_name option to list the ID names.

Use the -hierarchical option to list the sink pins in the sub-modules and the sink pins of the instances this net connects to.





module l\_block (out, in, clka, clkb); input clka, clkb, in; output out; FD1 A\_reg(.Q(w01), .CP(clka), .D(in)); FD1 B\_reg(.Q(w02), .CP(clkb), .D(in)); BUF8A abuf (.Z(PA), .A(w01)); BUF8A bbuf (.Z(PB), .A(w02)); AN2 u000 (.Z(out), .A(PA), .B(PB)); endmodule

module J\_block (out, in, clkc, clkd); input clkc, clkd, in; output out; IV iC(.Z(inC), .A(in)); BUF8A cbuf (.Z(PC), .A(inC)); IV iD(.Z(inD), .A(in)); FD1 A\_reg(.Q(w03), .CP(clkc), .D(PC)); FD1 B\_reg(.Q(w04), .CP(clkd), .D(PD)); BUF8A dbuf0 (.Z(w041), .A(inD)); BUF8A dbuf2 (.Z(w042), .A(w041)); BUF8A dbuf2 (.Z(W03prime), .A(w03)); BUF8A zbuf0 (.Z(PD), .A(w03prime)); AN2 u000 (.Z(out), .A(Z), .B(w04)); endmodule

- The following commands show how to get the load pin for the current module and sub-modules shown in Figure 7-3:
  - □ get\_load\_pin -hier in 74006 73878
  - get\_load\_pin -full in
     I\_block/in
  - get\_load\_pin -hier -full in I\_block/B\_reg/D I\_block/A\_reg/D
  - □ get\_load\_pin -hier w00 74614 74486
  - get\_load\_pin -full w00
    J\_block/in
  - get\_load\_pin -hier -full w00
    J\_block/iD/A J\_block/iC/A

- get\_load\_pin -full J\_block/w041
  J\_block/dbuf2/A
- get\_load\_pin -full J\_block/w042
  J\_block/dbuf/A

# **Related Information**

<u>get\_drive\_pin</u>

get\_fanout

<u>get\_fanin</u>

# get\_module\_worst\_slack

get\_module\_worst\_slack [-clknet\_too] [-early | -late]

Returns the worst slack time for the module and all of its children. The module that is set as the current module is searched for the worst slack time on its paths.

If there are negative slack paths in the module, the returned value is the most negative value. If there are no negative slack paths in the module, the returned value is the least positive slack value.

#### **Options and Arguments**

| -clknet_too    |                                                                                                                                                                                                                                                                               |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | Includes clock nets while searching for the worst slack time on all<br>paths in the module. By default, slack time on clock nets is not<br>considered. For clock pins the late arrival is determined by the<br>hold time check and the early arrival by the setup time check. |
|                | Note: If the global variable                                                                                                                                                                                                                                                  |
|                | clock_gating_regardless_of_downstream_logic is<br>set to true, the results from using the<br>get_module_worst_slack command without the<br>-clknet_too option may not match the slack numbers from<br>using the report_timing command without the<br>-check_clocks option.    |
| -early   -late |                                                                                                                                                                                                                                                                               |
|                | Indicates whether the worst slack time should be considered on<br>early arrivals (data hold) or late arrivals (data setup) of signals. If<br>neither option is specified, the default is to obtain worst slack<br>time for late arrivals on signals.                          |

#### Example

get\_module\_worst\_slack -early

#### **Related Information**

<u>set current module</u>

# get\_operating\_conditions

get\_operating\_conditions [-pvt {min | typ | max}]

Returns the operating conditions asserted by the set\_operating\_condition command.

# Examples

The following commands query a single operating condition previously set using the set\_operating\_condition command:

```
get_operating_conditions -pvt min
fast_0_3.60
get_operating_conditions -pvt typ
slow
```

#### **Related Information**

get\_operating\_parameter

<u>read\_alf</u>

<u>read tlf</u>

<u>report\_library</u>

reset operating condition

set operating conditions

set\_operating parameter

# get\_operating\_parameter

```
get_operating_parameter {-process | -voltage | -temperature}
    [-pvt {min | typ | max}]
```

Queries the database for the process, voltage, or temperature used for delay calculation.

Specify only one of the parameter options per command.

#### **Options and Arguments**

| -process             | Returns the process multiplier.                                                                                                                                                                                                                                                              |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -pvt {min   typ   ma | Returns the operating parameter for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. <i>Default</i> : The typ value is returned. |
| -temperature         | Returns the operating temperature.                                                                                                                                                                                                                                                           |
| -voltage             | Returns the operating voltage.                                                                                                                                                                                                                                                               |

#### **Examples**

The following command queries the database for the voltage used for delay calculation: get\_operating\_parameter -voltage -pvt {min max}

3.100000 3.500000

■ The following command queries the database for the process used for delay calculation: get\_operating\_parameter -process

1.000000

■ The following command queries the database for the temperature used for delay calculation:

```
get_operating_parameter -temperature
25.000000
```

# **Related Information**

<u>load\_dcl\_rule</u>

- set operating parameter
- set operating conditions

# get\_operating\_voltage

get\_operating\_voltage [-pvt {min | typ | max}] leaf\_level\_instance

Returns the current operating voltage on the specified hierarchical instance.

# **Options and Arguments**

| leaf_level_instance  | 9                                                                                                                                   |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies the leaf level instance for which the operating voltage needs to be obtained. Specify only one instance, not a list.      |
| -pvt {min   typ   ma | x}<br>Returns the value for the environment corner of interest. Specify<br>only one PVT corner per command.<br><i>Default</i> : max |

#### Examples

■ The following command returns by default only the max PVT value:

```
get_operating_voltage ld1
5.500000
```

■ The following example shows all PVT values using three commands:

```
get_operating_voltage -pvt min ld1
4.500000
get_operating_voltage -pvt typ ld1
5.000000
get_operating_voltage -pvt max ld1
5.500000
```

# **Related Information**

<u>read\_irdrop</u>

<u>read\_rrf</u>

reset operating voltage

set\_operating\_voltage

# get\_propagated\_clock

get\_propagated\_clock [-clock clock\_list] [-pin pin\_list]

Returns the clock propagation mode, either ideal or propagated, for the given  $clock\_list$  and  $pin\_list$  arguments.

**Note:** The return value for the get\_propagated\_clock command is only accurate when get\_clock\_propagation command returns an ideal clock propagation mode. If the get\_clock\_propagation command returns a propagated clock propagation mode, the values returned by the get\_propagated\_clock command are not relevant.

# **Options and Arguments**

| -clock <i>clock_list</i> | Specifies one or more clock waveforms for which you want to get the clock propagation mode information.                                                 |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| -pin <i>pin_list</i>     | Specifies the pin where you want to get the clock propagation mode.                                                                                     |
|                          | Specifies one or more pins or ports for which you want to get the clock propagation mode information. No hierarchical pins are allowed in the pin_list. |
|                          | Either the clock_list option or the pin_list option must be specified. You can also specify both the clock_list and the pin_list options.               |

#### Example

The following command gets the clock propagation mode information for all clock waveforms and the pin ff1/CP:

get\_propagated\_clock -clock {\*} -pin {ff1/CP}

# **Related Information**

get\_clock\_propagation

reset propagated clock

set\_clock\_propagation

set propagated clock

# get\_scale\_delays

get\_scale\_delays [-net\_delay | -cell\_delay | -cell\_check] [-pvt {min | typ | max}]

Returns the value of the delay scaling factor for a specific PVT corner (min, typ, or max) for cells or nets.

# **Options and Arguments**

| -cell_check          |                                                                                                                                                                                                                                                                                                                                           |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Returns scaling on timing checks.                                                                                                                                                                                                                                                                                                         |
| -cell_delay          | Returns the delay scaling factor on cells.<br>If neither the <code>-cell_delay</code> nor the <code>-net_delay</code> option is<br>specified, the scaling factor for cells is returned. You cannot<br>specify both <code>-cell_delay</code> and <code>-net_delay</code> in the same<br>command.                                           |
| -net_delay           | Returns the delay scaling factor on nets.                                                                                                                                                                                                                                                                                                 |
|                      | <b>Note:</b> Specifying -cell is equivalent to using both the -cell_delay and the -cell_check options.                                                                                                                                                                                                                                    |
| -pvt {min   typ   ma | x}<br>Returns the delay scaling factor for a particular PVT (process,<br>voltage, temperature) corner. Choose one, two, or three PVT<br>corners. If you choose more than one corner, enclose the list in<br>curly braces ({}) and separate the values by spaces.<br><i>Default</i> : The max PVT corner delay scaling factor is returned. |

# Examples

■ The following commands return delay scaling factor for nets:

```
get_scale_delays -net_delay -pvt min
0.950000
get_scale_delays -net_delay -pvt max
1.050000
```

■ The following command returns cell delay scaling factor for the max PVT corner:

```
get_scale_delays
1.050000
```

# **Related Information**

<u>set scale delays</u>

# get\_slack

get\_slack [-early | -late] net\_or\_pin\_id

Returns the slack of the given net or pin. The late mode slack is the worst case required time minus the worst case arrival time.

#### **Options and Arguments**

| -early        | Reports the amount of time that the data signal misses or passes<br>the hold check. If the signal changes before the required hold<br>time, it is early. Early slack is calculated as arrival time minus<br>required time. If the signal arrives after the required hold time,<br>there is no violation and the slack is positive. This is the opposite<br>of late slack.   |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | For clock nets or pins, using the -early option reports the time that the clock signal misses or passes the setup check.                                                                                                                                                                                                                                                    |
| -late         | Reports the amount of time that the data signal misses or passes<br>the setup check. If the signal changes after the required setup<br>time, it is late. Late slack is calculated as required time minus<br>arrival time. If the signal arrives before the required setup time,<br>there is no violation and the slack is positive.<br><i>Default</i> : Late check reports. |
|               | amount of time that the clock signal misses or passes the hold check.                                                                                                                                                                                                                                                                                                       |
| net_or_pin_id | Specifies the net or pin for which you want to get the slack.                                                                                                                                                                                                                                                                                                               |

#### Examples

■ The following command returns the slack of net out within the current module and sub-modules as shown in Figure 7-3 on page 874:

```
get_slack [find -net out]
-2.000000
```

The following command returns an error message if multiple net or pin ID arguments are specified:

```
find -registers -full -hier
J_block/B_reg J_block/A_reg I_block/B_reg I_block/A_reg
```

Only one net ID or pin ID can be given as an input. If more than one ID is given, the following error message is displayed:

==> ERROR: Invalid object id'Id1 Id2....' <TCLCMD-117>.

The following command reports the fanin cone of the specified design objects in the current module:

```
report fanin J block/A reg/*
+-----+
| Level | From(Instance/Pin) | To(Instance/Pin) | Net
|----+----|
 1 J_block/A_reg/Q
                      J block/w03
 _____+______
  J block/A reg/QN
 1
J_block/iC/A J_block/in
 1 | J_block/in
   J_block/iC/Z | J_block/cbuf/A | J_block/inC |
 2
 3 | J_block/cbuf/Z | J_block/A_reg/D | J_block/PC
 1 | J_block/clkc | J_block/A_reg/CP | J_block/clkc |
+-----+
```

- The following commands get the slack based on the example report:
  - get\_slack [find -pin J\_block/A\_reg/D]
    1.285744
  - get\_slack [find -net J\_block/clkc]
    0.561901
  - get\_slack -early [find -net J\_block/clkc]
    1.081700

# **Related Information**

#### get module worst slack

<u>get\_area</u>

# get\_slew\_thresholds

get\_slew\_thresholds

Returns a list containing the lower and upper slew threshold values in percentage used for the entire design.

#### Example

The following command returns the lower and upper slew threshold values used for the design:

get\_slew\_thresholds 10.000000 90.000000

#### **Related Information**

reset slew thresholds

<u>set\_tech\_info</u>

# get\_tech\_info

```
get_tech_info {([-library list_of_library_names]
     {[-default_wire_load] | [-default_wire_load_selection] |
     [-default_operating_conditions] |
     [-default fanout load] | [-default max capacitance] |
     [-default_max_fanout] | [-default_max_transition] |
     [-default_min_capacitance] [-default_min_fanout] [-default_min_transition]
     [-input_threshold_pct_rise] | [-input_threshold_pct_fall] |
     [-output_threshold_pct_rise] | [-output_threshold_pct_fall] |
     [-slew_lower_threshold_pct_rise] | [-slew_lower_threshold_pct_fall] |
     [-slew_upper_threshold_pct_rise] | [-slew_upper_threshold_pct_fall]
     [-slew lower meas threshold pct rise]
     [-slew_lower_meas_threshold_pct_fall]
     [-slew_upper_meas_threshold_pct_rise] |
     [-slew_upper_meas_threshold_pct_fall] }
     [-pvt {min | typ | max}]}
     {[-library list_of_library_names]
     -cell list_of_cell_names
     {[-dont_modify] | [-dont_utilize] | [-scaling_factors] |
     [-input_threshold_pct_rise] | [-input_threshold_pct_fall]
     [-output_threshold_pct_rise] | [-output_threshold_pct_fall] |
     [-slew lower threshold pct rise] | [-slew lower threshold pct fall] |
     [-slew_upper_threshold_pct_rise] | [-slew_upper_threshold_pct_fall]
     [-slew lower meas threshold pct rise]
     [-slew_lower_meas_threshold_pct_fall]
     [-slew upper meas threshold pct rise]
     [-slew_upper_meas_threshold_pct_fall] }
     [-pvt {min | typ | max}]}
     ([-library list_of_library_names]
     -cell list_of_cell_names
     -pin list_of_pin_names
     {[-fanout load] | [-max fanout] | [-min fanout]
     [-max_transition] | [-min_transition] |
     [-max_capacitance] | [-min_capacitance] }
     [-pvt {min | typ | max}])}
```

Returns data for the specified library parameters in the named target libraries. The data can come either from the library itself or the overrides (assertions) as previously specified with the set\_tech\_info command.

# Options and Arguments (any level)

-library list\_of\_library\_names Reports data for the named libraries.

| -pvt {min   typ   m                      | <i>Default</i> : All libraries specified with the set_global target_technology command.                                        |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
|                                          | nax}<br>Returns the value for the environment corner of interest. Specify<br>one PVT corner at a time.<br><i>Default</i> : typ |
| Options and Arguments<br>(library level) |                                                                                                                                |
| -default_fanout_load                     | Returns the value of the default fanout load for all pins on all cells in the library.                                         |
| -default_max_capacit                     | ance<br>Returns the value of the default maximum capacitance for all<br>pins on all cells in the library.                      |
| -default_max_fanout                      | Returns the value of the default maximum fanout for all pins on all cells in the library.                                      |
| -default_max_transit                     | tion<br>Returns the value of the default maximum transition time for all<br>pins on all cells in the library.                  |
| -default_min_capacit                     | ance<br>Returns the value of the default minimum capacitance for all pins<br>on all cells in the library.                      |
| -default_min_fanout                      | Returns the value of the default minimum fanout for all pins on all cells in the library.                                      |
| -default_min_transit                     | tion<br>Returns the value of the default minimum transition time for all<br>pins on all cells in the library.                  |
| -default_operating_c                     | conditions<br>Returns the default operating conditions for the library.                                                        |

#### **Command Reference for BuildGates Synthesis and Cadence PKS** Common Timing Engine (CTE) Commands

| -default_wire_load          |                                                                                                                           |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------|
| <u></u>                     | Returns the default wire-load model for the library.                                                                      |
| -default_wire_load_s        | election<br>Returns the default wire-load selection table for the library.                                                |
| -input_threshold_pct        | _fall<br>Returns the value of the default input threshold percent for the<br>falling edge for all cells in the library.   |
| -input_threshold_pct        | _rise<br>Returns the value of the default input threshold percent for the<br>rising edge for all cells in the library.    |
| -output_threshold_pc        | t_fall<br>Returns the value of the default output threshold percent for the<br>falling edge for all cells in the library. |
| -output_threshold_pc        | t_rise<br>Returns the value of the default output threshold percent for the<br>rising edge for all cells in the library.  |
| Note: The following clow th | reshold antions refer to the section of the waveform where the                                                            |

**Note:** The following slew threshold options refer to the section of the waveform where the slew is nearly linear. This is measured and extended like a linear waveform. The linear waveform, a result of extending the near-linear slew waveform, is measured at certain points. The points where this extended waveform is measured are called slew thresholds. Measured slew thresholds are determined at the time of library characterization.

# Slew Thresholds

-slew\_lower\_threshold\_pct\_fall

Returns the value of the default lower threshold percent for the slew time of the falling transition for all cells in the library.

-slew\_lower\_threshold\_pct\_rise

Returns the value of the default lower threshold percent for the slew time of the rising transition for all cells in the library.

-slew\_upper\_threshold\_pct\_fall

Returns the value of the default upper threshold percent for the slew time of the falling transition for all cells in the library.

| -slew_upper_threshol                  | d_pct_rise                                                                                                                                   |  |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                       | Returns the value of the default upper threshold percent for the slew time of the rising transition for all cells in the library.            |  |
| Measured Slew Thresholds              |                                                                                                                                              |  |
| -slew_lower_meas_thr                  | eshold_pct_fall<br>Returns the measured lower threshold percent of the slew time<br>for the falling transition for all cells in the library. |  |
| -slew_lower_meas_thr                  | eshold_pct_rise<br>Returns the measured lower threshold percent of the slew time<br>for the rising transition for all cells in the library.  |  |
| -slew_upper_meas_thr                  | eshold_pct_fall<br>Returns the measured upper threshold percent of the slew time<br>for the falling transition for all cells in the library. |  |
| -slew_upper_meas_thr                  | eshold_pct_rise<br>Returns the measured upper threshold percent of the slew time<br>for the rising transition for all cells in the library.  |  |
| Options and Arguments<br>(cell level) |                                                                                                                                              |  |
| -cell list_of_cell_                   | names<br>Reports assertions on the named cells. Required option for cell<br>and pin level assertions.                                        |  |
| -dont_modify                          | Returns true or false. If true, the cell is not modified in optimization or time budgeting.                                                  |  |
| -dont_utilize                         | Returns true or false. If true, the cell is not used in optimization.                                                                        |  |
| -input_threshold_pct                  | _fall<br>Returns the value of the default input threshold percent for the<br>falling edge for the listed cells.                              |  |
|                                       |                                                                                                                                              |  |

| -input_threshold_pct_rise  |                                                                                                     |
|----------------------------|-----------------------------------------------------------------------------------------------------|
|                            | Returns the value of the default input threshold percent for the rising edge for the listed cells.  |
| -output_threshold_pct_fall |                                                                                                     |
|                            | Returns the value of the default output threshold percent for the                                   |
|                            | falling edge for the listed cells.                                                                  |
| -output_threshold_pct_rise |                                                                                                     |
|                            | Returns the value of the default output threshold percent for the rising edge for the listed cells. |
|                            |                                                                                                     |

-scaling\_factors

Returns the name of the derating table used for scaling.

**Note:** The following slew threshold options refer to the section of the waveform where the slew is nearly linear. This is measured and extended like a linear waveform. The linear waveform, a result of extending the near-linear slew waveform, is measured at certain points. The points where this extended waveform is measured are called slew thresholds. Measured slew thresholds are determined at the time of library characterization.

# Slew Thresholds

| -slew_lower_threshol | d_pct_fall<br>Returns the value of the default lower threshold percent for the<br>slew time of the falling transition for the listed cells. |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| -slew_lower_threshol | d_pct_rise<br>Returns the value of the default lower threshold percent for the<br>slew time of the rising transition for the listed cells.  |
| -slew_upper_threshol | d_pct_fall<br>Returns the value of the default upper threshold percent for the<br>slew time of the falling transition for the listed cells. |
| -slew_upper_threshol | d_pct_rise                                                                                                                                  |

Returns the value of the default upper threshold percent for the slew time of the rising transition for the listed cells.

# Measured Slew Thresholds

| -slew_lower_meas_thr                 | eshold_pct_fall<br>Returns the measured lower threshold percent of the slew time<br>for the falling transition for the listed cells.      |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| -slew_lower_meas_thr                 | eshold_pct_rise<br>Returns the measured lower threshold percent of the slew time<br>for the rising transition for the listed cells.       |
| -slew_upper_meas_thr                 | eshold_pct_fall<br>Returns the measured upper threshold percent of the slew time<br>for the falling transition for the listed cells.      |
| -slew_upper_meas_thr                 | eshold_pct_rise<br>Returns the measured upper threshold percent of the slew time<br>for the rising transition for the listed cells.       |
| Options and Arguments<br>(pin level) |                                                                                                                                           |
| -fanout_load                         | Returns the value of the fanout load constraint for the named pins. Specify this option only for an input pin.                            |
| -max_capacitance                     | Returns the value of the maximum capacitance constraint for the named pins. Specify this option only for an output pin.                   |
| -max_fanout                          | Returns the value of the maximum fanout constraint for the named pins. Specify this option only for an output pin.                        |
| -max_transition                      | Returns the value of the maximum transition time constraint for<br>the named pins. Specify this option for both input and output<br>pins. |
| -min_capacitance                     | Returns the value of the minimum capacitance constraint for the named pins. Specify this option only for an output pin.                   |

| -min_fanout            |                                                                                                                                    |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------|
|                        | Returns the value of the minimum fanout constraint for the named pins. Specify this option only for an output pin.                 |
| -min_transition        |                                                                                                                                    |
|                        | Returns the value of the minimum transition time constraint for<br>named pins. Specify this option for both input and output pins. |
| -pin list_of_pin_names |                                                                                                                                    |
|                        | Reports assertions on the named pins. Required option for pin level assertions.                                                    |
|                        | <b>Note:</b> The pin assertions apply to a specific pin type. If the correct pin type is not specified, an error is issued.        |

# Examples

These examples follow those for the set\_tech\_info command:

The following command returns the value of the default fanout load for all pins on all cells in the library:

```
get_tech_info -library lib1 -default_fanout_load
1.411100
```

■ The following command returns true or false. If true, the cell is not used in optimization:

```
get_tech_info -cell FD2ESSA -dont_utilize
true
```

■ The following command reports data for the named libraries.

```
get_tech_info -library lca300kv -cell B2I -pin Z1 Z2 -pvt min -max_fanout
3.000000
```

Default: All libraries specified with the set\_global target\_technology command

# **Related Information**

<u>reset\_tech\_info</u>

set global target technology

<u>set\_tech\_info</u>

```
write library assertions
```

# get\_time\_borrow\_limit

get\_time\_borrow\_limit [-pin pin\_list] [-clock list\_of\_clksigs]

Returns the limit on time that can be borrowed by one cycle from the next cycle as previously specified with the set\_time\_borrow\_limit command. Query for borrow limits on pins or waveforms.

**Note:** This command only returns an assertion value when one has been set by the set\_time\_borrow\_limit command. Nothing is returned if no assertion has been set.

# **Options and Arguments**

-clock list\_of\_clksigs

Returns the borrow limit for the specified list of ideal (or generated) clock names.

-pin pin\_or\_instance\_list

Returns the borrow time limit for a single pin on a latch.

You can alternatively give one latch instance name, which returns the assertion for the clock pin of the instance.

# Examples

The following commands return the limit on time that can be borrowed by one cycle from the next cycle as previously specified with the set\_time\_borrow\_limit command on a pin:

```
set_time_borrow_limit -pin l1/q 3.0
get_time_borrow_limit -pin l1/q
3.0
```

#### **Related Information**

reset\_time\_borrow\_limit

<u>set time borrow limit</u>

<u>Analyzing Latch-Based Designs</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

# get\_time\_unit

get\_time\_unit

Returns the time unit for the session as previously set by the set\_time\_unit command.

# Example

The following command returns the time unit for the session:

get\_time\_unit 0.001

# **Related Information**

<u>reset\_time\_unit</u>

set\_time\_unit

# get\_timing

Retrieves timing information for the specified pin property on the given pin. Specify the pin by the object ID or the hierarchical name. Only one pin is allowed per command. *Default*: Return information about the most critical path.

Note: If no information is found, this command does not return anything.

Slack is a function of required time and arrival time, both must be present in order for the get\_timing command to return a value for slack, arrival, required, edge, and stolen.

⊂ \_ Tip

Run <u>check timing</u> first and resolve all warnings that cause paths to pins to be unconstrained. For example:

--> WARNING: No required or external delay assertion found at port DOUT.

A constraint consists of a required time that can be compared to an arrival time. Because port DOUT does not have a required time, any path to it is unconstrained.

# **Options and Arguments**

| arrival      | Returns the arrival time of the path causing the worst slack at the given pin.                                                                                                                                                                                                       |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cell         | Returns the cell of the given pin's instance.                                                                                                                                                                                                                                        |
| clkordata    | Tells you whether the specified path is of type clock or of type data. Change this behavior using the <i>-rise</i> or <i>-fall</i> option.                                                                                                                                           |
| clkordatapin | Tells you whether the specified pin expects a clock or data signal.<br>This information is currently derived from the library, except in the<br>case of output ports. Output ports are considered of type DATA<br>if there is a delay constraint asserted on the port. This behavior |

| Command Reference for BuildGates Synthesis and Cadence PKS<br>Common Timing Engine (CTE) Commands |                                                                                                                                                 |
|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                   | is consistent with the check_timing command. This option is not path dependent.                                                                 |
| -early   -late                                                                                    | Specifies analysis type, either early or late.<br><i>Default</i> : late                                                                         |
| edge                                                                                              | Returns the edge of the worst slack causing path at the given pin. Rising edge is ^, falling edge is $\mathbf{v}$ .                             |
| fanout                                                                                            | Returns the total fanout on a given pin.                                                                                                        |
| hpin                                                                                              | Returns the full hierarchical name of the pin. Equivalent to using the -full_path_name option with the get_fanin, get_fanout, or find commands. |
| instance                                                                                          | Returns the hierarchical name of the given pin's instance.                                                                                      |
| load                                                                                              | Returns the total capacitive load on a given pin.                                                                                               |
| net                                                                                               | Returns the hierarchical name of the net connected to given pin.                                                                                |
| phase                                                                                             | Returns the phase of a pin in the same format as using the <u>report cell instance</u> -timing command.                                         |
| pin                                                                                               | Returns the pin name of the given hierarchical pin.                                                                                             |
| pinload                                                                                           | Returns the total capacitive load from pins on a given pin, including its own load.                                                             |
| pin_path_or_id                                                                                    | Specifies the port or pin for which timing information is to be returned. Specify the port or pin by the object ID or the hierarchical name.    |

| Command Reference for BuildGates Synthesis and Cadence PKS<br>Common Timing Engine (CTE) Commands |                                                                                                |
|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| required                                                                                          |                                                                                                |
|                                                                                                   | Returns the required time of the path causing the worst slack at the given pin.                |
| -rise   -fall                                                                                     | Specifies the edge, either rise or fall. <i>Default</i> : The edge with the worst timing.      |
| slack                                                                                             | Returns the worst slack at the given pin.                                                      |
| slew                                                                                              | Returns the propagated slew at the given pin.                                                  |
| stolen                                                                                            | Returns the slack stolen at the given pin (only visible on the output of transparent latches). |
| wireload                                                                                          | Returns the total capacitive load from the wire on a given pin.                                |

# Examples

The following command returns the arrival time of the path causing the worst slack at the given pin:

```
get_timing i00/Z arrival
1.23
```

The following command returns the hierarchical name of the net connected to given pin:

```
get_timing i00/Z net
n001
```

■ The following command returns the edge of the worst slack causing path at the given pin. Rising edge is ^, falling edge is v:

```
get_timing in edge
^
```

The following command tells whether the specified path is of type clock or of type data:

```
get_timing clkC clkordata
CLOCK
```

■ The following command returns the phase of a pin:

```
get_timing clkC phase
CLK2(C)(P)
```

# **Related Information**

report cell instance

<u>report net</u>

<u>report\_ports</u>

<u>report\_timing</u>

set global slew propagation mode

# get\_top\_timing\_module

get\_top\_timing\_module

Returns the object ID of the module that was designated as the top timing module by the set\_top\_timing\_module command.

#### Examples

The following command returns the object ID of the module that was designated as the top timing module:

```
get_top_timing_module
67841
```

■ The following command returns the names of specified objects in the design:

get\_names 67841 top

### **Related Information**

<u>get names</u>

set\_top\_timing\_module

# libcompile

```
libcompile [-force] (UNIX command) [-help] [-version] [-expire] [-queue]
    [-ipformat] [-debug] [-verbosity level] [-logfile file_name]
    [library_file_name] [output_file_name]
```

Support for libcompile is being phased out. Use the <u>read\_dotlib</u> or the <u>read\_tlf</u> command to read .lib files directly. Some .lib constructs are supported in read\_dotlib and syn2tlf, but not in libcompile.

**Note:** The following .lib constructs are supported by the read\_dotlib command and syn2tlf only:

- Interface Timing Specification (ITS) constructs such as generated clocks, functional modes, interface timing, and so forth.
- Conditional expressions involving bus pins.
- Rise/fall capacitance.

See <u>Using Synopsys Liberty (.lib) Libraries</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)* for more information.

# load\_dcl\_rule

load\_dcl\_rule

Loads a binary Delay and Power Calculation Module (DPCM) into memory. The DPCM is an executable shared library that is linked to an application (like BuildGates Synthesis) at runtime. DPCM is often abbreviated as DCM. After loading the DCM, all timing calculations are performed using delay tables and equations defined in the DCM.

**Note:** Before loading a DCM, set environment variables before running bg\_shell. For example:

```
setenv DCMRULEPATH /dcl_libs/sample_dcm
setenv DCMRULESPATH /dcl_libs/%RULENAME
setenv DCMTABLEPATH /dcl_libs/
```

Refer to the DCL library vendor documentation for information about how to set these variables.

# Example

The following command loads a binary Delay and Power Calculation Module (DPCM) into memory:

# **Related Information**

get dcl functional mode array

<u>read\_ola</u>

set\_dcl\_calculation\_mode

set dcl functional mode

<u>set\_dcl\_level</u>

set operating parameter

<u>Using IEEE 1481 Delay and Power Calculation System (DPCS) Libraries</u> in the *Timing* Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).

# read\_alf

```
read_alf [-force]{alf_library_name | {{-min filename -max filename -typ
filename [-name merged_filename]} | alf_library_filename |
{list_of_alf_filenames}}
```

Reads the Advanced library format (ALF) file. The binary .alf files are previously compiled from the .lib format using the libcompile utility. For more details, see <u>"Using Synopsys</u> <u>Liberty (.lib) Libraries</u>" in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

Use this command in two ways:

To read an ALF library into the database, use this form:

```
read_alf alf_filename
```

The above command loads the library data from *alf\_filename*. CTE uses the library data for all min, typ, and max process, voltage, and temperature (pvt).

**Note:** When you are not merging libraries, you can only read one library at a time. If you try to read in more than one library, for example, read\_alf 1.alf 2.alf, without using the following merged library form, you will receive an error.

■ To create and read a merged library from single operating point libraries, use this form:

read\_alf [-min filename] [-typ filename] [-max filename]
[-name merged\_filename]

Use the  $-\min$ , -typ,  $-\max$  options to create a merged library from libraries different operating points. Use the min library for min pvt analysis, and use the typ library and max library for typ pvt and max pvt respectively. When merging two libraries or more, the libraries have to define the same cell names with the same number and type of timing arcs. See Examples on page 905.

The values from each library are scaled to the current session units using the units from that library. The first library read\_ command will provide the default session units. The library for the max corner is used for the default units if it is present, otherwise the  $t_{YP}$  corner is used, or finally, the min corner.

Use the -name option to change the name of the merged library to a new name. For example, -name merged\_lib\_name changes the merged library name to merged\_lib\_name.

When merging libraries, specify libraries for at least two pvt corners.

# **Options and Arguments**

| alf_library_name           |                                                                                                                                                                                                                                                          |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Specifies the ALF library file name. This name can be a fully qualified file name or a relative file name. If the AMBIT_SLIB_PATH environment variable is set, the search is performed in the order specified.                                           |
| -force                     | Overrides invalid 0-100 percent measured threshold values. If you do not use this option, CTE will not read libraries that define 0-100 percent threshold values. <i>Default</i> : Delay threshold value is 50-50, and measured slew threshold is 20-80. |
| list_of_alf_filenar        | nes<br>Lets you specify multiple library names. Use curly braces to<br>specify multiple library filenames, for example:<br>{lib1 lib2 lib3}                                                                                                              |
| -max filename              | Uses data from library <i>max_filename</i> to populate the max field of the merged library.                                                                                                                                                              |
| -min <i>filename</i>       | Uses data from library <i>min_filename</i> to populate the min field of the merged library.                                                                                                                                                              |
| -name <i>merged_filena</i> | me<br>Changes the new merged library name to<br>merged_lib_name.                                                                                                                                                                                         |
| -typ filename              | Uses data from the library $filename$ to populate the typ field of the merged library.                                                                                                                                                                   |

### Examples

- The following command reads the LSI Logic G11 library: read\_alf lca\_G11.alf
- The following command shows that ALF files can contain data for multiple operating points:

read\_alf library\_with\_min\_and\_typ\_and\_max\_data.alf

Suppose min.alf contains 0.02, typ.alf contains 0.03, and max.alf contains 0.04, the resultant triplet in merged\_lib is (0.02:0.03:0.04).

#### **Related Information**

<u>read\_adb</u>

read dotlib

<u>read\_library\_update</u>

<u>read\_tlf</u>

<u>read verilog</u>

<u>read\_vhdl</u>

See <u>Using Advanced Library Format (ALF) Libraries</u> in *Common Timing Engine (CTE) User Guide*.

# read\_ctlf

read\_ctlf
 OBSOLETE: Use read\_tlf instead.

The <code>read\_ctlf</code> command is no longer supported. Obtain a <code>.tlf</code> source file with version 4.4 and use <code>read\_tlf</code>.

# **Related Information**

<u>read\_tlf</u>

<u>"Using Timing Library Format (TLF) Libraries</u>" in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

# read\_dc\_script

read\_dc\_script [-dc] [-group\_path\_effort {weight\_boundary1 weight\_boundary2}]
 [-group\_path\_for\_clocks] [-tcl] [-verbose] [-help] write\_script\_file
 The options -ambit ambit\_output\_file, -apply\_only, -write\_only, -no\_write,
 and -no\_apply are obsolete. To enable the old options, set the following tcl
 variable:
 set syn2ambit\_flow\_control\_support 0

Translates Synopsys PrimeTime and Design Compiler constraints to the CTE constraint format automatically. Also automatically detects whether the write\_script file is in Tcl or dcsh format. See the <u>SDC Constraint Support Guide</u> for details about this command.



Do not mix CTE and PrimeTime constraints. Mixing CTE and PT constraints causes different interpretations of constraints. Once you use the read\_dc\_script command to read constraints, all other constraints must be read before using this command.

Using the read\_dc\_script command automatically sets the <u>set\_flow\_compatible\_mode</u> command to on.

The -through option on a net name will apply on a driver pin/port in CTE, for the set\_false\_path command and the set\_multicycle\_path command.

Note: When using the set\_false\_path, set\_multicycle\_path, or the set\_path\_delay commands in your read\_dc\_script, you may see the following error with both the -sparc and the -64 options:

==> ERROR: An unrecoverable exception has occurred (SEGV).
--> Info: Probably due to a stack overflow.
--> Info: Consider a higher stacksize limit; see limit(1).

This occurs only on Solaris 32 and 64 platforms when you have a large number of the above commands, or if you use a large number of pins as arguments to the -to, -from, or the -through options with the these commands. To prevent this error, before starting PKS or Timing Analysis, enter the following command from the UNIX prompt:

limit stacksize unlimited

#### **Options and Arguments**

-dc

Specifies that the Synopsys Synthesis constraints file is in the dc\_shell format. To read a dc-format file, specify the -dc

option with the read\_dc\_script command and set the syn2ambit\_no\_tcl\_detection tcl variable to true.

**Note**: Without the -dc option, the read\_dc\_script command assumes that the input file is in tcl format.

-group\_path\_effort {weight\_boundary1 weight\_boundary2} The mapping between Synopsys weight and CTE effort is handled as follows:

| weight               | effort |
|----------------------|--------|
| Between 0 and 1.0    | low    |
| Between 1.0 and 10.0 | medium |
| above 10.0           | high   |

The -group\_path\_effort option lets you change the upper boundary values (by default, 1.0 and 10.0). For example, read\_dc\_script -group\_path\_effort {2.0 15.0} changes the mapping to the following:

| weight               | effort |
|----------------------|--------|
| Between 0 and 2.0    | low    |
| Between 2.0 and 15.0 | medium |
| above 15.0           | high   |

#### -group\_path\_for\_clocks

Changes the default behavior. By default, the create\_clock and create\_generated\_clock commands do not create any group path. When you use this option, create\_clock and create\_generated\_clock add the following constraint:

set\_path\_group -name syn2ambit\_clock\_name
-clock\_to clock\_name

-help

Prints the read\_dc\_script usage message.

-verbose

Specifies that the translator should write the line number and the

corresponding Synopsys Synthesis command in the Ambit Synthesis constraints output along with the translated command.

write\_script\_file

Specifies the name of the Synopsys Synthesis constraints input file. This is a required argument and must be the last specified argument.

#### **Related Information**

<u>write\_sdc</u>

set flow compatible mode

# read\_dotlib

```
read_dotlib {{-min filename -max filename -typ filename
    [-name merged_filename]} | dotlib_library_filename |
    {list_of_dotlib_filenames}} [-nopower] [-nonoise] [-notiming]
```

Reads the Synopsys Liberty file for timing data. For more details, see "<u>Using Synopsys</u> <u>Liberty (.lib) Libraries</u>" in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

Use this command in the following two ways.

■ To read the .lib library into the database, use this form:

read\_dotlib dotlib\_library\_filename

The above command loads the library data from the *dotlib\_library\_filename*. CTE uses the library data for all min, typ, and max pvt.

To create and read a merged library from multiple single operating point libraries, use this form:

read\_dotlib [-min filename] [-typ filename]
[-max filename] [-name merged\_filename]

Use the  $-\min$ , -typ,  $-\max$  options to create a merged library. Use the  $\min$  library for  $\min$  pvt analysis, and use the typ library and  $\max$  library for typ pvt and  $\max$  pvt respectively. When merging libraries, the libraries have to define the same cell names with the same number and type of timing arcs. See <u>Examples</u> on page 912.

Use the -name option to change the name of the merged library to a new name. For example, -name merged\_filename changes the merged library name to merged\_filename.

# **Options and Arguments**

dotlib\_library\_filename

Specifies the name of the .lib library. This name can be a fully qualified file name or a relative file name. If the AMBIT\_SLIB\_PATH environment variable is set, the search is performed in the order specified.

list\_of\_dotlib\_filenames

Specifies multiple dotlib library filenames. Use curly braces to specify multiple library filenames, for example: {lib1 lib2 lib3}

| -max filename        | Uses data from library max_filename to populate the max field of the merged library.                                                                                          |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -min <i>filename</i> | Uses data from library <i>filename</i> to populate the min field of the merged library.                                                                                       |
| -name merged_filena  | me<br>Changes the new merged library name to a<br>merged_filename.                                                                                                            |
| -nonoise             | Does not read the Liberty SI data, such as noise_immunity and noise_propagation from the .lib file.                                                                           |
| -nopower             | Does not read the power data from the .lib file.                                                                                                                              |
| -notiming            | Does not read the timing data present in the library.                                                                                                                         |
|                      | <b>Note</b> : You can use the -nonoise, -nopower, and the -notiming options together in any combination. Using these options saves time and memory while reading a .lib file. |
| -typ_filename        | Uses data from library <i>filename</i> to populate the typ field of the merged library.                                                                                       |

# Examples

- The following command reads the *dotlib\_library\_filename* library: read\_dotlib\_dotlib\_library\_filename
- The following command populates data from each respective single operating point library into the min, typ, max fields of the merged library named merged\_lib:

read\_dotlib -min min.lib -typ typ.lib -max max.lib -name merged\_lib

Suppose that the pin capacitance value for min.alf,typ.alf, and max.alf are 0.02, 0.03, and 0.04 respectively. The resultant triplet for pin capacitance in merged\_lib is (0.02:0.03:0.04).

■ The following command reads only the timing data from a.lib file and skips the power and noise data:

read\_dotlib -nopower -nonoise a.lib

■ The following command will not load constructs such as internal\_power from the .lib file:

read\_dotlib -nopower a.lib

### **Related Information**

<u>read\_adb</u>

<u>read\_alf</u>

<u>read\_tlf</u>

<u>read\_verilog</u>

<u>read vhdl</u>

# read\_irdrop

```
read_irdrop [-pvt {min|typ|max}] filename
```

Reads an irdrop report file generated by VoltageStorm and asserts the operating voltage accordingly.

# **Options and Arguments**

filename

Specifies the name of the irdrop file that has the voltage drop data.

-pvt {min | typ | max} Applies an operating voltage specified in the filename for a specific PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. If you do not specify a -pvt value, by default, the operating voltage specified in the filename is applied to all

### Example

The following command applies an operating voltage specified in the filename into operating voltages for a min PVT corner:

read\_irdrop -pvt min voltage\_storm\_ir\_drop\_report\_file.ir

three PVT corners.

### **Related Information**

<u>get operating voltage</u>

<u>read\_rrf</u>

reset operating voltage

set operating voltage

# read\_library\_update

```
read_library_update [-library library_name] [-pvt {min | typ | max}]
    [-wireloads] [-scaling_factors] [-operating_conditions][-cells]
    [-spice spice_subckt_file] filename
```

Replaces existing technology library data with new data, and updates wire load, operating conditions, and cell-specific information in the library.

**Note:** The read\_library\_update command is not a substitute for directly reading a complete .lib file. This command updates wireloads and a limited set of globals from the .lib file.

If none of the three options (wireloads, operating\_conditions, cells) are specified, all wire-load models, operating conditions, and cells from *libname* are used to update the library.

**Note:** The read\_library\_update command updates scaling factor groups to the target library similar to a wire-load models update. Use the -scaling\_factors option to set a new scaling factors group for a cell or to change the scaling factors group of a cell within a library.



You can only update a library with linear models with data from another library with linear models. The same is true for nonlinear models. The defaults and k-factors are significantly different for linear and nonlinear library types. A forced overwrite of one over the other is not desirable. To use both linear and nonlinear libraries, read them in with separate read\_tlf or read\_alf statements, then set the global target\_technology to the list of libraries. In this flow, without overwriting data, the cells and timing information from the corresponding libraries is used.

# **Options and Arguments**

-cells Adds cells from the file *filename* to the library. If the cell already exists in the library, an error is reported. *filename* Specifies the name of the ASCII file that contains the new data. The file can be .tlf, .alf, or .lib file types. Required argument. -library *library\_name* 

Specifies the name of the library to be updated. If this option is

|                            | not used, the target library specified by the set_global target_technology is updated.                                                                                                                                                                                                                                 |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -operating_condition       | s<br>Indicates that the operating conditions specified in the file<br>filename are used to update the library.                                                                                                                                                                                                         |
| -pvt {min   typ   ma       | Replaces library data for a particular PVT (process, voltage,<br>temperature) corner. Choose one, two, or three PVT corners. If<br>you choose more than one corner, enclose the list in curly braces<br>({ }) and separate the values by spaces.<br><i>Default</i> : The library is updated for all three PVT corners. |
| -scaling_factors           | Uses the scaling factor groups from the file for updating the scaling factor groups in the library. If a scaling factor group already exists in the library, then it is overwritten by the one from the file.                                                                                                          |
| -spice <i>spice_subckt</i> | _file<br>Reads the vendor provided <i>spice_subckt_file</i> that<br>contains Spice subcircuit definitions of cells in the technology<br>library. CTE reads the pin order of each SUBCKT defined and<br>uses the pin order when it generates the Spice netlist of a path.                                               |
|                            | For cells that do not have a Spice SUBCKT definition, CTE uses the cell pin order specified in the timing library.                                                                                                                                                                                                     |
|                            | For more information about generating a Spice netlist for a path, see the report_timing command Options for Creating Spice Output.                                                                                                                                                                                     |
| -wireloads                 | Uses the wire-load models from the file for updating the wire-load models in the library. If a wire-load model already exists in the library then it is overwritten by the one from the file.                                                                                                                          |

#### Examples

■ The following command adds cells in library file memgen.lib to the library previously specified by set\_global target\_technology.

read\_library\_update -cells memgen.lib

■ The following command loads TLF library lib1.tlf:

read\_tlf lib1.tlf

■ The following command appends all information from TLF library lib2.tlf to lib1.tlf:

read\_library\_update lib2.tlf

■ The following command updates the target technology library with data from corelib.lib and adds the Spice SUBCKT definitions from corelib.spf:

read\_library\_update -spice corelib.spf corelib.lib

#### **Related Information**

<u>read adb</u>

<u>read\_alf</u>

<u>read\_tlf</u>

<u>read verilog</u>

<u>read\_vhdl</u>

set global target technology

# read\_ola

read\_ola

Loads an OLA into memory in the form of a DCM (compiled module) and initializes it for use in BuildGates Synthesis. Upon loading the OLA library, all timing calculations are performed using the OLA delay tables and equations. The synthesis properties and functions are also derived from the OLA library.

**Note:** Before loading an OLA library, set certain environment variables before running the ac\_shell.The following list shows an example:

```
setenv DCMRULEPATH /dcl_libs/sample_dcm
setenv DCMRULESPATH /dcl_libs/%RULENAME
setenv DCMTABLEPATH /dcl_libs/
```

Refer to the OLA library vendor documentation for information about how to set these variables.

See<u>"Using Open Library API (OLA) Libraries</u>" in the *Common Timing Engine (CTE) User Guide* for more information.

# Example

This example shows the proper sequence for loading OLA libraries when using a DPCM:

At the UNIX prompt, set the library path:

setenv LD\_LIBRARY\_PATH "/libdata/lib"

- At the shell prompt:
  - Set the UNIX environment variables: set env(DCMRULEPATH) "/libdata/OLA/myDPCM" set env(DCMTABLEPATH) "/libdata/OLA/tables:/libdata/OLA/%RULENAME"
  - □ Load the library:

read\_ola

Merge (backannotate) wire-load information from a floorplanner: read\_library\_update my\_wire\_load.pdef

### **Related Information**

<u>load dcl rule</u>

#### set dcl calculation mode

set\_dcl\_functional\_mode

set\_dcl\_level

set operating parameter

# read\_rrf

read\_rrf [-pvt {min | typ | max}] rrf\_filename

Reads the SE power analyzer output Rail Result File (RRF), which contains the power and ground IR drop information. The relevant information is read into CTE and converted internally into operating voltages on leaf level instances.

<u>See Performing Voltage Drop Analysis</u> in the *Common Timing Engine (CTE) User Guide* for more information.

Read in a compressed RRF file in GNU zip format if the specified input file ends in the .gz suffix. No special option is needed to read a gzipped file. For example: read\_rrf rrf\_filename.rrf.gz. However, you cannot create a gzipped file with the read\_rrf command.

This command is used in the SE-PKS flow. Run the SE power analyzer before using the read\_rrf command.

### **Options and Arguments**

| -pvt | {min | typ | max} |
|------|------|-----|------|
|      |      |     |      |

Converts the data into operating voltages for a particular PVT (process, voltage, temperature) corner. You can choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces.

*Default*: The data is converted into operating voltages for all three PVT corners.

*rrf\_filename* 

Specifies the name of the RRF file that has the voltage drop data.

### Examples

- The following command converts the data into operating voltages for a min PVT corner: read\_rrf -pvt min route1.rrf
- The following command converts voltage drops from this file into operating voltages on leaf level instances used to derate delays and slews of cells during timing analysis:

read\_rrf pa\_1.rrf

# **Related Information**

get operating voltage

<u>read\_irdrop</u>

reset\_operating\_voltage

set operating voltage

# read\_sdf

```
read_sdf [-continue_on_error] [-ignore_sdf_cond] [-min |-typ | -max]
    [-store_as_min | -store_as_typ | -store_as_max] [-scale float]
    [-worst_case_mismatched_conds] sdf_filename
```

Reads a Standard Delay Format (SDF) file. After the physical design is complete, backannotate the post-layout delay data for further timing analysis, and use the read\_sdf command to read SDF files into the design. See <u>Reading Standard Delay Format (SDF) Files</u> in the *Common Timing Engine (CTE) User Guide* for more information.

For supported SDF constructs, see <u>Supported SDF Constructs</u> in the *Common Timing Engine* (*CTE*) *User Guide*.

Read in a compressed SDF file in GNU zip format if the specified input file ends in the .gz suffix. No special option is needed to read a gzipped file. For example: read\_sdf sdf\_filename.gz. However, you cannot create a gzipped file with the read\_sdf command.

*Default*: Read all the MTM information in the SDF, and store it as it is presented in the SDF. For example:

read\_sdf SDF

| SDF     | Command               | CTE     |
|---------|-----------------------|---------|
| (1:2:3) | read_sdf (no options) | (1:2:3) |

Use the  $-\min|-typ|-max$  options for pulling the values only from a given MTM field. For example:

read\_sdf -max SDF1
read\_sdf -typ SDF2
read\_sdf -min SDF3

| SDF1        | SDF2        | SDF3        | Commands      | CTE     |
|-------------|-------------|-------------|---------------|---------|
| (2.8:2.9:3) | N/A         | N/A         | read_sdf -max | (::3)   |
| N/A         | (2.0:2:2.1) | N/A         | read_sdf -typ | (:2:3)  |
| N/A         | N/A         | (1:1.1:1.2) | read_sdf -min | (1:2:3) |

In the example session, the first read\_sdf loads the SDF1 max value into the CTE max field, and leaves the min and typ fields unannotated. The next command gets the typ data from another SDF, which still leaves the min field unannotated. The third command completes the annotation by picking up the min value from yet another SDF.

# Caution

# Partially annotated SDFs can give unexpected results. Make sure you fully annotate min/typ/max.

- Tip

The -min | -typ | -max and -store\_as\_min | -store\_as\_typ | -store\_as\_max options provide a powerful mechanism for reading and storing the -min | -typ | -max values from multiple SDF files. However, use these options carefully (see Caution above).

# **Options and Arguments**

| -continue_on_error | Continues to read a file if an error occurs. Usually when an error occurs, the read_sdf command stops reading the file. By specifying this option, you can attempt to continue reading the file if possible. Use caution if you continue because some annotations could be missing due to the errors. Use the <u>report annotations</u> command to find missing annotations. If the file is corrupted, obtain a new SDF file.                                                                                                                                                                                                                                        |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -ignore_sdf_cond   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | Allows the SDF reader to support SDF files with dummy<br>conditions used to speedup simulation. This option is<br>distinguished from the -worst_case_mismatched_conds<br>option that lets the SDF reader match the SDF assertions to<br>timing and check arcs even when their conditions do not match.<br>See Figure 7-4 on page 926.<br>With the -ignore_sdf_cond option, the SDF delay and check<br>assertion is matched with a timing and check arc only if the<br>condition of the SDF assertion matches the condition of the<br>timing/check arc, or the SDF assertion has a condition (dummy<br>condition) and the library timing/check arc does not have one. |
| -min -typ -max     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | Specifies only one field, either the min, typ, or max numbers<br>from the SDF file to be applied to the arc.<br><i>Default</i> : This number is applied to all three delay values in the<br>timing system. To override this behavior, use one of the<br>-store_as_* options.                                                                                                                                                                                                                                                                                                                                                                                         |

| -scale float         | Scales all values in the SDF file by the given number.                                                                                                                                                                                                                |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sdf_filename         | Specifies the name of the SDF file that has the backannotation data.                                                                                                                                                                                                  |
| -store_as_min -store | <pre>e_as_typ   -store_as_max Tells the system to store the specified value into a specific value in the timing system. Must be used with one of the -min   -typ   -max options.These options must be compatible with pvt_early_path and pvt_late_path globals.</pre> |
|                      | For example, to load the minimum values from an SDF file and ignore the other two values, use one of the following sets of commands:                                                                                                                                  |
|                      | <pre>set_global pvt_early_path min set_global pvt_late_path min read_sdf -min -store_as_min</pre>                                                                                                                                                                     |
|                      | <b>Or:</b><br>set_global pvt_early_path typ<br>set_global pvt_late_path typ<br>read_sdf -min -store_as_typ                                                                                                                                                            |
|                      | or simply:<br>read_sdf -min -store_as_max                                                                                                                                                                                                                             |
|                      | <pre>since pvt_early_path and pvt_late_path are set to max by default.</pre>                                                                                                                                                                                          |
|                      | If you want to use the minimum SDF values for early paths and<br>the typical SDF values for late paths, use the following<br>commands:<br>set_global pvt_early_path min<br>set_global pvt_late_path typ<br>read_sdf -min -store_as_min<br>read_sdf -typ -store_as_typ |
|                      | <b>Or:</b><br>set_global pvt_early_path min<br>set_global pvt_late_path max                                                                                                                                                                                           |

read\_sdf -min -store\_as\_min
read\_sdf -typ -store\_as\_max

**Note:** This option assumes that you have previously annotated the design from another SDF file with all three values or that you will eventually fill in all values with subsequent read\_sdf -store\_as\_\* commands. The behavior of the timing analysis is not defined unless all three fields are annotated.

-worst\_case\_mismatched\_conds

Specifies that the SDF file contains conditional delays that do not match the conditional delays in the library. When this option is specified, the mismatched condition is compared to the default conditional delay and the worst delay is used. *Default*: Mismatched conditional delays in the SDF file are ignored. See Figure 7-4 on page 926.

# Examples

The following command scales all delay values in the file typ.sdf by 2:

read\_sdf -scale 2 typ.sdf

■ The following commands store the min values from min.sdf in the min delay of the timing system, and so on for typ and max values. This method is useful when setting up a model for simultaneous worst case, best case analysis:

read\_sdf -min -store\_as\_min min.sdf read\_sdf -typ -store\_as\_typ typ.sdf read\_sdf -max -store\_as\_max max.sdf

*Default*: The default timing analysis type is min\_max.

**Note:** For best-case/worst-case, you must use set\_global
timing\_analysis\_type bc\_wc. For more information about best-case/worst-case
analysis, see Analyzing On and Off Chip Variation
in the Timing Analysis for
BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).

■ Example 7-1, 2-2, and 2-3 show how to use the -worst\_case\_mismatched\_conds and the -ignore\_sdf\_cond options. Assume a timing model as shown in Figure 7-4.

# Figure 7-4 Timing Model



The timing arcs between pin A and pin F are described in the following TLF code:

```
// timing arc (1)
Path( A => F 01 10 COND(B) SDF_COND(B == 1'b1) DELAY(ioDelayFallModel0)
SLEW(SlopeFallModel0) )
Path( A => F 10 01 COND(B) SDF_COND(B == 1'b1) DELAY(ioDelayRiseModel2)
SLEW(SlopeRiseModel2) )
// timing arc (2)
Path( A => F 10 01 COND(~B) SDF_COND(B == 1'b0) DELAY(ioDelayRiseModel1)
SLEW(SlopeRiseModel1) )
```

Assume the SDF description of instance I1 of the library cell FA shown in Example 7-1, where the SDF description matches the TLF description.

# Example 7-1 SDF Description Matches the TLF Description

```
(CELL ( CELLTYPE "FA" )
(INSTANCE I1 )
  (DELAY
        (ABSOLUTE
        ( COND B == 1'bl (IOPATH A F (1.5:1.5:1.5) (3:3:3) ) )// SDF assertion (1)
        (COND B == 1'b0 (IOPATH A F (1:1:1) () ) ) // SDF assertion (2)
        )
)
```

SDF assertion (1) is matched with timing arc (1) and SDF assertion (2) is matched with timing arc (2), therefore, you do not need to use the -ignore\_sdf\_cond or the -worst\_case\_mismatched\_conds options.

Example 7-2 shows a SDF description where you need to use the -worst\_case\_mismatched\_conds option.

#### Example 7-2 SDF Description Using the -worst\_case\_mismatched\_conds Option

```
(CELL ( CELLTYPE "FA" )
(INSTANCE I1 )
  (DELAY
      (ABSOLUTE
      ( COND B == 1'bl (IOPATH A F (1.5:1.5:1.5) (3:3:3) ) )// SDF assertion (1)
      (COND dummyCond (IOPATH A F (1:1:1) (2:2:2) ) ) // SDF assertion (2)
      (IOPATH A F (0.8:0.8:0.8) (1.2:1.2:1.2) ) ) // SDF assertion (3)
      )
)
```

SDF assertion (1) is matched with timing arc (1). However, SDF assertions (2) and (3) cannot be matched with a timing arc, because these conditions do not match a timing arc condition. *Default*: An error message is issued and the delays from these SDF assertions are discarded. If the -worst\_case\_mismatched\_conds option is specified, the condition SDF assertion (2) is ignored, and this assertion is merged with SDF assertion (3). Both assertions are matched with the timing arc (2).

Using the -ignore\_sdf\_cond option will not have any affect as this option will not change the default behavior.

Assume that the timing arcs are described by the following TLF code:

```
// timing arc (1)
Path( A => F 01 10 COND(B) SDF_COND(B == 1'b1) DELAY(ioDelayFallModel0)
SLEW(SlopeFallModel0) )
// timing arc (2)
Path( A => F 10 01 COND(~B) SDF_COND(B == 1'b0) DELAY(ioDelayRiseModel1)
SLEW(SlopeRiseModel1) )
// timing arc (3)
Path( A => F 10 01 DELAY(ioDelayRiseModel2) SLEW(SlopeRiseModel2) )
Path( A => F 01 10 DELAY(ioDelayFallModel2) SLEW(SlopeFallModel2) )
```

Assume now that the SDF description of instance I1 of the library cell FA, after specifying the -ignore\_sdf\_cond option, shown in Example 7-3.

### Example 7-3 SDF Description After Using the -ignore\_sdf\_cond Option

```
(CELL ( CELLTYPE "FA" )
(INSTANCE I1 )
  (DELAY
     (ABSOLUTE
        ( COND B == 1'bl (IOPATH A F () (3:3:3) ) )// SDF assertion (1)
```

```
(COND B == 1'b0 (IOPATH A F (1:1:1) () ) // SDF assertion (2)
  (COND Dummy (IOPATH A F (1.3:1.3:1.3) (2:2:2) ) ) // SDF assertion (3)
  )
)
```

SDF assertion (1) is matched with timing arc (1) and SDF assertion (2) is matched with timing arc (2). SDF assertion (3) cannot be matched to any timing arc, because its condition does not match any timing arc condition.

*Default*: An error message is issued and the delay from SDF assertion (3) is discarded. However, if the -ignore\_sdf\_cond option is specified, condition SDF assertion (3) is assumed to be a dummy condition and is ignored. The SDF assertion (3) is matched with the timing arc (3).

The -worst\_case\_mismatched\_conds option has the same effect as the -ignore\_sdf\_cond in this example. However if you want to allow the mismatches shown in this example, but catch the type of mismatches shown in Example 7-2, then use the -ignore\_sdf\_cond option.

### **Related Information**

<u>read adb</u>

<u>read alf</u>

<u>read\_pdef</u>

<u>read verilog</u>

<u>read vhdl</u>

# read\_spef

read\_spef [-instance instance\_name] [-reduce\_for\_user\_pvt] [-verbose] file\_name

Lets you read in a parasitics file in Standard Parasitics Exchange Format (SPEF). The SPEF file can be in detailed (DSPEF) or reduced (RSPEF) form. Internally a detailed SPEF is reduced. The reduced file is stored in the database and used for delay calculation.

If the OLA library implements all post-layout APIs, CTE passes each RLC network to the OLA library for reduction to obtain the pi model for each driver pin and to get the poles and residues for each net segment in the netlist.

Read in a compressed SPEF file in GNU zip format if the specified input file ends in the .gz suffix. No special option is needed to read a gzipped file. For example: read\_spef spef\_filename.gz. However, you cannot create a gzipped parasitics file with the read\_spef command.

For flow information and details about delay calculation with parasitics, see <u>Reading</u> <u>Parasitics File Formats</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

### **Options and Arguments**

| file_name                  | Specifies the name of the SPEF file to be read.                                                                                                                                                               |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance <i>instance_</i> | name<br>Reads multiple parasitics files associated with different logical or<br>physical hierarchical blocks. The SPEF file being read is<br>associated with the instance specified by <i>instance_name</i> . |
| -reduce_for_user_pvt       | Reduces detailed parasitics only for the corner specified with the <pre>pvt_early_path</pre> and <pre>pvt_late_path</pre> globals. This option <pre>makes runtime faster.</pre>                               |
| -verbose                   | Performs various checks such as resistance loops in detailed parasitics and the completion of parasitics specified and reports them.                                                                          |

# Example

The following performs various checks such as resistance loops in detailed parasitics and the completion of parasitics specified and reports them:

read\_spef -verbose spiffy.spef

### **Related Information**

<u>read\_spf</u>

<u>write spf</u>

# read\_spf

```
read_spf [-instance instance_name] [-reduce_for_user_pvt]
        [-left_bus_delimiter char][-right_bus_delimiter char] [-verbose] file_name
```

Reads in a parasitics file in Standard Parasitics Format (SPF). The SPF file can be in detailed (DSPF) or reduced (RSPF) form. Internally a detailed SPF is reduced. The reduced file is stored in the database and used for delay calculation. Write out the reduced file using the write\_spf command.

Read in a compressed SPF file in GNU zip format if the specified input file ends in the .gz suffix. No special option is needed to read a gzipped file. For example: read\_spf spf\_filename.spf.gz. However, you cannot create a gzipped file with the read\_spf command.

For flow information and details about delay calculation with parasitics, see <u>Reading</u> <u>Parasitics File Formats</u> in *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

### **Options and Arguments**

| file_name            | Specifies the name of the SPF file to read.                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance instance_  | name<br>Reads multiple parasitics files associated with different logical or<br>physical hierarchical blocks. The SPF file being read is<br>associated with the instance specified by <i>instance_name</i> .                                      |
| -left_bus_delimiter  | <i>char</i> -right_bus_delimiter <i>char</i><br>Specifies the left bus delimiter and the right bus delimiter. Both<br>of these options are required for SPF versions 1.3 and older.<br>These options are ignored for SPF versions newer than 1.3. |
| -reduce_for_user_pvt | Reduces detailed parasitics only for the corner specified with the <pre>pvt_early_path and pvt_late_path globals. This option</pre> makes runtime faster.                                                                                         |
| -verbose             | Performs various checks such as resistance loops in detailed<br>parasitics and the completeness of parasitics data and reports<br>them. This option lets you check the correctness of the parasitics<br>file.                                     |

#### Examples

- The following command reads in a version 1.4 detailed SPF file named new.dspf: read\_spf new.dspf
- The following command reads in a version 1.3 reduced SPF file named old.rspf: read\_spf old.rspf -left\_bus\_delimiter \[ -right\_bus\_delimiter \]



Some delimiter characters like square brackets and curly braces must be escaped characters (preceded by  $\)$  for proper Tcl interpretation. See above example.

### **Related Information**

<u>read spef</u>

write\_spf

# read\_stamp

```
read_stamp (-model model_file model_data_file) |
    ({[-min min_model_data_file] | [-typ typ_model_data_file] |
    [-max max_model_data_file]} -model model_file [-name merged_name])
```

Reads in a timing model in the Synopsys Stamp format. Use this command in two ways:

The first usage associates one model data file with the model. In this case, the model data file is assumed to contain typ data:

```
read_stamp -model model_file model_data_file
```

The second usage lets you associate data from one or more model data files to the same model:

```
read_stamp {[-min min_model_data_file] | [-typ typ_model_data_file] |
[-max max_model_data_file]} -model model_file [-name merged_name]
```

# **Options and Arguments**

```
-max max model data file
                         Specifies the name of the max data file associated with the
                         Stamp model.
-min min_model_data_file
                         Specifies the name of the min data file associated with the
                         Stamp model.
model_data_file
                         Specifies the name of the data file associated with the Stamp
                         model. This model data file is assumed to contain typ data.
-model model file
                         Specifies the name of the Stamp model to load.
-name merged lib name
                         Changes the new merged library name to
                         merged_lib_name.
-typ typ_model_data_file
                         Specifies the name of the typ data file associated with the
                         Stamp model.
```

December 2003

# Example

The following command loads the data from cpu.data into the typical field of the library:

read\_stamp -mod cpu.mod cpu.data

#### **Related Information**

reset functional mode

<u>report\_functional\_mode</u>

set functional mode

<u>Using Synopsys Stamp Models</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

# read\_tlf

```
read_tlf [-force] [-silent] [-password password] {{-min filename -max filename
    -typ filename [-name merged_filename]} | tlf_library_filename |
    {list_of_tlf_filenames}}
```

Reads in an encrypted (.etlf) or unencrypted (.tlf) Timing Library Format (TLF) library format. TLF version 4.3 or higher is supported. For information about the latest version supported, see <u>"Using Timing Library Format (TLF) Libraries</u>" in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

Read in a compressed TLF file in GNU zip format if the specified input file ends in the .gz suffix. No special option is needed to read a gzipped file. For example: read\_tlf tlf\_filename.tlf.gz. However, you cannot create a gzipped file with the read\_tlf command.

Use this command in two ways.

■ To read a TLF library into the database, use this form:

read\_tlf [-silent] [-password password] tlf\_library\_filename

If the library has complete triplets of data (min/typ/max values), then all three fields are loaded simultaneously.

To create and read a merged TLF library from multiple single operating point libraries, use this form:

```
read_tlf [-silent] [-password password]
{{-min filename -max filename -typ filename -name merged_filename}}
```

Use the  $-\min$ , -typ, and  $-\max$  options to create a merged library from libraries containing one or more operating point data. The libraries to be merged must contain data in the appropriate operating point field or the typ field. For example, if the library for the  $-\min(-\max)$  option contains multiple operating point data, it must contain data in the  $\min(\max)$  or typ field. The merged library is read into the database immediately. See Example on page 937.

The values from each library are scaled to the current session units using the units from that library. The first library read\_ command will provide the default session units. The library for the max corner is used for the default units if it is present, otherwise the typ corner is used, or finally, the min corner.

Use the -name option to change the name of the merged library to a new name. For example, -name merged\_filename changes the merged library name to merged\_filename.

Note: When performing crosstalk analysis using the do\_analyze\_crosstalk -engine celtic command, CeltIC<sup>™</sup> does not support

the signal integrity (SI) analysis of two mixed corner-case timing libraries. For example:

read\_tlf -min \$rootDir/links/tsmc13\_ff.tlf -max \$rootDir/links/tsmc13\_ss.tlf
-name tsmc13

CeltIC only supports the use of single corner-case timing libraries each time SI is performed.

### **Options and Arguments**

| -force                     | Overrides invalid 0-100 percent measured threshold values. If<br>you do not use this option, CTE will not read libraries that define<br>0-100 percent threshold values. The measured delay threshold<br>value is 50-50, while the measured slew threshold is 40-60. Also<br>lets older TLF versions lower than 4.3 be accepted. |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| list_of_tlf_filena         | Mes<br>Allows reading multiple tlf library filenames. Use curly braces to<br>specify multiple library filenames, for example:<br>{lib1 lib2 lib3}                                                                                                                                                                               |
| -max filename              | Uses max data from the library $filename$ to populate the max field of the merged library. If the max data is not present, the typ data is used. This option is required when using the -name option.                                                                                                                           |
| -min <i>filename</i>       | Uses min data from the library <i>filename</i> to populate the min field of the merged library. If the min data is not present, the typ data is used. This option is required when using the <i>-name</i> option.                                                                                                               |
| -name <i>merged_filena</i> | ame<br>Changes the name of the merged library to<br>merged_filename. This option requires the use of the -min,<br>-typ, -max options.                                                                                                                                                                                           |
| -password password         | Passes the key password for an encrypted TLF library.                                                                                                                                                                                                                                                                           |

| -silent            | Suppresses the message which says that the library has been successfully loaded.                                                                |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| tlf_library_filena | me<br>Specifies the name of the tlf library filename.                                                                                           |
| -typ filename      | Uses typ data from the library $filename$ to populate the typ field of the merged library. This option is required when using the -name option. |

# Example

■ The following command picks up min values from the min.tlf library and populates the min fields of the merged library with name merged\_lib. If min values are not present in min.tlf then typ values are used. The typ values are obtained from the typ.tlf library. Likewise max values of the merged library are obtained from the max.tlf library. If max values are not present in max.tlf, then typ values are used:

read\_tlf -min min.tlf -typ typ.tlf -max max.tlf -name merged.tlf

Suppose min.tlf contains (0.01:0.02:0.03) as the (min:typ:max) pin-to-pin delay for some cell, typ.tlf contains (0.04:0.05:0.06) for the corresponding delay, and max.tlf contains (0.07:0.08:0.09), the resultant triplet in merged.tlf is (0.01:0.05:0.09).

#### **Related Information**

<u>read alf</u>

<u>read\_dotlib</u>

<u>"Using Timing Library Format (TLF) Libraries</u>" in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

## remove\_assertions

Removes all (or specified) assertions on the given list of pins. This command removes assertions on a pin in a more general way than the reset\_\* commands.

The impact on the database is to remove the assertions; there is no change to the netlist.

By contrast, the reset\_\* commands provide specific ways to remove assertions. The rules for resetting an assertion are the same for setting one. The following example shows the difference between reset\_\* assertion and remove\_assertions. First, the command below sets a late external\_delay assertion on pin out with a clock CLK:

set\_external\_delay -clock CLK out 0

Then the following command resets the late external\_delay assertion on pin out:

reset\_external\_delay -clock CLK out

However, this command would not:

reset\_external\_delay out

The original assertion is not reset because the -clock option is not specified (the default clock is @, which is different from CLK). To remove general assertions, use the following command:

remove\_assertions -type external\_delay out

The above command removes all external\_delay assertions on pin out, regardless of rise or fall, early or late, or clock.

**Note:** Currently, the remove\_assertions command does not remove assertions that are set on waveforms. Use the reset\_\* commands to remove assertions from waveforms. For example, reset\_clock\_uncertainty or reset\_clock\_insertion\_delay.

#### **Options and Arguments**

list\_of\_pins

Specifies the pins where the assertion is to be removed.

-type assertion\_type

Removes only the assertion types specified. When no -type option is provided, the default is to remove all assertions listed

below. The following are the allowable <code>assertion\_type</code> values:

#### arrival

Removes assertions previously given by the <u>set data arrival time</u> command. Also removes assertions given by the obsolete <u>set clock arrival time</u> command.

#### clock\_arrival\_time

Removes only assertions given by the obsolete <u>set clock arrival time</u> command.

#### clock\_gating\_check

Removes only assertions previously given by the <u>set\_clock\_gating\_check</u> command.

#### clock\_info\_change

Removes only assertions previously given by the <u>set clock info change</u> command.

#### clock\_insertion\_delay

Removes only assertions previously given by the <u>set clock insertion delay</u> command for both source and network pins. Waveform insertion delays are not removed.

#### clock\_required\_time

Removes only assertions given by the rarely used <u>set clock required time</u> command.

#### clock\_root

Removes only assertions previously given by the <u>set clock root</u> command.

#### clock\_uncertainty

Removes only assertions previously given by the <u>set\_clock\_uncertainty</u> command. Waveform uncertainty is not removed.

#### constant\_for\_timing

Removes only assertions previously given by the <u>set constant for timing</u> command.

Common Timing Engine (CTE) Commands

#### data\_arrival\_time

Removes only assertions previously given by the <u>set data arrival time</u> command.

#### data\_required\_time

Removes only assertions previously given by the <u>set\_data\_required\_time</u> command.

#### drive\_cell

Removes only assertions previously given by the <u>set drive cell</u> command.

#### drive\_resistance

Removes only assertions previously given by the <u>set drive resistance</u> command.

#### external\_delay

Removes only assertions previously given by the <u>set\_external\_delay</u> command.

#### fanout\_load

Removes only assertions previously given by the <u>set fanout load limit</u> command.

#### fanout\_load\_limit

Removes only assertions previously given by the <u>set fanout load limit</u> command.

#### generated\_clock

Removes only assertions previously given by the <u>set\_generated\_clock</u> command.

#### num\_external\_sinks

Removes only assertions previously given by the <u>set num external sinks</u> command.

#### num\_external\_sources

Removes only assertions previously given by the <u>set num external sources</u> command.

#### port\_capacitance

Removes only assertions previously given by the <u>set\_port\_capacitance</u> command.

port\_capacitance\_limit
Removes only assertions previously given by the
set port capacitance limit command.

port\_wire\_load
Removes only assertions previously given by the
set\_port\_wire\_load command.

#### required

Removes assertions previously given by the <u>set data required time</u> command. Also removes assertions given by the rarely used <u>set clock required time</u> command.

#### slew\_time

Removes only assertions previously given by the <u>set\_slew\_time</u> command.

slew\_time\_limit

Removes only assertions previously given by the <u>set slew time limit</u> command.

#### time\_borrow\_limit

Removes only assertions previously given by the <u>set\_time\_borrow\_limit</u> command.

# Examples

The following command writes the existing assertions, then removes some, and writes a new assertions file:

```
write_assertions assert.txt
cat assert.txt
set_current_module {top}
set_top_timing_module {top}
set_clock_propagation ideal
set_input_delay -clock clkA -lead -early -rise 0.000 {in}
set_external_delay -clock clkA -lead -late -rise 0.000 {out}
#end of assertions for module top
```

The following command removes assertions on ports in and out:

```
remove_assertions [find -port in out]
write assertions assert2.txt
```

```
cat assert2.txt
set_current_module {top}
set_top_timing_module {top}
set_clock_propagation ideal
#end of assertions for module top
```

# **Related Information**

<u>reset clock info change</u>

reset\_clock\_gating\_check

<u>reset clock root</u>

reset clock uncertainty

reset\_constant\_for\_timing

<u>reset drive cell</u>

<u>reset\_external\_delay</u>

<u>reset\_fanout\_load</u>

reset fanout load limit

reset generated clock

<u>reset\_input\_delay</u>

<u>reset port capacitance</u>

reset port capacitance limit

<u>reset\_port\_wire\_load</u>

<u>reset num external sinks</u>

<u>reset num external sources</u>

reset\_time\_borrow\_limit

set\_clock\_arrival\_time

set clock required time

- set\_data\_arrival\_time
- set data required time
- set drive resistance
- set\_slew\_time
- <u>set slew time limit</u>
- write assertions

# report\_analysis\_coverage

```
report_analysis_coverage [-pins pin_list] [-check_type check_type_list]
  [-verbose check_status_list] [-sort {pin | refpin | checktype | slack |
    reason}] [-tcl_list] [{> | >> } file_name]
  Valid check types are clock_gating_hold clock_gating_pulse_width
    clock_gating_setup clock_period clock_separation external_delay hold
    no_change_hold no_change_setup path_delay pulse_width recovery removal setup
    skew time_borrow
    Valid status types are: met untested violated
```

Provides information about the timing checks in the design. For each type of timing check, the command reports the number of checks that meet constraints, violated constraints, or that are untested in the SUMMARY section. The DETAILS section includes information about the signal pin, reference pin, check type, slack, and the reason for being untested.

A met check shows as a positive value in the Slack column. A violated check shows as a negative value in the Slack column. An untested check shows as UNTESTED in the Slack column and the reason is given in the Reason column. The Reason column is blank when a Slack number is given because the check has been tested.

**Note:** If there are no timing checks in the design of the type specified by -check\_type, the report shows "No timing checks found."

Tip

Use <u>check timing</u> to look for missing assertions.

# **Options and Arguments**

{> | >>} filename

Stores the generated report in the file specified by *filename*. If no file name is specified, the report is displayed on standard output. The file name must be the last argument in the list.

```
-check_type check_type_list
```

Limits the report to the type of check(s) in the *check\_type\_list*.

Valid check types are: setup, hold, pulse\_width, clock\_period, clock\_gating\_setup, clock\_gating\_hold, clock\_gating\_pulse\_width, recovery, removal, clock\_separation, skew, no\_change\_setup, no\_change\_hold, time\_borrow,

|                       | external_delay, and path_delay.<br>Default: All check_types are reported.                                                                                                                                                         |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -pins <i>pin_list</i> | Limits the report to timing checks on pins in <i>pin_list</i> .                                                                                                                                                                   |
| -sort {pin   refpin   | checktype   slack   reason}<br>While reporting detailed information (-detail option), checks<br>are sorted by the specified method.<br><i>Default</i> : The checks are sorted by pin. This option requires the<br>-detail option. |
|                       | The $-sort$ option does not change the order of the columns.<br>When you sort by $slack$ , the slack value is reported in order of<br>least negative to most negative (worst slack last).                                         |
|                       |                                                                                                                                                                                                                                   |

Improve usability of the report for debugging purposes by using the -detail and -sort options as shown in these examples:

report\_analysis\_coverage -detail untested -sort reason
report\_analysis\_coverage -detail violated -sort slack

-tcl\_list

Produces a report in a tcl list, not a human-readable report. This is useful for integrating timing with custom Tcl functions and also for customizing report generation.

-verbose check\_status\_list

Limits the detailed information to only the checks with the status specified.

*Default*: The details are shown regardless of met, violated, or untested status. A default report is given in the Examples section.

Valid status types are: met, violated, and untested.

**Note**: The -verbose option replaces the -detail option, which is obsolete.



Reduce the number of lines in the DETAILS section and improve usability of the report by using the -detail option to filter out the met checks as shown in this example:

report\_analysis\_coverage -detail {violated untested}

## Example

The following command provides information about the timing checks in the design:

report\_analysis\_coverage

| +             | TIMING (         | CHECK COVER        | RAGE SUMMARY      | ζ                  |
|---------------|------------------|--------------------|-------------------|--------------------|
| Check<br>Type | No. of<br>Checks | Met                | Violated          | Untested           |
| Hold<br>Setup | 7<br>7           | 2 (28%)<br>4 (58%) | 1 (14%)<br>0 (0%) | 4 (58%)<br>3 (42%) |

| TIMING CHECK COVERAGE DETAILS                                                                                                                              |                                                                                                                                                        |                                                                                                             |                                                                                                                                           |                                                                                                                                                          |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Pin                                                                                                                                                        | Reference<br>Pin                                                                                                                                       | Check<br>Type                                                                                               | Slack                                                                                                                                     | Reason                                                                                                                                                   |  |  |  |  |
| reg1/D<br>reg1/D<br>reg2/D<br>reg2/D ^<br>reg2/D v<br>reg3/D v<br>reg3/D ^<br>reg3/D ^<br>reg4/D ^<br>reg4/D ^<br>reg4/D v<br>reg4/D v<br>reg5/D<br>reg5/D | reg1/CP ^<br>reg2/CP ^<br>reg2/CP ^<br>reg2/CP ^<br>reg3/CP ^<br>reg3/CP ^<br>reg3/CP ^<br>reg4/CP ^<br>reg4/CP ^<br>reg4/CP ^<br>reg4/CP ^<br>reg5/CP | Setup<br>Hold<br>Setup<br>Hold<br>Hold<br>Setup<br>Setup<br>Hold<br>Setup<br>Setup<br>Hold<br>Setup<br>Hold | UNTESTED<br>UNTESTED<br>UNTESTED<br>1.05<br>UNTESTED<br>1.86<br>1.90<br>0.05<br>2.86<br>-0.07<br>2.90<br>UNTESTED<br>UNTESTED<br>UNTESTED | No data signal<br>No data signal<br>No data signal<br>Data signal with @ clock<br>Data signal with @ clock<br>No reference signal<br>No reference signal |  |  |  |  |

#### **Related Information**

<u>check\_timing</u>

<u>report\_timing</u>

<u>set table style</u>

**Note:** Setting the <u>clock gating regardless of downstream logic</u> global can effect timing related report commands. For example, the report\_analysis\_coverage command may or may not report clock gating checks.

# report\_annotated\_check

```
report_annotated_check [-missing_delays] [-missing_setup] [-missing_hold]
   [-missing_recovery] [-missing_removal] [-missing_no_change]
   [-missing_period] [-missing_skew] [-missing_mpw] [-max_missing integer]
   [-tcl_list]
```

Reports coverage of annotated timing checks. To limit the search for annotations to a specific area of a design, use the set\_current\_module and set\_current\_instance commands before using the report\_annotated\_check command.

## **Options and Arguments**

| -max_missing integer | Limits the number of missing annotations to the number specified.<br>Default: 1000                        |
|----------------------|-----------------------------------------------------------------------------------------------------------|
| -missing_delay       | Reports all the timing checks that are missing SDF annotations, in addition to the total coverage report. |
| -missing_hold        | Provides a detailed report of the missing annotations on hold timing checks.                              |
| -missing_mpw         | Provides a detailed report of the missing annotations on both mpwl and mpwh timing checks                 |
| -missing_no_change   | Provides a detailed report of the missing annotations on the no_change timing checks.                     |
| -missing_period      | Provides a detailed report of the missing annotations on period timing checks.                            |
| -missing_recovery    | Provides a detailed report of the missing annotations on recovery timing checks.                          |

| -missing_removal | Provides a detailed report of the missing annotations on removal timing checks |
|------------------|--------------------------------------------------------------------------------|
| -missing_setup   | Provides a detailed report of the missing annotations on setup timing checks.  |
| -missing_skew    | Provides a detailed report of the missing annotations on skew timing checks.   |
| -tcl_list        | Formats the information for use in a Tcl program.                              |

## Examples

- The following command reports missing annotated setups in SDF: report\_annotated\_check -missing\_setup
- The following command reports all the missing annotated timing checks in SDF: report\_annotated\_check -missing\_delays

# **Related Information**

set current module

set current instance

# report\_annotations

```
report_annotations [-missing_resistances] [-missing_capacitances] [-missing_rc]
    [-missing_delays] [-missing_spf] [-max_missing integer] [-tcl_list]
    [-ignore_floating_nets] [-ignore_tied_low_high_nets]
```

Reports the coverage of the annotations on a design. These annotations include SDF delay arc annotations, SPF annotations, wire resistances, and wire capacitances.

Limit the search for annotations to a specific area of the design by specifying the set\_current\_module and set\_current\_instance commands before issuing the report\_annotations command.

Use the *-missing\_*\* options to get a detailed report of all delay arcs and wires that are missing annotations. You can use the information in a Tcl program.

## **Options and Arguments**

| -ignore_floating_net        | ຣ<br>Ignores nets without drivers.                                                                                           |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------|
| -ignore_tied_low_hig        | h_nets<br>Ignores timing arcs of power and ground nets.                                                                      |
| -max_missing <i>integer</i> | Limits the number of missing annotations to the number specified.<br>Default: 1000                                           |
| -missing_capacitance        | s<br>Reports the nets that are missing capacitances.<br><i>Default</i> : Only a summary of the coverage is reported.         |
| -missing_delays             | Reports the arcs that are missing SDF annotations. <i>Default</i> : Only a summary of the coverage is reported.              |
| -missing_rc                 | Reports the nets that are missing resistances and capacitances. <i>Default</i> : Only a summary of the coverage is reported. |
| -missing_resistances        | Reports the nets that are missing resistances.<br><i>Default</i> : Only a summary of the coverage is reported.               |

| -missing_spf |                                                      |
|--------------|------------------------------------------------------|
|              | Reports the nets that are missing SPF data.          |
|              | Default: Only a summary of the coverage is reported. |
|              |                                                      |
| -tcl_list    |                                                      |
|              | Formats the information for use in a Tcl program.    |

## Examples

The following command reports the nets that are missing capacitances: report\_annotations -missing\_capacitances

Default: Only a summary of the coverage is reported.

- The following commands show the difference between the summary and the \_missing\_spf reports:
  - $\Box$  report\_annotations

| - | Total<br>Nets | Total C<br>Annotated | Percentage<br>C<br>Annotated | Total R<br>  Annotated | Percentage<br>R<br>Annotated | Total SPF<br>Annotated | Percentage<br>SPF<br>Annotated |
|---|---------------|----------------------|------------------------------|------------------------|------------------------------|------------------------|--------------------------------|
| 1 | 21            | 0                    | 0.000000                     | 0                      | 0.000000                     | 15                     | 0.714286                       |

| Total<br>Arcs | Total<br>Arcs<br>Annotated | Percentage<br>Arcs<br>Annotated |
|---------------|----------------------------|---------------------------------|
| 272           | 0                          | 0.000000                        |

report\_annotations -missing\_spf

|          |   | Min |     |      | Тур |          |   | Max |          |
|----------|---|-----|-----|------|-----|----------|---|-----|----------|
| Net Name | R | C   | SPF | <br> | C   | SPF      | R | C   | _ SPF    |
| bar/n019 | - | -+  | N   | +    | –   | +<br>  N | + | +   | +<br>  N |
| bar/n018 | - | -   | N N | -    | -   | N        | - | -   | N        |
| bar/n017 | - | -   | N N | -    | -   | N        | - | -   | N        |

If your SDF has only cell arcs, and net delays are included in the cell delays, you can report the status of annotation for cell arcs, internal net arcs, net arcs from primary inputs, and net arcs to primary outputs, and all timing arcs separately as shown below:

report\_annotations

| +              |       |           |           | +          |
|----------------|-------|-----------|-----------|------------|
| Delay Arc Type | Total | Annotated | Not       | Percentage |
|                |       |           | Annotated | Annotated  |

|                                                                     | +                             |                              |                               | +                                                |
|---------------------------------------------------------------------|-------------------------------|------------------------------|-------------------------------|--------------------------------------------------|
| Cell arcs<br>Input net arcs<br>Internal net arcs<br>Output net arcs | 551319<br>18<br>501156<br>597 | 353103<br>7<br>304341<br>456 | 198216<br>11<br>196815<br>141 | 64.046951<br>38.888889<br>60.727798<br>76.381912 |
| +All timing arcs                                                    | 1053090                       | 657907                       | 395183                        | 62.473957                                        |

# **Related Information**

<u>report\_net</u>

# report\_cell\_instance

```
report_cell_instance list_of_cell_instances [-timing | -power]
      [-early | -late] [-tcl_list] filename
```

Reports information about the timing context or power specifications of a library cell instance. *Default*: -timing.

Timing information on all pins of the instance are reported, followed by all the delay arcs between those pins.

Note: Internal pins (pins inside the instance boundary) are also reported.

The timing report contains three tables:

■ The first table in the report contains information about the pins of the instance.

The propagated slew is the slew that is propagated to the pin, based on the slew propagation mode.

■ The second table contains information about the arcs through the instance.

The slew out is the slew calculated at the arc output from the arc input slew, using the timing model.

■ The third table contains information about the timing checks, if present, on the cell.

Only checks that are from the library are shown in this table. Automatic checks, such as clock gating setup and hold, are not reported.

Power information includes three tables showing the cell internal power, leakage power, and net power. You must have a license that includes low power synthesis to get this information.

The following table indicates the table names to be specified with the <u>set table style</u> command if you want to adjust the format of the tables generated with report\_cell\_instance -power.

| Table Name for set_table_style | Corresponds to                  |
|--------------------------------|---------------------------------|
| pa_inst_leak_pwr_rep_table     | leakage power table             |
| pa_inst_net_pwr_rep_table      | net power table                 |
| pa_inst_int_pwr_rep_table      | first table for internal power  |
| pa_inst_int_pwr_rep_table1     | second table for internal power |

# **Options and Arguments**

| -early -late        | Reports the early timing (data hold/clock setup) or late timing (data setup/clock hold).                                                                                                                                                    |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| filename            | <i>Default</i> : -late                                                                                                                                                                                                                      |
|                     | Specifies the name of the output file where the tables are printed out.<br>Default: stdout                                                                                                                                                  |
| list_of_cell_instar |                                                                                                                                                                                                                                             |
|                     | Specifies a flat (non-hierarchical) cell instance or list of cell instances. Use curly braces ({ }) to enclose the list and separate the instance names with white space.                                                                   |
| -power              | Reports information about the power specifications of a library cell instance, as shown in the Examples section below. Without the -power option, the timing information is reported. You must read in a TCF file before using this option. |
| -tcl_list           |                                                                                                                                                                                                                                             |
|                     | Produces the report in a Tcl list instead of the default table<br>report. Use this option to integrate timing or power analysis with<br>custom Tcl functions or to customize report generation.                                             |
| -timing             |                                                                                                                                                                                                                                             |
|                     | Reports information about the timing context of a library cell instance. This is the default report. See the Examples section below.                                                                                                        |

# Examples

■ Reports information about the timing context of instance reg01:

report\_cell\_instance -timing reg01

| +<br> <br>+ |     |                    | Instance re | eg01 of LD1 |       | ++<br> <br>+      |
|-------------|-----|--------------------|-------------|-------------|-------|-------------------|
|             | Pin | Propagated<br>Slew | Arrival     | Required    | Slack | Phase             |
|             | Q ^ |                    | +           | +<br>  1.78 | +     | + <br>  CLK(D)(P) |

|    | Q V<br>QN ^<br>QN V<br>D ^<br>G V<br>G V | (<br>(<br>(<br>(                                          | D.06<br>D.02<br>D.03<br>D.03<br>D.03<br>D.03<br>D.03<br>D.00<br>D.00 | 0.65<br>0.66<br>0.71<br>1.25<br>1.31<br>0.04<br>2.03         | 1.7<br>0.08<br>0.0<br>1.16<br>5.29   | 3 -1.17<br>7 -1.24<br>5 1.12                                 | CLK(D)(P)<br>CLK(D)(P)<br>CLK(D)(P)<br>CLK(D)(P)<br>CLK(D)(P)<br>CLK(C)(P)                           | +                                                |
|----|------------------------------------------|-----------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| +- |                                          |                                                           | Insta                                                                | ance reg(                                                    | )1 of LD1                            | <br>L                                                        | ++                                                                                                   |                                                  |
|    | Ar                                       |                                                           | Sle                                                                  | ≥w                                                           |                                      |                                                              |                                                                                                      |                                                  |
|    | From                                     | То                                                        | In                                                                   | Out                                                          | Load                                 | Delay                                                        | Phase                                                                                                |                                                  |
| +- | <pre></pre>                              | QN V<br>QN ^<br>Q V<br>QN ^<br>QN v<br>QN v<br>Q v<br>Q v | 0.03<br>0.03<br>0.03<br>0.03<br>0.00<br>0.00<br>0.00<br>0.00         | 0.03<br>0.02<br>0.09<br>0.07<br>0.02<br>0.03<br>0.09<br>0.06 | 0.12<br>0.12<br>0.12<br>0.12<br>0.12 | 0.62<br>0.59<br>0.58<br>0.57<br>0.62<br>0.67<br>0.62<br>0.61 | CLK(D)(P)<br>CLK(D)(P)<br>CLK(D)(P)<br>CLK(D)(P)<br>CLK(C)(P)<br>CLK(C)(P)<br>CLK(C)(P)<br>CLK(C)(P) |                                                  |
| +- |                                          |                                                           |                                                                      | Instar                                                       | nce reg01                            | l of LD1                                                     |                                                                                                      | ++                                               |
|    |                                          | Pins                                                      |                                                                      |                                                              |                                      | <br> <br>+                                                   | Phas                                                                                                 | e                                                |
|    | Check                                    | Sig                                                       | Ref                                                                  | Slack                                                        | <br>  Delay                          | Adjust                                                       | Sig                                                                                                  | Ref                                              |
|    | HOLD<br>HOLD<br>SETUP<br>SETUP           | D ^<br>D V<br>D ^<br>D V                                  | G V<br>G V<br>G V<br>G V                                             | 3.22<br>3.29<br>0.73<br>0.53                                 | 0.01<br>0.01<br>0.05<br>0.19         | 4.00<br>4.00<br>0.00<br>0.00                                 | CLK(D)(P)<br>CLK(D)(P)<br>CLK(D)(P)<br>CLK(D)(P)                                                     | CLK(C)(P)<br>CLK(C)(P)<br>CLK(C)(P)<br>CLK(C)(P) |

# ■ If a constant is asserted or propagated to the instance pin, it is reported in the *Phase* column of the pin table:

report\_cell\_instance -timing xor2

| + | Instance xor2 of XOR2         |                              |                 |                              |                              |          |       |                                                                |
|---|-------------------------------|------------------------------|-----------------|------------------------------|------------------------------|----------|-------|----------------------------------------------------------------|
|   | Pin                           | Dir                          | Propaga<br>Slev |                              | Arrival                      | Required | Slack | Phase                                                          |
| + | Y ^<br>Y V<br>A ^<br>A V<br>B | OUT<br>OUT<br>IN<br>IN<br>IN |                 | 1.00<br>1.00<br>0.00<br>0.00 | 1.00<br>6.00<br>0.00<br>5.00 | 0.00     |       | clk(C)(P)<br>clk(C)(P)<br>clk(C)(P)<br>clk(C)(P)<br>Constant 0 |
| + | Instance xor2 of XOR2         |                              |                 |                              |                              |          |       |                                                                |
|   | Ar                            | c                            | Slew            |                              |                              |          |       |                                                                |
|   | From                          | То                           | In<br>          | Out                          | Load                         | Delay    | Phase |                                                                |

| A ^<br>A v<br>A v<br>B ^<br>B ^<br>B v<br>B v<br>B v | Y *<br>Y V<br>Y *<br>Y *<br>Y *<br>Y *<br>Y * | 0.00<br>0.00<br>0.00<br>0.00 | 1.00 | 1.00<br>1.00<br>1.00<br>1.00<br>1.00<br>1.00<br>1.00<br>1.00 | 1.00 | <pre>clk(C)(P)<br/>clk(C)(P)<br/>clk(C)(P)<br/>clk(C)(P)</pre> |  |
|------------------------------------------------------|-----------------------------------------------|------------------------------|------|--------------------------------------------------------------|------|----------------------------------------------------------------|--|
|------------------------------------------------------|-----------------------------------------------|------------------------------|------|--------------------------------------------------------------|------|----------------------------------------------------------------|--|

■ In the power report, a "-" in the column implies that the value is not present for those fields.

report\_cell\_instance -power i\_53 ex.rpt

| +<br>Report                | report_cell_instance  |
|----------------------------|-----------------------|
| Options                    | -power i_191 > ex.rpt |
| Date                       | 20021018.173603       |
| Tool                       | pks_shell             |
| Release                    | v5.0-s005             |
| Version                    | Oct 15 2002 15:12:07  |
| Module                     | AWDP_MULT_0           |
| Timing Operating Condition | slow                  |
| Power Operating Library    | Typical               |
| Process                    | 1.000000              |
| Voltage                    | 1.620000              |
| Temperature                | 125.000000            |
| time unit                  | 1.00 ns               |
| capacitance unit           | 1.00 pF               |
| power unit                 | 1.00mW                |

|      | Internal Cell Power for i_1/i_191 |        |     |           |      |     |      |           |           |
|------|-----------------------------------|--------|-----|-----------|------|-----|------|-----------|-----------|
|      |                                   | Source | Pin |           |      |     | S    | ink Pin   |           |
| name | dir                               | slew   | cap | td        | name | dir | slew | cap       | td        |
| В    | ^v                                | 0.2002 | -   | 2.655e-03 | Y    | v   | _    | 5.729e-03 | 5.067e-03 |
| В    | ^v                                | 0.2002 | -   | 2.655e-03 | Y    | ^   | -    | 5.729e-03 | 5.067e-03 |
| В    | ^v                                | 0.2002 | -   | 2.655e-03 | Y    | v   | -    | 5.729e-03 | 5.067e-03 |
| В    | ^v                                | 0.2002 | -   | 2.655e-03 | Y    | ^   | -    | 5.729e-03 | 5.067e-03 |
| A    | ^v                                | 0.3145 | -   | 2.412e-03 | Y    | v   | -    | 5.729e-03 | 5.067e-03 |
| А    | ^v                                | 0.3145 | -   | 2.412e-03 | Y    | ^   | -    | 5.729e-03 | 5.067e-03 |
| A    | ^v                                | 0.3145 | -   | 2.412e-03 | Y    | v   | _    | 5.729e-03 | 5.067e-03 |
| A    | ^v                                | 0.3145 | _   | 2.412e-03 | Y    | ^   | -    | 5.729e-03 | 5.067e-03 |
| -    | -                                 | -      | _   | _         | -    | -   | -    | -         | -         |

| Interna                         | al Cel                                                                       | l Power f                                      | or i_1/i_5                                           | 3 (cont.)                                                                                                    |                                                                                          |                                                                                                                   |
|---------------------------------|------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| C                               | Other                                                                        | Pin                                            | When<br>Condi                                        | effTD                                                                                                        | arcPo<br>wer                                                                             | effPower                                                                                                          |
| name                            | sle                                                                          | w   cap                                        |                                                      |                                                                                                              |                                                                                          |                                                                                                                   |
| -<br>-<br>-<br>-<br>-<br>-<br>- | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- |                                                | ! (A)<br>! (A)<br>A<br>A<br>! (B)<br>! (B)<br>B<br>B | 2.008e-04<br>2.008e-04<br>1.127e-03<br>1.127e-03<br>2.650e-04<br>2.650e-04<br>9.409e-04<br>9.409e-04<br>Tota | 0.0405<br>0.0235<br>0.0262<br>0.0386<br>0.0277<br>0.0116<br>0.0215<br>0.0300<br>al Power | 8.129e-06<br>4.726e-06<br>2.948e-05<br>4.354e-05<br>7.332e-06<br>3.085e-06<br>2.021e-05<br>2.822e-05<br>1.447e-04 |
|                                 |                                                                              | Leakage<br>i_0/                                | Power for<br>i_0                                     |                                                                                                              | +                                                                                        |                                                                                                                   |
| Wher<br>Condit                  |                                                                              | When  <br>Prob                                 | Leak<br>Power                                        | Eff Leal<br>Power                                                                                            | k                                                                                        |                                                                                                                   |
|                                 | +                                                                            | 1.0000  <br>T                                  | 1.458e-07<br>otal Power                              |                                                                                                              | -                                                                                        |                                                                                                                   |
| Net Power for i_0/i_0           |                                                                              |                                                |                                                      |                                                                                                              |                                                                                          |                                                                                                                   |
| Name   Cap                      |                                                                              | TD                                             | Prob                                                 | Power                                                                                                        |                                                                                          |                                                                                                                   |
| 00[10] 0.0057                   |                                                                              | 2.412e-0<br>2.655e-0<br>5.067e-0<br>Total Powe | 3 0.2485<br>3 0.5026                                 | 0.0000<br>3.809e-0                                                                                           | 05                                                                                       |                                                                                                                   |

#### **Related Information**

<u>get timing</u>

<u>report net</u>

<u>report\_timing</u>

set global slew propagation mode

<u>set table style</u>

# report\_cell\_instance\_timing

report\_cell\_instance\_timing

This command is obsolete.Use the <u>report cell instance</u> -timing command instead.

# report\_clocks

```
report_clocks [-description] [-arrival_points] [-clock_to_data] [-data_to_clock]
    [-phase_shift_table] [-total_shift_table] [-uncertainty_table]
    [-adjustment_table] [-delay_adjustment_table] [-source_insertion]
    [-insertion] [-generated] [-clocks clk_signame | clk_signame_list]
    [-tcl_list] [{> | >>} filename]
```

Reports information about ideal (or generated) clocks and assertions with respect to those clocks. It reports information about all clock waveforms, clock arrival points, clock uncertainties, where clocks are converted to data, and where data is converted to clocks.

Use the -description, -arrival\_points, -clock\_to\_data, -data\_to\_clock, -uncertainty\_table, and the \*\_table options to specify different parts of the report. If one of these options is supplied, only the section that the option corresponds to is reported. If other options are supplied, those sections are also reported.

Use the -tcl\_list option to format the information for use in a Tcl program.



The report\_clocks command only reports assertions with respect to clock waveforms. Use the report\_port -type command for assertions applied to clock pins (except for the set\_clock\_root command, which can be reported by either command). If you use the set\_clock\_info\_change command, use the report\_port -type arrival command, not the report\_clocks -arrival command. For more information, see <u>report\_ports</u>.

# **Options and Arguments**

```
{> | >>} filename
```

Specifies the name of the file in which the report is saved. The *filename* argument must be the last argument in the list. If the file name is not specified, the report displays on the standard output without being saved. Since the report is often large, text may be lost if you do not save the report to a file.

```
-adjustment_table
```

Reports two tables that detail the early and late cycle adjustments between clock waveforms as set by the set\_cycle\_addition command.

|                           | <b>Note:</b> If specific ideal (or generated) clocks are requested with the -clocks <i>clock_name_list</i> option, then only the relationships between those clock signals are reported.                                                                                                                                                                                                                                                                                                   |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -arrival_points           | Reports only the clock arrival points. A clock arrival point is the pin where the set_clock_root or the set_clock_arrival_time command has been asserted.                                                                                                                                                                                                                                                                                                                                  |
|                           | The data is reported differently if the set_clock_root<br>command is used instead of the set_clock_arrival_time<br>command. If the set_clock_arrival_time command is<br>used, the early/late rise/fall fields are displayed along with the<br>Ideal (or generated) clock name and the place where the clock is<br>attached. If the set_clock_root command is used, only the<br>Ideal clock name and the attachment point are displayed; the<br>rise/fall early/late fields are left empty. |
| -clock_to_data            | Reports only the clock to data change points. A clock to data change point is where the set_clock_info_change command has been used to convert any clock signals to data signals.                                                                                                                                                                                                                                                                                                          |
| -clocks <i>clock_name</i> | <pre>clock_name_list Requests information on a specific ideal (or generated) clock. If a list is given, only information about those clocks is reported. You can use wildcards in the names. Default: All ideal clocks are reported. Use the -generated option to also report generated clocks.</pre>                                                                                                                                                                                      |
| -data_to_clock            | Reports only the data-to-clock change points. A data-to-clock change point is where the set_clock_info_change command has been used to convert any data signals to clock signals.                                                                                                                                                                                                                                                                                                          |
| -delay_adjustment_ta      | Reports two tables that detail the early and late path delay<br>adjustments between clock waveforms as set by the<br>set_path_delay_constraint command with<br>-clock_from -clock_to options.                                                                                                                                                                                                                                                                                              |

|                    | <b>Note:</b> If specific ideal (or generated) clocks are requested with the -clocks <i>clock_name_list</i> option, then only the relationships between those clock signals are reported.                                                                                  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -description       | Reports only the description of the specified clock waveform(s).                                                                                                                                                                                                          |
| -generated         | Reports generated clocks created by the set_generated_clock command in addition to the ideal clocks. The report uses the internal clock names created by the system, if you did not specify new clock names while creating these clocks. See <u>Examples</u> on page 962. |
| -insertion         | Reports the network insertion delays specified on clock waveforms. The values in the table are in min:typ:max format.                                                                                                                                                     |
| -phase_shift_table | Reports two tables that detail the phase shift between clock waveforms. One table shows the phase shifts in late mode and the other in early mode.                                                                                                                        |
|                    | <b>Note:</b> If specific ideal (or generated) clocks are requested with the -clocks <i>clock_name_list</i> option, then only the relationships between those clock signals are reported.                                                                                  |
| -source_insertion  | Reports the source insertion delays specified on clock waveforms.                                                                                                                                                                                                         |
| -tcl_list          | Produces the report in a Tcl list, not in a readable report. This is useful for integrating timing with custom Tcl functions and also for customizing report generation.                                                                                                  |
| -total_shift_table | Reports two tables (late mode and early mode) that detail the total relationship between clock waveforms.                                                                                                                                                                 |
|                    | <b>Note:</b> If specific ideal (or generated) clocks are requested with the -clocks <i>clock_name_list</i> option, then only the relationships between those clock signals are reported.                                                                                  |

#### -uncertainty\_table

Reports two tables (late mode and early mode) that detail the uncertainty between clock waveforms as specified by the set\_clock\_uncertainty command.

**Note:** If specific ideal (or generated) clocks are requested with the -clocks *clock\_name\_list* option, then only the relationships between those clock signals are reported.

## Examples

■ The following command displays the default report:

report\_clocks

| +                                 | Clock Des        | scription                      | 15<br>                           | -+                            |                                |
|-----------------------------------|------------------|--------------------------------|----------------------------------|-------------------------------|--------------------------------|
| Clock<br>Name                     | Period           | Lead                           | Trail                            |                               |                                |
| A<br>B                            | 15.00<br>10.00   | 0.00                           | 7.50<br>8.00                     | -                             |                                |
| Total Clock To Clock Relationship |                  |                                |                                  |                               |                                |
| From                              | То               | L->L                           | L->T                             | T->L                          | T->T                           |
| A<br>A<br>B<br>B                  | A<br>B<br>A<br>B | 14.76<br>-1.20<br>2.84<br>6.88 | -0.48<br>-6.44<br>-7.40<br>-3.36 | 14.28<br>8.32<br>7.36<br>6.40 | 14.04<br>-1.92<br>2.12<br>6.16 |

#### ■ The following command displays only the uncertainty information:

report\_clocks -uncertainty\_table

| +                                | Clock To                         | Clock Ur                     | ncertaint                    | cy (Late)                    | )                            |
|----------------------------------|----------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|
| From                             | To                               | L->L                         | L->T                         | T->L                         | T->T                         |
| iclk1<br>iclk1<br>iclk2<br>iclk2 | iclk1<br>iclk2<br>iclk1<br>iclk2 | 0.00<br>1.70<br>0.00<br>0.00 | 0.00<br>1.70<br>0.00<br>0.00 | 0.00<br>1.70<br>0.00<br>0.00 | 0.00<br>1.70<br>0.00<br>0.00 |

| +Cl                     | lock To (               | Clock Und             | certainty             | y (Early)             | ·+<br>)<br>           |
|-------------------------|-------------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| From                    | То                      | L->L                  | L->T                  | T->L                  | T->T                  |
| iclk1<br>iclk1<br>iclk2 | iclk1<br>iclk2<br>iclk1 | 0.00<br>-2.70<br>0.00 | 0.00<br>-2.70<br>0.00 | 0.00<br>-2.70<br>0.00 | 0.00<br>-2.70<br>0.00 |

| iclk2 | iclk2 | 0.00 | 0.00 | 0.00 | 0.00 |

■ The following command displays a report from a design with a generated clock (created in the example for get\_clock):

| re  | report_clocks -generated                    |                                                                        |                |                               |                                          |                                      |                                     |                                    |
|-----|---------------------------------------------|------------------------------------------------------------------------|----------------|-------------------------------|------------------------------------------|--------------------------------------|-------------------------------------|------------------------------------|
| +-  | ++<br>Clock Descriptions                    |                                                                        |                |                               |                                          |                                      |                                     |                                    |
| -   | Clock<br>Name                               | Period   Lead   Trail                                                  |                |                               |                                          |                                      |                                     |                                    |
|     | CLK<br>my_clock                             | 10.000<br>20.000                                                       | 0.000<br>0.000 |                               | 5.000                                    |                                      |                                     |                                    |
| +-  | <br>Tot                                     | al Clock 7                                                             | Fo Clock       |                               | elations                                 | <br>shi                              | p (Late)                            | +                                  |
| -   | From                                        | <br>To                                                                 | L->I           |                               | <br>  L->T                               |                                      | T->L                                | <br>T->T                           |
| -   | CLK<br>CLK<br>my_clock<br>my_clock          | CLK   10.000   0.00<br>my_clock   10.000   0.00<br>CLK   10.000   0.00 |                | 0.000 0.000 0.000 0.000 0.000 | -+-                                      | 10.000<br>10.000<br>20.000<br>20.000 | 10.000<br>0.000<br>10.000<br>20.000 |                                    |
| +-  | + Total Clock To Clock Relationship (Early) |                                                                        |                |                               |                                          |                                      |                                     |                                    |
| -   | From                                        | То                                                                     | L->I           |                               | L->T                                     |                                      | T->L                                | T->T                               |
| + - | CLK<br>CLK<br>my_clock<br>my_clock          | CLK<br>my_clock<br>CLK<br>my_clock                                     | 0.000          |                               | -10.000<br>-10.000<br>-10.000<br>-20.000 | 0                                    | 0.000<br>0.000<br>10.000<br>0.000   | 0.000<br>-10.000<br>0.000<br>0.000 |

# **Related Information**

<u>get\_clock</u>

set\_clock info\_change

set\_clock\_insertion\_delay

<u>set clock root</u>

<u>set\_clock\_uncertainty</u>

set generated clock

<u>set table style</u>

# report\_fanin

report\_fanin [-level integer] [-tristate] [-sequential] [-hierarchical]
 [{> | >>} filename] [-maxline integer] list\_of\_pin\_path\_or\_id

Generates a report on the fanin cone of the specified design objects in the current module. The report generated contains all the pertaining information on fanin cone, for example, from pin, to pin, level in the module and the module. All pins and their associated nets on the fanin path are reported with hierarchical names (starting at the current module).

#### **Options and Arguments**

| -hierarchical           |                                                                                                                                                                                                                                                          |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | Allows the command to traverse backwards across hierarchy boundaries to generate a report on the fanin cone. <i>Default</i> : Stops at the input port and it will report on the fanin path starting from that port (this is treated as the start point). |
| -level integer          | Specifies the number of levels that need to be traversed for generating the report.                                                                                                                                                                      |
| list_of_pin_path_or     | Specifies the Tcl list of pin or port path names or object identifiers for which to start the fanin cone search.                                                                                                                                         |
| -maxline <i>integer</i> | Specifies the number of lines which need to be traversed for generating the report.                                                                                                                                                                      |
| -output filename        | Specifies that a report be written out to a file that can be reviewed later. The name of the file written out is designated by <i>filename</i> .                                                                                                         |
| -tristate               | Includes the tristates in the fanin path.                                                                                                                                                                                                                |
| -sequential             | Includes the sequential cells in the fanin path.<br><i>Default</i> : The reporting stops at the encounter of the first<br>sequential cell in the fanin path.                                                                                             |

# **Related Information**

<u>get\_fanin</u>

<u>get\_fanout</u>

<u>report\_fanin</u>

<u>set\_table\_style</u>

# report\_fanout

report\_fanout [-level integer] [-tristate] [-sequential] [-hierarchical]
 [{> | >>} filename] [-maxline integer] list\_of\_pin\_path\_or\_id

Generates a report on the fanout cone of the specified design objects in the current module. The report generated contains all the pertaining information on fanout, for example, from pin, to pin, level in the module and the module. All pins and their associated nets on the fanout path are reported with hierarchical names (starting at the current module).

#### **Options and Arguments**

| -hierarchical           | Allows the command to traverse forward across hierarchy boundaries to generate a report on the fanout cone. <i>Default</i> : Stops at output ports and report the fanout path ending at that port (which is treated as the end point). |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -level integer          | Specifies the number of levels that need to be traversed for generating the report. <i>Default</i> : Value is infinity.                                                                                                                |
| list_of_pin_path_or     | $f_{id}$<br>Specifies the Tcl list of pin or port path names or object identifiers<br>for which to start the fanin cone search.                                                                                                        |
| -maxline <i>integer</i> | Specifies the number of lines which need to be traversed for generating the report.                                                                                                                                                    |
| -output <i>filename</i> | Specifies that a report be written out to a file that can be reviewed later. The name of the file written out is designated by <i>filename</i> .                                                                                       |
| -sequential             | Includes the sequential cells in the fanout path.<br><i>Default</i> : The reporting stops at the encounter of the first<br>sequential cell in the fanout path.                                                                         |
| -tristate               | Includes the tristates in the fanout path.                                                                                                                                                                                             |

# **Related Information**

<u>get\_fanin</u>

<u>get\_fanout</u>

report\_fanout

<u>set\_table\_style</u>

# report\_functional\_mode

report\_functional\_mode [-cell cell\_name] instance\_list

Reports the status (active or inactive) of all modes in the instance list.

The following form of the command reports a list of mode groups and modes for *cell\_name*:

report\_functional\_mode -cell cell\_name

Without arguments, the command reports status of all modes in all instances:

report\_function\_mode

# **Options and Arguments**

| -cell <i>cell_name</i> | Specifies the name of the cell.                                                         |
|------------------------|-----------------------------------------------------------------------------------------|
| instance_list          | Specifies the list of instances for which the functional mode status needs to reported. |

#### **Examples**

- The following command reports the status of all modes in all instances: report\_functional\_mode
- The following command reports the status of all modes in cell named RAM: report\_functional\_mode -cell RAM
- The following command reports the status of all modes in instances A1/B3/C2 and A1/ B2/C2:

```
report_functional_mode {A1/B3/C2 A1/B2/C2}
```

# **Related Information**

reset\_functional\_mode

<u>set\_functional\_mode</u>

# report\_inactive\_arcs

```
report_inactive_arcs [-from {instance | pin}] [-to {instance | pin}]
    [-delay_arcs_only | -check_arcs_only] [-type disable_type]
    [{> | >>} filename]
```

Reports information about disabled timing and timing check arcs in the design. Reports all arcs disabled due to specified exceptions using commands such as set\_disable\_timing, set\_disable\_clock\_gating\_check or set\_constant\_for\_timing, as well as information about arcs disabled by constant propagation during timing analysis, snipped loop arcs, and arcs disabled in the timing library.

# **Options and Arguments**

| <pre>{&gt;   &gt;&gt;} filename</pre> |                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       | Specifies the name of the file in which the report is saved. The $filename$ argument must be the last argument in the list. If the file name is not specified, the report displays on the standard output without being saved. Since the report is often large, text may be lost if you do not save the report to a file. |
| -check_arcs_only                      |                                                                                                                                                                                                                                                                                                                           |
|                                       | Lists only disabled check arcs. The check_arcs are disabled by<br>using the set_disable_timing and the<br>set_disable_clock_gating_check commands.<br><i>Default</i> : Both disabled timing delay arcs and check arcs are<br>listed.                                                                                      |
| -delay_arcs_only                      | Lists only disabled timing delay arcs.                                                                                                                                                                                                                                                                                    |
| -from instance                        |                                                                                                                                                                                                                                                                                                                           |
|                                       | Reports all disabled timing arcs in the fanout logic cone of instance output pins.                                                                                                                                                                                                                                        |
| -from pin                             |                                                                                                                                                                                                                                                                                                                           |
|                                       | Reports all disabled timing arcs in the fanout logic cone of a specified pin.                                                                                                                                                                                                                                             |
| -from -to                             |                                                                                                                                                                                                                                                                                                                           |
|                                       | Reports all disabled timing arcs in the cone of logic between the from and to pins.                                                                                                                                                                                                                                       |

| -to instance       | Reports all disabled timing arcs in the fanin logic cone of instance input pins.                                                                                                                                                                                                                                                                                            |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -to pin            | Reports all disabled timing arcs in the fanin logic cone of a specified pin.                                                                                                                                                                                                                                                                                                |
| -type disable_type | Lists only the disabled arcs that belong to this category of disabled arcs. The disable_type option restricts the report to only those arcs which are disabled due to a particular timing analysis step, such as constant propagation, specified disables, or loop arc disables. The following are valid disable_type values:                                               |
|                    | <b>check_types:</b><br>Setup, Hold, Recovery, Removal, PulseWidth,<br>ClockGatingSetup, ClockGatingHold, ClockGatingPulseWidth,<br>ClockPeriod, Skew, ClockSeparation, NoChange. These types<br>apply to the disabled check arcs and are listed under the<br>"CheckType" field if the disabled arc is a timing check arc. For<br>delay arcs the "CheckType" field is empty. |
|                    | <b>const</b><br>Propagated constant — arcs disabled due to a constant value.<br>The constant value can apply to one of the arc nets/pins, to side<br>inputs which disable a condition for the arc, to nets that disable<br>an active mode for the arc, or disable a default conditional arc.                                                                                |
|                    | disable<br>Defined by using the <u>set disable timing</u> command.                                                                                                                                                                                                                                                                                                          |
|                    | disable_clock_gating<br>Defined by using the <u>set disable clock gating check</u><br>command. These arcs are only listed if the -check_arc option<br>is specified.                                                                                                                                                                                                         |
|                    | <b>library_disable</b><br>Delay arc disabled due to library disables. These disables may<br>be caused by the following conditions: Disables specified using<br>the <u>set disable cell timing</u> command; The arc is an<br>asynchronous arc and the global <u>lib build asynch arc</u> is                                                                                  |

set to false; the arc is a conditional default timing arc and the global <u>lib build timing cond default arc</u> is set to false.

#### snipped

Loop snipped arcs — arcs automatically disabled by CTE as part of a feedback loop. The arcs can be enabled by using the <u>reset\_feedback\_loop\_snipped\_arcs</u> command.

## Example

The following command reports all disabled arcs in the design:

report\_inactive\_arcs

| From             | То                | Summary             | CheckType | Reason             |
|------------------|-------------------|---------------------|-----------|--------------------|
|                  |                   |                     |           |                    |
| U1/U2/reg[0]/E ^ | `U1/U2/reg[0]/D ^ | const               |           | U1/U2/reg[0]/D = 0 |
| U1/U2/reg[0]/E ^ | `U1/U2/reg[0]/D v | const               |           | U1/U2/reg[0]/D = 0 |
| U1/RAM1/A ^      | U1/RAM1/D v       | const               |           | mode (RW) = 0      |
| M0/M1/D ^        | M0/M1/Q ^         | const               |           | (EN) == 0          |
| A0/D v           | A0/Q ^            | disable             |           | User Disable       |
| N0/A v           | N0/Q ^            | snipped             |           | loop arc           |
| DREG1/CP ^       | DREG1/D ^         | const setup         |           | DREG1/D = 1        |
| DREG1/CP ^       | DREG1/D V         | const Setup         |           | DREG1/D = 1        |
| N0/A ^           | N0/B ^            | disable_clock_gatin | g setup   | NO/A = 1           |
| N0/A v           | N0/B ^            | disable_clock_gatin | g setup   | NO/A = 1           |
| D0/A ^           | D0/Z v            | library_disable     |           | library disable    |
|                  |                   |                     |           |                    |

# report\_library

```
report_library[-library_name] [-cells [pattern]] [-wireloads]
    [-operating_conditions] [-pvt {min | typ | max}] [-tcl_list]
    [{> | >>} filename]
```

Generates a report about the technology library used in the design.

# **Options and Arguments**

| <pre>{&gt;   &gt;&gt;} filename</pre> | Specifies the name of the file in which the report is saved. The $filename$ argument must be the last argument in the list. If the file name is not specified, the report is displayed on the standard output without being saved. Since the report is often large, text may be lost if you do not save the report to a file.                                                     |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -cells [pattern]                      | Reports information about all cells in the library. If a <i>pattern</i> is specified, only the cell names in the library that match the pattern are reported. See <u>Examples</u> on page 973.                                                                                                                                                                                    |
| -library library_nam                  | Reports contents of the specified library.<br>Default: Contents of the library set by set_global<br>target_technology are reported.                                                                                                                                                                                                                                               |
| -operating_condition                  | Reports information on all the operating conditions in the library.                                                                                                                                                                                                                                                                                                               |
|                                       | If none of the three options (-cells, -wireloads,<br>-operating_conditions) are specified, the report contains<br>information about all the cells, wire-load models and operating<br>conditions.                                                                                                                                                                                  |
| -pvt {min   typ   ma                  | Reports library data for a particular PVT (process, voltage,<br>temperature) corner. Specify only one PVT corner per<br>command.<br><i>Default</i> : The library data is reported for the max PVT corner only.<br>If the library is a merged library, the order of reporting is max if it<br>exists, then typ if it exists, and finally min if neither max or typ<br>data exists. |



If you have a merged library, use multiple commands with different -pvt options to report all the data. See <u>Examples</u> on page 973.

-tcl\_list

Produces the report in a Tcl list, not a readable report. This is useful for integrating timing with custom Tcl functions and also for customizing report generation.

-wireloads

Reports information on all the wire-load models in the library.

#### Examples

■ The following command reports the contents of the technology library to the file named library.rep:

report\_library library.rep

- The following command reports all cells matching the string AO\* in library lca300kv: report\_library -library lca300kv -cells AO\*
- The following commands use a merged library defined by:

read\_tlf -min lib\_bc.tlf -max lib\_wc.tlf -name merge.tlf

□ This command shows only the operating conditions for the max PVT (those from the -max library):

report\_library -operating\_condition

| Operating<br>Condition | process | temperature | voltage | OC type       |
|------------------------|---------|-------------|---------|---------------|
| WCMIL                  | 1.50    | 125.00      | 1.65    | balanced_tree |
| WCCOM                  | 1.50    | 85.00       | 1.65    | balanced_tree |

□ This command shows the operating conditions that come from the -min library:

report\_library -operating\_condition -pvt min

| +- | Operating<br>Condition | process | temperature | voltage | OC type        |
|----|------------------------|---------|-------------|---------|----------------|
| -  | BCMIL                  | 0.50    | -55.00      | 1.95    | best_case_tree |
|    | WCMIL                  | 1.50    | 125.00      | 1.65    | balanced_tree  |
|    | BCCOM                  | 0.50    | 0.00        | 1.95    | best_case_tree |
|    | WCCOM                  | 1.50    | 85.00       | 1.65    | balanced_tree  |

# **Related Information**

<u>report\_timing</u>

<u>set table style</u>

set global target technology

# report\_net

```
report_net [-min_fanout int] [-max_fanout int]
    {-net list_of_net_name_or_id | -pin list_of_pin_name_or_id}
    [-old] [-tcl_list] [-hier] [-output filename | {> | >>} filename]
```

Reports the net information on the current module. The information includes the net name, the number of source pins, sink pins and bidirectional pins on the net, the wireload model, the wire capacitance, wire resistance, and total capacitance.

Electrical information such as pin capacitance, wire capacitance, wire resistance, and the wireload model with which the net is associated are also included. If wire capacitance or wire resistance are backannotated from post-layout information, such as an SDF file, they are indicated in the Wireload Model (WLM) column accordingly. If any attributes are set on the net, they are also indicated in the attribute column.

Use the -pin option to report the net that is connected to the specified pin (or port). Both -net and -pin cannot be specified at the same time. The net (or pin) names can be hierarchical names that are unique relative to the top timing module.

Note: Set the top timing module with the set\_top\_timing\_module command before using the report\_net command.

This command only searches for the defined nets and does not modify any object in database.

# **Options and Arguments**

-hier

Reports all of the nets in the design hierarchy. Without this argument, only the nets in the current level of hierarchy are reported.

# -max\_fanout integer Reports the net whose number of fanouts is less than the maximum number specified by integer.

-min\_fanout integer

Reports the net whose number of fanouts is greater than the minimum number specified by *integer*.

-net list\_of\_net\_name\_or\_id

Reports the set of nets on the list of net names. This argument

|                     | cannot be specified at the same time as -pin. If neither -net or -pin is specified, all nets are listed by default.                                                                                                                   |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | <b>Note</b> : This argument also reports the capacitance of the net and the input pins.                                                                                                                                               |
| -old                |                                                                                                                                                                                                                                       |
|                     | Produces the table in 3.0 format (without information about the interconnect delay model).                                                                                                                                            |
| -output filename    | <pre>{&gt;   &gt;&gt;} filename Dumps the report to the specified file instead of to the standard output. The filename argument must be the last argument in the list. Cannot be used simultaneously with the -tcl_list option.</pre> |
| -pin list_of_pin_na | ame_or_id                                                                                                                                                                                                                             |
|                     | Reports the set of nets to which the pins on the list<br>list_of_pin_name_or_id are connected. This argument<br>cannot be specified at the same time as -net.                                                                         |
| -tcl_list           |                                                                                                                                                                                                                                       |
|                     | Produces the report in Tcl list form instead of a tabular format.<br>This is useful for extracting information from the report in a Tcl<br>program. Cannot be used simultaneously with the -output<br>filename option.                |

# Examples

The format of the report is the same for all examples, as shown in the first example.

■ The following command reports information about net named in:

| report_net -net in                                                  |                                                          |
|---------------------------------------------------------------------|----------------------------------------------------------|
| Net Name<br>Number of Sources<br>Number of Sinks<br>Number of Bidis | : in<br>: 1<br>: 2<br>: 0                                |
| Source of parasitics<br>Net Capacitance<br>Total Capacitance        | : Wireload model(.lib B0X0 lca300kv)<br>: 0.00<br>: 0.02 |
| +                                                                   | Source                                                   |
| Pin                                                                 | Reduced Net   Driver Load   Slew                         |
|                                                                     |                                                          |

#### Command Reference for BuildGates Synthesis and Cadence PKS Common Timing Engine (CTE) Commands

| Name | Dir                    | Cell | Cap            | Mod          | lel     | Mod    | lel   C      | total | Rise | Fall         | Phase              |
|------|------------------------|------|----------------|--------------|---------|--------|--------------|-------|------|--------------|--------------------|
| in   | IN                     | top  | 0.00           | Elmore       | e Delay | CTOI   | 'AL          | 0.02  | 0.05 | 0.04         | @(D)(P)            |
| +    |                        |      |                |              |         |        |              |       |      |              | +                  |
|      |                        |      |                |              | Sinks f | for pi | n in         |       |      |              |                    |
|      |                        | Pin  |                |              | Reduced | d Ne   | I            | Delay |      | Slew         |                    |
| Na   | ame                    | Dir  | Cell           | Cap          | Paramet | ters   | Rise         | Fall  | Rise | Fall         | Phase              |
| . —  | x/B_reg/D<br>x/A_reg/D |      | FD1QA<br>FD1QA | 0.01<br>0.01 | 0.00    |        | 0.00<br>0.00 | 0.00  | 0.05 | 0.04<br>0.04 | @(D)(P)<br>@(D)(P) |

The following command reports the net to which the pin interesting\_pin is connected:

report\_net -pin interesting\_pin

■ The following command reports all the nets in the current module:

report\_net -net \*

■ The following command reports all nets with a fanout greater than 16:

report\_net -net \* -min\_fanout 16

The following commands report nets without wire capacitance or resistance assertions using the <u>report annotations</u> command:

report\_annotations -missing\_capacitances
report\_annotations -missing\_resistances

#### **Related Information**

report path exceptions

<u>report\_timing</u>

<u>set\_current\_module</u>

# report\_path\_exceptions

report\_path\_exceptions {-ignored] [-tcl\_list] [{> | >>} filename]

Generates a report about the path exceptions that you have specified using the <u>set false path</u>, <u>set path delay constraint</u> and <u>set cycle addition</u> commands.

A path can have more than one path exception. Multiple path exceptions that match a given path are prioritized. The adjustment on the path is from the path exception with the highest priority. <u>Table 7-1</u> on page 797 ranks path exception priorities from highest to lowest.

## **Options and Arguments**

| <pre>{ &gt;   &gt;&gt; filename }</pre> | Redirects the output to the named file. If this option is omitted, the default is stdout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -ignored                                | Reports only the path exceptions that have been ignored by<br>timing analysis. Useful for debugging assertions that may be<br>ineffective or incorrectly entered. A path exception may be<br>ineffective if it is covered by, or over-ridden by another path<br>exception. For example:<br>set_false_path -to OUT<br>set_cycle_addition -to OUT 2<br>The set_cycle_addition command would be ignored<br>because the false path has a higher priority.<br>One example of such an ineffective or incorrectly entered<br>assertion is the set_cycle_addition command that is<br>ignored due to the set_false_path command shown in the |
| -tcl_list                               | Produces the report in Tcl list form instead of a tabular format.<br>This is useful for extracting information from the report in a Tcl program.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### Examples

The following commands shows that a false path has priority over cycle addition on the same path:

set\_false\_path -from I\_block/A\_reg/Q -to J\_block/D\_reg/D
set\_cycle\_addition -from I\_block/A\_reg/Q -to J\_block/D\_reg/D 2
report\_path\_exceptions

| +<br>  From                        | То | Early | +<br>  Late            |
|------------------------------------|----|-------|------------------------|
| I_block/A_reg/Q<br>I_block/A_reg/Q |    | false | false<br>add 2 ignored |

The term false means that the path is treated as a false path due to the path exception, and false ignored means that there was a false path assertion but that it is ignored. This may be because a path does not exist that matches the path exception. If you notice ignored path exceptions in your design, it is a good idea to check why they are ignored. The problem may be a typo in the script or some other reason

The following command shows how edges are handled:

```
set_false_path -from_rise {in[0]} -through {out[0]}
set_false_path -from_rise {in[0] in[1]} -to_fall {out[0]}}
set_false_path -from_rise {in[0]}
```

| +<br>  From                       | Through    | To       | Early                                   | <br>  Late                              |
|-----------------------------------|------------|----------|-----------------------------------------|-----------------------------------------|
| ^ in[0]<br>^ in[0] in <br>^ in[0] | [1] out[0] | v out[0] | false ignored<br>false ignored<br>false | false ignored<br>false ignored<br>false |



```
set_disable_timing -from foo/i/A
report_path_exceptions
```

| <br>  From | Early   | Late    |  |
|------------|---------|---------|--|
| foo/i/A    | disable | disable |  |

# **Related Information**

<u>report timing</u>

<u>report\_area</u>

<u>report\_design\_rule\_violations</u>

<u>report hierarchy</u>

<u>report\_fsm</u>

reset path exception

set current module

See <u>Generating Path Exception Reports</u> in the Common Timing Engine (CTE) User Guide.

# report\_path\_groups

report\_path\_groups [-name group\_name] [-tcl\_list] [{> | >>} filename]

Lists the names of all path groups with the corresponding paths.

## **Options and Arguments**

| <pre>{ &gt;   &gt;&gt; filename }</pre> | Redirects the output to the named file. If this option is omitted, the default is stdout.                                                           |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| -name group_name                        | Limits the report to the path specifications that define the given group.<br>Default: All path groups are reported.                                 |
| -tcl_list                               | Produces the report in Tcl list form instead of a tabular format.<br>This is useful for extracting information from the report in a Tcl<br>program. |

# Example

The following command reports the group defined in the example for <u>set path group</u>:

report\_path\_groups

| From   | То  | Group<br>  Name |
|--------|-----|-----------------|
| "CLKA" | "*" | GRPA            |

# **Related Information**

report path group options

<u>reset\_path\_group</u>

<u>set path group</u>

# report\_path\_group\_timing

report\_path\_group\_timing [-tcl\_list] [{> | >>} filename]

Produces a report of the timing of all active path groups in the design. The report includes the name of the path group, the number of critical (out of the total) endpoints, the worst slack of the group, and the Total Endpoint Negative Slack (TENS), which is the sum of the negative slack of all endpoints in the group.

## **Options and Arguments**

| >   >> filename | Redirects the output to the named file. If this option is omitted, the default is stdout.                                                |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| -tcl_list       | Produces the report in Tcl list form instead of a tabular format.<br>Useful for extracting information from the report in a Tcl program. |

#### **Related Information**

report path group options

report path group options

<u>set path group</u>

<u>set\_port\_capacitance</u>

# report\_poles\_residues

```
report_poles_residues {[-source pin_list -sink pin_list] | [-net netname_list]}
      [-early | -late] [-tcl_list] [-output filename | {> | >>} filename]
```

Reports poles and residues from interconnect RC networks in an OLA library. The PI model is report\_net.

## **Options and Arguments**

| -early -late            | Reports the early timing (data hold/clock setup) or late timing (data setup/clock hold). <i>Default</i> : -late.                                                                          |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -net netname_list       | Reports the poles and residues for the named nets only. <i>Default</i> : Poles and residues for all nets are reported. This option cannot be used with -source -sink pair options.        |
| -output <i>filename</i> | <pre>{&gt;   &gt;&gt;} filename Dumps the report to the specified file instead of to the standard output. The filename argument must be the last argument in the list.</pre>              |
| -source pin_list -s     | ink pin_list<br>Specifies the list of source-sink pairs of a net for which the poles<br>and residues are displayed. The specified sources and sinks<br>must be connected to the same net. |
| -tcl_list               | Produces the report in Tcl list form instead of a tabular format.<br>This is useful for extracting information from the report in a Tcl<br>program.                                       |

# Example

The following command reports the poles and residues for the named nets only:.

report\_poles\_residues -net n1

| Н | +       | +                      |
|---|---------|------------------------|
|   | Report  | report_poles_residues  |
|   | Options | -net n1 > n1_poles.rpt |
|   |         |                        |

|     | Date<br>Tool<br>Release<br>Version | bg_she<br>v5.0-k |                          |                       |                        |          |
|-----|------------------------------------|------------------|--------------------------|-----------------------|------------------------|----------|
| +   | Module                             | msinks           | s_yhn                    | +<br> <br>+           |                        |          |
|     | et Name                            | mban af          | : nl                     |                       |                        |          |
| Iv] | laximum nu                         |                  | poles : 2                |                       |                        |          |
|     | Source                             | Sink             | Poles                    | 5                     | Resid                  | lues     |
|     | Name                               | Name             | Real                     | Img                   | Real                   | Img      |
|     | drv1/Z                             | ld2/A            | -1430.454346             | -0.028014             | 0.033253               | 0.000000 |
|     | drv1/Z                             | ld1/A            | -36.852859<br>-36.300274 | 0.000761<br>-0.027548 | -1.033253<br>-1.000000 | 0.000000 |

Default: Poles and residues for all nets are reported.

# **Related Information**

<u>read\_ola</u>

<u>read\_spef</u>

<u>report\_net</u>

# report\_ports

```
report_ports [-type ([input] | [source_insertion] | [insertion] | [clock_root] |
    [uncertainty] | [arrival] | [required] | [external] | [clk_arrival] |
    [clk_required] | [port_cap] | [fanout_load] | [num_external_sinks] |
    [num_external_sources] | [fanout_load_limit] | [port_wire_load] |
    [drive_resistance] | [[drive_cell] | [slew_time] | [slew_limit] |
    [constant] | external_detail | drive_resistance_detail)] [-tcl_list]
    [-pins port_name_id_list]
```

Reports timing assertions on ports and pins. Specify a specific port using either an object ID, a name, or a list of IDs or names.

*Default*: If no parameters are supplied) reports all timing assertions on all ports of the current module.

Use the -type option to query specific assertions.

Use the -tcl\_list option to format the information for use in a Tcl program.

# **Options and Arguments**

| -pins port_name_id_ | list                                                                                                                                                                              |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | Specifies the pins or ports to be reported. Pins can be specified by name or object ID in a Tcl list.                                                                             |
| -tcl_list           |                                                                                                                                                                                   |
|                     | Produces the report in a Tcl list, not a human-readable report.<br>This is useful for integrating timing with custom Tcl functions and<br>also for customizing report generation. |
| -type {assertion_ty | pe   assertion_type_list}                                                                                                                                                         |
|                     | Specifies the assertions to be reported.<br>Default: All assertions are reported. The following are valid<br>assertion_type values:                                               |
|                     | arrival                                                                                                                                                                           |
|                     | Reports arrival time assertions as set by (obsolete) <u>set data arrival time</u> .                                                                                               |
|                     | clk_arrival                                                                                                                                                                       |
|                     | Reports clock arrival time assertions as set by                                                                                                                                   |
|                     | set clock insertion delay.                                                                                                                                                        |

**clk\_required** Reports clock required time assertions as set by <u>set clock required time</u>.

clock\_root Reports the clock root as set by <u>set clock root</u>.

constant Reports constant assertions as set by set constant for timing.

drive\_cell Reports drive cell assertions as set by <u>set\_drive\_cell</u>.

drive\_resistance Reports drive resistance assertions as set by set drive resistance.

drive\_resistance\_detail Reports detail about the input ports with drive resistance assertions.

**external** Reports external delay assertions as set by <u>set\_external\_delay</u>.

**external\_detail** Reports detail about the output ports with external delay assertions.

fanout\_load
Reports fanout load assertions as set by
set\_fanout\_load\_limit.

fanout\_load\_limit
Reports fanout load limit assertions as set by
set\_fanout\_load\_limit.

insertion Reports the network insertion delay as set by set clock insertion delay. num\_external\_sinks
Reports external sink assertions as set by
set\_num\_external\_sinks.

num\_external\_sources
Reports external source assertions as set by
set\_num\_external\_sources.

port\_cap
Reports port capacitance assertions as set by
set port capacitance.

port\_wire\_load
Reports port wire-load model assertions as set by
set port wire load.

required

Reports required time assertions as set by <u>set\_data\_required\_time</u>.

slew\_limit
Reports slew time limit assertions as set by
set\_slew\_time\_limit.

slew\_time
Reports slew time assertions as set by set slew time.

source\_insertion
Reports the source insertion delay as set by
set clock insertion delay -source.

uncertainty
Reports the clock uncertainty as set by
set\_clock\_uncertainty.

# Examples

The following command shows a port report:

report\_port

|          |     |           |            | Ear  | rly  | Lat  | .e   |
|----------|-----|-----------|------------|------|------|------|------|
| Pin Name | Dir | Assertion | Clock Name | Rise | Fall | Rise | Fall |

#### Command Reference for BuildGates Synthesis and Cadence PKS Common Timing Engine (CTE) Commands

|   | I_block<br>J_block/<br>J_block/<br>clk<br>clk<br>clk<br>clk<br>clk<br>clk<br>in<br>ou | D_reg/D<br>A<br>A<br>B<br>B<br>C<br>D                 | N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>O<br>T                                                                                                 | slew_time<br>arrival<br>drive_resistance<br>clk_arrival<br>slew_time<br>clk_arrival<br>slew_time<br>clk_arrival<br>clk_arrival<br>drive_cell<br>external | CLK1(C)(P)<br>CLK1(D)(P)<br>CLK1(D)(P)<br>CLK2(C)(N)<br>CLK1(C)(P)<br>CLK2(C)(P)<br>CLK2(C)(P)<br>CLK2(C)(P)<br>CLK2(C)(N)<br>*(D)(P)<br>CLK1(C)(N) | 1.60<br>1.20<br>2.00<br>1.30<br>0.00<br>1.30<br>0.05<br>3.00<br>BUFA | 1.60<br>0.07<br>1.20<br>0.00<br>1.30<br>2.00<br>1.30<br>0.07<br>0.50<br>BUFA | 1.60<br>1.20<br>2.00<br>1.30<br>0.00<br>1.30<br>0.05<br>3.00<br>BUFA<br>1.00 | 1.60<br>1.20<br>0.00<br>1.30<br>2.00<br>1.30<br>0.07<br>0.50<br>BUFA<br>1.00 |
|---|---------------------------------------------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| - | Pin<br>Name                                                                           | Dir                                                   |                                                                                                                                                          | Assertion                                                                                                                                                | Va                                                                                                                                                  | lue                                                                  | +                                                                            |                                                                              |                                                                              |
|   | out<br>out<br>in<br>clkA<br>clkB<br>clkC<br>clkD                                      | OUT<br>OUT<br>OUT<br>IN<br>IN<br>IN<br>IN<br>IN<br>IN | port_cap<br>num_external_sinks<br>port_cap_limit<br>slew_limit<br>port_cap_limit<br>port_cap_limit<br>port_cap_limit<br>port_cap_limit<br>port_cap_limit |                                                                                                                                                          | ( 3.20 : 3                                                                                                                                          |                                                                      | .2)<br>4<br>4.00<br>1.50<br>2.00<br>2.00<br>2.00<br>2.00<br>2.00<br>2.00     |                                                                              |                                                                              |

■ The following command shows, from a different design, that input, source\_insertion and clock\_root assertion type options report the assertions in the same format as arrival.

report\_port -type clock\_root source\_insertion input -pin clk in

|                  |                      |                                         |                                   | Ear          | rly          | Lat          | ce           |
|------------------|----------------------|-----------------------------------------|-----------------------------------|--------------|--------------|--------------|--------------|
| Pin<br>Name      | Dir                  | Assertion                               | Clock<br>Name                     | Rise         | Fall         | Rise         | Fall         |
| clk<br>clk<br>in | IN<br>IN<br>IN<br>IN | clock_root<br>source_insertion<br>input | CLK(C)(P)<br>*(D)(P)<br>CLK(D)(P) | 2.50<br>3.00 | 2.50<br>3.00 | 2.50<br>3.00 | 2.50<br>3.00 |

The following command shows that the insertion and uncertainty are reported as one value in the following format:

```
insertion : RISEmin FALLmin : RISEtyp FALLtyp : RISEmax FALLmax
uncertainty : EARLYrise EARLYfall LATErise LATEfall
```

■ The following command shows that the -to uncertainty is denoted by (T) next to the number. If a value is not specified, it is denoted by a dash (-):

report\_port -type insertion uncertainty -pin clk

| + | Pin<br>Name | Dir | Assertion | Value                       |
|---|-------------|-----|-----------|-----------------------------|
|   | clk         | IN  | insertion | ( 1.50 3.50 : : 2.50 4.50 ) |

| clk | IN | uncertainty | 1.00(T) 1.10 - 1.20(T) |

## **Related Information**

<u>report\_clocks</u>

<u>report net</u>

report\_timing

<u>set table style</u>

# report\_timing

```
report_timing [-clock_from clk_signame_list] [-clock_to clk_signame_list]
     [-edge_from {lead | trail}] [-edge_to {lead | trail}]
     [-rise | -fall] [-early | -late] [-max_slack float] [-min_slack float]
     [-max paths integer | -max points npoint] [-nworst integer]
     [{-from | -from_rise | -from_fall} pin_list]
     [{-through | -through_rise | -through_fall} pin_list]
     [{-to | -to_rise | -to_fall} pin_list]
     [-bidi_input_from | -bidi_output_from] [-bidi_input_to | -bidi_output_to]
     [-bidi_input_through | -bidi_output_through]
     [-unconstrained [-delay_limit float]] [-check_clocks]
     [-latch] [-path group groupname list]
     [-false_path_analysis {static | robust}] [-justify] [-true]
     [-tclfile tclfile_name] [-gcffile gcffile_name]
     [-hdl_sim_file hdlfile_name]
     [-spice output filename [-spice power node power rail voltage name list]]
     [-net] [-unique_pins] [-path_type {end | summary | full | full_clock}]
     [-check_type {setup | hold | pulse_width | clock_period | clock_gating_setup
     | clock_gating_hold | clock_gating_pulse_width | recovery | removal |
     clock_separation | skew | no_change_setup | no_change_hold}]
     [-format column_list] [-tcl_list] [{> | >>} filename]
    Valid columns are: addition arc arrival bottle cell clkordata clkordatapin
    delay delay_ast direction dont_modify_instance dont_modify_net edge eslack
```

delay delay\_ast direction dont\_modify\_instance dont\_modify\_net edge eslack fanin fanout fpin from\_edge hpin instance instance\_location load lslack net phase pin pinload pin\_location required slack slew stolen to\_edge tpin wireload wlmodel

Generates a timing report that provides information about the various paths in the design. The reports typically contain data on the delay through the entire path. The start node and the end node of each path is identified.

**Note:** Timing reports show different slack times because of slew merging. For more information on timing differences due to slew merging, see <u>Explaining Timing Differences</u> <u>Caused by Slew Merging When Path Exceptions are Applied</u> in the *Common Timing Engine (CTE) User Guide*.

The report contains the following information:

- The slack times of the arriving signal at the end node
- The start node
- The associated transitions
- The signal required times and the actual signal arrival times
- Any phase shifts applied when evaluating timing checks

■ Any CPPR values applied to timing check evaluation

If the *filename* is specified, then the report is written out to the file. Otherwise, the report is displayed on the standard output.

Default: The detailed timing information is reported.

Use the -format option to customize the reports to your needs by requesting the exact fields in which you have an interest. Use a combination of the -format and -tcl\_list options to integrate the timing reports into your Tcl scripts.

Use the -from option to limit the number of paths reported, and to find specific paths in the design.

## **Options and Arguments**

| -bidi_input_from   - | bidi_output_from<br>Specifies that the bidirectional pins in the -from/-from_rise/<br>-from_fall pin list refer to the input or output part of the<br>bidirectional pins. For default value, see <u>Bidirectional Pin</u><br><u>Defaults</u> on page 799.                                                                                                                                                                                                                           |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -bidi_input_through  | <ul> <li>-bidi_output_through</li> <li>Specifies that the bidirectional pins in the -through/</li> <li>-through_rise/-through_fall pin list refer to the input or output part of the bidirectional pins. For default value, see</li> <li><u>Bidirectional Pin Defaults</u> on page 799.</li> </ul>                                                                                                                                                                                  |
| -bidi_input_to   -bi | di_output_to<br>Specifies that the bidirectional pins in the -to/-to_rise/<br>-to_fall pin list refer to the input or output part of the<br>bidirectional pins. For default value, see <u>Bidirectional Pin</u><br><u>Defaults</u> on page 799.                                                                                                                                                                                                                                     |
| -check_clocks        | Generates reports based on timing paths on the clock network<br>instead of the standard timing to data endpoints. This report<br>includes clock paths that end at the reference end of a check or<br>a clock gating end point.<br><i>Default</i> : Data paths and all the other clock paths (for example, a<br>clock path ending at a D pin of a register) are reported.<br>A clock path ending at a D pin of a register is considered a data<br>path by default because the global |

clock\_gating\_regardless\_of\_downstream\_logic is
false by default.

Note: If the clock\_gating\_regardless\_of\_downstream\_logic global is set to true, the report\_timing command slack results without the -check\_clocks option may not match the slack numbers from the get\_module\_worst\_slack command without the -clknet\_too option. Default: Without the <u>-clknet\_too</u> option, the <u>get\_module\_worst\_slack</u> command does not consider clock networks at all.

-check\_type check\_type

Reports only the paths that end at the specified timing check. The supported check types are: setup, hold, pulse\_width, clock\_period, clock\_gating\_setup, clock\_gating\_hold, clock\_gating\_pulse\_width, recovery, removal, clock\_separation, skew, no\_change\_setup, no\_change\_hold.

Do not use this option with the -unconstrained or -early |-late options.

-clock\_from clk\_signame\_list

Generates reports based on source clock waveform(s). Reports only those paths whose source clocks are the clock signals in *clk\_signame\_list*.

-clock\_to clk\_signame\_list

Generates reports based on target clock waveform(s). Reports only those paths whose target clocks are the clock signals in *clk\_signame\_list*.

-delay\_limit float

Specifies the path delay limit for unconstrained paths (-unconstrained option).

For early paths (-early option), reports only those paths with path delay less than the delay limit. For late paths (-late option) reports only those paths with path delay more than the delay limit.

|                      | The -delay_limit option can only be used in conjunction with the -unconstrained option.                                                                                                                                                                                                                                                                                                                   |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late       | Generates the timing report for early paths (data hold checks/<br>clock setup checks) or late paths (data setup checks/clock hold<br>checks).<br>Default: -late.                                                                                                                                                                                                                                          |
|                      | The -late and -early options in report_timing are meant<br>for the data path, not the clock path. CTE will check late data<br>against early clock in the -late option, and early data against<br>late clock in the -early option.                                                                                                                                                                         |
|                      | For clock signals, there is another timing criteria called the PulseWidth Check in the report. Specifying report_timing with the -late option will report the worst slack path between the pulsewidth check and the hold check. Similarly, the -early option reports the worst slack path between the pulsewidth check. See <u>Examples</u> on page 1004 for some sample reports. <i>Default</i> : -late. |
| -edge_from {lead   t | Generates reports based on source clock edge, either leading or trailing.<br>Default: Both                                                                                                                                                                                                                                                                                                                |
| -edge_to {lead   tra | Generates reports based on the target clock edge, either leading or trailing.<br>Default: Both                                                                                                                                                                                                                                                                                                            |
| -from   -from_rise   | <pre>-from_fall pin_list Reports paths starting from the pin(s) specified by the pin_list. Using -from_rise (or -from_fall) specifies that the rising (or falling) edge of the signals on the pins in pin_list are the start of the paths.</pre>                                                                                                                                                          |
|                      | <b>Note</b> : Use this option with the -through and -to options for specifying particular paths in the design.                                                                                                                                                                                                                                                                                            |

| -max_paths integer      |                                                                                                                                                                                                                                                                                                                            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | Reports the specified number of worst paths in the design,<br>regardless of the endpoint. This is useful, but can be time<br>consuming if a large number of paths are requested. The paths<br>are always sorted based on slack.<br><i>Default</i> : worst path                                                             |
|                         | The -max_paths option cannot be used with the -max_points option.                                                                                                                                                                                                                                                          |
|                         | <b>Note</b> : You cannot use this option when the following CPPR analysis global is set to true: timing remove clock reconvergence pessimism                                                                                                                                                                               |
| -max_points integer     | Reports the worst path it finds to each endpoint up to the number specified by the <code>-max_points</code> option. If <code>-path_type</code> end option is specified, it reports worst path to each endpoint. This is the most frequently used report. <i>Default</i> : Only the worst path to one endpoint is reported. |
|                         | The <pre>-max_points option cannot be used with the -max_paths option.</pre>                                                                                                                                                                                                                                               |
| -max_slack <i>float</i> | Reports only those paths with slack equal to or less than the value of $float$ are reported. The $-max_slack$ option limits the report to paths that fall into the specified range. A positive slack value indicates that timing was met. A negative value for slack indicates a timing violation.                         |
|                         | The -max_slack option cannot be used with the -unconstrained option.                                                                                                                                                                                                                                                       |
|                         | Typically, you can report all violating endpoints by using:<br>-max_slack 0.0 -max_points 1000                                                                                                                                                                                                                             |
|                         | <b>Note:</b> This still limits the report to 1000 endpoints. The endpoint limitation can be adjusted to a reasonable number.                                                                                                                                                                                               |
| -min_slack <i>float</i> | Reports only those paths whose slack is greater than the value of <i>float</i> .                                                                                                                                                                                                                                           |

|                            | The -min_slack option cannot be used with the -unconstrained option.                                                                                                                                                                                                                                                                                                                  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Generate a timing report containing any path with greater than<br>the specified slack by using the <code>-max_paths</code> option. For<br>example, to report all paths with slack greater than 2ns:<br><code>-min_slack 2.0 -max_paths 1000</code>                                                                                                                                    |
|                            | <b>Note:</b> This still limits the report to 1000 paths. The path limitation can be adjusted to a reasonable number.                                                                                                                                                                                                                                                                  |
| -nworst integer            |                                                                                                                                                                                                                                                                                                                                                                                       |
|                            | Specifies the number of paths to be enumerated for each<br>endpoint. Use the -nworst option to report all the checks at an<br>end point or use the -check_type option to report a specific<br>check.                                                                                                                                                                                  |
|                            | Default: Only the worst path to each endpoint is reported.                                                                                                                                                                                                                                                                                                                            |
|                            | The -nworst option cannot be used with the -max_paths option.                                                                                                                                                                                                                                                                                                                         |
|                            | Note: You cannot use this option when the following CPPR<br>analysis global is set to true because it removes common path<br>pessimism (CPPR) from slack calculation:<br><u>timing remove clock reconvergence pessimism</u> . For<br>more information, see " <u>Removing Delay Pessimism from</u><br><u>Reported Paths</u> " in the Cadence Common Timing Engine<br>(CTE) User Guide. |
| -path_group <i>groupna</i> | me_list<br>Reports only paths contained in the groups specified in<br>groupname_list.                                                                                                                                                                                                                                                                                                 |
|                            | Report paths belonging to the default path group by using -path_group default. The paths that do not belong to any user-specified path group belong to the default path group named default.                                                                                                                                                                                          |
| -rise   -fall              |                                                                                                                                                                                                                                                                                                                                                                                       |
|                            | Reports the path with the specified edge on the endpoint.                                                                                                                                                                                                                                                                                                                             |

995

|                      | If an endpoint is specified using -to_rise (or -to_fall)<br>option, the -rise (or -fall) option is ignored and paths with<br>edge specified by -to_rise (or -to_fall) are reported.                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -through   -through_ | <pre>_rise   -through_fall pin_list<br/>Reports paths that pass through the pin(s) specified by the<br/>pin_list. Any number of -through pins can be specified.<br/>Using -through_rise (or -through_fall) specifies that the<br/>paths go through the rising (or falling) edge of the signals on the<br/>pins in pin_list.<br/>The pin_list is a logical OR function. The resulting path may<br/>pass through any of the pins in the -through pin_list. To<br/>force the report to pass through multiple pins, separate<br/>-through statements are needed.</pre> |
| -to   -to_rise   -to | <pre>b_fall pin_list<br/>Reports paths leading to the pin(s) specified by the pin_list.<br/>Pins in the pin_list can be either pins on the design<br/>boundary (ports) or pins on an instance. Only one list of -to pins<br/>can be specified per report. Using -to_rise (or -to_fall)<br/>specifies that the rising (or falling) edge of the signals on the pins<br/>in pin_list are at the end of the paths.</pre>                                                                                                                                               |
| -unconstrained       | Reports only the unconstrained paths (paths with no slack). If no paths are found, there may be constrained paths or false paths or the path may not exist. Each signal arriving at the path end node which does not have a matching required time, results in an unconstrained path. If there is an asynchronous signal (specified with'@' clock) arriving at the path end node, the path is always reported as an unconstrained path.                                                                                                                            |
|                      | <b>Note</b> : An asynchronous signal is applied to all the unconstrained primary inputs during this mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                      | The report_timing command without the -unconstrained<br>option reports only constrained paths. If no constrained path is<br>found, there may be unconstrained paths or false paths or the<br>path may not exist. If no constrained or unconstrained path is<br>found, the path is either false or does not exist structurally.                                                                                                                                                                                                                                     |

|              | Note: The -min_slack and -max_slack options cannot be specified with the -unconstrained option. See the -delay_limit option described below.                                                                       |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | See for the conditions under which a path is reported as constrained or unconstrained.                                                                                                                             |
| -unique_pins | Reports paths through unique set of pins. Only one path (the worst) is reported for unique set of pins. This option suppresses multiple paths that differ only because of transition polarity or conditional arcs. |
|              | <b>Note</b> : Using this option may significantly affect runtime and memory usage if the number of paths to be reported is high.                                                                                   |

# **Option for Latch Analysis Type**

-latch

Reports the paths through latches in maximum time borrow latch mode. With this option, latch\_time\_borrow\_mode is automatically set to max\_borrow, if not already set. After report\_timing the global is automatically reset back to its previous mode. Only the worst path is reported for each end point.

The -latch option cannot be used with the -max\_paths, -nworst, or any of the -from\* or -through\* options.

For more information, see <u>Analyzing Latch-Based Designs</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

#### **Options for Reporting False Paths**

In addition to the analysis that is performed by default, you can use options to perform false path analysis. The following five options (-false\_path\_analysis through -gcffile) deal with false path analysis. For more information, see <u>Identifying and Eliminating False</u> <u>Paths</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

-false\_path\_analysis {static | robust} Determines the status of a path using <u>static</u> (or <u>robust</u>) analysis. You must always specify the analysis type, either static or robust, with the -false\_path\_analysis option.

Unless the -true option is used to disable printing of false paths, a false path is indicated in the report as shown in this example: Path 1: FALSE PATH

-gcffile gcffilename

Generates a General Constraint Format (GCF) file, gcffilename, containing GCF DISABLE constraints which correspond to the false paths identified. An error message is issued if gcffilename is not specified.

Use *gcffilename* to pass the DISABLE constraints (false paths) to backend tools for operations like place and route. These backend tools will not consider the timing on the false paths while doing placement and routing.

**Note:** This option can only be used with the -false\_path\_analysis option.

-hdl\_sim\_file hdlfile\_name

Generates HDL simulation models for combinational TRUE paths. The HDL simulation models are appended to the file specified by *hdlfile\_name*.

Use the -hdl\_sim\_file option to pass the result of false path analysis to dynamic simulation tools for the purpose of verifying true paths under sequential operation.

**Note:** This option can only be used with the -false\_path\_analysis option.

# Important

Before you use the -hdl\_sim\_file option, you must set two globals: set\_global cfpv\_testbench\_name testbench\_name set\_global cfpv\_design\_instance\_name instance\_name

The first specifies the name of the simulation testbench, and the second specifies the design instance name within the testbench. These parameters are needed to produce the HDL output file for simulation. For more information and an example

output file, see <u>Producing Simulation Vectors for Sequential Verification</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

| -justify                   |                                                                                                                                                                                                                                                                                                 |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| JUSCILY                    | Gets one test vector for which the reported paths become true.<br>This option also displays a test pattern for each true path.                                                                                                                                                                  |
|                            | <b>Note:</b> Use this option only with the <code>-false_path_analysis</code> option.                                                                                                                                                                                                            |
| -tclfile <i>tclfilenam</i> |                                                                                                                                                                                                                                                                                                 |
|                            | Generates a Tcl file, <i>tclfilename</i> , containing<br>set_false_path commands corresponding to the false paths<br>identified. An error message is issued if <i>tclfilename</i> is not<br>specified.                                                                                          |
|                            | Source <i>tclfilename</i> before running the report_timing command again. This filters out the false paths from the report and next available true paths are reported. The Tcl file can also be sourced before performing finer timing optimizations so that the false paths are not optimized. |
|                            | <b>Note:</b> Use this option only with the <code>-false_path_analysis</code> option.                                                                                                                                                                                                            |
| - + 7110                   |                                                                                                                                                                                                                                                                                                 |
| -true                      | Displays only identified true paths. The false paths identified are<br>not printed. Specify the sensitization criterion using the<br>-false_path_analysis option.                                                                                                                               |
|                            |                                                                                                                                                                                                                                                                                                 |

**Note:** Use this option only with the <code>-false\_path\_analysis</code> {static | robust} option.

# **Options for Creating Spice Output**

Use the following two options to generate Spice files.

Împortant

For the prerequisites, limitations, and example Tcl procedure, see <u>Generating a</u> <u>Spice Netlist</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

| -spice_output | t filename |
|---------------|------------|
|---------------|------------|

Creates output in Spice format for the path reported. The file can be simulated in a Spice simulator for transient analysis of the path waveform.

CTE appends the suffix .sp to the given filename. If report\_timing gives more than one path, then CTE generates more than one output file with the following pattern: filename.sp filename2.sp filename3.sp. In this example, filename.sp is the Spice representation of Path 1 in report\_timing, filename2.sp corresponds to Path 2 and so on.

See <u>Generating a Spice Netlist</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)* for more information.

-spice\_power\_node power\_rail\_voltage\_name\_list

Ties any node whose name is in the list of power rail names to its instance operating voltage. The instance-specific operating voltage can be updated using the read\_rrf command when rrf file is available. Use this option only in conjunction with the -spice\_output option.

When the instance operating voltage value is not specified, the rail voltage value from the operating conditions is used.

# **Options for Formatting and Redirecting Reports**

| <pre>{&gt;   &gt;&gt;} filename</pre> | Stores the generated report in the file specified by <i>filename</i> .<br>If the file name is not specified the report is displayed on<br>standard output. The file name must be the last argument in the<br>list.                        |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| end                                   | Generates an end point report for each path consisting of an endpoint, cause, slack, arrival time, required time, and phase. This option generates a very fast report. The -format option does not have any impact on this report format. |
|                                       | <b>Note:</b> The -path_type end format is identical to the format produced by the obsolete -summary option.                                                                                                                               |

| -format  | column_list | Formats the report according to the <i>column_list</i> . The <i>column_list</i> specifies which columns to display in the timing report and the order in which they appear. For example:                                                                                                                                                                                                                                                                                         |  |  |  |  |
|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|          |             | -format {hpin cell delay required arrival required edge}                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|          |             | See <u>Table 7-8</u> on page 1002 for a list of valid options.                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|          |             | <b>Default</b> : {instance arc cell delay arr req}                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|          |             | The default net format (with -net option) for the full path is: {hpin edge net cell delay arr req}.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|          |             | If the $-\texttt{unconstrained}$ option is specified, the $\texttt{req}$ column is not displayed.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|          |             | The -format option cannot be used with the -path_type end or -path_type Summary options.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|          |             | Note: To control the report_timing table fields, such as the min/<br>max column width, see the <u>set_table_style</u> command. For<br>example, the following command:<br><u>set_table_style -name report_timing -max_width</u><br>{100, , , , , } resizes the first column to a maximum range of<br>(100) and specifies a minimum width for that column based on<br>the data in that column.<br><i>Default</i> : For the minimum width is 5, and for the maximum width<br>is 50. |  |  |  |  |
|          |             | <b>Note</b> : Do <i>not</i> include a blank space between commas ", " when specifying widths. If you are specifying a value for the width(s), make sure there is <i>no</i> leading or trailing blank space.                                                                                                                                                                                                                                                                      |  |  |  |  |
| full     |             | Generates a report that displays the full path with accompanying required time and slack calculation. This is the default path type. Control the report format using the -format option.                                                                                                                                                                                                                                                                                         |  |  |  |  |
| full_clc | ock         | If the path reported ends at a timing check, this option also reports the full clock path (Other End Path) in addition to the                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |

|                      | full data path (Timing Path). If the reported path is a clock<br>path, it also reports the full data path. By default, without this<br>option, either the full data path or the full clock path is reported<br>depending on the endpoint (data or clock).                      |  |  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| -net                 | Adds a row for the net arc.<br><i>Default</i> : The net arc is not shown, and the net delay is added to<br>the following delay. This option also separates the cell delay from<br>the wire delay.                                                                              |  |  |  |
|                      | <b>Note</b> : The report_timing -net command displays the net delays separate from the cell delays. However, the net delay is sometimes shown as 0.0.To get the net delays to show up, increase the report precision using the following global: set_global report_precision 5 |  |  |  |
| -path_type {end   su | The path_type option lets you choose the format of the report<br>by path type. The default format, if the -path_type option is not<br>specified is full. See path type examples.                                                                                               |  |  |  |
| summary              | Generates a summary report for each path consisting of a start<br>point, endpoint, cause, slack, arrival time, required time, and<br>phase. The -format option does not have any impact on this<br>report format.                                                              |  |  |  |
|                      | <b>Note:</b> The -path_type summary format differs from that produced by the obsolete -summary option. To generate a report in the same format as -summary, use -path_type end.                                                                                                |  |  |  |
| -tcl_list            | Produces a report in a tcl list. This is useful for integrating timing with custom Tcl functions and customizing report generation.                                                                                                                                            |  |  |  |

# Table 7-8 Report Timing—Column List Options

| Option   | Description                                                                                                                             |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------|
| addition | Delay addition on pin. This delay typically comes from cycle<br>addition or clock uncertainty. The column is labeled Delay<br>Addition. |

| Option               | Description                                                                                                                                                                             |  |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| arc                  | The arc as described by the from pin, from pin edge, to pin,<br>and to pin edge. For example, the arc from the rising edge of<br>pin $A$ to the falling edge of pin $z$ is reported as: |  |  |  |
|                      | A ^->Z V                                                                                                                                                                                |  |  |  |
| arrival              | Arrival time on the pin.                                                                                                                                                                |  |  |  |
| bottle               | Number of paths in the report that pass through the pin.                                                                                                                                |  |  |  |
| cell                 | Cell name of the given pin's instance.                                                                                                                                                  |  |  |  |
| clkordata            | Reports whether the given pin is on a clock path or a data path. The column is labeled Clock/Data.                                                                                      |  |  |  |
| clkordatapin         | Reports whether the given pin expects a clock signal or a data signal. The column is labeled Clock Expected.                                                                            |  |  |  |
| delay                | Arc delay. If stolen slack at the arc output pin (output of transparent latches) is not zero, the stolen column is also displayed along with this column.                               |  |  |  |
| delay_ast            | Reports if a delay has been asserted on the arc.                                                                                                                                        |  |  |  |
| direction            | Pin direction (IN, OUT).                                                                                                                                                                |  |  |  |
| dont_modify_instance | Reports whether the instance is dont_modify. If it is, YES appears in the column. Otherwise, this column is blank. This argument displays the instance column automatically.            |  |  |  |
| dont_modify_net      | Reports whether the net is dont_modify. If it is, YES appears in the column. Otherwise, this column is blank. This argument displays the net column automatically.                      |  |  |  |
| edge                 | Edge on the pin (^=rise, v=fall).                                                                                                                                                       |  |  |  |
| eslack               | Worst early slack at the given pin.                                                                                                                                                     |  |  |  |
| fanin                | Total fanin on the net.                                                                                                                                                                 |  |  |  |
| fanout               | Total fanout on the net.                                                                                                                                                                |  |  |  |
| fpin                 | From or source pin of the arc.                                                                                                                                                          |  |  |  |
| from_edge            | Edge on the from, or source, pin.                                                                                                                                                       |  |  |  |
| hpin                 | Hierarchical pin name.                                                                                                                                                                  |  |  |  |
| instance             | Hierarchical name of the given pin's instance.                                                                                                                                          |  |  |  |
|                      |                                                                                                                                                                                         |  |  |  |

# Table 7-8 Report Timing—Column List Options, continued

| Option            | Description                                                                                                                                                                                                                         |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| instance_location | Location (x,y) of the instance. If the design is not placed, the column is blank. This argument displays the instance column automatically.                                                                                         |
| load              | Total capacitive load on a given pin.                                                                                                                                                                                               |
| lslack            | Worst late slack at the given pin.                                                                                                                                                                                                  |
| net               | Hierarchical name of the net connected to given pin.                                                                                                                                                                                |
| phase             | Phase name on pin.                                                                                                                                                                                                                  |
| pin               | Pin name of the given hierarchical pin.                                                                                                                                                                                             |
| pinload           | Total capacitive load from pins on a given pin, including its own load.                                                                                                                                                             |
| pin_location      | Location (x,y) of the pin. If the design is not placed, the column is blank.                                                                                                                                                        |
| required          | Required time on the pin.                                                                                                                                                                                                           |
| slack             | Slack on the pin (this is the same for the entire path).                                                                                                                                                                            |
| slew              | Propagated slew at the given pin                                                                                                                                                                                                    |
| stolen            | Slack stolen (or the time given to previous stage) at the given<br>pin. If the slack is not zero and the delay column is specified,<br>this column is displayed by default. (only visible on the output<br>of transparent latches.) |
| to_edge           | Edge on the to, or sink, pin.                                                                                                                                                                                                       |
| tpin              | To, or sink, pin of the arc.                                                                                                                                                                                                        |
| wireload          | Total capacitive load from the wire on a given pin.                                                                                                                                                                                 |
| wlmodel           | Wireload model used to calculate load on the net.                                                                                                                                                                                   |

#### Table 7-8 Report Timing—Column List Options, continued

#### Examples

■ The following command reports both late data paths, such as setup, recovery and so on, and late clock paths, such as hold, removal, pulse width and so on, in the same report.

report\_timing -late -check\_clocks

**Note:** This is the only way to report multiple checks on clock end points. Using the -check\_type option reports only one type of check.

■ The following command reports paths leading to the pin(s) specified by the pin\_list:

| report_timing -to O                       |                                                          |                                          |            |      |             |                              |                              |
|-------------------------------------------|----------------------------------------------------------|------------------------------------------|------------|------|-------------|------------------------------|------------------------------|
| Path 1: VIOLATED External Delay Assertion |                                                          |                                          |            |      |             |                              |                              |
| Endpo                                     | point: O $(v)$ checked with leading edge of 'CK1'        |                                          |            |      |             |                              |                              |
| Beging                                    | Beginpoint: fd3/Q (v) triggered by leading edge of 'CK1' |                                          |            |      |             |                              |                              |
| Other                                     | End Arrival                                              | Time 1.0                                 | 00         |      |             |                              |                              |
| - Exte                                    | ernal Delay                                              | 4.7                                      | 70         |      |             |                              |                              |
| + Phas                                    | se Shift                                                 | 5.0                                      | 00         |      |             |                              |                              |
| = Requ                                    | uired Time                                               | 1.3                                      | 30         |      |             |                              |                              |
| - Arr                                     | ival Time                                                | 1.7                                      | 70         |      |             |                              |                              |
| = Slad                                    | = Slack Time -0.40                                       |                                          |            |      |             |                              |                              |
| (                                         | Clock Rise Edge 1.00                                     |                                          |            |      |             |                              |                              |
| =                                         | = Beginpoint Arrival Time 1.00                           |                                          |            |      |             |                              |                              |
| -                                         | +                                                        |                                          |            |      |             |                              | +                            |
|                                           | Instance                                                 | Arc                                      | Cell       | Dela | y Arr<br>Ti | ival<br>me                   | Required<br>Time             |
|                                           | an2<br>fd3                                               | CK ^<br>B ^ -> Z ^<br>CP ^ -> Q V<br>O V | AN2<br>FD1 | 0.0  | 0           | 1.00<br>1.00<br>1.70<br>1.70 | 0.60<br>0.60<br>1.30<br>1.30 |

■ The following command shows a report similar to the first with the addition of net arc information.

| -                                                                                            |                                         |                  |                               |                          |          |                         |                                              |                                      |
|----------------------------------------------------------------------------------------------|-----------------------------------------|------------------|-------------------------------|--------------------------|----------|-------------------------|----------------------------------------------|--------------------------------------|
| Path 1: VIOLATED External Delay Assertion                                                    |                                         |                  |                               |                          |          |                         |                                              |                                      |
| Endpoi                                                                                       | nt: O                                   | (v)              | checked v                     | vith le                  | eading e | edge of                 | ′CK1 ′                                       | ,                                    |
| Beginp                                                                                       | oint: fd3                               | 3/Q (v)          | triggered                     | d by le                  | eading e | edge of                 | 'CK1                                         | ,                                    |
| Other                                                                                        | End Arriv                               | val Time         | 1.0                           | 00                       |          |                         |                                              |                                      |
| - Exte                                                                                       | ernal Dela                              | ay               | 4.7                           | 70                       |          |                         |                                              |                                      |
| + Phas                                                                                       | se Shift                                |                  | 5.0                           | 00                       |          |                         |                                              |                                      |
| = Requ                                                                                       | aired Time                              | 2                | 1.3                           | 30                       |          |                         |                                              |                                      |
| - Arri                                                                                       | val Time                                |                  | 1.7                           | 70                       |          |                         |                                              |                                      |
| = Slac                                                                                       | = Slack Time -0.40                      |                  |                               |                          |          |                         |                                              |                                      |
| C                                                                                            | Clock Rise Edge 1.00                    |                  |                               |                          |          |                         |                                              |                                      |
| = Beginpoint Arrival Time 1.00                                                               |                                         |                  |                               |                          |          |                         |                                              |                                      |
| +                                                                                            |                                         |                  |                               |                          |          |                         |                                              |                                      |
| Pin     Edge     Net     Cell     Delay     Arrival     Require       Time     Time     Time |                                         |                  |                               |                          |          |                         | Required<br>Time                             |                                      |
|                                                                                              | CK<br>an2/B<br>an2/Z<br>fd3/CP<br>fd3/Q | ^<br>^<br>^<br>V | CK<br>CK<br>CLK1<br>CLK1<br>0 | AN2<br>AN2<br>FD1<br>FD1 | 0.00     | )   1<br>)   1<br>)   1 | L.00<br>L.00<br>L.00<br>L.00<br>L.00<br>L.70 | 0.60<br>0.60<br>0.60<br>0.60<br>1.30 |

0 | v | 0 | latch | 0.00 | 1.70 | 1.30 |

The following command displays the worst late path in the design. The format of the report is similar to the first example:

report\_timing

The following command displays the worst late path to each violating endpoint that has a slack less than -1.0:

```
report_timing -max_slack -1.0
```

■ The following command displays all the late paths that end at port out[2] and that have negative slack up to a maximum of 1000 worst paths. If there are more than 1000 paths, only the 1000 worst paths are reported:

report\_timing -to out[2] -max\_paths 1000 -max\_slack 0.0

■ The following command reports the worst late path that starts at in[0] and ends at out[1]:

report\_timing -from in[0] -to out[1]

■ The following command displays the three worst paths that start at in[1] and end at out[3]. With reconvergent fanout, more than one path may exist:

report\_timing -from in[1] -to out[3] -max\_paths 3

■ The following command displays the ten worst paths. Only the paths between the specified pins are enumerated. With reconvergent fanout, more than one path may exist:

report\_timing -from i102/Z -to i123/A -max\_paths 10

The following command enumerates the worst ten paths through the given two pins, starting at the beginning points in the design and ending at the endpoints, similar to using the -from option:

report\_timing -through i102/Z -through i123/A -max\_paths 10

The following command reports the ten worst paths through blocks A and C, or blocks B and C. The path only has to satisfy one element in a through list, but all through lists must be satisfied. The example can be thought of as ((A or B) and C):

report\_timing -through  ${A/*B/*}$  -through  ${C/*}$  -max\_paths 10

■ The following command forces a path through pin A and pin B. Use the syntax shown in the example. Do not use -through {A B}:

```
report_timing -through -through A -through B
```

■ The following command reports the worst endpoint and the ten worst paths to that endpoint. Similar to report\_timing -max\_paths 10 -to out[1], if out[1] is the worst endpoint:

```
report_timing -max_points 1 -nworst 10
```

The following command displays the clock path through the clock root to Launch flop:

report\_timing -through aBC\_bs/bs\_mex1/r2\_00\_q1\_reg\_10\_/CK -to .... -path\_type
full\_clock

You will not see the path for the launch clock if you specify:

report\_timing -from aBC\_bs/bs\_mex1/r2\_00\_q1\_reg\_10\_/CK

Because you specified to report timing to start *from* the CK pin, that is exactly what it will report. The first command displays the path leading to the CK pin.

■ The following command shows the -unconstrained option:

report\_timing -unconstrained

| Report              | report_timing        |
|---------------------|----------------------|
| Options             | -unconstrained       |
| Date                | 20010122.181608      |
| Tool                | ac_shell             |
| Release             | v4.1-eng             |
| Version             | Jan 22 2001 15:25:02 |
| Module              | scid                 |
| Timing              | LATE                 |
| Slew Propagation    | WORST                |
| Operating Condition | NOM                  |
| PVT Mode            | max                  |
| Tree Type           | balanced             |
| Process             | 1.00                 |
| Voltage             | 5.00                 |
| Temperature         | 25.00                |
| time unit           | 1.00 ns              |
| capacitance unit    | 1.00 pF              |
| resistance unit     | 1.00 kOhm            |

Path 1:Endpoint: 02 (^)

Beginpoint: reg2/Q (v) triggered by trailing edge of 'vclk'

| Instance                       | Arc                                                                     | Cell                       | Delay                                | Arrival  <br>Time                                  |
|--------------------------------|-------------------------------------------------------------------------|----------------------------|--------------------------------------|----------------------------------------------------|
| nand1<br>buf1<br>reg2<br>nand4 | clk1 v<br>B v -> Z ^<br>A ^ -> Z ^<br>CP ^ -> Q v<br>A v -> Z ^<br>O2 ^ | ND2<br>BUF8A<br>FD1<br>ND2 | 0.17<br>0.18<br>0.74<br>0.07<br>0.00 | 10.00<br>10.17<br>10.35<br>11.09<br>11.16<br>11.16 |

report\_timing -unconstrained -summary

| +       | +                          |
|---------|----------------------------|
| Report  | report_timing              |
| Options | -unconstrained<br>-summary |
| Date    | 20010122.181053            |

| Tool<br>Release<br>Version                                                                                                                                               | ac_shell<br>v4.1-eng<br>Jan 22 20                                                                                                        | 01 15:25:02                                           |                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------|
| Module<br>Timing<br>Slew Propagatic<br>Operating Cond:<br>PVT Mode<br>Tree Type<br>Process<br>Voltage<br>Temperature<br>time unit<br>capacitance unit<br>resistance unit | ition NOM<br>max<br>balanced<br>1.00<br>5.00<br>25.00<br>1.00 ns<br>1.00 pF                                                              |                                                       | -+                                                                                   |
| Pin   Cau                                                                                                                                                                | use                                                                                                                                      | Arrival                                               | Phase                                                                                |
| Ol v Und<br>reg2/D ^ Und<br>reg3/D ^ Und<br>reg1/D v Und<br>reg4/D v Und                                                                                                 | constrained Path<br>constrained Path<br>constrained Path<br>constrained Path<br>constrained Path<br>constrained Path<br>constrained Path | 10.82<br>0.70<br>0.24<br>0.17<br>0.15<br>0.15<br>0.00 | vclk N<br>vclk P<br>Unconstrained<br>Unconstrained<br>Unconstrained<br>Unconstrained |

The following examples refer to Figure 7-5.

#### Figure 7-5 Conditions for Unconstrained and Constrained Paths



- <u>Figure 7-5</u> shows the path from I to 0 is reported as an unconstrained path under the following conditions (constraints on I and 0):
  - □ No constraints on either I or O
  - set\_input\_delay -clock ckl 1.0 I No set\_external\_delay constraint on 0
  - set\_external\_delay -clock ck1 1.0 0
    No set\_input\_delay constraint on I
  - set\_input\_delay 1.0 I
    set\_external\_delay 1.1 0

- set\_input\_delay -clock ck1 1.0 I
  set\_data\_required\_time -clock ck2 1.0 0
- Shows the path from I to O is reported as a constrained path under the following conditions (constraints on I and O):
  - set\_input\_delay -clock ckl 1.0 I
    set\_external\_delay -clock ckl 1.0 0
  - set\_input\_delay -clock ck1 1.0 I
    set\_external\_delay -clock ck2 1.0 0
  - set\_data\_arrival\_time -clock ck1 1.0 I set\_data\_required\_time -clock ck1 1.0 0 set\_data\_required\_time -clock ck2 1.0 0
- Shows two paths from I to O and reports one as a constrained path and the other one as an unconstrained path under the following conditions (constraints on I and O):
  - set\_input\_delay -clock ck1 1.0 I
    set\_input\_delay -clock ck2 1.0 I
    set\_data\_required\_time -clock ck2 1.0 0
  - set\_input\_delay 1.0 I
    set\_data\_required\_time 1.1 0
- Explains the -late and -early reports for clock signals. Consider the following instance of a flip-flop. First the <u>report cell instance</u> -timing command is used to show all of the checks for the instance. The results are given below:

| Instance tmp_reg of FD1                                    |                                          |                                      |                                                                |                                               |                                                    |                                                                                  |                                                                                  |
|------------------------------------------------------------|------------------------------------------|--------------------------------------|----------------------------------------------------------------|-----------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| Check                                                      | Sig                                      | Ref                                  | Slack                                                          | Delay                                         | Adjust                                             | Sig                                                                              | Ref                                                                              |
| PULSEWIDTH<br>PULSEWIDTH<br>HOLD<br>HOLD<br>SETUP<br>SETUP | CP ^<br>CP v<br>D ^<br>D v<br>D v<br>D v | CP ~<br>CP ~<br>CP ~<br>CP ~<br>CP ~ | <b>14.58</b><br>14.63<br><b>1.05</b><br>1.93<br>28.86<br>27.90 | 0.42<br>0.37<br>-0.05<br>0.07<br>0.14<br>0.10 | 0.00<br>-30.00<br>0.00<br>0.00<br>-30.00<br>-30.00 | cl(C)(P)<br>cl(C)(P)<br>cl(D)(P)<br>cl(D)(P)<br>cl(D)(P)<br>cl(D)(P)<br>cl(D)(P) | cl(C)(P)<br>cl(C)(P)<br>cl(C)(P)<br>cl(C)(P)<br>cl(C)(P)<br>cl(C)(P)<br>cl(C)(P) |

Since the hold check has worse slack than pulsewidth check, report\_timing shows:

| Path 1: MET Hold Check |                  |                      |
|------------------------|------------------|----------------------|
| Endpoint: tmp_reg/CP   | (^) checked with | leading edge of 'cl' |
| Beginpoint: cl         | (^) triggered by | leading edge of 'cl' |
| Other End Arrival Time | 1.00             |                      |
| + Hold                 | 0.05             |                      |
| + Phase Shift          | 0.00             |                      |
| = Required Time        | 1.05             |                      |
| - Arrival Time         | 0.00             |                      |
| = Slack Time           | 1.05             |                      |

And similarly, since pulsewidth check has worse slack than setup check, report\_timing -early shows:

Path 1: MET PulseWidth Check with Pin tmp\_reg/CPEndpoint: tmp\_reg/CP (v) checked with leading edge of 'cl'Beginpoint: c1 (v) triggered by trailing edge of 'cl'Other End Arrival Time0.00+ PulseWidth0.42+ Phase Shift0.42- Arrival Time15.00= Slack Time14.58

*Default*: -late

Shows the transparent latch reports using the default global setting latch\_time\_borrow\_mode budget. For a comparison of reports using max\_borrow analysis mode, see <u>Analyzing Latch-Based Designs</u> in the *Timing* Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).

| report_timing -to                                                                                                           | b ld2/D                  |           |           |                      |                      |
|-----------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------|-----------|----------------------|----------------------|
| Path 1: MET Latch Borrowed Time Check with Pin ld2/G                                                                        |                          |           |           |                      |                      |
| Endpoint: ld2/I                                                                                                             | ) (v) checked            | with l    | eading eo | dge of 'CK1          | L′                   |
| Beginpoint: I                                                                                                               | (^) triggere             | ed by l   | eading eo | dge of 'CK1          | L ′                  |
| Other End Arriva                                                                                                            | L Time 1                 | .00       |           |                      |                      |
| + Time Borrowed                                                                                                             | 1                        | .81       |           |                      |                      |
| + Phase Shift                                                                                                               | 0                        | .00       |           |                      |                      |
| = Required Time                                                                                                             | 2                        | .81       |           |                      |                      |
| - Arrival Time                                                                                                              | 2                        | .10       |           |                      |                      |
| = Slack Time                                                                                                                | 0                        | .71       |           |                      |                      |
| Clock Rise Edge 1.00                                                                                                        |                          |           |           |                      |                      |
| + Input Delay 1.00                                                                                                          |                          |           |           |                      |                      |
| = Beginpoint Arrival Time 2.00                                                                                              |                          |           |           |                      |                      |
| Instance                                                                                                                    | Arc                      | Cell      | Delay     | Time                 | Required<br>Time     |
| inv0<br>1d2                                                                                                                 | I ^<br>A ^ -> Z v<br>D v | IV<br>LD1 | 0.10      | 2.00<br>2.10<br>2.10 | 2.71<br>2.81<br>2.81 |
| report_timing -through ld2/Q<br>Path 1: MET External Delay Assertion<br>Endpoint: 02 (^) checked with leading edge of 'CK1' |                          |           |           |                      |                      |
| Reginnoint: $1d_2/0$ (A) triggered by leading edge of $(CK1)$                                                               |                          |           |           |                      |                      |

Beginpoint:  $ld_2/Q$  (^) triggered by leading edge of 'CK1'

Other End Arrival Time 1.00

- External Delay 1.00 + Phase Shift 5.00

| = Required Time | 5.                                       | .00        |                      |                                       |                              |                              |
|-----------------|------------------------------------------|------------|----------------------|---------------------------------------|------------------------------|------------------------------|
| - Arrival Time  | 3 .                                      | .40        |                      |                                       |                              |                              |
| = Slack Time    | 1.                                       | .60        |                      |                                       |                              |                              |
| Clock Rise E    | Idge                                     |            | 1.00                 |                                       |                              |                              |
| = Beginpoint    | Arrival Time                             | 9          | 1.00                 |                                       |                              |                              |
| +<br>Instance   | Arc                                      | Cell       | Delay                | Time<br>Given<br>To<br>Start<br>Point | Arrival<br>Time              | Required<br>Time             |
| an2<br>1d2      | CK ^<br>B ^ -> Z ^<br>D ^ -> Q ^<br>O2 ^ | AN2<br>LD1 | 0.00<br>0.46<br>0.00 | 1.94                                  | 1.00<br>1.00<br>3.40<br>3.40 | 2.60<br>2.60<br>5.00<br>5.00 |

Changes the format of the report. Compare the output to that shown in the first example (report\_timing -to out):

```
report_timing -to 0 -net -format {instance arc net load delay arrival}
Path 1: VIOLATED External Delay Assertion
Endpoint: 0 (v) checked with leading edge of 'CK1'
Beginpoint: fd3/Q (v) triggered by leading edge of 'CK1'
Other End Arrival Time 1.00
- External Delay
                       4.70
+ Phase Shift
                        5.00
                       1.30
= Required Time
- Arrival Time
                        1.70
= Slack Time
                       -0.40
    Clock Rise Edge
                                 1.00
    = Beginpoint Arrival Time
                                 1.00
    +------
                 Arc | Cell | Delay | Arrival | Required
Time | Time
      Instance
     an2<br/>fd3CK ^<br/>B ^ -> Z ^<br/>Q VAN20.001.00<br/>D.000.60<br/>D.00fd3CP ^ -> Q V<br/>O VFD10.70<br/>D.001.701.30<br/>D.30
```

## **Related Information**

<u>report\_net</u>

<u>report ports</u>

set\_global slew\_propagation\_mode

<u>set\_table\_style</u>

## reset\_capacitance\_limit

```
reset_capacitance_limit [-min | -max] [-instance instance_list]
    [-port port_list]
```

Resets instance-specific or port-specific design rule constraints. Design rules set on a hierarchical instance applies to all the pins contained in that hierarchical instance.

Use the set\_global max\_capacitance\_limit or the set\_global min\_capacitance\_limit to set context specific design rules. If either one of these globals has also been set, the most constraining value is used.

## **Options and Arguments**

| -instance instance_li | st<br>Specifies the list of hierarchical instances where the limit is reset.                |
|-----------------------|---------------------------------------------------------------------------------------------|
| -min   -max           | Resets the minimum (or maximum) instance-specific or port-specific design rule constraints. |
| -port port_list       | Specifies the list of ports where the limit is reset.                                       |

#### Example

The following command resets the maximum instance-specific or port-specific design rule constraints:

reset\_capacitance\_limit -max -instance [I1}

#### **Related Information**

reset port capacitance limit

<u>reset\_slew\_time\_limit</u>

set capacitance limit

set global max capacitance limit

<u>set global min capacitance limit</u>

<u>set port capacitance limit</u>

<u>set slew\_time\_limit</u>

## reset\_capacitance\_unit

```
reset_capacitance_unit
```

Resets the session capacitance unit. The default target technology units become applicable for the session.

## Example

The following command resets the session capacitance unit to the default target technology units:

reset\_capacitance\_unit

## **Related Information**

<u>reset\_time\_unit</u>

<u>set capacitance unit</u>

set\_time\_unit

# reset\_clock\_gating\_check

reset\_clock\_gating\_check [-setup | -hold] [-rise | -fall]
 [-pin instance\_or\_pin\_list] [-clock clock\_list [-lead | -trail]]

Resets the timing margin specified with  $\verb+set_clock_gating_check$  back to the default value.

### **Options and Arguments**

| -clock <i>clock_list</i> |                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Specifies the clock signals for which the command resets a clock-gating assertion to the default. The timing margins for clock-gating checks for any instance that gates a clock signal having such an assertion are reset.                                                                                                                         |
| -lead   -trail           |                                                                                                                                                                                                                                                                                                                                                     |
|                          | Resets the specified timing margin for only those clock-gating<br>checks for which the reference clock edge is the leading (or<br>trailing) edge. If neither option is specified, the timing margins<br>are reset on both leading and trailing edges.                                                                                               |
|                          | Use the -lead or -trail options only with the -clock option.                                                                                                                                                                                                                                                                                        |
| -pin instance_or_pi      | n list                                                                                                                                                                                                                                                                                                                                              |
|                          | Lists the pins for which the timing margins (setup/hold values) for<br>clock-gating checks are reset. If the name of a clock-gating<br>instance is given in the argument list, the command resets all<br>inputs of the instance. Likewise, if the clock input pin of the<br>instance is given, the command again resets all the instance<br>inputs. |
| -rise   -fall            | Resets the specified timing margin for the rising (or falling) delay<br>only. If neither option is specified, the default resets both rising<br>and falling.                                                                                                                                                                                        |
| -setup   -hold           |                                                                                                                                                                                                                                                                                                                                                     |
|                          | Resets the timing margin (setup value or hold value) for the clock-gating setup check back to the default setup or hold value.                                                                                                                                                                                                                      |

## Example

The following command resets the setup value for the clock-gating setup check and the clock signal CLK1 back to the default value:

reset\_clock\_gating\_check -setup -clock CLK1

#### **Related Information**

set\_clock\_gating\_check

<u>Setting Clock Gating Setup and Hold Checks</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

# reset\_clock\_info\_change

```
reset_clock_info_change
To reset a data signal use: reset_clock_info_change
[-lead | -trail] [-early | -late] [-rise | -fall]
-clock clock_name
pin_list
||
To reset a clock signal use: reset_clock_info_change
[-pos | -neg] [-early | -late] [-rise | -fall]
-clock clock_name
pin_list
```

Changes the clock/data information for paths going through the specified pins for the downstream logic. This command removes assertions previously given by the set\_clock\_info\_change command.



Remove all clock info assertions on pin z regardless of clock name or current signal type with the following command:

remove\_assertions -type clock\_info\_change Z

## **Options and Arguments**

| -clock <i>clock_name</i> | Specifies the clock waveform to apply or remove from the pin.                                                                                                                                                                        |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late           | Resets early or late arrival of the signal.<br><i>Default</i> : Both                                                                                                                                                                 |
| -lead   -trail           | Indicates that the signal at the specified pin is currently (before<br>the reset) recognized as a data signal with the specified<br>association (lead or trail) with respect to the specified clock<br>clock_name.<br>Default: -lead |
| pin_list                 | Associates paths from the pin list with the specified clock $clock\_name$ . The pin list can be ports or instance pins. These can be object IDs or hierarchical names relative to the current module.                                |

| -pos   -neg   | Indicates that paths are recognized as clock paths prior to the reset and that the clock has the specified polarity. This option is required to reset a clock path. If neither $-pos$ or $-neg$ is specified, the path is recognized as a data path prior to the reset. |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <b>Note:</b> Because the signal cannot be both a clock signal and a data signal, the -pos   -neg options cannot be used with the -lead   -trail options.                                                                                                                |
| -rise   -fall | Resets the rising or falling edge of the signal. <i>Default</i> : Both                                                                                                                                                                                                  |

### Example

The following command changes the output of an AND gate from a clock signal type back to the data signal type that it had before being changed to clock:

reset\_clock\_info\_change -clock clk -pos U1/A1/0

#### **Related Information**

remove\_assertions

<u>set clock info change</u>

## reset\_clock\_insertion\_delay

```
reset_clock_insertion_delay {([-source] [-lead | -trail] [-early | -late]
    [-pvt {min | typ | max}] list_of_clocks) | ([-source] [-clock clock_name]
    [-early | -late] [-pvt {min | typ | max}] [-rise | -fall] -pin list_of_pins)}
HINT: Use [-early | -late] only with -source. Use -pvt only for network delay
    (no -source).
```

Resets the clock insertion delay (either source or network) as previously specified with the set\_clock\_insertion\_delay assertion.



Alternatively, you can use the following command to remove both source and network clock insertion delay assertions from pin in1:

remove\_assertions -type clock\_insertion\_delay in1

## **Options and Arguments**

| -clock <i>clock_name</i> | Resets only the source insertion delay that is caused by the named clock waveform. Used when more than one clock generator is connected to the port.                                                                              |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late           | Specifies clock arrival time with respect to the early (setup) or the late (hold) time of the clock signal. If neither option is specified, the default is both -early and -late. Use these options only with the -source option. |
| -lead   -trail           | Resets insertion delay at the leading or trailing edge of the clock waveform. <i>Default</i> : Both edges                                                                                                                         |
| list_of_clocks           | Lists clock waveform names to associate with the clock insertion delay reset.                                                                                                                                                     |
| -pin list_of_pins        | Lists pins to associate with the clock insertion delay reset. The pin can be a port or an instance pin. These can either be object IDs or hierarchical names relative to the current module.                                      |

|                      | For internal pins, both the source and network delay must be specified.                                                                                                                                                                                                                                                                                                                      |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -pvt {min   typ   ma | Resets the clock insertion delay for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. <i>Default</i> : The specified clock insertion delay applies to all three PVT corners. This option cannot be used with the -source option. |
| -rise   -fall        | Resets the insertion delay at the rising or falling edge of the clock.                                                                                                                                                                                                                                                                                                                       |
| -source              | Specifies that the delay being reset is a source delay. Without this option, the delay being reset is considered a network delay.                                                                                                                                                                                                                                                            |

## Example

The following command resets the insertion delay at the falling edge of the clock and lists the pins clkB clkD associated with the clock insertion delay reset:

reset\_clock\_insertion\_delay -fall -pin {clkB clkD}

## **Related Information**

<u>remove\_assertions</u>

<u>set\_clock\_insertion\_delay</u>

## reset\_clock\_root

reset\_clock\_root [-clock clk\_signame] [-pos] [-neg] pin\_list

Removes previously given clock root assertions. The command behavior follows that of set\_clock\_root, except both -pos and -neg can be given at the same time. If the -clock option is absent, all clock root assertions are removed.



Alternatively, you can use the following command to remove all clock root assertions on a pin x:

```
remove_assertions -type clock_root x
```

## **Options and Arguments**

| -clock <i>clk_signame</i> | Specifies the name of the ideal clock signal as specified by the previous set_clock_root assertion.                                                                                                           |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -neg                      | Removes a negative ideal clock signal. If neither $-pos$ nor $-neg$ is specified, the default is $-pos$ (rising edge precedes falling edge).                                                                  |
| pin_list                  | Lists the pins to remove from association with an ideal clock<br>signal. The pin can be a port or an instance pin. These can either<br>be object IDs or hierarchical names relative to the current<br>module. |
| -pos                      | Removes a positive ideal clock signal. If neither $-pos$ nor $-neg$ is specified, the default is $-pos$ (rising edge precedes falling edge).                                                                  |

#### Example

The following command removes a previously given clock root assertion for the master ideal clock signal and removes a negative negclk and a positive posclk ideal clock signal:

reset\_clock\_root -clock master -neg -pos {negclk posclk}

## **Related Information**

remove\_assertions

<u>set\_clock\_root</u>

## reset\_clock\_uncertainty

```
reset_clock_uncertainty [-ideal | -propagated] [-early | -late]
    {([-clock_from clk_from] [-clock_to clk_to]
    [-edge_from {leading | trailing}] [-edge_to {leading | trailing}]) |
    (-pin list_of_clock_tree_pins [-rise] [-fall] [-to])}
```

Resets the assertions that were made by previous set\_clock\_uncertainty commands.

## **Options and Arguments**

| -clock_from <i>clk_from</i>    | <sup><i>n</i></sup> Specifies the starting point of the paths for which the uncertainty is reset. The $clk_from$ argument is the name of clock signal with respect to which the uncertainty was specified.                                                                                                     |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | If the -clock_from option is omitted then the uncertainty reset applies to all the paths ending at the registers clocked by the -clock_to signal.                                                                                                                                                              |
| -clock_to <i>clk_to</i>        | Specifies the endpoint of the paths for which the uncertainty is reset. The uncertainty reset applies to all paths starting from the -clock_from signal and ending at the registers clocked by -clock_to signal.                                                                                               |
|                                | If the <pre>-clock_to option is omitted, then the uncertainty reset applies to all paths starting at the <pre>-clock_from signal.</pre></pre>                                                                                                                                                                  |
|                                | If both the options <code>-clock_from</code> and <code>-clock_to</code> are omitted, then the uncertainty reset applies to all clocked paths in the design, including combinational paths constrained by the <code>set_input_delay</code> and <code>set_external_delay</code> times associated with the clock. |
| -early   -late                 | Specifies whether the uncertainty is reset with respect to the<br>early times or the late times. In other words, whether the reset<br>applies to hold (-late) or setup (-early) checks on the clock<br>signals<br><i>Default</i> : Both -early and -late                                                       |
| <pre>-edge_from {leading</pre> | trailing}<br>Specifies whether the triggering (launching) edge of the clock is                                                                                                                                                                                                                                 |

|                      | a leading or a trailing edge.<br><i>Default</i> : The leading edge.                                                                                                                                                                                                                                                                                          |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -edge_to {leading    | trailing}<br>Specifies whether the capturing edge at the destination register<br>is a leading or a trailing edge.<br><i>Default</i> : The leading edge                                                                                                                                                                                                       |
| -ideal   -propagated | Specifies whether the uncertainty applies to the ideal clock<br>propagation mode or the propagated mode of analysis. If<br>neither option is given, the uncertainty applies in both ideal and<br>propagated modes by default.                                                                                                                                |
| -pin list_of_clock_  | _tree_pins<br>Resets the uncertainty for the given list of clock pins. Each pin<br>can be a port or an instance pin. It can either be given as an<br>object ID or a hierarchical name relative to the current module.<br>Cannot be used with -clock_from or -clock_to options.                                                                               |
| -rise   fall         | Specifies the rising (or falling) edge of the clock pins on which the uncertainty is reset. For each edge, the assertion is reset only if that edge fans out to the data and the clock pin of a register or latch. With the $-to$ option, the assertion is reset if that edge fans out to the clock pin of a register or latch. <i>Default</i> : Both edges. |
| -to                  | Specifies that the uncertainty reset applies to all the registers and latches whose clock pin is in the transitive fanout of a clock pin from the <i>list_of_clock_tree_pins</i> .                                                                                                                                                                           |

## Example

The following command resets an uncertainty on a clock pin (clk\_in) only for propagated mode, which is how the uncertainty was originally set:

reset\_clock\_uncertainty -propagated -pin clk\_in

## **Related Information**

<u>remove assertions</u>

<u>set\_clock\_uncertainty</u>

# reset\_constant\_for\_timing

reset\_constant\_for\_timing {-bidi\_input | -bidi\_output} pin\_list

Removes previously asserted constants on the specified pin(s). Once a constant has been reset, CTE returns to analyzing the system by calculating and propagating the arrival times (and in turn computing the required times) at the pin.

## **Options and Arguments**

| -bidi_input   -bidi | _output<br>Resets the constant that is set on the input or output part of<br>bidirectional pins.<br><i>Default</i> : Resets the constant on the input part.              |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pin_list            | Specifies a single pin or multiple pins to reset. To specify multiple pins, enclose the list with curly braces ({ )} and separate the pin information with white spaces. |

#### Example

The following command removes previously asserted constants on pin x20/z:

reset\_constant\_for\_timing X20/Z

#### **Related Information**

get constant for timing

# reset\_dcl\_calculation\_mode

reset\_dcl\_calculation\_mode

Resets the current Delay Calculation Library (DCL) calculation mode to the default mode of worst\_case.

The library developer defined the calculation modes in the DCL library to model three process conditions, best\_case, nominal\_case, and worst\_case within one library. Refer to the vendor documentation for more information.

**Note:** Process, temperature, and voltage are reset independently of the calculation mode using the reset\_operating\_parameter command.

## Example

The following command resets the DCL calculation mode to worst\_case:

reset\_dcl\_calculation\_mode

### **Related Information**

get dcl calculation mode

get operating parameter

<u>load\_dcl\_rule</u>

set dcl calculation mode

<u>set\_operating\_parameter</u>

## reset\_dcl\_functional\_mode

reset\_dcl\_functional\_mode [-group group\_name] [-mode mode\_name] instance\_list

Resets the current DCL functional mode to the library default.

### **Options and Arguments**

| -group group_name      | Specifies the functional mode group name.                            |
|------------------------|----------------------------------------------------------------------|
| instance_list          | Lists the instances for which the functional mode needs to be reset. |
| -mode <i>mode_name</i> | Specifies the functional mode name.                                  |

### Example

The following command resets the current DCL functional mode to the library default for group rw, functional mode read, for instances A1/B3/C2 A1/B2/C2:

reset\_dcl\_functional\_mode -group rw -mode read {A1/B3/C2 A1/B2/C2}

#### **Related Information**

get dcl\_functional\_mode

get dcl functional mode array

<u>load dcl rule</u>

set dcl functional mode

## reset\_dcl\_level

reset\_dcl\_level

Resets the performance level for DCL-based delay calculations to the default level of 0 (lower accuracy but faster run time).

## **Related Information**

<u>set\_dcl\_level</u>

## reset\_default\_slew\_time

reset\_default\_slew\_time [-early | -late] [-rise | -fall]

Resets the default slew time for the ports to a value of 0.0. The system uses this slew value for any input or bidirectional port for which slew or drive assertions are not specified.

The reset\_default\_slew\_time command is ignored for a port if set\_slew\_time, set\_drive\_cell, or set\_drive\_resistance constraints have been set for that port.

#### **Options and Arguments**

| -late   -early | Indicates whether the slew times being reset are with respect to<br>the late (data setup) or the early (data hold) checks. If neither<br>option is specified the default is to use both. |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -rise   -fall  | Specifies that the slew time should be reset on the rising edge or<br>the falling edge of the signal. If neither edge is specified, the<br>default is to use both.                       |

#### Example

The following command resets the default slew time with respect to early (data hold) checks on the rising edge of the signal previously set with the set\_default\_slew\_time command:

reset\_default\_slew\_time -rise -early 10.0

#### **Related Information**

set default slew time

<u>set\_drive\_cell</u>

<u>set\_drive\_resistance</u>

<u>set slew time</u>

# reset\_disable\_cell\_timing

```
reset_disable_cell_timing [-library library_name] [-cell cell_name]
    [{-from_pin | -from_rise | -from_fall} from_pin_name ]
    [{-to_pin | -to_rise | -to_fall} to_pin_name]
```

Re-enables timing arcs that were disabled by the set\_disable\_cell\_timing command. The timing arcs from or to internal pins inside IP cells can also be re-enabled.

### **Options and Arguments**

| -cell <i>cell_name</i>     | Specifies the cell in the library for which timing arcs are re-enabled.                                                                                                                                                                                                                                                 |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -from_pin -from_rise       | Re-enables timing arcs originating from the specified from_pin<br>from_pin_name option. Re-enable timing arcs that have been<br>disabled using either the from_rise option or the from_fall<br>option. All arcs from input pins specified with the -from_pin<br>from_pin_name option are re-enabled.                    |
| -library <i>library_na</i> | me<br>Specifies the library name which contains the cell whose arcs<br>are to be re-enabled. If not specified, the default is the target<br>technology library.                                                                                                                                                         |
| -to_pin -to_rise -t        | o_fall to_pin_name<br>Re-enables disabled timing arcs specified for the source pin of<br>the timing arc. You can re-enable disabled cell arcs with specific<br>edges using either the to_rise option or the to_fall option.<br>All arcs to output pins specified with the -to_pin<br>to_pin_name option are re-enabled. |

## Example

The following command re-enables arcs with a specific transition. Arcs originating from rising pin A and falling to pin Y are re-enabled:

reset\_disable\_cell\_timing -cell XORS -from\_rise A -to\_fall Y

## **Related Information**

- set constant for timing
- set disable cell timing
- set disable timing

<u>set\_false\_path</u>

## reset\_disable\_clock\_gating\_check

```
reset_disable_clock_gating_check [-from from_pins] [-to to_pins]
        [-bidi_input_from | -bidi_output_from] [-bidi_input_to | -bidi_output_to]
```

Resets all disabled clock gating checks to, from, or between the specified pins.

## **Options and Arguments**

| -bidi_input_from   -   | ·bidi_output_from<br>Specifies the assertion on the input or output part of the from<br>pin. Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.                                                                                                                                                              |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -bidi_input_to   -bi   | di_output_to<br>Specifies the assertion on the input or output part of the to pin.<br>Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.                                                                                                                                                                     |
| -from <i>from_pins</i> | Specifies the sink pin (clock pin) of the clock gating check to be disabled. If the -from option is used without the -to option, all clock gating checks that reference from_pins are disabled. Either -from or -to must be used with this command. Specifying both -from and -to identifies a check with specific start and endpoints. |
| -to to_pins            | Specifies the source (data enable signal) pin of the clock gating check to be disabled.                                                                                                                                                                                                                                                 |
|                        | If the $-to$ option is used without the $-from$ option, all clock gating checks with $to_pins$ for data enable signal (clock gating pin) are disabled.                                                                                                                                                                                  |

#### **Related Information**

reset\_clock\_gating\_check

set clock gating check

set disable clock gating check

## reset\_disable\_timing

```
reset_disable_timing -from from_pins -to to_pins
    [-bidi_input_from | -bidi_output_from] [-bidi_input_to | -bidi_output_to]
```

Deletes the assertion created by set\_disable\_timing with the exact same pin(s). For example, you cannot disable all the arcs to a pin individually and then use reset\_disable\_timing -to pin to reset all the arcs.

Deletes assertions applied to check arcs and delay arcs for the pin or arc.



To reset all of the arcs, use the same number of commands with the exact same pin(s), only replacing the set\_disable\_timing command with the reset\_disable\_timing command.

## **Options and Arguments**

| -bidi_input_from   - | bidi_output_from<br>Specifies the assertion on the input or output part of the from<br>pin. Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.                                                                                                                                       |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -bidi_input_to   -bi | di_output_to<br>Specifies the assertion on the input or output part of the to pin.<br>Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.                                                                                                                                             |
| -from from_pins      | Specifies the source pin of the timing arc or the clock reference<br>pin of the check arc to be re-enabled. If the -from option is used<br>without the -to option, all paths originating from the<br>from_pins are enabled. All check arcs with the specified from<br>pin as reference pin are also re-enabled. |
|                      | Use either the -from or -to option with this command.<br>Specifying both the -from and -to options identifies a path with<br>specific start and endpoints.                                                                                                                                                      |
|                      | The <pre>-from and <pre>-to</pre> options can be intermediate hierarchical boundaries.</pre>                                                                                                                                                                                                                    |

-to  $to\_pins$ Specifies the sink pin of the timing arc or the data pin of the check arc to be re-enabled. If the -to option is used without the -from option, all paths ending in  $to\_pins$  are enabled.

## Examples

The following command re-enables all timing arcs from the Q pin of instance I1:

```
reset_disable_timing -from I1/Q
```

■ The following command re-enables the timing arc from the input part of bidirectional pin A to the output part of bidirectional pin B:

reset\_disable\_timing -from A -to B -bidi\_input\_from -bidi\_output\_to

■ The following command re-enables the timing arc from the A pin to z pin of instance NAND2:

reset\_disable\_timing -from NAND2/A -to NAND2/Z

■ The following command re-enables all timing arcs which pass through the hierarchical port, port1, of module mod and end at an input or bidirectional pin:

reset\_disable\_timing -from mod/port1

■ The following command re-enables all timing check arcs with r/D as data signal and r/ CP as check reference pin:

reset\_disable\_timing -from r/CP to r/D

## **Related Information**

- set disable cell timing
- <u>set disable timing</u>
- <u>set false path</u>

## reset\_drive\_cell

```
reset_drive_cell [-early | -late] [-clock clock_signame]
    [-lead | -trail | -pos | -neg] port_list
```

Removes the drive cell assertion, previously set by the set\_drive\_cell command, from the named ports.

- Tip

You can more easily remove all drive cell assertions from port  ${\tt IN}$  with this command:

```
remove_assertions -type drive_cell IN
```

## **Options and Arguments**

| -clock clock_signam  | e<br>Specifies the ideal clock that was controlling the signal.                                                                                                         |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early               | Specifies that the driver provided a signal for early mode analysis (data hold check).                                                                                  |
| -late                | Specifies that the driver provided a signal for late mode analysis (data setup check).                                                                                  |
| -lead   -trail   -po | S   -neg<br>Specifies that the slew time was for a data signal triggered by the<br>leading or the trailing edge of the ideal clock.<br>Default: -lead.                  |
|                      | For a clock signal, $-pos$ and $-neg$ specify that the slew time was applied to an actual clock that has positive or negative polarity with respect to the ideal clock. |
| port_list            | Specifies the list of ports for which the driver cell is to be removed.                                                                                                 |

## Example

The following command finds the previously set drive cell input1, previously set by the set\_drive\_cell command, then removes the drive cell assertion from the named ports:

reset\_drive\_cell -clock clk [ find -input -port \* ]
reset\_drive\_cell input1

## **Related Information**

remove assertions

<u>set\_drive\_cell</u>

## reset\_drive\_resistance

```
reset_drive_resistance -clock clk_signame [-lead | -trail | -pos | -neg]
    [-rise | -fall] [-early | -late] port_list
```

Removes assertions previously specified by the set\_drive\_resistance command.

### **Options and Arguments**

| -clock <i>clk_signame</i> | Specifies the name of the clock signal.                                                                                                                                                                                                                    |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late            | Specifies that the drive resistance should be removed from the early arrival time (data hold time) or late arrival time (data setup time).                                                                                                                 |
| -lead   -trail   -po      | Indicates that the signal at the specified port must be recognized<br>as a data signal with the specified association (lead or trail)<br>with respect to the specified clock <i>clock_name</i> .<br><i>Default</i> : -lead.                                |
|                           | For a clock signal, $-pos$ and $-neg$ specify that the slew time<br>should be applied to an actual clock that has positive or negative<br>polarity with respect to the ideal clock.<br><i>Default</i> : $-pos$ .                                           |
| -rise   -fall             | Specifies that the drive resistance is removed only from the rising<br>edge or the falling edge transition at the input port. If neither rise<br>nor fall options are specified then the resistance is removed from<br>both transitions at the input port. |
| port_list                 | Specifies the list of ports for which drive resistance is removed.                                                                                                                                                                                         |

## Example

reset\_drive\_resistance [-input -port \* ]

## **Related Information**

<u>set\_drive\_cell</u>

<u>set drive resistance</u>

set\_slew\_time

## reset\_external\_delay

```
reset_external_delay [-clock clk_name] [-lead] [-trail] [-early] [-late]
      [-rise] [-fall] pin_list
```

Resets previously given external delay assertions. Its behavior follows that of the set\_external\_delay command, except both the -lead and -trail options can be
given at the same time.



Remove all external delay assertions (without specifying the clocks) for a pin x using the following command:

```
remove_assertions -type external_delay x
```

## **Options and Arguments**

| -clock <i>clock_name</i> | Specifies the name of the clock.<br><i>Default</i> : The asynchronous (@) clock.                                                                                                                        |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late           | Specifies that the constraint refers to the early (data hold) or late (data setup) times. If both -late and -early options are omitted, then the external delay is reset for both early and late times. |
| -lead                    | Resets the external delay for the leading edge of the clock. If neither -lead nor -trail is specified, the default is -lead.                                                                            |
| pin_list                 | Specifies a single pin or multiple pins for which the external delay is reset. To specify multiple pins, enclose the list with curly braces ({ )} and separate the pin information with white space.    |
| -rise   -fall            | Resets the external delay for the rising edge or falling edge at the input port. If both -rise and -fall options are omitted, the external delay is reset on both the edges.                            |

-trail

Resets the external delay for the trailing edge of the clock. If neither option is provided, the default is *-lead*.

#### Example

The following command resets the external delay on the out pin of the clock (clk1) that was previously set by a set\_external\_delay constraint:

reset\_external\_delay -clock clk1 -lead out

#### **Related Information**

remove assertions

set\_external\_delay

## reset\_fanout\_load

reset\_fanout\_load port\_list

Resets the fanout load on the ports of a cell to the default values specified in the library. The fanout load previously specified by the set\_fanout\_load assertion is removed. Fanout loads are only used to enforce the design rule checks and have no effect on timing. Setting (or resetting) the port capacitance affects timing analysis.

### **Options and Arguments**

port\_list

Specifies the list of ports for which the assertion is removed.

#### Example

reset\_fanout\_load [find -port -output data\*]

#### **Related Information**

<u>remove assertions</u>

set fanout load limit

# reset\_fanout\_load\_limit

reset\_fanout\_load\_limit port\_list

Resets the fanout load limit (maximum value) on the ports of a cell. Fanout load limits are only used to enforce the design rule checks; they do not affect timing analysis. Setting (or resetting) port capacitance limit affects timing analysis.

The design rule requirement of a maximum fanout load value is set using the set\_global
fanout\_load\_limit global. For the specified ports, the reset\_fanout\_load\_limit
command restores the global default fanout load limit.

## **Options and Arguments**

port\_list

Specifies the list of ports for which the assertion is removed.

### Examples

reset\_fanout\_load\_limit [find -port -output data\*]
reset\_fanout\_load\_limit [find -port -input reset]

## **Related Information**

remove\_assertions

<u>set fanout load limit</u>

# reset\_feedback\_loop\_snipped\_arcs

reset\_feedback\_loop\_snipped\_arcs {[-from from\_pin] | [-to to\_pin]}

Restores the arcs that the tool disabled in order to time the loops in the design. The tool chooses the arc at which to break a loop somewhat arbitrarily. This command lets you reactivate the timing arcs that were previously snipped by the tool. If there was no snipped arc, a warning message is issued.

After issuing this command, you must disable (snip) a different arc to break the loop where you want it broken. Use the set\_disable\_timing command to break feedback loops. if the loop is not broken, a warning message is issued by the check\_timing command.

#### **Options and Arguments**

The arcs to be reactivated must be chosen using -from, or -to, or both options.

-from from\_pin

Resets all arcs out of the  $from_pin$  which were snipped by the tool.

-to to\_pin

Resets all arcs into the *to\_pin* which were snipped by the tool.

#### Example

reset\_feedback\_loop\_snipped\_arcs -from g1/Z

#### **Related Information**

check\_timing

<u>set disable timing</u>

# reset\_functional\_mode

reset\_functional\_mode [-group group\_name] [-mode mode\_name] instance\_list

Resets the DCL or the STAMP functional mode group and name on hierarchical instances. To determine what modes are available for an instance, use the report\_functional\_mode command.

This command has no effect if the mode is already inactive. If you reset a mode which is the only active mode, then all modes become active. For example, consider a mode group rw with two modes read and write. If you set read and then reset it, both read and write modes become active again, as if no modes had been set. This behavior differs from PrimeTime which leaves all modes inactive if one is set and then later reset.

**Note:** Currently there is no command to make all modes inactive.

## **Options and Arguments**

| -group group_name      | Specifies the string value of the functional mode group name.                    |
|------------------------|----------------------------------------------------------------------------------|
| instance_list          | Specifies the list of instances for which the functional mode needs to be reset. |
| -mode <i>mode_name</i> | Specifies the string value of the functional mode name.                          |

#### Example

The following command resets the DCL or the STAMP functional mode group rw and name read on hierarchical instances A1/B3/C2:

reset\_functional\_mode -group rw -mode read A1/B3/C2

# **Related Information**

<u>report\_functional\_mode</u>

<u>set functional mode</u>

# reset\_generated\_clock

reset\_generated\_clock target\_pin\_list

Removes generated clock assertions previously created using the set\_generated\_clock command. This command removes all the generated clock assertions on each pin in the *target\_pin\_list*. However, the generated clock waveforms themselves are not removed from the system, because they may be referenced by other generated clocks in the design. A generated clock can be reused by a subsequent set\_generated\_clock command.

## **Options and Arguments**

target\_pin\_list

Specifies the list of pins where the generated clock assertion is removed. The signal propagating downstream from the pins is no longer associated with the generated clock.

## Example

The following command removes generated clock assertions on pinY previously created using the set\_generated\_clock command:

reset\_generated\_clock pinY

# **Related Information**

<u>set generated clock</u>

# reset\_ideal\_net

reset\_ideal\_net net\_name\_or\_id

Removes the ideal assertion from the net. The net delays revert to their Steiner, annotated, or wire-load model (WLM) values.

# **Options and Arguments**

net\_name\_or\_id

Specifies one or more net names (or ids) that are not to be considered ideal nets anymore.

## Example

The following command removes the ideal assertion from nets clk1 clk2:

reset\_ideal\_net {clk1 clk2}

## **Related Information**

<u>set ideal net</u>

# reset\_input\_delay

```
reset_input_delay [-clock clk_name] [-lead] [-trail] [-early] [-late] [-rise]
        [-fall] pin_list
```

Resets previously given input delay assertions. Its behavior follows that of the set\_input\_delay command, except both the -lead and -trail options can be given at the same time.



To remove all input delay assertions (without specifying the clocks) for a pin x, use: remove\_assertions -type input\_delay x

# **Options and Arguments**

| -clock <i>clock_name</i> |                                                                                                                                                                                                       |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Specifies the name of the clock.                                                                                                                                                                      |
|                          | Default: The asynchronous (@) clock.                                                                                                                                                                  |
| -early   -late           |                                                                                                                                                                                                       |
|                          | Specifies that the constraint refers to the early (data hold) or late (data setup) times. If both -late and -early options are omitted, then the input delay is reset for both early and late times.  |
| -lead                    |                                                                                                                                                                                                       |
|                          | Resets the input delay for the leading edge of the clock. If neither -lead nor -trail is specified, the default is -lead.                                                                             |
| pin_list                 |                                                                                                                                                                                                       |
|                          | Specifies a single pin or multiple pins for which the input delay is reset. To specify multiple pins, enclose the list with curly braces $(\{ \})$ and separate the pin information with white space. |
| -rise   -fall            |                                                                                                                                                                                                       |
|                          | Resets the input delay for the rising edge or falling edge at the input port. If both $-rise$ and $-fall$ options are omitted, the input delay is reset on both the edges.                            |
| -trail                   |                                                                                                                                                                                                       |
|                          | Resets the input delay for the trailing edge of the clock. If neither option is provided, the default is $-lead$ .                                                                                    |

# Example

reset\_input\_delay -clock clk1 -lead -trail in

## **Related Information**

remove assertions

# reset\_num\_external\_sinks

reset\_num\_external\_sinks port\_list

Resets the number of external sinks previously specified by the set\_num\_external\_sinks command to the default value of 1.

## **Options and Arguments**

port\_list

Specifies the list of ports to have 1 external sink.

#### Example

The following command resets the number of external sinks to the default value of 1 for port out:

reset\_num\_external\_sinks out

#### **Related Information**

remove\_assertions

set num external sinks

# reset\_num\_external\_sources

reset\_num\_external\_sources port\_list

Resets the constraint for the number of external sources previously specified by the set\_num\_external\_sources command to the default value of 1.

#### **Options and Arguments**

port\_list

Specifies the list of ports to have 1 external source.

#### Example

The following command resets the constraint for the number of external sources to the default value of 1 for port in:

reset\_num\_external\_sources in

#### **Related Information**

remove\_assertions

<u>set num external sources</u>

# reset\_operating\_condition

Removes the operating condition (process, temperature, voltage, and tree-type) from the current design. No operating condition is used by the mapping and optimization commands.

Each technology library contains one or more operating conditions. Each condition is identified by name, which specifies a set of process, temperature, voltage, and tree-type conditions as the operating condition. This information is used to calculate accurate cell delays from the nominal cell delays and the k-factors (also called derating factors) from either linear or nonlinear models.

Get a list of all operating conditions in a technology library along with their PVT and OC type values by using the <code>report\_library</code> command.

## **Options and Arguments**

-library library\_name

Specifies the technology library containing the named operating condition.

operating\_condition\_name Specifies the name of the operating condition in the library.

-pvt {min | typ | max}

Resets the operating condition for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. *Default*: The specified operating condition is removed for all three PVT corners.

#### Example

reset\_operating\_condition

# **Related Information**

#### get operating parameter

<u>report library</u>

set operating conditions

set operating parameter

# reset\_operating\_parameter

```
reset_operating_parameter {-process | -voltage | -temperature}
    [-pvt {min | typ | max}]
```

Resets the process, voltage, and temperature (PVT) operating parameters for the design used in calculating accurate cell delays from the nominal cell delays and the k-factors (also called derating factors) from either linear or non-linear models.

## **Options and Arguments**

**Note:** Only one of the parameters (process, voltage, or temperature) can be reset per command.

| -process             |                                                                                                                                                                                                                                                                                                                                                |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Resets the process multiplier.                                                                                                                                                                                                                                                                                                                 |
| -pvt {min   typ   ma | Resets the operating parameter for a particular PVT (process, voltage, temperature) corner. You can choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. <i>Default</i> : The specified operating parameter is reset for all three PVT corners. |
| -temperature         | Resets the temperature at which the circuit operates.                                                                                                                                                                                                                                                                                          |
| -voltage             | Resets the voltage at which the circuit operates.                                                                                                                                                                                                                                                                                              |

# Examples

```
reset_operating_parameter -voltage -typ
reset_operating_parameter -process
reset_operating_parameter -temperature -typ
```

# **Related Information**

set operating parameter

# reset\_operating\_voltage

reset\_operating\_voltage [-pvt {min | typ | max}] list\_of\_leaf\_level\_instances

Resets the operating voltages asserted on the list of leaf level instances specified. The value is reset to the operating voltage defined in the library.

# **Options and Arguments**

-pvt {min | typ | max} Resets the voltage for a particular PVT corner. Default: The command applies to all three PVT corners.

## Example

The following commands reset the max operating voltage for 1d1 to the value in the library (5.61):

reset\_operating\_voltage -pvt max ldl
get\_operating\_voltage -pvt max ldl
5.610000

# **Related Information**

get\_operating\_voltage

<u>read\_irdrop</u>

<u>read</u> rrf

<u>set\_operating\_voltage</u>

# reset\_path\_exception

```
reset_path_exception [-exact] [-type {false_path | cycle_addition |
    path_delay_constraint}] [{-from | -from_rise | -from_fall} from_list]
    [{-through | -through_rise | -through_fall} through_list]
    [{-to | -to_rise | -to_fall} to_list] [-clock_from list_of_clocks]
    [-clock_to list_of_clocks] [-edge_from {leading | trailing}]
    [-edge_to {leading | trailing}] [-early | -late]
    [-bidi_input_from | -bidi_output_from] [-bidi_input_to | -bidi_output_to]
    [-bidi_input_through | -bidi_output_through] [-all]
```

Removes any previously set path exceptions (or path exception of the specified type) for the given paths. To remove all path exceptions, use the -all option with the reset\_path\_exception command.

## **Options and Arguments**

| -all                 |                                                                                                                                                                                         |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Removes all path exceptions. This option cannot be used with the -from, -through, -to, -clock_from, -clock_to, and -name options.                                                       |
| -bidi_input_from   - | bidi_output_from<br>Specifies the assertion on the input or output part of the from<br>pin. Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.               |
| -bidi_input_through  | -bidi_output_through<br>Specifies the assertion on the input or output part of the<br>through pin. Default value is shown in <u>"Bidirectional Pin</u><br><u>Defaults"</u> on page 799. |
| -bidi_input_to   -bi | di_output_to<br>Specifies the assertion on the input or output part of the to pin.<br>Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.                     |
| -clock_from list_of_ | _clocks<br>Specifies the clocks at the start of the path exceptions to be<br>reset.                                                                                                     |
| -clock_to list_of_c  | <i>locks</i> Specifies the clocks at the end of the path exceptions to be reset.                                                                                                        |

| -early   -late                 |                                                                                                                                                                                                                                                                                                                    |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | Resets only the early (or late) paths.<br><i>Default</i> : Both -early and -late are reset.                                                                                                                                                                                                                        |
| <pre>-edge_from {leading</pre> | <pre>  trailing} Specifies an edge for the -clock_from. Default: Both edges.</pre>                                                                                                                                                                                                                                 |
| -edge_to {leading              | <pre>trailing} Specifies an edge for the -clock_to. Default: Both edges.</pre>                                                                                                                                                                                                                                     |
| -exact                         |                                                                                                                                                                                                                                                                                                                    |
|                                | The path specifications must match exactly. By default, the given paths to the reset_path_exception command must be a subset or equal to the original paths given to any path exception command. The -exact option disallows subsets.                                                                              |
|                                | <b>Note</b> : Only the path specifiers and the pin list must match exactly. The <code>-early</code> and <code>-late</code> options do not need to match in order to reset the exception. However, if you use the <code>-early</code> and <code>-late</code> options, only the one specified is reset. For example: |
|                                | <pre>#default is both -early and -late set_false_path -to Z #removes only the early exception reset_path_exception -exact -early -to Z</pre>                                                                                                                                                                       |
|                                | This leaves a false path on the late portion, something that would look like:                                                                                                                                                                                                                                      |
|                                | set_false_path -late -to Z                                                                                                                                                                                                                                                                                         |
|                                | To reset both -early and -late, use this:<br>#removes both early and late exceptions<br>reset_path_exception -exact -to Z                                                                                                                                                                                          |
| {-from   -from_rise            | <pre>  -from_fall} from_list Specifies pins at the start of the path exceptions that are to be reset.</pre>                                                                                                                                                                                                        |
| {-through   -through           | _rise   -through_fall} <i>through_list</i> Specifies the pins that the path to be reset goes through.                                                                                                                                                                                                              |

| {-to   -to_rise   -t | co_fall} to_list<br>Specifies pins at the end of the path exceptions that are to be<br>reset.                                                       |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| -type {false_path    | cycle_addition   path_delay_constraint}<br>Removes only path exceptions of the specified type.<br>Default: All path exception assertions are reset. |

#### Examples

■ 1.0 Common Example Setup

The examples 1.1 through 1.11 all start with the following exceptions. The examples are not successive, that is, the <code>reset\_path\_exception</code> command in 1.2 does not follow the <code>reset\_path\_exception</code> command in 1.1.

```
set_false_path -from { A B C } -to { X Y Z }
set_cycle_addition -from { A B C } 1
set_cycle_addition -to { X Y Z } 1
report_path_exceptions
```

| <br>From       | То    | Early | Late           |
|----------------|-------|-------|----------------|
| A B C<br>A B C | XYZ   | false | false<br>add 1 |
| <br>+          | X Y Z | <br>+ | add 1          |

# ■ 1.1 Complete from/through/to Match

reset\_path\_exception -from { A B C } -to { X Y Z }
report\_path\_exceptions

| +<br>  From | To  | Early | +<br>  Late    |
|-------------|-----|-------|----------------|
| ABC         | хүг |       | add 1<br>add 1 |

#### 1.2 Partial from/through/to Match

reset\_path\_exception -from { A B C }
report\_path\_exceptions

| +<br>  From | +<br>  To | Early | Late  |
|-------------|-----------|-------|-------|
| +           | X Y Z     |       | add 1 |

#### ■ 1.3 Partial from/through/to Match

```
reset_path_exception -to { X Y Z }
```

report\_path\_exceptions

| - |       | +  | +     | ++    | + |
|---|-------|----|-------|-------|---|
|   | From  | То | Early | Late  |   |
|   | A B C |    |       | add 1 |   |
| ł | ++    | ++ | +     | ++    | - |

#### 1.4 Exact Match

reset\_path\_exception -exact -from { A B C }
report\_path\_exceptions

| +<br>  From | То         | Early | ++<br>  Late   |
|-------------|------------|-------|----------------|
| ABC         | XYZ<br>XYZ | false | false<br>add 1 |

#### 1.5 Exact Match

reset\_path\_exception -exact -to { X Y Z }

report\_path\_exceptions

| From           | То  | Early | Late           |
|----------------|-----|-------|----------------|
| A B C<br>A B C | ХҮΖ | false | false<br>add 1 |

#### 1.6 No Match

reset\_path\_exception -from { P D Q } -to { X Y Z }
report\_path\_exceptions

| ++             | То  | Early | <br>Late       |
|----------------|-----|-------|----------------|
| A B C<br>A B C | XYZ | false | false<br>add 1 |
|                | ХҮZ |       | add 1          |

# ■ 1.7 Partial List Match

reset\_path\_exception -from { A } -to { X Y Z }
report\_path\_exceptions

| +- | From         | То             | Early | Late                    |
|----|--------------|----------------|-------|-------------------------|
|    | B C<br>A B C | X Y Z<br>X Y Z | false | false<br>add 1<br>add 1 |
| +- |              | ++             | -<br> | ++                      |

#### 1.8 Partial List Match

```
reset_path_exception -from { A }
report_path_exceptions
```

| From       | То         | Early | Late                    |
|------------|------------|-------|-------------------------|
| B C<br>B C | XYZ<br>XYZ | false | false<br>add 1<br>add 1 |

#### 1.9 Partial List Match

reset\_path\_exception -from { A } -to { Y Z } report\_path\_exceptions

+----+

| From           | То              | Early          | Late                             |
|----------------|-----------------|----------------|----------------------------------|
| A<br>BC<br>ABC | X<br>XYZ<br>XYZ | false<br>false | false<br>false<br>add 1<br>add 1 |

#### 1.10 Partial List Match

reset\_path\_exception -from { A } -to { Z } report\_path\_exceptions

| +                 | То               | Early          | +<br>  Late                      |
|-------------------|------------------|----------------|----------------------------------|
| A<br>B C<br>A B C | XY<br>XYZ<br>XYZ | false<br>false | false<br>false<br>add 1<br>add 1 |

#### 1.11 Partial List Match w/ Early/Late

reset\_path\_exception -late -from { A } -to { Z } report\_path\_exceptions

| +                 |                         |       |                                  |
|-------------------|-------------------------|-------|----------------------------------|
| From              | То                      | Early | Late                             |
| ABC<br>ABC<br>ABC | XYZ<br>XY<br>XYZ<br>XYZ | false | false<br>false<br>add 1<br>add 1 |
|                   |                         |       |                                  |

# **Related Information**

report path exceptions

set cycle addition

set\_false\_path

```
December 2003
```

set path delay constraint

# reset\_path\_group

reset\_path\_group [-name group\_name]

```
[-from from_list] [-through through_list] [-to to_list]
[-clock_from clk_from_list] [-clock_to clk_to_list] [-exact]
```

Removes the specified path from the named group or completely removes the group.

■ To remove the entire group, use:

```
reset_path_group [-name group_name]
```

To remove specific paths, use the same options that were used to add the paths to the group.

# **Options and Arguments**

```
-clock from clk from list
                           Removes paths in the group whose start points are related to the
                          listed clocks as specified in set_path_group command. This
                           removes paths from flip-flops in the transitive fanout of the clock
                           source pin or port, and paths from ports that have input delay
                           related to the clock.
-clock_to clk_to_list
                           Removes paths in the group whose endpoints are related to the
                          listed clocks as specified in set path group command. This
                           removes paths to flip-flops in the transitive fanout of the clock
                           source pin or port, and paths to ports that have external delay
                           related to the clock.
-exact
                           Specifies that the path specifications must match exactly. By
                           default, the paths specified by the reset_path_group
                           command must be a subset or equal to the original paths given
                          to any path exception command. The -exact option disallows
                           subsets.
-from from_list
                           Specifies the path start points. The from_list is a list of port,
                           pin, or leaf names as specified in set_path_group. Paths
                           starting from from list are removed from the group.
```

| -name group_name    | Removes the named group completely when no path options are specified.                                                                                                                                                                                                                                                        |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | When the path options are a subset of those given in the <pre>set_path_group command, the specified paths are removed from the group. When the path options exactly match those given in set_path_group command, the specified group is removed completely. Partially specified paths or path segments are not removed.</pre> |
| -through through_li | st                                                                                                                                                                                                                                                                                                                            |
|                     | Specifies the path through points. The <i>through_list</i> is a list<br>of port or pin names, or leaf cell names as specified in<br>set_path_group command, Only those paths that pass<br>through one of the points in the <i>through_list</i> are removed.                                                                   |
|                     | If the -through option is used with the -from option as specified in set_path_group command, only paths that start in the from_list and pass through the through_list are removed.                                                                                                                                            |
|                     | If the -through option is used with the -to option as specified<br>in set_path_group command, the group includes only paths<br>that pass through the <i>through_list</i> and end at the<br><i>to_list</i> are removed.                                                                                                        |
|                     | If the -through option is used with both the -from and -to<br>options as specified in the set_path_group command, only<br>paths that start in the from_list and pass through the<br>through_list and end at the to_list are removed.                                                                                          |
|                     | If the -through option is specified multiple times as specified in set_path_group, only those paths that pass through one or more of the points in each <i>through_list</i> in the order specified are removed. See <u>Example</u> on page 1065.                                                                              |
| -to to_list         |                                                                                                                                                                                                                                                                                                                               |
|                     | Specifies the path endpoints. The <i>to_list</i> is a list of port or pin names as specified in <i>set_path_group</i> . Paths ending at the <i>to_list</i> are removed from the group.                                                                                                                                        |

# Example

reset\_path\_group -name GRPA

## **Related Information**

report path groups

<u>set path group</u>

# reset\_port\_capacitance

```
reset_port_capacitance port_list [-pvt {min | typ | max}]
```

Removes the port capacitance assertion previously set by the set\_port\_capacitance command.

# **Options and Arguments**

port\_list

Specifies the list of ports for which port capacitance is reset.

-pvt {min | typ | max} Re

Resets the port capacitance for a particular PVT (process, voltage, temperature) corner. You can choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces. *Default*: The port capacitance reset applies to all three PVT corners.

# Example

reset\_port\_capacitance [find -port -output dbus\*]

# **Related Information**

<u>remove\_assertions</u>

set port capacitance

# reset\_port\_capacitance\_limit

reset\_port\_capacitance\_limit [-min | -max] port\_list

Resets the maximum capacitance allowed to be driven by the port.

This design rule constraint can be reset on top level input and output ports. The limit, by default, is the maximum (or minimum) value for the total capacitances (wire capacitance and pin capacitance) of nets attached to the ports in the port list. Reset a minimum value limit using the -min option.

If set\_global max\_capacitance\_limit (or set\_global min\_capacitance\_limit) has also been set, the most constraining value is used.

## **Options and Arguments**

| -min   -max | Resets minimum (or maximum) design rule constraints. If neither option is given.<br><i>Default</i> : -max (for backward compatibility) |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| port_list   | Specifies the list of ports for which port capacitance limit is reset.                                                                 |

#### Example

reset\_port\_capacitance\_limit [find -port dbus\*]

#### **Related Information**

<u>remove\_assertions</u>

set capacitance limit

<u>set port capacitance limit</u>

# reset\_port\_wire\_load

reset\_port\_wire\_load [-pvt {min | typ | max}] port\_list

Resets the wire load for an input or output top level port of a design to the default wire-load model. The net connected to the port is associated with the default wire-load model, which is used for wire capacitance and resistance estimation.

# **Options and Arguments**

port\_list

Specifies the list of ports.

PVT corners.

-pvt {min | typ | max} Resets the port wire-load model for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. Default: The specified port wire-load model applies to all three

# Example

reset\_port\_wire\_load out

# **Related Information**

<u>remove assertions</u>

set port wire load

# reset\_propagated\_clock

reset\_propagated\_clock [-clock clock\_list] [-pin pin\_list]

Resets the clock propagation mode for the given clock waveforms or pins. There are two modes of clock propagation: ideal and propagated. See the <u>set propagated clock</u> command for more information.

Note: If the set\_clock\_propagation command is set to propagated, the reset\_propagated\_clock command has no effect until the set\_clock\_propagation command is set to ideal.

#### **Options and Arguments**

| -clock clock_list    | Specifies one or more clock waveforms for which you want to reset the clock propagation mode.                                                                                                                                                                                                    |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -pin <i>pin_list</i> |                                                                                                                                                                                                                                                                                                  |
|                      | Specifies one or more pins or ports for which you want to reset<br>the clock propagation mode. No hierarchical pins are allowed in<br>the pin_list. When a pin_list is specified, it affects the<br>propagation mode for all the registers in the transitive fanout<br>(TFO) of the pin or port. |
|                      | Either the clock_list option or the <i>pin_list</i> option must be specified. You can also specify both the <i>clock_list</i> and the <i>pin_list</i> options.                                                                                                                                   |

#### Examples

- The following command sets clock waveform CLK1 to propagated mode: set\_propagated\_clock -clock CLK1
- The following command resets clock waveform CLK1 back to ideal mode: reset\_propagated\_clock -clock CLK1

#### **Related Information**

get\_clock\_propagation

get propagated clock

set propagated clock

set clock propagation

# reset\_scale\_delays

```
reset_scale_delays [-clock | -data] [-net_delay | -cell_delay | -cell_check]
    [-incl_sdf] [-pvt {min | typ | max}]
```

Unscales min, typ, or max delays from the library and optionally from SDF assertions. This command removes the scaling as previously specified by the  $set_scale_delays$  command.

#### **Options and Arguments**

| -cell_check          |                                                                                                                                                                                      |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _                    | Removes scaling on timing checks.                                                                                                                                                    |
|                      | <b>Note:</b> Specifying the -cell option is equivalent to both the -cell_delay and -cell_check options.                                                                              |
| -cell_delay          | Removes scaling on cell delays.<br>If neither the -cell_delay nor the -net_delay option is<br>specified, the specified scaling factor is removed for both types<br>of delays.        |
| -clock               | Removes scaling on clock networks only.                                                                                                                                              |
| -data                | Removes scaling on data networks only.                                                                                                                                               |
|                      | <b>Note</b> : If neither the -clock option or the -data option is specified, the scaling is removed on both the clock and data networks.                                             |
| -incl_sdf            | Removes scaling on SDF assertions.                                                                                                                                                   |
| -net_delay           | Removes scaling on net delays.                                                                                                                                                       |
| -pvt {min   typ   ma | x}<br>Associates a min, typ, or max PVT (process, voltage, or<br>temperature) corner with the scale delay to be removed. Three<br>PVT corners are allowed, namely, min, typ and max. |

*Default*: The specified delay scaling is removed from all PVT corners.

### **Examples**

reset\_scale\_delays -incl\_sdf -pvt min
reset\_scale\_delays -incl\_sdf -pvt max

## **Related Information**

get scale delays

<u>set\_scale\_delays</u>

# reset\_slew\_limit

reset\_slew\_limit [-min | -max] port\_list - Renamed to reset\_slew\_time\_limit

**Note:** The reset\_slew\_limit command has been renamed, because it resets the limit on the slew time parameter. See reset slew time limit on page 1077.

# reset\_slew\_thresholds

reset\_slew\_thresholds

Resets the lower and upper slew threshold values to the default values.

*Default*: Slew thresholds are taken from the default target technology library. If the target technology library does not have thresholds defined, the defaults of 20-80 percent are used (some library formats use defaults of 10-90 percent, see <u>Using Different Default Thresholds</u> for Different Library Formats in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*).

#### Examples

reset\_slew\_thresholds
get\_slew\_thresholds
20.000000 80.000000

# **Related Information**

remove\_assertions

set slew thresholds

# reset\_slew\_time

reset\_slew\_time [-clock clkname] [-early | -late] [-rise | -fall]
 [-lead | -trail] |-pos | -neg] port\_list

Removes the slew time assertion previously set by the set\_slew\_time command.

## **Options and Arguments**

| -clock <i>clk_name</i> | Specifies the name of the ideal (or generated) clock waveform<br>that is associated with the slew time to be removed. If this option<br>is not specified, the default is @, a signal without an associated<br>clock (asynchronous). |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late         | Indicates whether the slew times to be removed are with respect<br>to the early (hold) or the late (setup) time checks of the data<br>signal. If neither time is specified the default is to use both.                              |
| -lead   -trail         | Specifies whether the slew time to be removed was asserted<br>with respect to the leading edge or trailing edge of the clock<br>signal.<br><i>Default</i> : -lead                                                                   |
| port_list              | Specifies the list of pins or leaf cell instance pins for which the slew time assertion is to be removed.                                                                                                                           |
| -pos   -neg            | Specifies whether the slew to be removed applied to an actual clock having a positive or negative polarity with respect to the clock. Only one option either -pos or -neg can be specified per command.<br>Default: -pos.           |
| -rise   -fall          | Specifies whether the slew time to be removed applied to the rising edge or the falling edge of the signal (data or clock). If neither time is specified, the default is to use both.                                               |

## Examples

reset\_slew\_time input3
reset\_slew\_time -clock B0 -pos clk\_b

#### **Related Information**

<u>set\_drive\_cell</u>

set drive resistance

set\_global slew\_propagation\_mode

set global slew time limit

<u>set\_slew\_time</u>

set\_slew\_time\_limit

# reset\_slew\_time\_limit

reset\_slew\_time\_limit [-min | -max] port\_list

Resets the limit (maximum or minimum) for slew time at the input and output ports of a module to the default slew time limit placed on specific ports by the set\_global max\_slew\_time\_limit or set\_global min\_slew\_time\_limit globals.

# **Options and Arguments**

| -min   -max | Specifies minimum (or maximum) design rule constraints. If neither option is given, the default is -max for backward compatibility. |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| port_list   | Specifies the list of ports to which the limit to be removed applies.                                                               |

# Example

The following command resets the maximum slew time limits for bus1 and bus2:

reset\_slew\_time\_limit {bus1 bus2}

# **Related Information**

- set\_capacitance\_limit
- set global max slew time limit
- set global min slew time limit
- set\_global slew\_propagation\_mode
- <u>set slew time</u>
- <u>set slew time limit</u>

# reset\_tech\_info

```
reset_tech_info
     ({[-library list_of_library_names]
     [-default_wire_load] [-default_wire_load_selection]
     [-default operating conditions]
     [-default fanout load] [-default max capacitance]
     [-default_max_fanout] [-default_max_transition]
     [-default_min_capacitance] [-default_min_fanout]
     [-default_min_transition][-input_threshold_pct_rise]
     [-input_threshold_pct_fall]
     [-output_threshold_pct_rise] [-output_threshold_pct_fall]
     [-slew lower threshold pct rise] [-slew lower threshold pct fall]
     [-slew_upper_threshold_pct_rise] [-slew_upper_threshold_pct_fall]
     [-slew_lower_meas_threshold_pct_rise]
     [-slew_lower_meas_threshold_pct_fall]
     [-slew upper meas threshold pct rise]
     [-slew_upper_meas_threshold_pct_fall] }
     [-pvt {min | typ | max}])
     ([-library list_of_library_names] [-cell list_of_cell_names]
     [-dont_modify] [-dont_utilize][-scaling_factors]
     [-input_threshold_pct_rise] [-input_threshold_pct_fall]
     [-output threshold pct rise] [-output threshold pct fall]
     [-slew_lower_threshold_pct_rise] [-slew_lower_threshold_pct_fall]
     [-slew_upper_threshold_pct_rise] [-slew_upper_threshold_pct_fall]
     [-slew_lower_meas_threshold_pct_rise]
     [-slew lower meas threshold pct fall]
     [[-slew upper meas threshold pct rise]
     [-slew_upper_meas_threshold_pct_fall]}
     [-pvt {min | typ | max}])
     ([-library list_of_library_names] [-cell list_of_cell_names]
     [-pin list_of_pin_names] [-fanout_load] [-max_fanout] [-min_fanout]
     [-max_transition] [-min_transition][-max_capacitance] [-min_capacitance]
     [-pvt {min | typ | max}])}
```

Resets the original value of the library data for the specified parameters in the named target libraries. This overrides values previously specified with the set\_tech\_info command with the values from the library itself.

# Options and Arguments (any level)

-library list\_of\_library\_names

Specifies the libraries to which the reset is applied. *Default*: All libraries specified with the set\_global target\_technology global.

| -pvt {min   typ   ma                     | ax}<br>Resets the value for the environment corner of interest. Sets the<br>value for the environment corner of interest. Set one PVT corner<br>per command.<br><i>Default</i> : typ |                                  |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Options and Arguments<br>(library level) |                                                                                                                                                                                      |                                  |
| -default_fanout_load                     | Resets the fanout load for all pins or default value.                                                                                                                                | all cells in the library to the  |
| -default_max_capacit                     | cance<br>Resets the maximum capacitance for<br>library to the default value.                                                                                                         | or all pins on all cells in the  |
| -default_max_fanout                      | Resets the maximum fanout for all p to the default value.                                                                                                                            | ins on all cells in the library  |
| -default_max_transit                     | Resets the maximum transition time<br>library to the default value.                                                                                                                  | for all pins on all cells in the |
| -default_min_capacit                     | cance<br>Resets the minimum capacitance fo<br>library to the default value.                                                                                                          | r all pins on all cells in the   |
| -default_min_fanout                      | Resets the minimum fanout for all pi to the default value.                                                                                                                           | ins on all cells in the library  |
| -default_min_transit                     | Resets the minimum transition time<br>library to the default value.                                                                                                                  | for all pins on all cells in the |
| -default_operating_o                     | conditions<br>Resets the operating conditions for t<br>values.                                                                                                                       | the library to the default       |
| -default_wire_load                       | Resets the wire-load model for the li                                                                                                                                                | ibrary to the default.           |
| December 2002                            | 4070                                                                                                                                                                                 | Draduct Version 5.0.42           |

Common Timing Engine (CTE) Commands

-default\_wire\_load\_selection Resets the wire-load selection table for the library to the default. -input\_threshold\_pct\_fall Resets the input threshold percent for the falling edge for all cells in the library to the default value. -input threshold pct rise Resets the input threshold percent for the rising edge for all cells in the library to the default value. -output\_threshold\_pct\_fall Resets the output threshold percent for the falling edge for all cells in the library to the default value. -output\_threshold\_pct\_rise Resets the output threshold percent for the rising edge for all cells in the library to the default value. **Note:** The following slew threshold options refer to the section of the waveform where the slew is nearly linear. This is measured and extended like a linear waveform. The linear waveform, a result of extending the near-linear slew waveform, is measured at certain points. The points where this extended waveform is measured are called slew thresholds. Measured slew thresholds are determined at the time of library characterization. Slew Thresholds -slew\_lower\_threshold\_pct\_fall Resets the lower threshold percent for the slew time of the falling transition for all cells in the library to the default value. -slew\_lower\_threshold\_pct\_rise

Resets the lower threshold percent for the slew time of the rising transition for all cells in the library to the default value.

-slew\_upper\_threshold\_pct\_fall

Resets the upper threshold percent for the slew time of the falling transition for all cells in the library to the default value.

-slew\_upper\_threshold\_pct\_rise

Resets the upper threshold percent for the slew time of the rising transition for all cells in the library to the default value.

### Measured Slew Thresholds

| -slew_lower_meas_thr                       | eshold_pct_fall<br>Returns the measured lower threshold percent of the slew time<br>for the falling transition for all cells in the library to the default<br>value.                                                                                                                                          |
|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -slew_lower_meas_thr                       | eshold_pct_rise<br>Resets the measured lower threshold percent of the slew time for<br>the rising transition for all cells in the library to the default value.                                                                                                                                               |
| -slew_upper_meas_thr                       | eshold_pct_fall<br>Returns the measured upper threshold percent of the slew time<br>for the falling transition for all cells in the library to the default<br>value.                                                                                                                                          |
| -slew_upper_meas_thr                       | eshold_pct_rise<br>Returns the measured upper threshold percent of the slew time<br>for the rising transition for all cells in the library to the default<br>value.                                                                                                                                           |
| Options and Arguments                      |                                                                                                                                                                                                                                                                                                               |
| (cell level)                               |                                                                                                                                                                                                                                                                                                               |
| (Cell level)<br>-cell list_of_cell_        | names<br>Specifies the cells to which the reset is applied. Required<br>argument for cell and pin level assertions.                                                                                                                                                                                           |
|                                            | Specifies the cells to which the reset is applied. Required                                                                                                                                                                                                                                                   |
| -cell list_of_cell_                        | Specifies the cells to which the reset is applied. Required argument for cell and pin level assertions.<br>Resets to the original value in the library. If true, the cell is not                                                                                                                              |
| -cell <i>list_of_cell_</i><br>-dont_modify | Specifies the cells to which the reset is applied. Required<br>argument for cell and pin level assertions.<br>Resets to the original value in the library. If true, the cell is not<br>modified in optimization or time budgeting.<br>Resets true or false. If true, the cell is not used in<br>optimization. |

-output\_threshold\_pct\_fall
 Resets the output threshold percent for the falling edge for the listed cells to the default value.

 -output\_threshold\_pct\_rise
 Resets the output threshold percent for the rising edge for the listed cells to the default value.

 -scaling\_factors

Resets the name of the derating table used for scaling.

**Note:** The following slew threshold options refer to the section of the waveform where the slew is nearly linear. This is measured and extended like a linear waveform. The linear waveform, a result of extending the near-linear slew waveform, is measured at certain points. The points where this extended waveform is measured are called slew thresholds. Measured slew thresholds are determined at the time of library characterization.

#### Slew Thresholds

```
-slew_lower_threshold_pct_fall
```

Resets the lower threshold percent for the slew time of the falling transition for the listed cells to the default value.

-slew\_lower\_threshold\_pct\_rise

Resets the lower threshold percent for the slew time of the rising transition for the listed cells to the default value.

-slew\_upper\_threshold\_pct\_fall

Resets the upper threshold percent for the slew time of the falling transition for the listed cells to the default value.

-slew\_upper\_threshold\_pct\_rise

Resets the upper threshold percent for the slew time of the rising transition for the listed cells to the default value to the default value.

### Measured Slew Thresholds

-slew\_lower\_meas\_threshold\_pct\_fall

Returns the measured lower threshold percent of the slew time for the falling transition for the listed cells to the default value.

| -slew_lower_meas_thr                 | reshold_pct_rise<br>Resets the measured lower threshold percent of the slew time for<br>the rising transition for the listed cells to the default value. |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| -slew_upper_meas_thr                 | reshold_pct_fall<br>Returns the measured upper threshold percent of the slew time<br>for the falling transition the listed cells to the default value.   |
| -slew_upper_meas_thr                 | reshold_pct_rise<br>Returns the measured upper threshold percent of the slew time<br>for the rising transition the listed cells to the default value.    |
| Options and Arguments<br>(pin level) |                                                                                                                                                          |
| -fanout_load                         | Resets the value of the fanout load constraint for the named pins.                                                                                       |
| -max_capacitance                     | Resets the value of the maximum capacitance constraint for the named pins.                                                                               |
| -max_fanout                          | Resets the value of the maximum fanout constraint for the named pins.                                                                                    |
| -max_transition                      | Resets the value of the maximum transition time constraint for the named pins.                                                                           |
| -min_capacitance                     | Resets the value of the minimum capacitance constraint for the named pins.                                                                               |
| -min_fanout                          | Resets the value of the minimum fanout constraint for the named pins.                                                                                    |
| -min_transition                      | Resets the value of the minimum transition time constraint for the named pins.                                                                           |

#### -pin list\_of\_pin\_names

Specifies the pins to which the reset is applied. Required argument for pin level assertions.

#### **Examples**

These examples follow those of the get\_tech\_info command:

reset\_tech\_info -library lib1 lib2 -default\_fanout\_load reset\_tech\_info -cell FD2ESSA -dont\_utilize reset\_tech\_info -library lca300kv -cell B2I -pin Z1 -pvt min -max\_fanout

#### **Related Information**

<u>get\_tech\_info</u>

<u>set\_tech\_info</u>

write library assertions

### reset\_time\_borrow\_limit

reset\_time\_borrow\_limit [-pin pin\_list] [-clock list\_of\_clocks]

Resets the maximum borrow time as set by the set\_time\_borrow\_limit command to the default value (Max = pulse width - setup). Set the borrow limit on pins, clocks, or waveforms.

#### **Options and Arguments**

-clock list\_of\_clocks

Resets the borrow limit for the named clocks.

If neither -pin nor -clock option is specified, the borrow limit is placed on all clocks.

-pin pin\_or\_instance\_list

Resets the borrow limit on a single pin or multiple pins of latches. To specify multiple pins, enclose the list with curly braces ({}) and separate the pin information with white space.

You can alternatively give a list of latch instances. In which case, the default limit applies to the clock pins of the instances listed.

#### Example

reset\_time\_borrow\_limit -pin l1/en

#### **Related Information**

get time borrow limit

set\_time\_borrow\_limit

<u>Analyzing Latch-Based Designs</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

# reset\_time\_unit

reset\_time\_unit

Resets the time units for the session to the default value. The default time unit is the one given in the first library in the target technology library list.

The data from all libraries are descaled appropriately to conform to the default units.

#### Example

reset\_time\_unit

#### **Related Information**

get\_time\_unit

<u>set\_time\_unit</u>

### reset\_wire\_capacitance

```
reset_wire_capacitance net_names [-pvt {min | typ | max}]
```

Removes any wire capacitance assertions previously set by the set\_wire\_capacitance command.

### **Options and Arguments**

net\_names

Specifies the list of nets for which the wire capacitance assertions are to be removed.

-pvt {min | typ | max} Rer

Removes the wire capacitance assertions for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces. *Default*: Wire capacitance assertions are removed for all three PVT corners.

#### **Related Information**

<u>reset wire resistance</u>

<u>set\_wire\_capacitance</u>

### reset\_wire\_load

reset\_wire\_load [-pvt {min | typ | max}] list\_of\_instances

Resets the wire-load model to the default wire-load model on the specified instances. The default model is the default specified in the library, unless overridden by the set\_tech\_info -default\_wire\_load command. If the list of instances is omitted, the wire-load model is reset for the current instance.

#### **Options and Arguments**

| list_of_instances    |                                                                                                                                                                                                                                                                                                                                |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies the instances to which the default wire-load model is re-applied. <i>Default</i> : The current instance.                                                                                                                                                                                                             |
| -pvt {min   typ   ma | Resets the wire-load model for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. <i>Default</i> : The specified wire-load model is reset for all three PVT corners. |

#### Example

The following command resets the wire-load model for pvt min to the default wire-load model on instance J\_block:

reset\_wire\_load -pvt min J\_block

#### **Related Information**

get tech info -default\_wire\_load

set tech info -default\_wire\_load

set\_wire\_load

write assertions

# reset\_wire\_load\_mode

reset\_wire\_load\_mode

Resets the wire-load mode to the default mode of top.

#### **Related Information**

<u>set wire load mode</u>

# reset\_wire\_load\_selection\_table

```
reset_wire_load_selection_table [-library library_name] [-pvt {min | typ | max}]
```

Resets the wire-load selection table entry previously specified by the set\_wire\_load\_selection\_table command. The default wire load selection table specified in the library *library\_name* becomes the selection table used for wire load calculations.

### **Options and Arguments**

| -library library_na  | me                                                                                                                                                                                                                                                                                                                                                    |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies the name of the technology library to search for the wire load selection table.                                                                                                                                                                                                                                                             |
|                      | Default: The target technology library.                                                                                                                                                                                                                                                                                                               |
| -pvt {min   typ   ma | Resets the wire-load model selection table for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces. <i>Default</i> : The wire-load model selection table is reset for all three PVT corners. |

### Example

The following command resets the wire-load selection table to the one specified in the wireloads2 library for the min PVT corner:

reset\_wire\_load\_selection\_table -library wireloads2 -pvt min

### **Related Information**

<u>report library</u>

set global target technology

set\_wire\_load\_selection\_table

<u>set\_wire\_load</u>

#### reset\_wire\_resistance

reset\_wire\_resistance [-pvt {min | typ | max}] net\_names

Removes wire resistance assertions previously specified by the set\_wire\_resistance command.

### **Options and Arguments**

net\_names

Specifies the list of nets for which the wire resistance assertions are to be removed.

-pvt {min | typ | max} Ren

Removes wire resistance assertions for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces. *Default*: Removes wire resistance assertions for all three PVT corners.

#### **Related Information**

reset wire capacitance

<u>set wire resistance</u>

### save\_mp\_model

save\_mp\_model
 [-min min\_file\_name] [-typ typ\_file\_name] [-max max\_file\_name] file\_name

Saves the prototype either to one or more files or to memory. It also ends an Module Prototyper (MP) session. If no parameters are given, the model is saved to memory where it can be used for binding. If there are any parameters, the model will be written to one or more files. One file will be written for each PVT corner present. If the ending of the file name ends in .lib, a Liberty file will be written. Otherwise, a TLF file will be written.

#### **Options and Arguments**

| file_name          |                                                                                                                                                                                                    |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Creates a file name if a file name is not specified using the -min,<br>-typ, or -max options. The typ corner will use the name as is.<br>The min and max corners will have a prepended min_ or max |
| -max max_file_name |                                                                                                                                                                                                    |
|                    | Specifies the file name used for the maximum PVT corner.                                                                                                                                           |
| -min min_file_name |                                                                                                                                                                                                    |
|                    | Specifies the file name used for the minimum PVT corner.                                                                                                                                           |
| -typ typ_file_name |                                                                                                                                                                                                    |
|                    | Specifies the file name used for the typical PVT corner.                                                                                                                                           |

### Examples

- The following command saves the Module Prototype to memory, which can be used by do\_bind\_generic command or the do\_rebind command, but is not saved to a file: save\_mp\_model
- The following command saves the Module Prototype to one or more tlf files. If present, the typical data will be saved to my\_block.tlf, the minimum data will be saved to "", and the maximum data will be saved to "". After using this command, the MP data is not present in memory and cannot be used for binding until it is read using the <u>read\_tlf</u> command:

```
save_mp_model my_block.tlf
```

The following command is similar to the proceeding command except the data is saved to a .lib Liberty format file:

```
save_mp_model my_block_max.lib
```

The following command saves the Module Prototype to Liberty files: the -max data is saved in my\_block\_max.lib and the -min data is saved in my\_block\_min.lib: save\_mp\_model -min my\_block\_min.lib -max my\_block\_max.lib

# **Related Information**

create mp model

### set\_annotated\_check

```
set_annotated_check [-clock clock_check] [-cond sdf_condtion] check_value
    [-setup | -hold | -recovery | -removal | -nochange_high | -nochange_low]
    [-rise] [-fall] [-min] [-max] [-from from_pins][-to to_pins]
```

Annotates the setup, hold, recovery, or removal timing check value between two or more pins on a cell in the current design.

#### **Options and Arguments**

| check_value               | Specifies the timing check value.                                                                                                                                                                  |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -clock <i>clock_check</i> | Specifies clock rising or falling.<br>Default: Sets checks for both clock rise and fall.<br>Use the <i>clock_check</i> argument to specify rise or fall.                                           |
| -cond sdf_expression      | n                                                                                                                                                                                                  |
|                           | Specifies the condition only if the library has a condition attached to the specified timing check arc. The <i>sdf_expression</i> must match the syntax of the condition specified in the library. |
| -fall                     | Specifies the data fall transition for the timing check.<br>Default: Sets both -rise and -fall.                                                                                                    |
| -from from_pins           | Specifies startpoints of the timing arcs for which checks are annotated. Use the <i>from_pins</i> argument to specify a list of leaf cell clock pins.                                              |
| -max                      | Specifies the maximum timing check for both data rise and data fall transitions. Use this option only if the design uses minimum and maximum (min_max) operating conditions.                       |
| -min                      | Specifies the minimum timing check for both data rise and data                                                                                                                                     |

|                       | fall transitions. Use this option only if the design uses minimum and maximum (min-max) operating conditions.                                 |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| -rise                 | Specifies the data rise transition for the timing check.<br>Default: Sets both rise and fall.                                                 |
| -setup   -hold   -rec | overy   -removal   -nochange_high   -nochange_low                                                                                             |
|                       | Specifies the timing check type. Make sure there is a corresponding timing arc between the <i>from_pins</i> and the <i>to_pins</i> arguments. |
| -to <i>to_pins</i>    | Specifies endpoints of the timing arcs for which checks are annotated. Use the $to_pins$ argument to specify a list of leaf cell clock pins.  |

### Examples

■ The following commands annotates a nochange check between data low and clock low. The nochange margin before the clock is 1.3 and the nochange margin after the clock is 2.4:

```
set_annotated_check -nochange_low 1.3 -clock fall -fall -from {I1/CP} -to {I1/
EN}
set_annotated_check -nochange_low 2.4 -clock fall -rise -from {I1/CP} -to {I1/
EN}
```

■ The following command annotates a 2.0 setup time between the CP clock pin and the A data pin of the instancename instance:

set\_annotated\_check -setup 2.0 from instancename/CP -to instancename/A

#### **Related Commands**

#### set\_annotated\_delay

See "Timing Checks" in the Cadence Common Timing Engine (CTE) User Guide for more information.

# set\_annotated\_delay

```
set_annotated_delay [-net | -cell] [-rise | -fall] [-pvt {min |typ | max}]
        [-from from_pins] [-to to_pins] [-sdf_cond expression] delay_value
```

Annotates delay to timing arcs.

#### **Options and Arguments**

delay\_value

| deiay_vaide          | Specifies the delay value to be annotated to the selected timing arcs.                                                                                                                                                                                                                                                                                                                            |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-from from_pins]    | Specifies timing arcs to which the delay applies. The selected timing arcs are those that have their source pins specified using this option and the sink pins specified using the $-to$ option. If this option is not specified, only timing arcs whose sink pins are specified using the $-to$ option are selected.                                                                             |
| [-net   -cell]       | Specifies whether the delay should be annotated to cell arcs or<br>net arcs. The tool automatically detects if the arcs specified with<br>the -from and -to options are cell arcs or net arcs. This option<br>is ignored if it conflicts with the -from and -to options. Use this<br>option if the pin specified by the -from option or the -to option<br>is a bidirectional pin. See Figure 7-6. |
| [-pvt {min   typ   m | ax}]<br>Specifies the PVT corner to which the delay<br>applies.<br><i>Default</i> : The delay applies to all three PVT<br>corners.                                                                                                                                                                                                                                                                |
| [-rise   -fall]      | Specifies the transition to which the delay applies. For cell arc, this is the output transition. <i>Default</i> : The delay applies to both transitions.                                                                                                                                                                                                                                         |
| [-sdf_cond expressio | n]<br>Specifies the sdf condition of the selected timing arcs.<br><i>Default</i> : The delay applies to all the timing arcs selected using<br>the -from and the -to options. The expression is ignored for net<br>arcs.                                                                                                                                                                           |

**Note**: Using the set\_annotated\_delay command without sdf\_cond option will overwrite all previously specified annotated delays with the sdf\_cond option. So, annotate delays without the condition first before annotating delays with the condition.

[-to to\_pins] Specifies timing arcs to which the delay applies. The selected timing arcs are those that have their sink pins specified using this option and the source pins specified using the -from option. If this option is not specified, only timing arcs whose source pins are specified using the -from option are selected.

### Examples

■ The following command affects three timing arcs: the cell arc carc2 and the net arcs narc1 and narc2 as shown in Figure 7-6:

```
set_annotated_delay 3.0 -from {I1/I0}
```

### Figure 7-6 Example Figure to Show How to Use the -cell and -net Options



// arc2
Path( A => Z 10 01 COND(B & C) SDF\_COND(B & C) DELAY(ioDelayRiseModel1)
SLEW(SlopeRiseModel1) )
Path( A => Z 01 10 COND(B & C) SDF\_COND(B & C) DELAY(ioDelayFallModel1)
SLEW(SlopeFallModel1) )
arc3
Path( A => Z 10 01 COND(~B | ~C) SDF\_COND(!B | !C) DELAY(ioDelayRiseModel2)
SLEW(SlopeRiseModel2) )
Path( A => Z 01 10 COND(~B | ~C) SDF\_COND(!B | !C) DELAY(ioDelayFallModel2)
SLEW(SlopeFallModel2) )
. . .
}

#### Figure 7-7 Example Figure to Show How to Use the -from and -to Options



■ The following command annotates a delay of 3.0 to arcs arc1, arc2, and arc3 for the rise and fall transition at the pin I1/Z, for the three pvt corners {min typ max}:

set\_annotated\_delay 3.0 -from A -to Z

■ The following command annotates a delay of 2.5 to net arc arc4 for both the rising and the falling transition and for the three pvt corners {min typ max}:

set\_annotated\_delay 2.5 -from I1/Z -to I2/A

■ The following command annotates a delay of 1.5 to arc2 for the rising transition and the min pvt corner:

set\_annotated\_delay 1.5 -from I1/A -to I1/Z -rise -pvt min -sdf\_cond "B & C"

■ The following commands annotate a delay of 3.0 to arc1 and arc2, and a delay of 2.4 to the arc3:

```
set_annotated_delay 3.0 -from I1/A -to I1/Z
set_annotated_delay 2.4 -from I1/A -to I1/Z -sdf_cond {!B | !C}
```

■ The following commands first annotate a delay of 3.0 to arc1, arc2 and arc3, then overwrite the value set by the first set\_annotated\_delay command:

set\_annotated\_delay 2.4 -from I1/A -to I1/Z -sdf\_cond {!B | !C} set\_annotated\_delay 3.0 -from I1/A -to I1/Z

#### **Related Commands**

set annotated check

### set\_capacitance\_limit

set\_capacitance\_limit [-min | -max] float [-instance instance\_list]
 [-port port\_list] [-module list\_of\_modules]

Sets instance-specific or port-specific design rule constraints. Design rules set on a hierarchical instance applies to all the pins contained in that hierarchical instance.

**Note:** If neither the -instance or the -port argument is specified, the design rule constraint is applied to the top timing module.

Use the set\_global max\_capacitance\_limit or the set\_global min\_capacitance\_limit to set context specific design rules. If either one of these globals has also been set, the most constraining value is used.

See <u>Extracting Design Rules on the Timing Model</u> in the *Common Timing Engine (CTE) User Guide* for supported design rules and more information.

#### **Options and Arguments**

| float                      | Specifies the minimum or maximum capacitance value.                                                                                                                                                                                                                                                                                 |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -instance <i>instance_</i> | list<br>Specifies the list of hierarchical instances where the limit is<br>applied.                                                                                                                                                                                                                                                 |
| -max                       | Sets the maximum instance-specific design rule constraints on all cells.                                                                                                                                                                                                                                                            |
| -min                       | Sets the minimum instance-specific capacitance on all cells.                                                                                                                                                                                                                                                                        |
| -module list_of_mod        | ules<br>Specifies the list of modules where the limit is applied.                                                                                                                                                                                                                                                                   |
|                            | <b>Note</b> : The -instance option takes precedence over the -module option. For example, if a module and its instance have a capacitance limit assertion, the instance assertion is used. Instances of a module inherit the capacitance limit assertion of the module unless the instance has its own capacitance limit assertion. |

-port port\_list

Specifies the list of ports where the limit is applied.

### Examples

Shows equivalent commands. The min capacitance limit 0.05 applies to the top timing module:

```
set_capacitance_limit 0.05 -min
set_capacitance_limit 0.05 -min -instance { }
```

Uses the last value set if several values are set to the same design rule using the same command or global:

```
set_capacitance_limit 0.05 -max -instance {I1}
set_capacitance_limit 0.07 -max -instance {I1}
set_capacitance_limit 1.1 -max -instance {I1}
```

The maximum capacitance limit used is 1.1.

Uses the most constraining value (smallest value for the max limit) (largest value for the min limit) if multiple values are set to the same design rule using different commands and globals. For example, if the capacitance limit of pin Z in the library is 0.7, and the context capacitance limit is set using the global:

set\_global max\_capacitance\_limit 1.0

and the capacitance limit is set on hierarchical instance I1 containing an instance of the pin Z:

set\_capacitance\_limit 0.8 -max -instance {I1}

The maximum capacitance limit used for the instance of pin Z in I1 is  $0.7 = \min \{0.7, 1.0, 0.8\}$ .

**Note:** Design rules asserted on a hierarchical block is inherited by the hierarchical subblock contained in the blocks. Design rules set on a sub-block overwrite design rules set on a block containing the subblock as shown in Figure 7-8.

### Figure 7-8 Design Rules Asserted on a Hierarchical Block



The following lists the pin block capacitance limits:

- The capacitance limit of the pin block 1/G1/Z is 0.75pf.
- The capacitance limit of the pin block1/block2/G1/Z is 1.0pf because the capacitance limit set on block1/block2 (1.0pf) overwrites the capacitance limit set on block1 (0.75pf).
- The capacitance limit of the pin block1/block3/Z is 0.75pf, because block1/block3 inherits the capacitance limit set on block1.
- The capacitance limit of the pin block1/block2/block4/G1/Z is 1.0pf (capacitance limit inherited from block1/block2).

### **Related Information**

<u>reset\_capacitance\_limit</u>

reset port capacitance limit

reset\_slew\_time\_limit

set global max capacitance limit

set global min capacitance limit

<u>set\_port\_capacitance\_limit</u>

<u>set slew time limit</u>

### set\_capacitance\_unit

set\_capacitance\_unit float\_unit

Sets the capacitance unit in picoFarads used for the entire session. Without this command, capacitance units for the session are decided by the first library in the target technology list.

All reports use these session units. All design assertions you make (such as set\_port\_capacitance) are also expected to be in these units. Any assertion you make
that modifies library data (read\_library\_update and set\_tech\_info) is expected to
provide data in units of the library (not session units).

The data from all libraries are scaled appropriately to conform to the session units. Units are for the entire session and are not removed by the do\_remove\_design -all command.

### **Options and Arguments**

float\_unit

Specifies the capacitance unit for this session in picoFarads.

### Example

The following command sets the capacitance unit to 1 picoFarad:

set\_capacitance\_unit 1

### **Related Information**

<u>get\_capacitance\_unit</u>

reset capacitance unit

<u>set time unit</u>

### set\_case\_analysis

set\_case\_analysis {0 | 1} {-bidi\_input | -bidi\_output} {-rising | -falling}
list\_of\_ports\_or\_pins

Sets constant or transitional values to a list of pins/ports to either a 1, 0, rising, falling value for use by the timing engine.

#### **Options and Arguments**

| 0   1                |                                                                                                                                                                                                                                                                                                          |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies a logic value of 0 or 1, which is propagated through combinational logic to disable or enable parts of logic.                                                                                                                                                                                  |
| -bidi_input   -bidi_ | output<br>Specifies that the constant is set on the input or output part of<br>bidirectional pins. The default places the constant on the input<br>part.                                                                                                                                                 |
| list_of_ports_or_p   | ins                                                                                                                                                                                                                                                                                                      |
|                      | Specifies a list of ports or pins on which to apply the value. To specify multiple pins, enclose the list with curly braces ( $\{$ ) and separate the pin names with white space.                                                                                                                        |
| -rising   -falling   | Specifies a valid transition value to be considered by the timing<br>engine. For example, If a rising value is specified at a certain pin<br>or port, only the rising signal transition from the pin or port is<br>considered for timing analysis. The opposite transition type<br>(falling) is ignored. |

### Examples

- The following command sets the value of pin i4/A to 1 for use by the timing engine: set\_case\_analysis 1 i4/A
- The following example shows that the pins P1/P2/B and P1/P3/CI are considered only for a rising transition. The falling transition on these pins is ignored.

```
set_case_analysis rising {P1/P2/B P1/P3/CI}
```

#### **Related Information**

check timing -type

<u>const\_collision</u>

const\_contradiction

get constant for timing

reset constant for timing

set constant for timing

<u>set disable timing</u>

<u>set false path</u>

<u>Setting Constant Values for Timing</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

# set\_cell\_pin\_load

```
set_cell_pin_load [-library library_name] [-cell cell_name]
    [-pin pin_name] load_val
```

Changes the pin capacitance value specified in the library. The assertion uses the capacitance unit specified in the first library of the target technology list.

### **Options and Arguments**

| -cell <i>cell_name</i>     | Specifies the name of the cell whose pin is specified by the $-\texttt{pin}$ argument.                                                                                                                                                                                                                                                                                                          |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -library <i>library_na</i> | me<br>Specifies the name of the library where the cell can be found.<br>Default: The target library is searched for the cell.                                                                                                                                                                                                                                                                   |
|                            | <b>Note</b> : If the target_technology is set to all loaded libraries, then the -library option is not needed. If you are querying the capacitance value of a cell or pin for a loaded library, but it is not part of the target technology list, an ERROR is returned. Use the -library option to find the cell or pin that is queried from the library name specified by the -library option. |
| load_val                   | Specifies the float value to be set.                                                                                                                                                                                                                                                                                                                                                            |
| -pin <i>pin_name</i>       | Specifies the name of the pin whose capacitive load is returned.                                                                                                                                                                                                                                                                                                                                |

#### Example

The following example describes a library cell. The timing arcs have been deleted for simplicity:

```
library(cell_load_example) {
  cell ( AN2 ) {
    area : 2.000 ;
        cell_footprint : "dpand2c" ;
    pin ( Z ) {
        direction : output;
        capacitance : 0.000000;
  }
}
```

```
...
...
function : "(A & B)";
max_capacitance : 1.14574;
}
pin ( A ) {
    direction : input;
    capacitance : 0.042000;
    }
pin ( B ) {
    direction : input;
    capacitance : 0.041000;
}
```

■ The following command changes the capacitance value of pin B for cell AN2to the value 0.063450:

```
set_cell_pin_load -library cell_load_example -cell AN2 -pin B 0.063450
```

**Note:** An ERROR is returned if you are setting or getting values for a pin that is not defined for a cell.

■ The following command gets the capacitance value for pin A:

```
get_cell_pin_load -library cell_load_example -cell AN2 -pin A
0.042000
```

The following command gets the capacitance value for pin B: get\_cell\_pin\_load -library cell\_load\_example -cell AN2 -pin B 0.063450

### **Related Information**

```
<u>get cell drive</u>
```

}

```
<u>get_cell_pin_load</u>
```

```
set global target technology
```

# set\_clock

set\_clock clock\_signame {[-period period] | [-waveform {lead\_time trail\_time}]}

Defines an ideal clock signal. An ideal clock must be defined as a global reference signal for all the data signals in the design. The ideal clock is defined by its name, period, and position of the leading edge and trailing edge.

In a single-clock design, only one set\_clock command is used. In a multiphase clock system, several set\_clock commands are used to define each phase of the clock. For purely combinational design, an ideal clock (or any clock) definition is not necessary.

The scope of this command is the entire session of ac\_shell. Once an ideal clock is defined, it remains accessible to all subsequent commands.

#### **Options and Arguments**

| clock_signame         | Specifies the name of the ideal clock signal.                                                                                                                                                                                                                |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -period <i>period</i> | Specifies the period of the ideal clock signal is set to <i>period</i> . If the period is not specified, it is derived from the waveform specification such that a symmetric clock (50 percent duty cycle) is generated. Units are specified in the library. |
| -waveform {lead_tim   | <pre>e trail_time } Specifies the clock waveform is defined by a leading edge and a trailing edge. The braces are used to create a list. A Tcl list can also be created using a pair of quotes (""), so braces can be replaced by quotes.</pre>              |
|                       | The <i>lead_time</i> is the time at which the first transition on the clock occurs. The <i>trail_time</i> is the time that the second transition on the clock occurs.                                                                                        |
|                       | <b>Note</b> : The <i>trail_time</i> should be greater than the lead time. For example:                                                                                                                                                                       |
|                       | set_clock {rfclk_ideal} -waveform<br>{38.400002 76.800003} -period 76.800003                                                                                                                                                                                 |

If the -waveform option is not specified, the leading edge is placed at 0 and the trailing edge is placed at the midpoint of the period such that a symmetric clock is generated.

Specify either the period or the waveform option.

#### Examples

■ The following command defines an ideal clock signal called master with a period of 10, with leading transition at 0 and trailing transition at 5:

Note: An ideal clock signal has no polarity.

```
set_clock master -period 10 -waveform {0 5}
```

### Figure 7-9 Ideal Cock Example 1

| lead | trail | period    |
|------|-------|-----------|
| 0    | 5     | -+ master |

■ The following command defines an ideal clock called A with a period of 100, with leading transition at 30 and trailing transition at 90:

set\_clock A -period 100 -waveform {30 90}

### Figure 7-10 Ideal Cock Example 2



### **Related Information**

<u>set\_clock\_root</u>

set clock insertion delay

set\_clock\_uncertainty

set data required time

<u>set external delay</u>

See <u>Specifying Clock Information</u> in the Common Timing Engine (CTE) User Guide.

# set\_clock\_arrival\_time

```
set_clock_arrival_time
    OBSOLETE: Use set_clock_root and set_clock_insertion_delay instead.
```

# Important

Do not use the set\_clock\_arrival\_time command, use the set\_clock\_root and the set\_clock\_insertion\_delay commands instead. See <u>set\_clock\_root</u> on page 1127 and <u>set\_clock\_insertion\_delay</u> on page 1120.

Cadence timing analysis still writes out set\_clock\_arrival\_time during time budgeting. The following description is for reference only.

```
set_clock_arrival_time
-clock clock_name [-early | -late] [-rise rise_time] [-fall fall_time]
[-pos | -neg] [-bidi_input | -bidi_output] pin_list
```

The internally generated set\_clock\_arrival\_time command associates the ideal clock to physical ports of the design in the database. It defines the actual clock signals arriving at the input port of the design in relation to the ideal clock signal defined by the set\_clock command.

# set\_clock\_gating\_check

```
set_clock_gating_check [-setup | -hold] [-clock clock_list [-lead | -trail]]
        [[-pin instance_or_pin_list] [-rise | -fall]] [-high | -low] float
```

Creates or overrides the default setup and hold values for clock-gating timing checks.

**Note:** This command has no effect on the ClockGatingSetup (or ClockGatingHold) check defined as a non-sequential setup (or hold) check in the library.

You cannot use this command to create clock-gating assertions for hierarchical pins or clock ports. If you use this command on pins where clock gating occurs, these assertions are not propagated along the clock tree.

If neither the -pin nor the -clock option is specified, then the timing margin specified becomes a global assertion and is used for all clock gating checks. However, pin-based timing check assertions have higher priority and, if they exist, they override the global assertion.

The timing analyzer uses the following priority rules to determine the timing margin to use for a particular clock gating check:

- 1. Use the timing check assertion on the data pin if it exists
- 2. Otherwise, use the timing check assertion on the clock pin if it exists
- 3. Otherwise, use the timing check assertion on the clock waveform (for the clock pin) if it exists
- 4. Otherwise, use the global timing check assertion if it exists
- 5. If no timing check assertion is present, use the gate delay. This value is as follows:
  - □ For setup checks: the delay from the data pin to the output
  - For hold checks: the delay from the clock pin to the output

These rules are demonstrated in Examples on page 1114.

#### **Options and Arguments**

-clock clock\_list

Specifies the clock waveforms for which the command creates a clock-gating assertion. The timing margins for clock-gating checks for any instance that gates a clock signal having such an assertion are overridden.

| float                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                           | The timing margin (setup value or hold value) for the clock-gating setup check.                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                           | The default values when this command is not used depends on<br>the analysis mode. In ideal propagation mode, the clock network<br>is assumed to have zero delays, so CTE uses zero setup and<br>zero hold time. In propagated mode, for setup time, the analysis<br>uses the maximum arc delay from the data pin to the output pin.<br>For hold time, it uses the minimum arc delay from the clock pin<br>to the output pin.                                                    |  |
| -high   -low              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 111911   10w              | Specifies that the non-controlling value of the clock is high or low.<br>By default, it determines the non-controlling value of the clock<br>using information from the gate's logic. For complex gates such<br>as XOR and MUX, the clock is never controlling, and it does not<br>perform checks unless you specify either the -high option or the<br>-low option. The specified value takes precedence over the<br>default values. Use this option only with the -pin option. |  |
| -lead   -trail            | Applies the specified timing margin to only those clock-gating<br>checks for which the reference clock edge is the leading (or<br>trailing) edge. If neither option is specified, the timing margins<br>apply to both leading and trailing edges.                                                                                                                                                                                                                               |  |
|                           | Use the <code>-lead</code> or <code>-trail</code> options only with the <code>-clock</code> option.                                                                                                                                                                                                                                                                                                                                                                             |  |
| -pin pin_or_instance_list |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                           | If a pin is specified, the clock-gating instance connected to this pin will use the specified setup and hold values for this pin.                                                                                                                                                                                                                                                                                                                                               |  |
|                           | If a clock-gating instance is specified, the assertion applies to all input pins of the instance.                                                                                                                                                                                                                                                                                                                                                                               |  |
| -rise   -fall             | Applies the specified timing margin to the rising (or falling) signals on the specified pins. If neither option is specified, the default is both rising and falling. Use the <code>-rise or -fall</code> options only with the <code>-pin</code> option.                                                                                                                                                                                                                       |  |

| -setup   -hold | Specifies the type of clock-gating check, either setup or hold. If neither option is present, the timing margin is applied to both setup and hold checks.                                                                                                                                                                                                                                    |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | The setup check is performed with respect to the edge of the clock signal that changes the state of the clock pin from controlling to non-controlling. For example, for AND and NAND gates, the setup check is performed with respect to the rising edge of the clock input. For OR and NOR gates, the setup check is performed with respect to falling edge of the clock input.             |
|                | The hold check is performed with respect to the edge of the clock<br>signal that changes the state of the clock pin from non-controlling<br>to controlling. For example, for AND and NAND gates, the hold<br>check is performed with respect to the falling edge of the clock<br>input. For OR and NOR gates, the hold check is performed with<br>respect to rising edge of the clock input. |
|                | If the clock pin is never controlling, no clock gating checks are performed. For example, there will be no clock gating check performed for XOR and MUX gates.                                                                                                                                                                                                                               |
|                | If the gate logic in unknown, setup and hold checks are performed with both the rising edge and the falling edge of the clock signal.                                                                                                                                                                                                                                                        |
|                | <b>Note</b> : The clock pin is controlling when the gate output is independent of the data input with which the clock gating check is performed.                                                                                                                                                                                                                                             |

# Examples

■ The following example show the priority rules for multiple timing check assertions for the gated clock shown in Figure 7-11.

### Figure 7-11 Gated Clock



```
Tcl script:
```

```
# ideal clock
set_clock CLK1 -period 12 -waveform "0 6"
set_clock_root -clock CLK1 clk
...
# clock-gating timing check assertions
# on ideal clock waveform
set_clock_gating_check -setup 0.44 -clock CLK1
# on clock pin
set_clock_gating_check -hold 0.11 -pin g1/A
#on data pin
```

```
set_clock_gating_check -setup 0.66 -rise -pin g1/B
set_clock_gating_check -hold 0.22 -fall -pin g1/B
```

Given the previous commands, the following timing margins are used for slack calculation:

```
SETUP g1/B rise: 0.66 — from assertion on data pin g1/B (rule 1.)
```

SETUP g1/B fall: 0.44 — from assertion on ideal clock CLK1 (rule 3.)

HOLD g1/B rise: 0.11 — from assertion on clock pin g1/A (rule 2.)

HOLD g1/B fall: 0.22 — from assertion on data pin g1/B (rule 1.)

# **Related Information**

reset clock gating check

set global clock gating to be checked

set clock gating check

<u>Setting Clock Gating Setup and Hold Checks</u> in the *Timing Analysis for BuildGates* Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).

# set\_clock\_info\_change

```
set_clock_info_change
To change to a data signal use: set_clock_info_change
[-lead | -trail] [-early | -late] [-rise | -fall]
-clock clock_name
pin_list
||
To change to a clock signal use: set_clock_info_change
[-pos | -neg] [-early | -late] [-rise | -fall]
-clock clock_name
pin_list
```

Changes the clock or data information for paths going through the specified pins for the downstream logic. This command is useful for modeling frequency dividers and clock-shaping circuits. Use this command to change:

- Clock to data
- Data to clock
- Clock to clock (derived clock)
- The associated clock information

# Calculations

This section describes how the rising and the falling edges of the final (mapped) clock signal are computed when the output of a gate register is defined as a clock.

Here  $RA_{old}$  is the arrival time of the rising edge of the original signal before mapping. Similarly,  $FA_{old}$  is the arrival time of the falling signal.

For a signal mapped to a positive clock:

Rising edge =  $RA_{old}$ 

Falling edge = FA<sub>old</sub> + (ClockTrailingEdge - ClockLeadingEdge)

ClockLeadingEdge and ClockTrailingEdge are times at which the leading and the trailing edges of the ideal clock signal occur. Here the rising edge of the mapped clock corresponds to the leading edge of the ideal clock waveform and falling edge corresponds to the trailing edge.

Similarly, if the signal is mapped to a negative clock:

Rising edge = RA<sub>old</sub> + (ClockTrailingEdge - ClockLeadingEdge)

Falling edge =  $FA_{old}$ 

Here the falling edge of the mapped clock corresponds to the leading edge of the ideal clock waveform and rising edge corresponds to the trailing edge.

# **Derived Clocks**

A clock to clock set\_clock\_info\_change command on a pin results in starting a new clock signal from the pin. The new clock signal is derived from the old. Source and network clock insertion delays from the source clock are transferred to the derived clock. Here, the clock coming into the pin is being called the source clock, and the new clock created on the pin is called the derived clock.

Details of how source and network insertion delays are transferred to the derived clock are as follows:

First, the edge correspondence is determined from the source and derived clock polarities. Edge correspondence means which edge of the derived clock is derived from which edge of the source clock. The clock polarity (positive or negative) of the source clock refers to the polarity of the clock signal arriving at the pin. Similarly, clock polarity of the derived clock refers to the polarity of the clock signal being generated from the pin.

Edge correspondence is determined as follows:

If source and derived clocks are both of positive polarity, or both of negative polarity, then rising (falling) edge of the derived clock is assumed to be derived from the rising (falling) edge of the source clock. Similarly, if source and derived clocks are of opposite polarity, the rising (falling) edge of the derived clock is assumed to be derived from the falling (rising) edge of the source clock.

Then, the source and network insertion delays from the source clock edges are transferred to the corresponding derived clock edges.

- Source and network insertion delays from the source clock edges are transferred to the corresponding derived clock edges if the following additional constraints are satisfied:
  - □ Derived clock period must be an integral multiple (n) of the source clock period, with  $n \ge 2$ .
  - □ For the corresponding edges of the source and derived clocks (as determined above), following relation must be satisfied:

Edge\_time\_of\_derived\_clock = Corresponding\_edge\_time\_of\_source\_clock + (n \* period\_of\_source\_clock)

where n is an integer.

## **Options and Arguments**

| -clock <i>clock_name</i> | Specifies the clock waveform to apply or remove from the pin.                                                                                                                                                                                |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late           | Specifies early or late arrival of the signal. <i>Default</i> : Both                                                                                                                                                                         |
| -lead   -trail           | Indicates that the signal at the specified pin must be recognized<br>as a data signal with the specified association (lead or trail)<br>with respect to the specified clock <i>clock_name</i> .<br><i>Default</i> : -lead                    |
| pin_list                 | Associates paths from the pin list with the specified clock<br><i>clock_name</i> . The pin list can be ports or instance pins. These can be object IDs or hierarchical names relative to the current module.                                 |
| -pos   -neg              | Indicates that paths must be recognized as clock paths and that the clock has the specified polarity. This option is required to set the path as a clock path. If neither $-pos$ or $-neg$ is specified, the path is treated as a data path. |
|                          | <b>Note:</b> Because the signal cannot be both a clock signal and a data signal, the -pos   -neg options cannot be used with the -lead   -trail options.                                                                                     |
| -rise   -fall            | Maps the rising or falling edge of the signal.<br><i>Default</i> : Both.                                                                                                                                                                     |

## Examples

- The following command changes the output of an AND gate to a clock signal type: set\_clock\_info\_change -clock clk -pos U1/A1/0
- The following command changes the output back to data signal type: set\_clock\_info\_change -clock clk U1/A1/O

## **Related Information**

<u>set\_clock</u>

set clock insertion delay

set\_clock\_root

<u>report\_clocks</u>

reset clock info change

# set\_clock\_insertion\_delay

```
set_clock_insertion_delay {{[-source] [-lead | -trail] [-early | -late]
    [-min | -max] insertion_delay list_of_clocks}
    | {[-source] [-clock clock_signame] [-early | -late] [-min | -max]
    [-rise | -fall] insertion_delay -pin list_of_pins}}
```

# /Important

Use this command in conjunction with the set\_clock\_root command to replace the set\_clock\_arrival\_time command.

Specifies clock insertion delay in the ideal and propagated modes. Clock insertion delay has two components:

■ Source latency

Specified by the -source option, source latency is the delay from the external clock generator to the clock port of the design. Source insertion delay is considered in both ideal and propagated modes.

Network latency (clock tree insertion delay)

The default delay type. Network delay is the delay from the clock port to the register. The network delay specified by the set\_clock\_insertion\_delay command is only considered in ideal mode. In propagated mode, this delay is replaced by the actual clock tree delays.

Network delay on the clock waveform or the clock port is ignored in the propagated mode. Only the source insertion delay is honored. Source insertion delay specified on the clock port has higher precedence than one on clock waveform. In addition, a source and network insertion delay pair specified on internal circuit pins (including hierarchical ports) is ignored in propagated mode. To summarize:

- Source (or network) insertion delay specified on a timing pin has higher precedence than clock waveform specification.
- Source insertion delay is honored in both ideal and propagated modes.
- Network insertion delay is ignored in the propagated mode, and the actual circuit delays are used.
- If both source and network insertion delays are specified on internal circuit pins (or hierarchical ports), they are used in the fanout cone of the pin in Ideal clock propagation mode.

- If the <u>set flow compatible mode</u> command is set to off, the network insertion delay on an internal pin is ignored if specified without a source insertion delay on the same pin.
- If the set\_flow\_compatible\_mode command is set to on, the source insertion delay on an internal pin is ignored, which is similar to Synopsys PrimeTime (PT does not allow setting a source insertion delay on an internal pin). If the network insertion delay is specified, it is applied to the pins in the fanout cone in ideal mode.
- Any source and/or network insertion delay specified on clock waveforms is used with both the set\_input\_delay and the set\_external\_delay command in both ideal and propagated modes.

Use the set\_clock\_insertion\_delay command in two ways:

- To specify clock insertion delay for a clock waveform:
  - Use this form for source delay associated with a clock signal:

```
set_clock_insertion_delay -source [-lead | -trail] [-early | -late]
[-min | -max] insertion_delay list_of_clocks
```

Use this form for network delay associated with a clock signal:

```
set_clock_insertion_delay [-pvt {min | typ | max}] [-lead | -trail]
[-min | -max] insertion_delay list_of_clocks
```

Source and network insertion delays specified on the clock waveforms are picked up for both the set\_input\_delay and the set\_external\_delay assertions. Insertion delay specification on a port/pin overrides any previous insertion delay on the port/pin/ waveform. The *list\_of\_clocks* is the list of the clock waveform names as specified by the <u>set\_clock</u> or the <u>set\_generated\_clock</u> command.

- To specify clock insertion delay on clock pins:
  - Use this form for source delay on a clock pin:

```
set_clock_insertion_delay -source [-early | -late] [-rise | -fall]
insertion_delay -pin list_of_pins
```

Use this form for network delay on a clock pin:

```
set_clock_insertion_delay [-pvt {min | typ | max}] [-rise | -fall]
insertion_delay -pin list_of_pins
```

**Note:** In case of assertions on both the clock waveform and the clock pin, the specification on the clock tree pin has priority over that on the clock waveform. The specification on the clock tree pin furthest down the clock tree decides the insertion delay to a register. A balanced clock tree is assumed.

During ideal propagation, the last specification along a path wins. This is useful when you want to intentionally skew the clock tree and model the physical hierarchical clock tree.

In rare cases, more than one clock generator is connected to the input port., for example CLK1 and CLK2 both connect to clock port clkA. The -clock option makes the assertion for the named clock. Use the -clock option only with -source option. Only source delay can be specified from the clock generator to the input port.

```
set_clock_insertion_delay -source -clock clock_name [-early | -late]
[-rise | -fall] insertion_delay -pin list_of_pins
```

## **Options and Arguments**

| -clock clock_signam | e                                                                                                                                                                                                                               |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -                   | Specifies that the source insertion delay is caused by the named clock waveform. Used when more than one clock generator is connected to the port.                                                                              |
| -early   -late      | Specifies clock arrival time with respect to the early (setup) or the late (hold) time of the clock signal. If neither option is specified, the default is both early and late. Use these options only with the -source option. |
| insertion_delay     | Specifies the insertion delay value. Floating point.                                                                                                                                                                            |
| -lead   -trail      | Specifies insertion delay at the leading or trailing edge of the clock waveform. <i>Default</i> : Both edges                                                                                                                    |
| list_of_clocks      | Specifies the list of clock waveform names to associate with the clock insertion delay.                                                                                                                                         |
| -pin list_of_pins   | Specifies the list of pins to associate with the clock insertion<br>delay. The pin can be a port or an instance pin. These can either<br>be object IDs or hierarchical names relative to the current<br>module.                 |
|                     | For internal pins, both the source and network delay must be specified.                                                                                                                                                         |
| -min   -max         | Specifies the clock insertion delay for a particular operating                                                                                                                                                                  |

|               | corner. Apply the $-\min$ option to the minimum operating corner, and $-\max$ to the maximum operating corner. |
|---------------|----------------------------------------------------------------------------------------------------------------|
| -rise   -fall | Specifies insertion delay at the rising or falling edge of the clock.                                          |
| -source       | Specifies that the delay is a source delay. Without this option, the delay is considered a network delay.      |

#### **Examples**

set\_clock CLK1 -period 10 # Define the ideal clock CLK1 set\_clock CLK2 -period 20 # Define the ideal clock CLK2 set\_clock\_root -pos -clock CLK1 clkA set\_clock\_root -pos -clock CLK2 {clkA clkB clkD} set\_clock\_insertion\_delay -source 2 -pin {clkB clkD} set\_clock\_insertion\_delay -rise 5 -pin {clkB clkD} set\_clock\_insertion\_delay -fall 7 -pin {clkB clkD} set\_clock\_insertion\_delay -source -clock CLK2 5 -pin clkA

#### **Related Information**

<u>reset\_clock\_insertion\_delay</u>

reset clock uncertainty

<u>set\_clock</u>

<u>set\_clock\_root</u>

set clock propagation

set clock uncertainty

set\_data\_required\_time

set external delay

See <u>Specifying Clock Insertion Delay</u> in the Common Timing Engine (CTE) User Guide.

# set\_clock\_propagation

set\_clock\_propagation
 {ideal | propagated}

Tells the timing analyzer to treat all clock signals associated with the current timing top module as either ideal or propagated signals for the purpose of timing analysis. One of the signal types must be specified when using this command. If this command is not used, the default is ideal.



if you backannotate delays to the clock network, use the propagated mode to enable them in CTE.

#### **Options and Arguments**

|    | -   | -  |
|----|-----|----|
| 10 | dea | al |
| _  |     |    |

Ignores actual clock tree network latency and uses network latency asserted by the set\_clock\_insertion\_delay command. The total delay is the sum of the clock source latency and the asserted network latency. This is the default when the command is not issued.

propagated

Uses the actual clock tree delays in the timing of the circuit. The total delay is the sum of the clock source latency and the backannotated clock tree delay. Use propagated mode for postlayout analysis when you have accurate clock tree information in the form of an SDF file, or backannotated net capacitance and resistance.

#### Example

set\_clock\_propagation propagated

## **Related Information**

get clock propagation

get propagated clock

reset\_propagated\_clock

<u>set\_clock</u>

- <u>set clock insertion delay</u>
- set clock root
- set propagated clock
- set top timing module

See <u>Setting the Clock Propagation Mode for Analysis</u> in the Common Timing Engine (CTE) User Guide.

# set\_clock\_required\_time

# Important

Do not use the set\_clock\_required\_time command, use the
set\_external\_delay command instead. Cadence timing analysis still writes out
set\_clock\_arrival\_time during time budgeting. The following description is for
reference only.

```
set_clock_required_time
-clock clock_name [-pos | -neg] [-late | -early] [-rise | -fall]
time pin_list
```

The internally generated set\_clock\_required\_time command specifies the required time that the output clock ports must be stable.

# set\_clock\_root

set\_clock\_root [-clock ideal\_clock\_name] [-pos | -neg] list\_of\_pins

Assigns a polarity to a previously specified ideal clock and associates a list of clock pins or ports with the ideal clock signal.

When a clock root assertion is present on an internal circuit pin, one that is not an input port, all incoming signals are blocked. Setting the set\_clock\_root command stops slew propagation, so the slew at this point is one of the following:

- The value specified using the set\_slew\_time command.
- The default slew value specified using the set\_default\_slew command.
- **0**

#### **Options and Arguments**

-clock ideal\_clock\_name
 Specifies the name of the ideal clock as specified by the set\_clock command.
 list\_of\_pins
 Specifies the list of pins to associate with an ideal clock waveform. The pin can be a port or an instance pin. These can either be object IDs or hierarchical names relative to the current module. Pins can be associated with more than one ideal clock signal.

```
Specifies a positive or negative ideal clock waveform.
Default: -pos (rising edge precedes falling edge).
```

#### Example

The following command puts the negative waveform of ideal clock named master on the input port named negclk shown in Figure 7-12. The ideal clock master is shown in Figure 7-9:

set\_clock\_root -clock master -neg negclk

# Figure 7-12 Defining a Clock Pin



## **Related Information**

<u>set\_clock</u>

<u>set\_clock\_insertion\_delay</u>

- <u>set clock uncertainty</u>
- <u>set external delay</u>

# set\_clock\_transition

set\_clock\_transition [-rise | -fall] [-min |-max] slew\_time clock\_list

Specifies the slew time of register clock pins. This is useful for pre-layout static timing analysis before clock tree synthesis (CTS) is performed since net delays can be inaccurate with large fanout nets.

Use this command only with ideal clocks. In propagated mode, CTE calculates slew times on register clock pins.

#### **Options and Arguments**

| -rise  -fall | Specifies the rising (or falling) edge of the register clock pins on which the slew time is asserted.                                                                                                                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -min   -max  | Specifies the clock slew time for minimum or maximum process corner slew time.                                                                                                                                                                                                                                  |
| slew_time    | Specifies the slew time of the clock pins.                                                                                                                                                                                                                                                                      |
| clock_list   | Specifies a list of clocks only with ideal mode in the design, which<br>affects the slew times on all register clock pins in the transitive<br>fanout of the specified clocks. Specified<br>set_clock_transition values on register clock pins in the<br>fanout of a clock with propagated latency are ignored. |

#### Example

The following example specifies a 2.0 rise slew time and a 1.0 fall slew time for register clock pins clocked by CLKA:

set\_clock\_transition -rise 2.0 [get\_clocks CLKA]
set\_clock\_transition -fall 1.0 [get\_clocks CLKA]

# set\_clock\_uncertainty

```
set_clock_uncertainty [-ideal | -propagated] [-early | -late]
    {([-clock_from clksig_from] [-clock_to clksig_to]
    [-edge_from {leading | trailing}] [-edge_to {leading | trailing}]) |
    (-pin list_of_clock_tree_pins [-rise] [-fall] [-to])} float
```

Specifies the clock uncertainty (skew) between two clock edges for one or more paths. The command has two mutually exclusive forms, one for uncertainty on the clock waveform and one for uncertainty on clock pins.

Specify uncertainty for clock waveforms using this set of options:

```
set_clock_uncertainty [-ideal | -propagated] [-early | -late]
[-clock_from clk_from] [-clock_to clk_to]
[-edge_from {leading | trailing}] [-edge_to {leading | trailing}] float
```

The specified uncertainty applies to paths starting from the clock\_from signal and ending at registers clocked by the clock\_to signal.

The edge\_from parameter is the type of edge for the launching clock of the path. The edge\_to parameter is the capturing clock edge type of the destination register.

Use this command to add optimism by using negative values for the clock uncertainty value. This is convenient when the design has paths starting in one clock domain and ending in another clock domain, and there is no synchronous relationship between the two clocks.

Specify clock uncertainty on a clock pin using this set of options:

```
set_clock_uncertainty [-ideal | -propagated] [-early | -late]
-pin list_of_clock_tree_pins [-rise] [-fall] [-to]
float
```

Uncertainty on a clock pin affects paths downstream from that pin. By default, an uncertainty specification on pin x is honored only at those registers or latches where there is a path from pin x to both the data pin and the clock pin of the register or latch. However, the -to option lifts this restriction and makes it applicable to all registers and latches whose clock pin is in the transitive fanout of pin x. Pin-based uncertainty has priority over clock-based uncertainty. Among all applicable pin-based uncertainty specifications, the one furthest down the clock tree has the highest priority.

- Priority of setting multiple assertions using the set\_clock\_uncertainty command is as follows:
  - set\_clock\_uncertainty -clock\_from -clock\_to
  - set\_clock\_uncertainty -clock\_from
  - set\_clock\_uncertainty -clock\_to

□ set\_clock\_uncertainty

When setting multiple assertions with the same options, the latest command is applied and the previous value is overwritten.

## **Options and Arguments**

| -clock_from clksig_f       | Erom                                                                                                                                                                                                                                                                                                               |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Specifies the starting point of the paths for which the uncertainty is specified. The $clksig_from$ argument is the name of clock signal with respect to which the uncertainty is specified.                                                                                                                       |
|                            | If the -clock_from option is omitted then the uncertainty applies to all the paths ending at the registers clocked by the -clock_to signal.                                                                                                                                                                        |
| -clock_to <i>clksig_to</i> | Specifies the endpoint of the paths for which the uncertainty is specified. The specified uncertainty applies to all paths starting from the -clock_from signal and ending at the registers clocked by -clock_to signal.                                                                                           |
|                            | If the -clock_to option is omitted then the uncertainty applies to all paths starting at the -clock_from signal.                                                                                                                                                                                                   |
|                            | If both the options <code>-clock_from</code> and <code>-clock_to</code> are omitted, then the specified uncertainty applies to all clocked paths in the design, including combinational paths constrained by the <code>set_input_delay</code> and <code>set_external_delay</code> times associated with the clock. |
| -early   -late             | Specifies whether the clock uncertainty is with respect to early times or late times. The <code>-late</code> option applies to setup, and the <code>-early</code> option applies to hold checks on the clock signals. <i>Default</i> : <code>-early</code> and <code>-late</code>                                  |
| -edge_from {leading        | <pre>  trailing} Specifies whether the triggering (launching) edge of the clock is a leading or a trailing edge. It must match the edge used in the timing check for the destination register. Default: leading edge.</pre>                                                                                        |

| -edge_to {leading    | <pre>trailing} Specifies whether the capturing edge at the destination register is a leading or a trailing edge. Default: leading edge</pre>                                                                                                                                                                                                                  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| float                | Specifies the uncertainty value.                                                                                                                                                                                                                                                                                                                              |
| -ideal   -propagated | Specifies whether the uncertainty applies to the ideal clock<br>propagation mode or the propagated mode of analysis. If<br>neither option is given, the uncertainty applies in both ideal and<br>propagated modes by default.                                                                                                                                 |
| -pin list_of_clock_  | Applies the uncertainty to the given list of clock pins. Each pin<br>can be a port or an instance pin. It can either be given as an<br>object ID or a hierarchical name relative to the current module.<br>Cannot be used with -clock_from or -clock_to options.                                                                                              |
| -rise   fall         | Specifies the rising (or falling) edge of the clock pins on which the uncertainty is asserted. For each edge, the assertion is used only if that edge fans out to the data and the clock pin of a register or latch. With the $-to$ option, the assertion is used if that edge fans out to the clock pin of a register or latch. <i>Default</i> : Both edges. |
| -to                  | Specifies that the uncertainty applies to all the registers and latches whose clock pin is in the transitive fanout of a clock pin from the <i>list_of_clock_tree_pins</i> .                                                                                                                                                                                  |

## Examples

■ The following command gives all paths starting from registers clocked by c1 to registers clocked by c2 a hold (early) uncertainty of 2.0 when the triggering edge is the leading edge and the capturing edge is the trailing edge:

```
set_clock_uncertainty -clock_from c1 -clock_to c2 \
-edge_from leading -edge_to trailing -early 2.0
```

In case of multiple assertions, the actual uncertainty applied by CTE depends on which constraint matches the specific path in the question. CTE may also apply the worst case uncertainty in some situations, as shown in the following example.

■ The following commands cause a path starting at a register clocked by c1 and ending at a register clock by c2 to have an uncertainty of 3.0 (which is the worse of the two).

set\_clock\_uncertainty -clock\_from c1 2.0 -late
set\_clock\_uncertainty -clock\_to c2 3.0 -late

■ The following command sets an uncertainty on a clock pin (clk\_in) only for propagated mode.

set\_clock\_uncertainty -propagated -pin clk\_in 1.2

## **Related Information**

<u>set\_clock</u>

reset clock uncertainty

<u>Specifying Clock-Based Uncertainty</u> in the *Timing Analysis for BuildGates Synthesis* and Cadence Physically Knowledgeable Synthesis (PKS).

# set\_constant\_for\_timing

Sets the value of the specified pin(s) to either a 1 or 0 for use by the timing engine. The applied state value propagates through the corresponding combinational logic cone(s) and the enable or disable sections of logic. Constants do not propagate through sequential logic, however you can set the constant at the sequential output. Constants can also be applied at primary IO and hierarchical ports.

Controls the transparency of a latch. Constants can also be applied to clear or preset a latch. For more information, see <u>Specifying Latch Transparency</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

**Note:** Any paths considered to be false paths because of set\_constant\_for\_timing will not be optimized. To set a constant for synthesis, use the <u>set\_logic0</u> or <u>set\_logic1</u> command.

#### **Options and Arguments**

| 0   1                |                                                                                                                                                                               |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies a logic value of 0 or 1, which is propagated through combinational logic to disable or enable parts of logic.                                                       |
| -bidi_input   -bidi_ | output<br>Specifies that the constant is set on the input or output part of<br>bidirectional pins. The default places the constant on the input<br>part.                      |
| list_of_ports_or_p   | ins                                                                                                                                                                           |
|                      | Specifies a list of ports or pins on which to apply the value. To specify multiple pins, enclose the list with curly braces ({}) and separate the pin names with white space. |
| -rising   -falling   |                                                                                                                                                                               |
|                      | Specifies a relevant transition value to be considered by the timing engine. For example, if rising is specified, the opposite transition type (falling) is ignored.          |

## Example

The following command sets the value of pin i4/A to 1 for use by the timing engine:

set\_constant\_for\_timing 1 i4/A

#### **Related Information**

check timing -type

const\_collision

<u>const\_contradiction</u>

get constant for timing

reset\_constant\_for\_timing

<u>set case analysis</u>

set disable timing

<u>set\_false\_path</u>

<u>Setting Constant Values for Timing</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

# set\_cycle\_addition

```
set_cycle_addition [{-from | -from_rise | -from_fall} pin_list]
  [{-through | -through_rise | -through_fall} pin_list]
  [{-to | -to_rise | -to_fall} pin_list] [-clock_from list_of_clksigs]
  [-edge_from {leading | trailing}] [-clock_to list_of_clksigs]
  [-edge_to {leading | trailing}] [-early | -late]
  [-bidi_input_from | -bidi_output_from]
  [-bidi_input_through | -bidi_output_through]
  [-bidi_input_to | -bidi_output_to]
  [-target][-reset_path] float
```

Identifies multicycle paths in the design for timing analysis. A path is a multicycle path when the signal propagation from the start point to the endpoint of the path takes more than one clock cycle. Normally, timing analysis takes place over one clock cycle, and by default all paths are considered one cycle paths. This command lets you add a certain number of cycles to the path under consideration. Timing analysis is then done for the total number of cycles, thereby eliminating violations caused by inadequate analysis time. The information about number of cycles for a path is attached to the pins of the path.

All paths starting in one clock domain and ending in another clock domain are taken as multicycle paths. You cannot have the  $-clock_from$  and  $clock_to$  options in the same command with the -from and to options.

If both the <code>-from</code> and <code>-clock\_from</code> options are specified, the path exception applies to all paths starting from the <code>-from</code> pin and all the paths starting from the <code>-clock\_from</code> signal. If both the <code>-to</code> and <code>-clock\_to</code> options are specified, the path exception applies to all the paths ending at the <code>-to</code> pin and all the paths ending at the <code>-clock\_to</code> signal.

If both the <code>-through</code> and <code>-clock\_from</code> options are specified, the path exception applies to all paths starting from the <code>-clock\_from</code> signal and going through the <code>-through</code> pin (AND operation). If both the <code>-through</code> and <code>-clock\_to</code> options are specified, the path exception applies to all paths going through the <code>-through</code> pin and ending at the <code>-clock\_to</code> path can have more than one path exception. Multiple path exceptions that match a given path are prioritized. The adjustment on the path is from the path exception with the highest priority. Table 7-1 on page 797 ranks path exception Priorities from highest to lowest. Examples are provided in "Examples of Path Exception Priorities" on page 798.

The cycle addition values are stored at the -to pins if the -to option is specified, otherwise values are stored at the -from pins. If neither the -to nor -from option is specified, values are stored at the -through pins.

Specify a group of pins by enclosing the group with curly braces ({}) within one set\_cycle\_addition command.



To add cycles for any path beginning at p1 or p2 and terminating at t1 or t2, group the pins as follows:

set\_cycle\_addition -from {p1 p2} -to {t1 t2} 2.2

**Note:** This method of pin grouping reduces the number of exceptions. Having large numbers of exceptions adversely impacts the run time of report\_timing.

## **Options and Arguments**

| -bidi_input_from   -           | -bidi_output_from<br>Specifies that the assertion applies to the input or output of<br>bidirectional pins in the -from pin list. Default value is shown in<br><u>"Bidirectional Pin Defaults"</u> on page 799.       |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -bidi_input_through            | -bidi_output_through<br>Specifies that the assertion applies to the input or output of<br>bidirectional pins in the -through pin list. Default value is<br>shown in <u>"Bidirectional Pin Defaults"</u> on page 799. |
| -bidi_input_to   -bi           | di_output_to<br>Specifies that the assertion applies to the input or output of<br>bidirectional pins in the -to pin list. Default value is shown in<br><u>"Bidirectional Pin Defaults"</u> on page 799.              |
| -clock_from list_of            | _ <i>clksigs</i><br>Adjusts the cycle count for all paths originating from the specified<br>ideal (or generated) clock signals.                                                                                      |
| -clock_to list_of_c            | <pre>lksigs Adjusts the cycle count for all paths going to the specified ideal (or generated) clock signals.</pre>                                                                                                   |
| -early   -late                 | Specifies whether the cycles added are with respect to the early (hold) or the late (setup) times of the data signal. If neither option is specified, the -late option is the default.                               |
| <pre>-edge_from {leading</pre> | <pre>  trailing} Specifies an edge for the -clock_from. This option can only be</pre>                                                                                                                                |

|                     | used with the <code>-clock</code> options.<br>Default: Both edges                                                                                                                                                                                                                    |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -edge_to {leading   | trailing}<br>Specifies an edge for the -clock_to option.<br><i>Default</i> : Both edges                                                                                                                                                                                              |
| float               | Specifies the number of extra cycles that should be added to the path. The number of cycles to be added for an $N$ cycle path is $N-1$ , because all paths by default are single cycle paths. The number of cycles can be negative, thus reducing the number of cycles for the path. |
|                     | <b>Note:</b> Although a floating point number is allowed, if you pass the constraint to downstream tools with GCF, the value must be an integer.                                                                                                                                     |
| {-from   -from_rise | <pre>-from_fall} pin_list Specifies the pins that are at the start of the paths. If the -from option is used without the -to option, all paths originating from the pin_list are considered as multicycle paths.</pre>                                                               |
|                     | Use either the -from, -to, or -through option with the set_cycle_addition command to identify the paths.<br>Specifying both the -from and -to options identifies a path with specific starting and ending points.                                                                    |
|                     | The <i>pin_list</i> variable can contain either object IDs or<br>hierarchical names relative to the current module. The pins can<br>be on intermediate hierarchical boundaries. Leaf design cells<br>(instances) can also be specified as the object for the -from*<br>options.      |
|                     | Use only one -from (or -from_rise or -from_fall) option<br>per command.<br><i>Default</i> : The -from option applies the assertion to both the<br>rising and the falling edges.                                                                                                      |
|                     | Using the -from_rise option applies the assertion at the rising edge of the signal on the -from pins.                                                                                                                                                                                |

|                      | Using the $\tt -from\_fall$ option applies the assertion at the falling edge of the signal on the -to pins.                                                                                                                                                    |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -reset_path          | Changes the constraint on the specified path to the new value.<br>See Examples.                                                                                                                                                                                |
| -target              | The cycle adjustment is calculated using the cycle time of the capturing (target) clock.<br>Default: The no -target option, which uses the launching clock cycle time.                                                                                         |
| {-through   -through | _rise   -through_fall} pin_list<br>Specifies the pins that the path goes through. When used<br>without the -from or -to option, all paths that go through the<br>-through pins are multicycle paths.                                                           |
|                      | When used with both the -from and -to options, any path starting at any pin on the -from list <i>and</i> going through any point on the -through pin list <i>and</i> going to any point on the -to list is affected by the assertion.                          |
|                      | The <i>pin_list</i> can contain either object IDs or hierarchical names relative to the current module. The pins can be on intermediate hierarchical boundaries. There can be only one -from and one -to option but many -through options in the same command. |
|                      | By default, the -through option applies the assertion to both the rising and the falling edges.                                                                                                                                                                |
|                      | Using the -through_rise option applies the assertion at the rising edge of the signal on the through pins.                                                                                                                                                     |
|                      | Using the -through_fall option applies the assertion at the falling edge of the signal on the through pins.                                                                                                                                                    |
| {-to   -to_rise   -t | o_fall} pin_list<br>Specifies the pins that are at the end of the paths. If the -to<br>option is used without the -from option, all paths ending in the<br>-to pin list are considered as multicycle paths.                                                    |

The  $pin_list$  can contain either object IDs or hierarchical names relative to the current module. The pins can be on intermediate hierarchical boundaries. Leaf design cells (instances) can also be specified as the object for the -to\* options.

Use only one -to (or -to\_rise or -to\_fall) option per command.

By default, the -to option applies the assertion to both the rising and the falling edges.

Using the -to\_rise option applies the assertion at the rising edge of the signal on the through pins.

Using the  $-to_fall$  option applies the assertion at the falling edge of the signal on the through pins.

## Examples

■ The following command specifies all paths from port Q of instance I1 as 3-cycle paths (additional 2 cycles). The paths can end anywhere in the design.

set\_cycle\_addition -from I1/Q 2

■ The following command sets all paths ending at port A of instance 12 as 2-cycle paths. The paths can start anywhere in the design.

set\_cycle\_addition -to I2/A 1

■ The following command sets all paths from port Q of instance I1 to port B of instance I3 as 2-cycle paths. The paths can go through any pins in the design.

```
set_cycle_addition -from I1/Q -to I3/B 1
```

■ The following command sets only the path from port Q of instance I1 through port Q of instance I2 to port B of instance I3 as a 3-cycle path.

set\_cycle\_addition -from I1/Q -through I2/Q -to I3/B 2

The following command sets a different number of cycles on the early and late paths using these commands:

```
set_cycle_addition -late -from I1/Q 2
set_cycle_addition -early -from I1/Q 1
```



Be careful of multiple cycle additions on the same path. The priority rules say that the most constraining value is used. For example:



■ Using the -reset\_path option changes the constraint on the specified path to the new value. However, if there is only one path and both paths are equivalent, using this option resets a path only when there is an exact match in the arguments. For example, the following command specifies the delay as U14/A 5:

set\_cycle\_addition -through U14/A 5

The following shows the report using this command:

| + | Through | Early      | +<br>  Late          |
|---|---------|------------|----------------------|
| + | U14/A   | +<br> <br> | <br>  delay 5  <br>+ |

If you then change the constraint to a new value using the -reset\_path option on the same path, but use a different argument as follows:

set\_cycl\_addition -through U12/Z 7 -reset\_path

The report using the report\_path\_exceptions command or the report\_timing command shows the following:

| +              | Early | Late                       |
|----------------|-------|----------------------------|
| U12/Z<br>U14/A |       | delay 7 ignored<br>delay 5 |

Using the -reset\_path option resets a path only when there is an exact match in the arguments, not when both the constraints represent the same path.

## **Related Information**

reset path exception

report timing -format addition

<u>set\_false\_path</u>

# set\_data\_arrival\_time

Do not use the set\_data\_arrival\_time command, use the set\_input\_delay command instead. Cadence timing analysis still writes out set\_data\_arrival\_time during time budgeting. The following description is for reference only.

```
set_data_arrival_time
[-clock clock_name]
[-lead | -trail] [-early | -late] [-rise | -fall] [-bidi_input | -bidi_output]
time pin_list
```

The internally generated set\_data\_arrival\_time command attaches arrival times to input ports in the database.

**Note:** The arrival time is always specified as an absolute time with respect to the ideal clock time zero, even if the pertinent edge of the ideal clock is not at time zero. When you use the set\_input\_delay command, the time is relative to the clock.

# set\_data\_required\_time

```
set_data_required_time
    OBSOLETE: Use set_external_delay.
```

# Important

Do not use set\_data\_required\_time command, use the
set\_external\_delay command instead. See set external\_delay on page 1167
for more details.

Cadence timing analysis still writes out set\_data\_required\_time during time budgeting. The following description is for reference only.

```
set_data_required_time
[-clock clock_name]
[-lead | -trail] [-early | -late] [-rise | -fall] [-bidi_input | -bidi_output]
time pin_list
```

The internally generated set\_data\_required\_time command specifies the required time that the output data ports must be stable.

The required time is always specified as an absolute time with respect to the ideal clock time zero, even if the pertinent edge of the ideal clock is not at time zero. When you use the set\_external\_delay command, the time is relative to the clock.

# set\_dcl\_calculation\_mode

set\_dcl\_calculation\_mode [-mode {best\_case | nominal\_case | worst\_case}]

Sets the current Delay Calculation Language (DC)L calculation mode. If this command is not specified, the default is worst\_case. Load the Delay Calculation Module (DCM) first with the load\_dcl\_rule command.

The library developer defined the calculation modes in the DCL library to model three process conditions, best\_case, nominal\_case, and worst\_case, within one library. Refer to the vendor documentation for more information.

**Note:** Process, temperature, and voltage are set independently of the calculation mode using the set\_operating\_parameter command.

#### **Options and Arguments**

-mode {best\_case | nominal\_case | worst\_case}
 Specifies which calculation mode to use for analysis.
 Default: worst\_case

## Example

The following command lets the current Delay Calculation Language (DCL) calculation mode to nominal\_case:

set\_dcl\_calculation\_mode -mode nominal\_case

## **Related Information**

get dcl calculation mode

get operating parameter

<u>load dcl rule</u>

reset dcl calculation mode

set\_operating\_parameter

See <u>Using IEEE 1481 Delay and Power Calculation System (DPCS) Libraries</u> in the *Common Timing Engine (CTE) User Guide* for more information.

# set\_dcl\_functional\_mode

set\_dcl\_functional\_mode [-group group\_name] [-mode mode\_name] instance\_list

Sets the Delay Calculation Language (DCL) functional mode by group and name on hierarchical instances. To determine what modes are available for an instance, use the command get\_dcl\_functional\_mode\_array on the underlying library cell of that instance.

Functional modes defined in a DCL library let the vendor library developer model the timing arcs and timing checks for a technology cell in a variety of ways. For example, a scan flip-flop could have functional modes defined for normal flip-flop behavior and for scan behavior with different timing arcs and checks for each mode.

#### **Options and Arguments**

| -group group_name      | Specifies the functional mode group name.                                    |
|------------------------|------------------------------------------------------------------------------|
| instance_list          | Specifies a list of instances for which the functional mode needs to be set. |
| -mode <i>mode_name</i> | Specifies the functional mode name.                                          |

## Example

```
set_dcl_functional_mode -group rw -mode read {A1/B3/C2 A1/B2/C2}
```

## **Related Information**

get\_dcl\_functional\_mode

get dcl functional mode array

load dcl rule

<u>reset\_dcl\_functional\_mode</u>

See <u>Using IEEE 1481 Delay and Power Calculation System (DPCS) Libraries</u> in the *Common Timing Engine (CTE) User Guide* for more information.

# set\_dcl\_level

```
set_dcl_level [-perfLevel {0 | 1}]
```

Sets the desired performance level for Delay Calculation Language (DCL) based delay calculations. A value 0 indicates lower accuracy in favor of faster run time while a value of 1 indicates calculations for maximum accuracy. If this command is not issued, the default performance level is 0.

#### **Options and Arguments**

```
-perfLevel \{0 \mid 1\}
```

Specifies the performance level. DCL supports two performance levels for delay calculation, where one performance level targets faster run time with less accurate timing, while the other targets more accurate timing with slower run time.

The library vendor who provided the Delay Calculation Module (DCM) also documents the characteristics of each performance level in their library and whether or not both 0 and 1 levels are supported and which is faster (usually 0). In general, the faster performance in terms of run time should be used for initial synthesis and the more accurate level should be used in final timing correction.

## Example

The following command sets the desired performance level to 1:

set\_dcl\_level -perfLevel 1

#### **Related Information**

<u>get\_dcl\_level</u>

<u>load dcl rule</u>

See <u>Using IEEE 1481 Delay and Power Calculation System (DPCS) Libraries</u> in the *Common Timing Engine (CTE) User Guide* for more information.

## set\_default\_slew\_time

set\_default\_slew\_time [-early | -late] [-rise | -fall] float

Specifies the default slew time for the ports. The system uses this slew value for any input or bidirectional port for which slew or drive assertions are not specified. If this command is not used, the system uses a value of 0.0.

The set\_default\_slew\_time command is ignored for a port if set\_slew\_time, set\_drive\_cell, or set\_drive\_resistance constraints have been set for that port.

#### **Options and Arguments**

| -early   -late | Indicates whether the slew times are with respect to the late (data setup) or the early (data hold) checks. If neither option is specified the default is to use both. |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| float          | Specifies the default slew time for input and bidirectional ports that do not have slew or drive assertions on them.                                                   |
| -rise   -fall  | Specifies that the slew time should be applied to the rising edge<br>or the falling edge of the signal. If neither edge is specified, the<br>default is to use both.   |

#### Examples

```
set_default_slew_time -rise -early 10.0
set_default_slew_time -fall -early 20.0
set_default_slew_time -rise -late 30.0
set_default_slew_time -fall -late 40.0
```

#### **Related Information**

reset default slew time

<u>set\_drive\_cell</u>

<u>set\_drive\_resistance</u>

<u>set\_slew\_time</u>

# set\_disable\_cell\_timing

```
set_disable_cell_timing [-library library_name][ -cell cell_name]
    [-from_pin | -from_rise | -from_fall from_pin_name]
    [-to_pin | -to_rise | -to_fall to_pin_name]
```

Disables delay arcs at the cell level. The set\_disable\_cell\_timing command effects all instantiations of the specified cell, and lets you disable delay arcs from and to internal pins.

#### **Options and Arguments**

| -cell <i>cell_name</i> |                                                                                                                                                                                                                                                                        |  |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                        | Specifies the cell in the library for which timing arcs are disabled.                                                                                                                                                                                                  |  |
| -from_pin -from_rise   | Specifies the source pin of the timing arc. You can disable cell<br>arcs with specific edges using either the from_rise option or<br>the from_fall option. All arcs specified using the -from_pin<br>from_pin_name option are disabled.                                |  |
| -library library_name  |                                                                                                                                                                                                                                                                        |  |
|                        | Specifies the library that contains the cell for which arcs are disabled. If not specified, the default is the target technology library.                                                                                                                              |  |
| -to_pin -to_rise -to   | <pre>b_fall to_pin_name<br/>Specifies the sink pin of the timing arc. You can disable cell arcs<br/>with specific edges using either the to_rise option or the<br/>to_fall option. All arcs specified using the -from_pin<br/>from_pin_name option are disabled.</pre> |  |
|                        |                                                                                                                                                                                                                                                                        |  |

## Examples

The following command disables all arcs in cell FD1. Any instantiation of this cell in your design will not propagate timing:

set\_disable\_cell\_timing -cell FD1

■ The following command disables all arcs originating from rising input pin A:

set\_disable\_cell\_timing -library lca300kv -cell AN2 -from\_rise A

■ The following command disables arcs with a specific transition. Arcs originating with rising from pin A and falling to pin Y are disabled.

set\_disable\_cell\_timing -cell XORS -from\_rise A -to\_fall Y

# **Related Information**

reset disable cell timing

set constant for timing

set disable timing

<u>set\_false\_path</u>

# set\_disable\_clock\_gating\_check

```
set_disable_clock_gating_check [-from from_pins] [-to to_pins]
    [-bidi_input_from | -bidi_output_from] [-bidi_input_to | -bidi_output_to]
    [-check_type check_type_list]
```

Valid check types are: clock\_gating\_hold clock\_gating\_setup

Disables any clock gating check from, to, or between the specified pins. Disables only the inferred clock gating checks, which result when a data signal meets a clock signal through a combination gate. (See section describing inferred clock gating checks.)

Use the -check\_type option to selectively disable the clock gating setup and clock gating hold.

## **Options and Arguments**

| -bidi_input_from   -        | bidi_output_from<br>Specifies the assertion on the input or output part of the from<br>pin. Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.                                                                                                                                                                                                    |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -bidi_input_to   -bi        | di_output_to<br>Specifies the assertion on the input or output part of the to pin.<br>Default value is shown in <u>"Bidirectional Pin Defaults"</u> on<br>page 799.                                                                                                                                                                                                          |
| -check_type <i>check_ty</i> | Specifies the check arc being disabled. If not specified, all arcs from, to, or between the specified pins are disabled. Valid check types are clock_gating_setup and clock_gating_hold.                                                                                                                                                                                     |
| -from <i>from_pins</i>      | Specifies the clock pin of the clock gating check to be disabled.<br>If the -from option is used without the -to option, all clock<br>gating checks that reference the <i>from_pins</i> are disabled.<br>Either the -from or -to option must be used with this<br>command. Specifying both the -from and -to options identifies<br>a path with specific start and endpoints. |
| -to to_pins                 | Specifies the data enable pin of the clock gating check to be disabled.                                                                                                                                                                                                                                                                                                      |

If the -to option is used without the -from option, all clock gating checks with  $to_pins$  as data signal are disabled.

#### **Related Information**

reset clock gating check

<u>reset\_disable\_clock\_gating\_check</u>

set clock gating check

# set\_disable\_timing

```
set_disable_timing [-from from_pins] [-to to_pins]
    [-bidi_input_from | -bidi_output_from] [-bidi_input_to | -bidi_output_to]
    [-check_type check_type_list]
    Valid check types are: clock_gating_hold clock_gating_pulse_width
    clock_gating_setup clock_period clock_separation hold no_change_hold
    no_change_setup recovery removal setup skew
```

Disables (snips) timing arc(s) of an instance or interconnect and is used for breaking combinational loops.

Use the set\_disable\_timing command to control the transparency of a latch. For more information, see <u>Specifying Latch Transparency</u> in the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS)*.

This command differs from the set\_false\_path command as follows:

- set\_disable\_timing command snips a timing arc such that neither arrival times nor constant values propagate through it.
- set\_false\_path command selectively disables the arrival time information depending upon the precedence rules given in <u>Table 7-1</u> on page 797. Constant values are not affected by the set\_false\_path command.

#### **Options and Arguments**

```
-bidi_input_from | -bidi_output_from
Specifies the assertion on the input or output part of the from
pin. Default value is shown in <u>"Bidirectional Pin Defaults"</u> on
page 799.
-bidi_input_to | -bidi_output_to
Specifies the assertion on the input or output part of the to pin.
Default value is shown in <u>"Bidirectional Pin Defaults"</u> on
page 799.
```

-check\_type check\_type\_list

Specifies the check arc being disabled. If not specified, all arcs from, to, or between the specified pins are disabled. Valid check types are setup, hold, recovery, removal, clock\_separation, clock\_gating\_setup, clock\_gating\_hold, clock\_gating\_pulse\_width,

|                 | clock_period, pulse_width, no_change_setup,<br>no_change_hold, <b>and</b> skew.                                                                                                                                                                                                                                                                           |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -from from_pins |                                                                                                                                                                                                                                                                                                                                                           |
|                 | Specifies the source pin of the timing arc to be disabled.<br>If the -from option is used without the -to option, all paths<br>originating from the <i>from_pins</i> are disabled.<br>Either the -from or -to option must be used with this<br>command. Specifying both the -from and -to options identifies<br>a path with specific start and endpoints. |
|                 | The -from and -to options can be intermediate hierarchical boundaries.                                                                                                                                                                                                                                                                                    |
|                 | If disabling check arcs, the $-from$ pin must be a clock pin, and the $-to$ pin must be a data signal pin.                                                                                                                                                                                                                                                |
| -to to_pins     |                                                                                                                                                                                                                                                                                                                                                           |
|                 | Specifies the sink pin of the timing arc to be disabled.                                                                                                                                                                                                                                                                                                  |
|                 | If the $-to$ option is used without the $-from$ option, all paths ending in the $to_pins$ option are disabled.                                                                                                                                                                                                                                            |

#### Examples

- The following command disables all check arcs between reg01/CP and reg01/D: set\_disable\_timing -from reg01/CP -to reg01/D
- The following command disables all check arcs and delay arcs from reg01/CP: set\_disable\_timing -from reg01/CP
- The following command disables only setup check arcs attached to reg01/CP. Any delay arcs from reg01/CP will not be disabled:

set\_disable\_timing -from reg01/CP -check\_type setup

#### **Related Information**

reset feedback loop snipped arcs

set disable cell\_timing

<u>set false path</u>

# set\_drive\_cell

```
set_drive_cell [-early | -late] [-library library_name]
  [-library_rise library_name] [-library_fall library_name]
  [-cell cell_name] [-cell_rise cell_name] [-cell_fall cell_name]
  [-pin pin_name] [-pin_rise pin_name] [-pin_fall pin_name]
  [-from_pin from_pin_name] [-from_pin_rise from_pin_name]
  [-from_pin_fall from_pin_name]
  [-rise_source_edge {R | F}] [-fall_source_edge {R | F}]
  [-clock clock_name] [-lead | -trail | -pos | -neg]
  [-source_slew slew_value] [-rise_source_slew rise_slew_value]
  [-fall_source_slew fall_slew_value] [-no_design_rule] port_list
```

Models the drive capability of an external driver connected to the input port. Use this command only for timing analysis. The command does not affect the electrical properties of the design, which means that the capacitance of the output pin of the driving cell does not add to the total capacitance of the input port.

The timing analyzer computes an offset to the arrival time of an input and also changes the slew time used to compute the delay of the cell on the sink of the net. The offset to data arrival time is computed by taking the total delay of the cell for C seen at the input (not including its own  $C_{driver}$ ) and subtracting the total delay of the cell given  $C_{load}$  of zero. The total delay means the propagation and transition delays, if applicable. The transition delay itself is used as the slew value for the delay calculation of the next cell. Identify the library cell that drives the input of the design, and designate the cell as the driving cell for the ports in context using set\_drive\_cell command.

This command overrides the set\_drive\_resistance command, per port or per net, if it is the last command applied. Also, if set\_drive\_cell is set for a port, the set\_slew\_time command is ignored for that port.

#### **Options and Arguments**

```
-cell cell_name
```

Specifies the name of the driver cell that provides both a rising edge transition driver and a falling edge transition driver.

-cell\_fall cell\_name

Specifies the name of the cell that provides a falling transition driver.

-cell\_rise cell\_name

Specifies the name of the cell that provides a rising transition driver.

| -clock <i>clock_name</i> | Specifies the clock signal that is controlling the data signal.                                                                                                                                                                                                                                                                                                   |  |  |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| -early                   | Specifies that the driver provides a signal for early mode analysis (data hold check).                                                                                                                                                                                                                                                                            |  |  |
| -fall_source_edge R      | F<br>Specifies whether the rising edge ( $\mathbb{R}$ ) or the falling edge ( $\mathbb{F}$ ) at the $from_pin_name$ option is controlling the falling edge transition at the input port of the design. This option is required for non-unate timing arcs.                                                                                                         |  |  |
| -fall_source_slew fa     | 11_s1ew_value<br>Specifies the slew value for the falling signal at the input of the<br>drive cell.                                                                                                                                                                                                                                                               |  |  |
| -from_pin_fall from_     | _pin_name<br>Specifies the name of the input port of the driver cell with the<br>controlling timing arc to the output port of the driver cell that<br>provides the falling edge transition drive to the input port of the<br>design.                                                                                                                              |  |  |
| -from_pin from_pin_:     | Specifies the name of the input port of the driver cell that has an arc to the output port of the driver cell, which is connected to the input port of the design. This option is required only if there are multiple timing arcs in the driver cell from its input ports to its output ports, and the arcs from those pins have different drive characteristics. |  |  |
|                          | The -from_pin option assumes that the same timing arc<br>between the input port and the output port of the driver cell is<br>driving both the rising edge transition and the falling edge<br>transition on the input port of the design. To specify one edge,<br>use the -from_pin_rise or the -from_pin_fall option.                                             |  |  |
|                          | Without the -from_pin* option, the default is to use the first timing arc found on the library cell.                                                                                                                                                                                                                                                              |  |  |
| -from_pin_rise from_     | _pin_name<br>Specifies the input port name of the driver cell with the controlling                                                                                                                                                                                                                                                                                |  |  |

|                              | timing arc to the output port of the driver cell that provides the rising edge transition drive to the input port of the design.                                                                                                                                                   |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -late                        | Specifies that the driver provides a signal for late mode analysis                                                                                                                                                                                                                 |
|                              | (data setup check).                                                                                                                                                                                                                                                                |
| -lead   -trail   -po         | S   -neg<br>Specifies that the slew time is for a data signal triggered by the<br>leading or the trailing edge of the clock waveform.<br>Default: -lead                                                                                                                            |
|                              | For a clock signal, $-pos$ and $-neg$ specify that the slew time should be applied to an actual clock that has positive or negative polarity with respect to the ideal clock waveform.                                                                                             |
| -library library_na          |                                                                                                                                                                                                                                                                                    |
|                              | Specifies the name of the library that contains the driving cell.<br>This option is used if the same cell provides both the rising and<br>the falling edge transitions, or if different cells provide the rising<br>edge and falling edge transitions but are in the same library. |
| -library_fall <i>libra</i> : | ry_name<br>Specifies the name of the library that contains the falling edge<br>transition driver.                                                                                                                                                                                  |
| -library_rise <i>libra</i> : | ry_name<br>Specifies the name of the library that contains the rising edge<br>transition driver.                                                                                                                                                                                   |
| -no_design_rule              |                                                                                                                                                                                                                                                                                    |
|                              | Prevents drive cell design rules from being used as design rules<br>for ports where the drive cell is asserted. This option is valid only<br>if the global use_drive_cell_design_rules is set to true.                                                                             |
| -pin_fall <i>pin_name</i>    | Specifies the name of the output port of the driver cell that provides the falling edge transition drive to the input port of the design.                                                                                                                                          |
| -pin <i>pin_name</i>         | Specifies the name of the output port of the driver cell that drives the signal at the input port of the design. This option is required                                                                                                                                           |

|                             | if there are multiple output ports on the driver. If there is only one output port on the driver cell, then using this option is not necessary.                                                       |  |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| -pin_rise <i>pin_name</i>   | Specifies the name of the output port of the driver cell that provides the rising edge transition drive to the input port of the design.                                                              |  |
| port_list                   | Specifies the list of ports driven by the driver cell.                                                                                                                                                |  |
| -rise_source_edge R         | F<br>Specifies whether the rising ( $\mathbb{R}$ ) edge or the falling edge ( $\mathbb{F}$ ) at the $from_pin_name$ option is controlling the rising edge transition at the input port of the design. |  |
| -rise_source_slew <i>ri</i> | Se_slew_value<br>Specifies the slew value for the rising signal at the input of the<br>drive cell. This option is required for non-unate timing arcs                                                  |  |
| -source_slew <i>slew_va</i> | alue<br>Specifies the slew value for the signal at the input of the drive<br>cell.                                                                                                                    |  |

#### Examples

■ The <u>Current Module and Sub-Modules Example</u> figure on page 874 shows an example module to help show how to use the <u>set\_drive\_cell</u> command. The following are the constraints that are specified on the example module and submodules:

```
set_clock CLK1 -period 3
set_clock_root -clock CLK1 "clkA clkB clkC clkD"
set_input_delay -clock CLK1 0.0 in
set_external_delay -clock CLK1 1.0 out
```

The following commands model the drive capability of an external driver connected to the input port. The timing analyzer computes an offset to the arrival time of an input and also changes the slew time used to compute the delay of the cell on the sink of the net:

```
set_drive_cell -cell IV [ find -input -port * ]
set_drive_cell -cell AN3 -from_pin I0 input1
```

The following command provides a detailed timing report based on this example:

```
check_timing -verbose
```

```
TIMING CHECK DETAIL |

Pin | Warning |

ClkA | No drive assertion |

ClkB | No drive assertion |

ClkC | No drive assertion |

ClkD | No drive assertion |

Herein |
```

The following commands show the timing results:

| get_timing -rise in load               | => | 0.0820 |
|----------------------------------------|----|--------|
| get_timing -fall in load               | => | 0.0820 |
| get_timing -rise in slew               | => | 0.0000 |
| get_timing -fall in slew               | => | 0.0000 |
| get_timing -rise in arrival            | => | 0.0000 |
| get_timing -fall in arrival            | => | 0.0000 |
| get_timing -rise I_block/A_reg/D slack | => | 2.8584 |
| get_timing -fall I_block/A_reg/D slack | => | 2.8992 |

The following command sets the drive cell on port in for rise:

```
set_drive_cell -cell_rise AN2 -clock CLK1 -from_pin_rise A -pin_fall Z
-rise_source_slew 0.43 in
```

For this example, a two input one output gate is used. Make sure you specify the pin. If an input pin is not specified, the tool picks up the first defined pin in the library for this cell. The drive\_cell assertion specifies the input pin as A and the specific edges that should be used for both the input and output pins to calculate the delay and slew values from the library tables. To understand how slew and delay values are calculated using library tables, see the <u>Calculating Slew and Propagation Delay Values from Non-Linear</u> <u>2D Tables</u> example in the *Common Timing Engine (CTE) User Guide*.

Because the set\_drive\_cell command was set only on the rise, the following command displays a warning for the missing drive\_assertion on the fall:

check\_timing -verbose

+-----+
| TIMING CHECK DETAIL |
|------|
| Pin | Warning |
|-------|
| clkA | No drive assertion |
| clkB | No drive assertion |

The slew value changes from 0.0000 to 0.0720 after setting the drive\_cell assertion. These values will be used only for the rise signal; fall is still 0. These new slew and delay values are calculated from the characterization tables for this cell in the library.

The following commands retrieves the timing information for the specified pin property on the given pin:

| get_timing -f | all in | slew    | => | 0.0000 |
|---------------|--------|---------|----|--------|
| get_timing -f | all in | arrival | => | 0.0000 |

The following commands show the changes in the arrival time, which leads to a change in slack but only on the rise because the set\_drive\_cell command was asserted only for the rising edge:

```
get_timing -rise I_block/A_reg/D slack => 2.7431
get_timing -fall I_block/A_reg/D slack => 2.8992
```

The following command sets the drive cell on port in for fall. If an inverter is used, you do not need to specify the pins. Specific edges are used to avoid any overrides by tool:

```
set_drive_cell -cell_fall IV -clock CLK1 -fall_source_edge R -fall_source_slew
0.35 in
```

Because the set\_drive\_cell command was set for the fall edge, the following check\_timing command will not issue a Missing drive assertion for in:

check\_timing -verbose

```
+---+
TIMING CHECK DETAIL |
|------|
Pin | Warning |
|-----+
ClkA | No drive assertion |
ClkB | No drive assertion |
ClkC | No drive assertion |
ClkD | No drive assertion |
```

The following commands show that the  ${\tt rise}$  values did not change but the  ${\tt fall}$  values did:

| get_timing -rise | e in slew    | => | 0.0720 |
|------------------|--------------|----|--------|
| get_timing -rise | e in arrival | => | 0.0832 |
| get_timing -fall | l in slew    | => | 0.0256 |

get\_timing -fall in arrival => 0.0487
get\_timing -rise I\_block/A\_reg/D slack => 2.7431
get\_timing -fall I\_block/A\_reg/D slack => 2.8421

#### **Related Information**

set drive resistance

set\_slew\_time

# set\_drive\_resistance

```
set_drive_resistance [-clock clk_name] [-lead | -trail | -pos | -neg]
[-rise | -fall] [-early | -late] [-slew_res_value]
[-slew_intrinsic slew_intrinsic_value] value port_list
```

Provides a simpler version of the set\_drive\_cell command used in situations where the drive resistance is specified. Use this command only for timing analysis. This command does not affect the electrical properties of the design, and is also used to specify the drive resistance of a cell. The command computes an offset to the arrival time of an input and also changes the slew time used to compute the delay of the cell on the sink of the net.

The arrival time at the input port is modified by adding the RC constant to the specified arrival time at the input port. The RC constant is the capacitance (C) seen at the input port multiplied by the drive resistance (R). The RC value is used as the slew value for the delay calculation of the next cell.

**Note:** This command overrides a set\_drive\_cell command previously applied to the same port. Also, if the set\_drive\_resistance command is set for a port, the set\_slew\_time command is ignored for that port.

## **Options and Arguments**

| -clock <i>clk_name</i> | Specifies the name of the clock.                                                                                                                                                                                           |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late         | Specifies that the drive resistance should be applied to the early arrival time (data hold time) or late arrival time (data setup time) for timing analysis.                                                               |
| -lead   -trail   -po   | Indicates that the signal at the specified port must be recognized<br>as a data signal with the specified association (lead or trail)<br>with respect to the specified clock <i>clock_name</i> .<br><i>Default</i> : -lead |
|                        | Specifies for a clock signal, -pos and -neg that the slew time should be applied to an actual clock that has positive or negative polarity with respect to the ideal clock waveform. <i>Default</i> : -pos.                |
| port_list              | Lists the ports for which drive resistance is specified.                                                                                                                                                                   |

| -rise   -fall                | Specifies that the drive resistance is applicable to only the rising<br>edge or the falling edge transition at the input port. If neither rise<br>nor fall options are specified then the resistance is applied to<br>both transitions at the input port.   |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -slew_intrinsic <i>slew</i>  | <i>intrinsic_value</i><br>Specifies the intrinsic value of slew used in the slew computation<br>at the input port of the module. The slew value at the input port<br>of the module is computed as follows, assuming cap is the<br>capacitance at this port: |
|                              | slew = slew_intrinsic_value + slew_res_value *<br>cap                                                                                                                                                                                                       |
| -slew_res <i>slew_res_</i> v | value<br>Specifies the value of resistance used in the slew computation at<br>the input port of the module.                                                                                                                                                 |
| value                        |                                                                                                                                                                                                                                                             |

Specifies the resistance value.

# Examples

The set\_drive\_resistance command provides a simpler version of the set\_drive\_cell command used only in STA. The command computes an offset to the arrival time of an input and also changes the slew time used to compute the delay of the cell on the sink of the net.

**Note:** This command overrides a set\_drive\_cell command previously applied to the same port. Also the set\_slew\_time command is ignored for that port.

<u>Current Module and Sub-Modules Example</u> figure on page 874 provides an example of how to use the set\_drive\_resistance command and related commands.

The following are the constraints applied to the design shown in Figure 7-3:

```
set_clock CLK1 -period 3
set_clock_root -clock CLK1 "clkA clkB clkC clkD"
set_input_delay -clock CLK1 0.0 in
set_external_delay -clock CLK1 1.0 out
```

The following command provides a detailed timing report, which shows that no specified drive assertions:

check\_timing -verbose

```
TIMING CHECK DETAIL |
TIMING CHECK DETAIL |
Pin | Warning |
ClkA | No drive assertion |
ClkB | No drive assertion |
ClkC | No drive assertion |
ClkD | No drive assertion |
No drive assertion |
```

The following commands gets the timing information for the specified pin property on the given pin. Specify the pin by the object ID or the hierarchical name:

| get_timing -rise | in load               | => | 0.0820 |
|------------------|-----------------------|----|--------|
| get_timing -fall | in load               | => | 0.0820 |
|                  |                       |    |        |
| get_timing -rise | in slew               | => | 0.0000 |
| get_timing -fall | in slew               | => | 0.0000 |
| get_timing -rise | in arrival            | => | 0.0000 |
| get_timing -fall | in arrival            | => | 0.0000 |
|                  |                       |    |        |
| get_timing -rise | I_block/A_reg/D slack | => | 2.8584 |
| get_timing -fall | I_block/A_reg/D slack | => | 2.8992 |
|                  |                       |    |        |

The following command sets the drive resistance on port in:

```
set_drive_resistance -clock CLK1 -rise -slew_res 0.03 -slew_intrinsic 0.08 0.9
in
```

Because the set\_drive\_resistance command is set using the -rise option, the check\_timing command shows a warning because the drive\_assertion is not also set using the-fall option, as shown in the following report:

The slew value is calculated using the slew\_res, slew\_intrinsic, and load values:

= slew\_intrinsic + (slew\_res \* load)

= 0.08 + (0.03 \* 0.0820)

= 0.082460 rounded to 0.0825

The port delay value is calculated using the load and the set\_drive\_resistance values:

= load \* set\_drive\_resistance\_value = 0.0825 \* 0.9 = 0.0738

The slew value changes from 0.0000 to 0.0825 after setting the drive\_assertion. This is only for the rise signal; fall is still 0.

The following commands gets the values, whose calculations are shown above:

| get_timing | -rise | in | slew    | => | 0.0825 |
|------------|-------|----|---------|----|--------|
| get_timing | -rise | in | arrival | => | 0.0738 |

The following commands show that for fall the value of slew is still 0.0000 because the drive\_resistance is specifically set on rise:

| get_timing | -fall | in | slew    | => | 0.0000 |
|------------|-------|----|---------|----|--------|
| get_timing | -fall | in | arrival | => | 0.0000 |

The following commands show the changes in the arrival time leads to a change in slack but only on the rise, since the set\_drive\_resistance command was asserted only for the rising edge:

get\_timing -rise I\_block/A\_reg/D slack => 2.7478
get\_timing -fall I\_block/A\_reg/D slack => 2.8992

#### **Related Information**

See Explaining Drive Adjustment in the Common Timing Engine (CTE) User Guide.

<u>set\_drive\_cell</u>

<u>set slew time</u>

# set\_external\_delay

set\_external\_delay [-rise | -fall] [-late | -early] [-sig | -ref] [-lead | -trail]
 [-clock clock\_name] [-arrival float] [-source\_insertion\_delay\_included]
 [-network\_insertion\_delay\_included] [-worst\_case] external\_delay
 port\_or\_pin\_list

Provides an alternate way to specify the required time that the output ports must be stable by using external delay requirements. This constraint considers the timing requirement of the configuration of the output port and the connection to the register input of the external block.

When you know the critical path from the output port of the current block to the register of the external block, you can specify required time at the output with this command. The required time is derived from the port and path configuration.

A successive set\_external\_delay assertion on the same output port with respect to the same clock overrides a previous assertion. If multiple set\_external\_delay assertions are used on the same output port, but with respect to different clocks, then the worst case required time is used for timing analysis.

#### **Options and Arguments**

-arrival float

Specifies the actual arrival time of the edge of the clock waveform used to determine the external delay. This is used if the arrival time of the capturing clock signal is different than the arrival time of the corresponding edge of the ideal (or generated) clock. This option is similar to specifying the actual clock arrival time using the <u>set clock insertion delay</u> command in relation to the ideal (or generated) clock signal defined by the set\_clock (or <u>set generated clock</u>) command.

The -arrival option is an archaic method of specifying latency for the clock network for the fictitious flops connected to the output ports. It is used to set the absolute clock arrival time for those flops, which requires you to calculate the clock reference time plus latency along the clock path. With the set\_clock\_insertion\_delay command, only the network latency needs to be given for those clocks. You do not need to do any arithmetic. The -arrival option is still available, and if it is given, this option overrides the set\_clock\_insertion\_delay specification.

| -clock <i>clock_name</i> | Specifies the ideal clock signal that is controlling the external register. A generated clock cannot be used with this option. <i>Default</i> : Asynchronous (@) clock                                                                                |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late           | Specifies that the constraint refers to the early (data hold/clock setup) or late (data setup/clock hold) times. If both -late and -early options are omitted, then the external delay is considered to apply to both early and late times.           |
| external_delay           | Specifies the external delay, including data setup time for the external register.                                                                                                                                                                    |
| -lead   -trail           | Specifies that the leading or trailing edge of the clock waveform controls the external register. If both -lead and -trail options are omitted, the default is lead. If the external register is a latch, the controlling edge is the capturing edge. |
| -network_insertion_de    | elay_included<br>Specifies that network insertion delays are already reflected in<br>the specified input and external delay values.                                                                                                                   |
|                          | When used with the -worsecase option, previously specified network insertion delays on associated clocks are used for the worse casing decision.                                                                                                      |
| -source_insertion_de     | lay_included<br>Specifies that source insertion delays are already reflected in the<br>specified input and external delay values.                                                                                                                     |
|                          | When used with the -worsecase option, previously specified source insertion delays on associated clocks are used for the worse casing decision.                                                                                                       |
| port_or_pin_list         | Specifies the list of output or bidirectional ports or pins. When an external delay is asserted on an internal circuit pin (one that is not an output port), all outgoing signals from the pin are blocked.                                           |

| -rise   -fall | Specifies that the external delay refers to the rising edge or falling edge at the output port. If both -rise and -fall options are omitted, the external delay applies to both the edges at the output port. |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -sig   -ref   | Determines whether the external delay assertion is being applied on a data path $(-sig)$ or a clock network $(-ref)$ . If neither option is given, the default is $-sig$ .                                    |
| -worst_case   | Takes the worst-case delay when multiple external delays for the same clock are specified. Without this option, successive external delays on the same clock overwrite previously asserted values.            |
|               | Worst-case calculation includes clock arrival time as specified by -arrival option. See Examples.                                                                                                             |

**Note:** The -bidi\_input | -bidi\_output options are obsolete for this command. Without the -bidi\_output option, the external delay assertion is made on the output part of bidirectional pins in the *port\_list* by default. An assertion made with the -bidi\_input option is ignored by set\_external\_delay.

# Examples

The following command sets an external delay of 4.1 ns on the output port pout, which is driving the input to a register that is controlled by the leading edge of the clock signal clk.

```
set_external_delay -lead -clock clk 4.1 pout
```

■ The following command shows that the set\_external\_delay has no effect because set\_data\_required\_time was previously specified for the same port:

```
set_data_required_time -clock "*" -lead -late -rise 2.000 {out}
set_external_delay -clock "@" -lead -arrival 0.000 -sig -late -rise 4.000
{out}
```

■ The following command shows the behavior of -worst\_case option when the -arrival option is specified and when it is not:

```
set_external_delay -clock CLK -worst_case -arrival 3 5 out
```

- □ For late analysis, if 5-3 (external delay arrival) is greater than what was previously given (or stored), then these values will replace the stored values. Otherwise they are ignored for late analysis.
- For early analysis, if 5-3 (external delay arrival) is less than what was previously given (or stored), then these values will replace the stored values. Otherwise they are ignored for early analysis.

Without the -arrival option, worst-case calculation is more straightforward:

set\_external\_delay -clock CLK -worst\_case 5 out

- □ For late analysis, if the given external delay is greater than the stored value, then it replaces the stored value.
- □ For early analysis, if the given external delay is less than the stored value, than it replaces the stored value.



Without the <code>-early</code> or <code>-late</code> options, the above worstcasing applies to both early and late analysis. So be careful. Avoid confusion by specifying <code>-early</code> or <code>-late</code> options whenever you specify the <code>-worst\_case</code> option. See the next example.

■ The following command shows the result of using -early and -late options with the -worst\_case option. The initial value is set as follows:

set\_external\_delay 2 -clock clk port1

By default, the value 2 applies to both early and late analysis.

If the subsequent assertion is applied to late analysis:

set\_external\_delay 1 -late -clock clk port1 -worst\_case

The stored value (2) is retained because the given value (1) is not greater than the stored value.

However, if the subsequent assertion is applied to early analysis:

set\_external\_delay 1 -early -clock clk port1 -worst\_case

The stored value (2) is replaced by the given value (1) because the given value is less than the stored value.

#### **Related Information**

<u>set clock</u>

set\_data\_required\_time

<u>remove\_assertions</u>

See <u>Setting External Delay at Clock Output Ports</u> in the *Common Timing Engine (CTE) User Guide* for more information.

# set\_false\_path

```
set_false_path [{-from | -from_rise | -from_fall} pin_list]
  [{-through | -through_rise | -through_fall} pin_list]
  [{-to | -to_rise | -to_fall} pin_list]
  [-clock_from clk_signame]
  [-edge_from {leading | trailing}] [-clock_to clk_signame]
  [-edge_to {leading | trailing}] [-early | -late]
  [-bidi_input_from | bidi_output_from]
  [-bidi_input_through | -bidi_output_through]
  [-bidi_input_to | bidi_output_to] [-reset_path] [-hold | -setup]
```

Identifies false paths in a design, and breaks or disables specific instance timing arcs in a design. Path exceptions between clock domains are accepted.

If both the <code>-from</code> and <code>-clock\_from</code> options are specified, the path exception applies to all paths starting from the <code>-from</code> pin and all the paths starting from the <code>-clock\_from</code> signal. If both the <code>-to</code> and <code>-clock\_to</code> options are specified, the path exception applies to all the paths ending at the <code>-to</code> pin and all the paths ending at the <code>-clock\_to</code> signal. As shown in the following example, when the output of the <code>ff1</code> flip-flop is connected to the inputs of two other flip-flops (ff2 & ff3) all paths for the <code>-clock\_from clk1</code> will be set as <code>false</code>:

set\_false\_path -from ff1/Q -to ff2/D -clock\_from clk1

If both the <code>-through</code> and <code>-clock\_from</code> options are specified, the path exception applies to all paths starting from the <code>-clock\_from</code> signal and going through the <code>-through</code> pin (AND operation). If both the <code>-through</code> and <code>-clock\_to</code> options are specified, the path exception applies to all paths going through the <code>-through</code> pin and ending at the <code>-clock\_to</code> signal.

# Important

To break combinational loops, use the set\_disable\_timing command (see set disable timing on page 1153) instead of the set\_false\_path command.

The set\_false\_path command differs from the set\_disable\_timing command as follows:

- set\_false\_path command selectively disables the arrival time information depending
  upon the precedence rules.
- set\_false\_path command does not affect constant values.
- set\_disable\_timing command physically snips a timing arc such that neither arrival times nor constant values propagate through it.

The set\_false\_path -from fpin command disables all timing arcs whose source pin is an fpin. Similarly, the set\_false\_path -to tpin command disables all timing arcs

whose sink pin is a tpin. Using the set\_false\_path -from fpin -to tpin command disables all timing arcs whose source is fpin and sink is tpin.

Specify a group of pins by enclosing the group with curly braces ({}) within one set\_false\_path command.

- Tip

To set a false path for any path beginning at p1 or p2 and terminating at t1 or t2, group the pins as follows:

set\_false\_path -from {p1 p2} -to {t1 t2}

**Note:** This method of pin grouping reduces the number of exceptions. Having large numbers of exceptions adversely impacts the run time of the <code>report\_timing</code> command.

## **Options and Arguments**

-bidi input from | -bidi output from Specifies the assertion on the input or output part of the from pin. Default value is shown in "Bidirectional Pin Defaults" on page 799. -bidi input through | -bidi output through Specifies the assertion on the input or output part of the through pin. Default value is shown in "Bidirectional Pin Defaults" on page 799. -bidi\_input\_to | -bidi\_output\_to Specifies the assertion on the input or output part of the to pin. Default value is shown in "Bidirectional Pin Defaults" on page 799. -clock from clk signame Specifies the starting point of the false paths. The clk signame argument is the name of the ideal (or generated) clock signal (waveform). If the -clock from option is omitted then the path exception applies to all the paths ending at the registers clocked by the

| -clock_to clk_signa            | ne<br>Specifies the endpoint of the false paths. The <i>clk_signame</i><br>argument is the name of the clock signal (waveform). The path<br>exception applies to all paths starting from the <i>-clock_from</i><br>signal and ending at the registers clocked by <i>-clock_to</i> signal. |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | If the -clock_to option is omitted then the path exception applies to all paths starting at the registers clocked by the -clock_from signal.                                                                                                                                              |
|                                | Do not use the -to and clock_to options together.                                                                                                                                                                                                                                         |
| -early   -late                 | If neither the -early nor the -late options are specified then<br>it is assumed to be both early and late (hold and setup for data<br>paths). This only applies to the -to side if the -to <i>pin_list</i><br>is present. It applies to the -from side in other case.                     |
| <pre>-edge_from {leading</pre> | <pre>  trailing} Specifies whether the triggering (launching) edge of the clock is a leading or a trailing edge. It should match the edge used in the timing check for the destination register. Default: leading edge</pre>                                                              |
| -edge_to {leading              | trailing}<br>Specifies whether the capturing edge at the destination register<br>is a leading or a trailing edge.<br><i>Default</i> : leading edge                                                                                                                                        |
| {-from  -from_rise             | -from_fall} pin_list }<br>Specifies the pins that are at the start of the false paths. If the<br>-from option is used without the -to option, all paths originating<br>from the pin_list are false paths.                                                                                 |
|                                | Either -from, -to, or -through must be used with the set_false_path command to identify the paths. Specifying both -from and -to identifies a path with specific starting and ending points.                                                                                              |
|                                | The <i>pin_list</i> can contain either object IDs or hierarchical names relative to the current module. The pins can be on intermediate hierarchical boundaries. Leaf design cells                                                                                                        |

|                      | (instances) can also be specified as the object for the <pre>-from*</pre> options.                                                                                                                                                                                                  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Use only one -from (or -from_rise or -from_fall) option per command.                                                                                                                                                                                                                |
|                      | By default, $-from$ applies the assertion to both the rising and the falling edges.                                                                                                                                                                                                 |
|                      | Using -from_rise applies the assertion at the rising edge of the signal on the from pins.                                                                                                                                                                                           |
|                      | Using -from_fall applies the assertion at the falling edge of the signal on the from pins.                                                                                                                                                                                          |
| -hold   -setup       | Specifies the early (hold) or late (setup) mode with PT syntax.                                                                                                                                                                                                                     |
| -reset_path          | Changes the constraint on the specified path to the new value.<br>See Examples.                                                                                                                                                                                                     |
| {-through   -through | rise   -through_fall} pin_list<br>Specifies the pins that the path goes through. When used<br>without the -from or -to options, all paths that go through the<br>-through pins are false paths.                                                                                     |
|                      | When used with both the -from and -to options, any path starting at any pin on the -from list <i>and</i> going through any point on the -through pin list <i>and</i> going to any point on the -to list is affected by the assertion.                                               |
|                      | The <i>pin_list</i> variable can contain either object IDs or<br>hierarchical names relative to the current module. The pins can<br>be on intermediate hierarchical boundaries.There can be only<br>one -from and one -to, option but many -through options in<br>the same command. |
|                      | By default, the -through option applies the assertion to both the rising and the falling edges. The -through pin_list can be a list of pin names, ID, or a collection of pins.                                                                                                      |

|                      | Using the -through_rise option applies the assertion at the rising edge of the signal on the through pins.                                                                                                                                                                   |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Using the -through_fall option applies the assertion at the falling edge of the signal on the through pins.                                                                                                                                                                  |
| {-to   -to_rise   -t | Specifies the pins that are at the end of the false paths. If the -to option is used without the -from option, all paths ending in the -to pin list are false paths.                                                                                                         |
|                      | The $pin_{list}$ variable can contain either object IDs or<br>hierarchical names relative to the current module. The pins can<br>be on intermediate hierarchical boundaries. Leaf design cells<br>(instances) can also be specified as the object for the $-to*$<br>options. |
|                      | Use only one -to (or -to_rise or -to_fall) option per command.                                                                                                                                                                                                               |
|                      | By default, the $-to$ option applies the assertion to both the rising and the falling edges.                                                                                                                                                                                 |
|                      | Using the -to_rise option applies the assertion at the rising edge of the signal on the to pins.                                                                                                                                                                             |
|                      | Using the -to_fall option applies the assertion at the falling edge of the signal on the to pins.                                                                                                                                                                            |

Note: Only internally generated scripts such as the write\_assertions command uses -rise and -fall as options. Use [-from\_rise | -from\_fall] and [-to\_rise | -to\_fall] options.

# Examples

■ The following command sets all paths from port Q of instance I1 to false paths:

```
set_false_path -from I1/Q
```

■ The following command specifies that all paths ending in port A of instance 12 are considered false paths:

```
set_false_path -to I2/A 1
```

■ The following command makes the path from port Q of instance I1 to port A of instance I2 into a false path:

set\_false\_path -from I1/Q -to I2/A 2

The following command resets all path exceptions on the specified path, then applies the new assertion:

```
set_false_path -reset_path -from A =
reset_path -from A
set_false_path -from A
```

Using the -reset\_path option changes the constraint on the specified path to the new value. However, if there is only one path and both paths are equivalent, using this option resets a path only when there is an exact match in the arguments. For example, the following command specifies the delay as U14/A 5:

set\_fale\_path -through U14/A 5

The following shows the report using this command:

| +       |       | +       |
|---------|-------|---------|
| Through | Early | Late    |
|         | +     | +       |
| U14/A   |       | delay 5 |
| +       |       | +       |

If you then change the constraint to a new value using the -reset\_path option on the same path, but use a different argument as follows:

set\_false\_path -through U12/Z 7 -reset\_path

The report using the report\_path\_exceptions command or the report\_timing command shows the following:

| +              | Early | Late                       |
|----------------|-------|----------------------------|
| U12/Z<br>U14/A |       | delay 7 ignored<br>delay 5 |

Using the -reset\_path option resets a path only when there is an exact match in the arguments, not when both the constraints represent the same path.

#### **Related Information**

reset path exception

set constant for timing

set cycle addition

set\_disable\_cell\_timing

<u>set disable timing</u>

set path delay constraint

# set\_fanout\_load\_limit

set\_fanout\_load\_limit float [-module module\_list] [-port port\_list]

Specifies the fanout load limit (maximum value) on the output ports and the input ports of a top level module. Fanout load limits are only used to enforce the design rule checks, they do not affect timing analysis. Setting port capacitance limit affects timing analysis.

The design rule requirement of a maximum fanout load value is set using the set\_global
fanout\_load\_limit global. For the specified ports, the set\_fanout\_load\_limit
global overrides the global default fanout load limit.

#### **Options and Arguments**

| float               | Specifies the fanout load limit on the ports.                                                                                  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------|
| -module module_list | Specifies the list of modules to which the limit applies. All instances of the specified modules will inherit the limit value. |
| -port port_list     | Specifies the list of top level ports for which the fanout load limit applies.                                                 |

#### Examples

set\_fanout\_load\_limit 4 [find -port -output data\*]
set\_fanout\_load\_limit 3 [find -port -input reset]

#### **Related Information**

<u>get\_fanout</u>

set\_current\_module

<u>set global max fanout load limit</u>

# set\_flow\_compatible\_mode

#### set\_flow\_compatible\_mode [ on | off ]

Controls the interpretation of constraints during timing analysis. Setting this command to on makes the interpretation of constraints compatible with Synopsys PrimeTime. The <u>read dc script</u> command automatically sets the set\_flow\_compatible\_mode command to on. The write\_assertions and write\_adb commands writes the set\_flow\_compatible\_mode command as part of the assertions.

Default: off

# Important

Constraints must be interpreted in one style from start to finish. Do not change the interpretation style in the middle of a run. Decisions that are made when using the read\_dc\_script command are not reversible by simply changing the set\_flow\_compatible\_mode command. One example is multiple constraints (such as the set\_input\_delay command) on the same ports. In PT style, the latest constraints override any previous ones and overwritten constraints are thrown away. In CTE style, the worst case is taken among all the constraints. Once the original constraints are gone, you can no longer do the worst casing in CTE style. Therefore, it's best to describe constraints in one style.

# **Options and Arguments**

off

Interprets constraints in the CTE style.

on

Interprets constraints in the Synopsys PrimeTime style.

#### **PrimeTime Interpretation of Constraints**

- False paths and multicycle paths originating from or terminating at invalid path start and end points are ignored.
- Multicycle paths on late paths will imply a hold constraint.
- The last assertion overwrites previous ones when multiple assertions of the same type exist on the same start and end points.

#### Valid Start Points for False Paths and Multicycle Paths

- Input port
- Input part of bidirectional port
- Clock pin of sequential cell
- Pin associated with the set\_input\_delay command
- Pin associated with the set\_path\_delay -from command

#### Valid End Points for False Paths and Multicycle Paths

- Output port
- Output part of bidirectional port
- Data pin of sequential cell
- Pin associated with set\_external\_delay
- Pin associated with set\_path\_delay -to

#### Examples

Use the set\_flow\_compatible\_mode command before reading in the constraints and do not change it in the middle of a run.

- The following command loads libraries: read\_tlf lib.tlf
- The following command reads a netlist:

```
read_verilog design.v
do_build_generic
```

- The following command interprets constraints in Synopsys PrimeTime style: set\_flow\_compatible\_mode on
- The following command reads constraints: source design.asrt
- The following command verifies timing: report\_timing
- The following flow is not supported: read\_tlf lib.tlf

```
    read_verilog design.v
do_build_generic
    The following command interprets constraints in PrimeTime style:
set_flow_compatible_mode on
source pt.asrt
    The following command interprets constraints in CTE style:
set_flow_compatible_mode off
source bgpks.asrt
```

report\_timing

## **Related Information**

get flow compatible mode

# set\_functional\_mode

set\_functional\_mode [-group group\_name] [-mode mode\_name] instance\_list

Sets the DCL or the STAMP functional mode by group and name on hierarchical instances. Determine what modes are available for an instance using the <code>report\_functional\_mode</code> command.

Once the *mode\_name* variable is set, all other modes in the *group\_name* variable become inactive and stay inactive unless they are explicitly set later.

The following form of the command makes all modes in all mode groups in the *instance\_list* variable active.

set\_functional\_mode instance\_list

While this form of the command makes all modes in the *group\_mode* variable in the *instance\_list* variable active.

set\_functional\_mode -group group\_mode instance\_list

#### **Options and Arguments**

| -group group_name      | Specifies the string value of the functional mode group name. <i>Default</i> : All groups |
|------------------------|-------------------------------------------------------------------------------------------|
| instance_list          | Specifies the list of instances for which the functional mode needs to be set.            |
| -mode <i>mode_name</i> | Specifies the string value of the functional mode name. <i>Default</i> : All modes        |

#### Example

set\_functional\_mode -group rw -mode read {A1/B3/C2 A1/B2/C2}

#### **Related Information**

#### report\_functional\_mode

reset functional mode

# set\_generated\_clock

```
set_generated_clock [-name clock_signame] [-from source_pin]
   ([-multiply_by integer] | [-divide_by integer]) [-edges edge_list]
   [-edge_shift edge_shift_list] [-duty_cycle percent] [-neg] target_pin_list
   [-master_clock] [-bidi_input_from | -bidi_output_from bidi port]
   [-bidi_input | -bidi_output bidi port] [-add] [-invert]
```

Creates a new clock signal from the clock waveform of a given pin in the design, or an existing virtual (ideal) clock signal, and binds it with the pins in the  $target_pin_list$  argument. Whenever the source clock changes, the derived clock(s) change automatically.



If you need to change the default for the generated\_clocks\_scale\_edge global, set it at the beginning of the session. Otherwise existing clocks are not updated.

Generate the new clock waveform by one of three ways:

- Multiplying the frequency of the source clock
- Dividing the frequency of the source clock
- Selecting the edges of the source clock to be mapped on to the edges of the new clock

For examples and information about assertions on generated clocks, <u>Specifying Generated</u> <u>Clocks</u> in the Common Timing Engine (CTE) User Guide.

**Note:** A set\_generated\_clock assertion on a pin overrides any existing set\_generated\_clock assertion if both the assertions have the same from pin or if the from pins are not specified (no -from option). For example, in the first and second command pairs below, the second assertion overwrites the first, while in the third and fourth pairs, both assertions are applied:

```
set_generated_clock -name GCK1 -from CK -divide_by 2 U_FD1/Q
set_generated_clock -name GCK2 -from CK -multiply_by 2 U_FD1/Q
set_generated_clock -name GCK1 -divide_by 2 U_FD1/Q
set_generated_clock -name GCK1 -from CK -divide_by 2 U_FD1/Q
set_generated_clock -name GCK2 -multiply_by 2 U_FD1/Q
set_generated_clock -name GCK1 -divide_by 2 U_FD1/Q
set_generated_clock -name GCK1 -divide_by 2 U_FD1/Q
set_generated_clock -name GCK1 -divide_by 2 U_FD1/Q
```

# **Options and Arguments**

| -add                      |                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | Models multiple generated clocks on the same source when<br>multiple clocks must fan into the source pin. Ideally, one<br>generated clock must be specified for each clock that fans into<br>the master pin. Specify this option with the -name and<br>-master_clock options.                                                                                                                                      |
|                           | By default, CTE creates one generated clock at the pin for each clock present on the source pin. However, this option lets you specify a different clock name for each generated clock when used with the <code>-master_clock</code> option. Subsequently, you can use this clock name for setting other constraints such as the <code>set_false_path</code> command and the <code>set_input_delay</code> command. |
| -bidi_input   -bidi_      | output <i>bidi port</i><br>Places the assertion on the input or the output bidirectional port<br>of the target pin.<br><i>Default</i> : -bidi_input                                                                                                                                                                                                                                                                |
| -bidi_input_from   -      | <pre>bidi_output_from bidi port Places the assertion on the input or the output bidirectional port of the source pin. Default: -bidi_output_from</pre>                                                                                                                                                                                                                                                             |
| -divide_by <i>integer</i> | Determines the frequency of the new clock by dividing the frequency of the source clock by $dfactor$ . For example, if $dfactor=5$ , the new frequency is 1/5 of the source frequency, and the new clock period is 5 times the source clock period.                                                                                                                                                                |
| -duty_cycle percent       | Sets the duty cycle (high pulse width or clock period).                                                                                                                                                                                                                                                                                                                                                            |
|                           | Use the -duty_cycle option only with the-multiply_by option.                                                                                                                                                                                                                                                                                                                                                       |
|                           | The number ( <i>percent</i> ) is between 0 and 100. For example, if <i>percent</i> =50, the high pulse width of the new clock waveform is the same as its low pulse width.                                                                                                                                                                                                                                         |

| -edges <i>edge_list</i>    | Selects a list of edges from the source clock that form the edges<br>of the derived clock. Currently, three edge numbers are allowed.<br>See the frequency division example below.                                                                                                                                                                                                                                                                                          |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -edge_shift <i>edge_sh</i> | <pre>ift_list Specifies the amount of shift for each edge in the edge_list option. See Example on page 1192.</pre>                                                                                                                                                                                                                                                                                                                                                          |
| -from <i>source_pin</i>    | Specifies the name of the source pin from which the new clock is<br>to be derived. If no from pin is specified, the clock is derived from<br>the clock arriving on the target pin.                                                                                                                                                                                                                                                                                          |
| -invert                    | Inverts the source clock. Use with the -from option and the -multiply_by or -divide_by options. Since virtual clocks do not have polarity, the -invert option has no impact when used with the -clock_from option.                                                                                                                                                                                                                                                          |
| -master_clock              | Generates a target clock. If you specify the -master_clock<br>option and multiple signals arrive at the target pin, the clock<br>specified by this option is used to generate the target clock. If you<br>do not specify this option, multiple target clocks are generated.                                                                                                                                                                                                 |
|                            | Specifying the -name option lets the set_input_delay command and the set_external_delay command use a generated_clock as a reference clock. For example:                                                                                                                                                                                                                                                                                                                    |
|                            | set_generated_clock-from IV/A-divide_by 1-name<br>gclk IV/Y                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                            | set_input_delay -clock gclk 3.0 in1<br>set_external_delay -clock gclk 2.0 out1                                                                                                                                                                                                                                                                                                                                                                                              |
|                            | Use the name option to pick the source of the generated clock.<br>For example, consider a 2 input mux input with clk1 on A and clk2<br>on B. Let the mux drive an inverter with a generated clock at the<br>output. Selecting the -master option creates a generated clock<br>based on the selected master clock. If the -master option is not<br>specified, then two clocks are generated at the output of the<br>inverter. For example, -master clk1 -divide_by 2 creates |

a generated\_clock on the inverter output based on clk1. If a master clock is not specified, then two clocks are generated at the output: one is derived from clk1 and the other from clk2.

-multiply\_by integer

Determines the frequency of the new clock by multiplying the frequency of the source clock by mfactor. For example, if mfactor=4, the new frequency is 4 times the source frequency, and the new clock period is 1/4 of the source clock period.

-name clock\_signame

Specifies the name for the generated clock. *Default*: The system creates a name for you.

Tip

Always specify a name for the generated clock. Some commands issue an error if you use the system-generated name. See" <u>Creating a Generated Clock</u>" of set\_generated\_clock in the Common Timing Engine (CTE) User Guide.

-neg

Inverts the source clock. Use with the <code>-from</code> option and the <code>-multiply\_by</code> or <code>-divide\_by</code> options. Since virtual clocks do not have polarity, the <code>-neg</code> option has no impact when used with the <code>-clock\_from</code> option.

target\_pin\_list

Specifies the list of pins where the generated clock assertion is applied. The clock signal propagating downstream from each of these pins becomes associated with the generated clock.

#### Examples

■ The following command generates the derived clock waveform, as shown in Figure 7-13: set\_generated\_clock -name mult\_3 -from pinX -multiply\_by 3 -duty\_cycle 50 pinY





This derives a clock with a clock period =1/3 of the source period, and duty cycle=50 percent as shown in Figure 7-15 on page 1189.

The following command shows one way to create a divide-by-3 clock by using edge numbers of the source waveform to specify the new waveform, as shown in Figure 7-14,:

set\_generated\_clock -name genclk -from pinX -edges {1 5 7} pinY

#### Figure 7-14 Derived Clock (Frequency Division)



■ The following command uses the -divide\_by option to get the same clock period; the difference is in the duty cycle:

set\_generated\_clock -name div\_3 -from pinX -divide\_by 3 pinY

With the -edges option, the above example creates a clock with a duty cycle of 67 percent (20/30). But  $-divide_by$  3 would preserve the 50 percent duty cycle of the source clock as shown in Figure 7-15.





=`\_\_\_́ *Tip* 

Use the <code>-duty\_cycle</code> option only with the <code>-multiply\_by</code> option. To set the duty cycle to any other number, use the <code>-edge\_shift</code> option to exactly determine where the fall edge should be as shown in the following example.

The following command uses edge shifts to create the 33 percent (10/30) duty-cycle waveform, as shown in Figure 7-16:

```
set_generated_clock -name foo -from pinX -edges {1 5 7} -edge_shift {0 -10 0}
pinY
```

## Figure 7-16 Derived Clock (Frequency Division, 33% Duty-cycle)



■ Using the following commands, when there is more than 1 source clock, the tool creates the generated clock based on the source clock specified with the -master option:

```
set_clock c1 -p 10
set_clock c2 -p 10
set_clock_root -clock c1 ck
set_clock_root -clock c2 ck
set_generated_clock -name newclk -from ck -divide_by 2 -pos -master c1 reg/Q
```

Using the report\_clocks command, the output waveform of the newclk clock is a divide-by-2 of the cl clock, and is reported as shown in Example 7-4.

### Example 7-4 report\_clocks after using the -master option

+-----+
Clock Descriptions
Clock | Period | Lead | Trail
Name
Clock | Period | Lead | Trail
Clock | 20.0000 | 0.0000 | 5.0000
Clock | 20.0000 | 0.0000 | 10.0000
Clock | Cloc

## **Related Information**

<u>get\_clock</u>

<u>report clocks</u>

<u>reset\_generated\_clock</u>

<u>set\_clock</u>

<u>set clock root</u>

## set\_ideal\_net

Specifies the delay and load that CTE uses for the net.

An ideal net is a net with no delay and no load. The set\_ideal\_net command expands that idea to let you specify the delay and load that CTE uses for the net. That is, the net load and delay seen by all pins on the net.

There are times in the physical implementation that the routing cannot be accurately modeled. An example of the type of routed net that cannot be modeled accurately is a spine with uniform length connections from the spine to all leaf pins. For high fanout nets (most commonly along a clock spine) the delays can be 300 percent or more off if you do not specify them as ideal nets. Use the set\_ideal\_net command for both preplacement and post placement.

CTE does not perform wire-load model (WLM) or Steiner lookup on ideal nets. The ideal net specification wins over parasitics. Uniquify copies net level assertions.

The set\_ideal\_net command has no effect on ideal clock networks. For ideal clock networks, the delays of gates and interconnects are idealized (delays = 0, slewout = slewin). On data networks and on clock networks in propagated mode, use this command to model the desired behavior.

## **Options and Arguments**

| -delay <i>net_delay</i> | Specifies the delay associated with the net. Every source-sink pin pair has the same delay. The $net\_delay$ variable is a floating number.<br>Default: 0.0               |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -load net_load          | Specifies the total capacitance that each driver of the net sees, including all pin capacitances. The <i>net_load</i> variable is a floating number. <i>Default</i> : 0.0 |
| net_name_or_id          | Specifies one or more net names (or ids) that are to be considered ideal nets.                                                                                            |

-slew\_degradation sink\_slew

Specifies the slew degradation at every sink pin. The specified slew value is added to the slew arriving at the source pin to yield the slew at the sink pin. If this option is not used, the slew at the sink pin is equal to the slew at the source pin.The *sink\_slew* variable is a floating point number. *Default*: 0.0

## Example

The following command specifies the delay associated with the net:

```
set_ideal_net -delay 0.2 {clk1 clk2}
```

## **Related Information**

<u>report net</u>

reset\_ideal\_net

See <u>Specifying Ideal Nets</u> in the Common Timing Engine (CTE) User Guide.

# set\_input\_delay

```
set_input_delay [-early | -late] [-rise |-fall] [-clock clock_name]
      [-lead |-trail] [-source_insertion_delay_included]
      [-network_insertion_delay_included] [-worst_case] float port_or_pin_list
```

Sets input path delay values on input ports or internal input pins. This input path delay models the delay from an external register to an input port of the module. The set\_input\_delay command differs from dc\_shell in that the -min and -max options are replaced by the -early and -late options. The justification is that there could be multiple paths between the fictitious register and the input port. The -early and -late options properly capture the difference in delays for these paths.

**Note:** The set\_input\_delay command replaces the set\_data\_arrival\_time command.

### **Options and Arguments**

| -clock <i>clock_name</i> | Specifies the name of the ideal clock. A generated clock cannot be used with this option. Default is the asynchronous clock.                                                                                                                         |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -clock <i>clock_name</i> | Specifies the name of the ideal clock. A generated clock cannot be used with this option. <i>Default</i> : Asynchronous (@) clock.                                                                                                                   |
| -early   -late           | Specifies that the constraint refers to the early (hold) or late (setup) times of the data signal. If both <code>-late</code> and <code>-early</code> options are omitted, then the input delay is considered to apply to both early and late times. |
| float                    | Specifies the delay value.                                                                                                                                                                                                                           |
| -lead   -trail           | Specifies that the input delay is with respect to the leading or the trailing edge of the clock. If neither option is provided, the default is $-lead$ .                                                                                             |
| -network_insertion_de    | elay_included<br>Specifies that network insertion delays are already reflected in<br>the specified input and external delay values.                                                                                                                  |

|                      | When used with the -worst_case option, previously specified network insertion delays on associated clocks are used for the worse casing decision.                                                                                                                                         |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| port_or_pin_list     | Specifies a single input port or pin or multiple ports or pins to which the input delay applies. To specify multiple ports or pins, enclose the list with curly braces ({)} and separate the port or pin information with white space.                                                    |
|                      | When an input delay assertion is present on an internal circuit pin (one that is not an input port), all incoming signals to the pin are blocked.                                                                                                                                         |
| -rise   -fall        | Specifies that the input delay refers to the rising edge or falling edge at the input port/pin. If both -rise and -fall options are omitted, the input delay applies to both the edges.                                                                                                   |
| -source_insertion_de | lay_included<br>Specifies that source insertion delays are already reflected in the<br>specified input and external delay values.                                                                                                                                                         |
|                      | When used with the -worst_case option, previously specified source insertion delays on associated clocks are used for the worse casing decision.                                                                                                                                          |
| -worst_case          | Takes the worst-case delay when multiple input delays for the same clock are specified. Without this option, successive input delays on the same clock overwrite previously asserted values.                                                                                              |
| The-bidi_input   -b: | idi_output options are obsolete for this command. Without the<br>-bidi_input option, the input delay assertion is made on the<br>input part of bidirectional pins in the <i>port_list</i> by default. An<br>assertion made with the -bidi_output option is ignored by<br>set_input_delay. |

#### Examples

■ The following command specifies the name of the ideal clock, specifies that the constraint refers to the early (hold) time of the data signal, and specifies that the input delay refers to the rising edge at the input port/pin:

set\_input\_delay -clock CLK -early -rise -0.05 [ find -inputs ]

■ The following command specifies the name of the ideal clock, specifies that the constraint refers to the late (setup) time of the data signal, and specifies that the input delay refers to the falling edge at the input port/pin:

set\_input\_delay -clock CLK -late -rise 0.05 [ find -inputs ]

■ The following command specifies the name of the ideal clock, specifies that the constraint refers to the early (hold) time of the data signal, and specifies that the input delay refers to the falling edge at the input port/pin:

set\_input\_delay -clock CLK -early -fall 0.15 [ find -inputs ]

■ The following command specifies the name of the ideal clock, specifies that the constraint refers to the late (setup) time of the data signal, and specifies that the input delay refers to the falling edge at the input port/pin:

set\_input\_delay -clock CLK -late -fall 0.25 [ find -inputs ]

■ The following commands reference an input\_delay to a generated clock:

set\_clock sysclk -waveform "0 0.5" -period 1.0
set\_clock\_root -clock sysclk -pos clk
set\_generated\_clock -from clk -divide\_by 2 -name genclk clkbuf/Y
set\_input\_delay -clock sysclk -worst\_case 0 in
set\_input\_delay -clock genclk -worst\_case 0 in

### **Related Information**

remove assertions

<u>reset\_input\_delay</u>

set clock insertion delay

<u>set external delay</u>

# set\_max\_delay

set\_max\_delay

Not an ac\_shell command, use set\_path\_delay\_constraint instead.

See set path\_delay\_constraint on page 1230.

# set\_min\_delay

set\_min\_delay

Not an ac\_shell command, use set\_path\_delay\_constraint instead.

See set path\_delay\_constraint on page 1230.

### set\_mp\_area

set\_mp\_area value

Specifies the estimated area of the module in square microns. The estimate represents a composite result for the block as a whole.

### **Options and Arguments**

value

Specifies the area of the module in square microns, which must be a number.

### Example

The following command sets the area of the Module Prototype to 10.7:

set\_mp\_area 10.7

## set\_mp\_global\_parameter

set\_mp\_global\_parameter

```
[-param {clk_to_output | setup | hold | recovery | removal |no_change_setup
|no_change_hold | period | min_pulse_width_low | min_pulse_width_high |
skew}] [-lib_cell cell_name] [-pin pin_name] [-clock pin_name]
[value parameter_value]
```

Sets base values for sequential delays and constraint arcs (all other parameter types). These values are used by the <u>create mp delay arc</u> command for edge based arcs (clk\_to\_output param type) or by the <u>create mp constraint arc</u> command (all other parameter types). The base value is either found by identifying an arc in the reference cell or by a given, explicit value. Use the <u>create mp model</u> command to reset the global parameters.

## **Options and Arguments**

| -clock pin_name            | Specifies the reference pin for a sequential delay or a constraint arc.                                                                                                                                                                                                                                                                       |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -lib_cell <i>cell_name</i> | Specifies a cell in the reference library used for sequential information.                                                                                                                                                                                                                                                                    |
| -param                     | Specifies which global parameter will be set. If it is the<br>clk_to_output option, the global parameter will be added to<br>all edge delay arcs. Other param types select a specific<br>constraint arc.                                                                                                                                      |
| -pin pin_name              | Specifies the non-reference pin for a sequential delay or a constraint arc.                                                                                                                                                                                                                                                                   |
|                            | The <i>pin_name</i> is the name of a single pin the a reference cell.<br>Bus names or bus ranges are not allowed. The current name<br>space is used for special character escaping. See <u>Pin Names</u> in<br>the "Using the Module Prototyper (MP)" section in the <i>Common</i><br><i>Timing Engine</i> ( <i>CTE</i> ) <i>User Guide</i> . |
| -value parameter_va        |                                                                                                                                                                                                                                                                                                                                               |
|                            | Specifies a constant sequential value, which can be a single number or an SDF style triplet.                                                                                                                                                                                                                                                  |

### Examples

- The following command sets a delay time of 1 that will be added to all edge delay arcs: set\_mp\_global\_parameter -param clk\_to\_output -value 1
- The following command sets the base setup check time to 4:

set\_mp\_global\_parameter -param setup -value 4

■ The following command sets the base hold time to be the same as for the hold time between pins D and cp in the jk01d2 reference cell:

set\_mp\_global\_parameter -param hold -lib\_cell jk01d2 -pin D -clock cp

### **Related Information**

create mp path type

create\_mp\_constraint\_arc

## set\_mp\_max\_fanout\_limit

```
set_mp_max_fanout_limit
    [-value port_limit_value] [-port port_list]
```

Sets the maximum fanout limit for ports.

### **Options and Arguments**

-port port\_list

Specifies the name of the affected ports. They must be output or inout ports. If the *port\_list* argument is not specified, all output or inout ports will be affected.

The port\_name\_list can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

```
-value port_limit_value
```

Specifies the maximum fanout value, which can be either a single number or an SDF triplet.

## Examples

- The following command sets the maximum fanout limit on port Z to 8: set mp max fanout limit -value 8 Z
- The following command sets the maximum fanout limit on ports Q and QN to 8: set\_mp\_max\_fanout\_limit -value 8 {Q QN}

### **Related Information**

<u>set mp port drive</u>

<u>set mp technology</u>

## set\_mp\_min\_fanout\_limit

```
set_mp_min_fanout_limit
    [-value port_limit_value] [-port port_list]
```

Defines the minimum fanout for ports.

### **Options and Arguments**

-port port\_name\_list

Specifies the name of the affected ports. They must be output or inout ports. If this option is not specified, all output and inout ports will be affected.

The port\_name\_list can be either a single name or a list of names in curly braces. Each name may be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

```
-value port_limit_value
```

Specifies the minimum fanout value, which can be either a single number or an SDF triplet.

## Examples

■ The following command sets the minimum fanout limit on port z to 8:

```
set_mp_min_fanout_limit -value 8 Z
```

The following command sets the minimum fanout limit on ports Q and QN to 8: set\_mp\_min\_fanout\_limit -value 8 {Q QN}

## **Related Information**

<u>set mp\_port\_drive</u>

<u>set mp technology</u>

## set\_mp\_port\_drive

set\_mp\_port\_drive
 [-type drive\_type] [-value port\_limit\_value] port\_name\_list

Specifies the driver strength (resistance) for each of the specified output or inout ports. If you do not specify any ports, this command applies to all output or inout ports. All delay arcs to these ports will be affected. If you specify more than one set\_mp\_port\_drive command for the same port, the last one specified before using the <u>create mp\_delay\_arc</u> command creates a given timing arc to the port is used in the model for that arc.

By default, only the delay arcs to this port are affected. If a reference type is used and the <u>set mp technology</u> -inherit\_port\_limits on command was used, then any port limits on the reference pin will be copied to the ports.

### **Options and Arguments**

| port_name_list      | Specifies the name of the ports. If missing, then all output and inout ports are affected.                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                     | The port_name_list can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the <i>Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).</i> |  |  |
| -type drive_type    | If a drive type is specified, then the drive information will come from the path information from a reference cell delay arc.                                                                                                                                                                                                                                                                                                                                                       |  |  |
| -value port_limit_v | Specifies an explicit drive resistance for the ports. The drive resistance is not in library resistance units. Instead, the output slew time and the base delay will equal this value times the output load. The value can be either a single number or an SDF style triplet.                                                                                                                                                                                                       |  |  |
|                     | For output slew, if the set_mp_port_drive command is not set on the output, then the output slew is the same as the input                                                                                                                                                                                                                                                                                                                                                           |  |  |

slew. If the set\_mp\_port\_drive command is used with the -value option, then the output slew is value\*Cload. If the set\_mp\_port\_drive command is used with a drive type, then the output slew is copied from reference cell data.

## Examples

The following command specifies that all subsequently created delay arcs to port z have timing based on the arc used to create the drive1 drive type:

```
set_mp_port_drive -type drive1 Z
```

The following command specifies that for all subsequently created delay arcs to ports Q and Qn, the output slew will be twice the output load and the base delay time is also twice the output load:

```
set_mp_port_drive -value 2 {Q QN}
```

## **Related Information**

<u>create\_mp\_delay\_arc</u>

create mp path type

set mp global parameter

<u>set\_mp\_technology</u>

## set\_mp\_port\_load

set\_mp\_port\_load
 {-type load\_type | -value port\_cap} port\_name\_list

Specifies the port capacitance for each of the specified input or inout ports. If you do not specify any ports, this command applies to all input or inout ports.

By default, only the port capacitance of this port are affected. If a reference type is used and the <u>set mp technology</u> -inherit\_port\_limits on command was used, then any maximum or minimum transition port limits on the reference pin will be copied to the ports.

### **Options and Arguments**

| port_name_list  | Specifies the name of the affected ports. They must be output or inout ports. If the <i>port_name_list</i> argument is not specified, all output or inout ports will be affected.                                                                                                                                                                                                                                                                                                          |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | The <i>port_name_list</i> can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the <i>Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).</i> |
| -type load_type | If a load type is specified, then the port capacitance will come from a reference cell pin.                                                                                                                                                                                                                                                                                                                                                                                                |
| -value port_cap | Specifies an explicit port capacitance, which can be either a single number or an SDF style triplet.                                                                                                                                                                                                                                                                                                                                                                                       |

## Examples

■ The following command sets the load on port A of the Module Prototype to 1.5 times the load of the pin used in defining the load1 load type:

set\_mp\_port\_load -type load1 -factor 1 A

The following command sets the load on the Module Prototype's port to B max load = 0.8, typ load = 0.85, max load = 0.9 set\_mp\_port\_load -value 0.8::0.9 {A B}

### **Related Information**

create mp delay arc

- set\_mp\_max\_fanout\_limit
- set mp min fanout limit
- set mp port max capacitance
- <u>set mp port min capacitance</u>
- set mp port max transition

set mp port min transition

## set\_mp\_port\_max\_capacitance

set\_mp\_port\_max\_capacitance [-value port\_limit\_value] port\_name\_list

Specifies an explicit constraint on the maximum external capacitance that can be driven by each of the output or bidirectional ports. This command overwrites any previous maximum port capacitance.

## **Options and Arguments**

port\_name\_list

Specifies the name of the ports. The ports must be and output or inout type. If this argument is not specified, all output and inout ports will be affected.

The port\_name\_list can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

```
-value port_limit_value
```

Specifies a constraint on the external capacitance for the ports, which can be either a single number or an SDF style triplet.

## Examples

■ The following command sets the maximum capacitance for port z to 0.9:

set\_mp\_max\_capacitance -value 0.9 Z

■ The following command sets the maximum capacitance for ports Q and QN. The minimum value is set to 0.8 and the maximum value is set to 0.9. No typical value is supplied, which is legal only if the Module Prototype has no type corner.

set\_mp\_max\_capacitance -value 0.8::0.9 {Q QN}

## **Related Information**

<u>set mp port drive</u>

<u>set\_mp\_technology</u>

## set\_mp\_port\_max\_transition

set\_mp\_port\_max\_transition [-value port\_limit\_value] port\_name\_list

Specifies an explicit constraint on the maximum transition time measured at each of the input, output, or inout ports.

### **Options and Arguments**

port\_name\_list

Specifies the name of the affected ports. If this argument is not specified, then this command applies to all ports.

The port\_name\_list argument can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

```
-value port_limit_value
```

Specifies a constraint on the maximum transition time measured at each of the ports, which can be either a single number or an SDF style triplet.

### Examples

■ The following command sets the maximum transition time for port z to 0.5:

set\_mp\_port\_max\_transition -value 0.5 Z

■ The following command sets the maximum transition time for ports Q and QN. The minimum value is set to 0.8 and the maximum value is set to 0.9. No typical value is supplied, which is legal only if the MP prototype has no type corner:

set\_mp\_port\_max\_transition -value 0.8::0.9 {Q QN}

### **Related Information**

<u>set\_mp\_port\_drive</u>

<u>set mp port load</u>

<u>set\_mp\_technology</u>

## set\_mp\_port\_min\_capacitance

set\_mp\_port\_min\_capacitance [-value port\_limit\_value] port\_name\_list

Specifies an explicit constraint on the minimum external capacitance that can be driven by each of the output or bidirectional ports. This command overwrites any previous minimum port capacitance.

### **Options and Arguments**

port\_name\_list

Specifies the name of the affected ports. They must be output or inout ports. If the *port\_name\_list* argument is not specified, all input or input ports will be affected.

The port\_name\_list argument can be either a single name or a list of names in curly braces. Each name can be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

```
-value port_limit_value
```

Specifies a constraint on the external capacitance for the ports, which can either be a single number or an SDF style triplet.

## Examples

■ The following command sets the minimum capacitance for port z to 0.9:

```
set_mp_min_capacitance -value 0.9 Z
```

■ The following command sets the minimum capacitance for ports Q and QN. The minimum value is set to 0.8 and the maximum value is set to 0.9. No typical value is supplied, which is legal only if the Module Prototype has no type corner:

set\_mp\_min\_capacitance -value 0.8::0.9 {Q QN}

## **Related Information**

<u>set\_mp\_port\_drive</u>

<u>set\_mp\_technology</u>

## set\_mp\_port\_min\_transition

set\_mp\_port\_min\_transition [-value port\_limit\_value] port\_name\_list

Specifies an explicit constraint on the minimum transition time measured at each of the input, output, or inout ports.

## **Options and Arguments**

port\_name\_list

Specifies the name of the affected ports. If this option is not specified, then this command applies to all ports.

The port\_name\_list argument can be either a single name or a list of names in curly braces. Each name may be a simple name, such as A, a bus element name, such as Data[3], a bus name, such as Data, or a bus range, such as Data[3:6]. The current name space is used for special character escaping. See <u>Port Names</u> in the "Using the Module Prototyper (MP)" section of the *Timing Analysis for BuildGates Synthesis and Cadence Physically Knowledgeable Synthesis (PKS).* 

```
-value port_limit_value
```

Specifies a constraint on the minimum transition time measured at each of the ports, which can be either a single number or an SDF style triplet.

## Examples

■ The following command sets the minimum transition time for port z to 0.5:

set\_mp\_port\_max\_transition -value 0.5 Z

■ The following command sets the minimum transition time for ports Q and QN. The minimum value is set to 0.8 and the maximum value is set to 0.9. No typical value is supplied which is legal only if the Module Prototype has no type corner:

set\_mp\_port\_max\_transition -value 0.8::0.9 {Q QN}

## **Related Information**

<u>set\_mp\_port\_drive</u>

<u>set mp port load</u>

<u>set\_mp\_technology</u>

# set\_mp\_technology

```
set_mp_technology
  [-library library_name][-max_transition trans_value]
  [-min_transition trans_value] [-max_capacitance cap_value]
  [-min_capacitance cap_value][-inherit_port_limits {on | off}]
  [-wire_load_model wlm_name]
```

Sets technology parameters. These values should be set at the beginning of an Module Prototyper (MP) session. Use the <u>create mp model</u> command to reset the technology parameters.

## **Options and Arguments**

|                      | <pre>{on   off} If the -inherit_port_limits option is set to on, then the set_mp_port_drive and set_mp_port_load commands copies port limits from reference pins to the affected ports. Default: off</pre>                                                                                         |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -library library_nam | e                                                                                                                                                                                                                                                                                                  |
|                      | Sets the technology library, which is used for all library level<br>quantities (PVT corners, kfactors, defaults, and units). Also, all<br>pin, delay, and constraint information used to create the<br>prototype come from this library. Once set, the reference library<br>should not be changed. |
|                      | _value<br>Specifies the default maximum capacitance, which can be either<br>a single number or an SDF style triplet.                                                                                                                                                                               |
|                      | _value<br>Specifies the default minimum transition time, which can be<br>either a single number or an SDF style triplet.                                                                                                                                                                           |
|                      | $s_value$<br>Specifies the default maximum transition time, which can be<br>either a single number or an SDF style triplet.                                                                                                                                                                        |
| -min_transition tran | $s_value$                                                                                                                                                                                                                                                                                          |

Specifies the default minimum transition time, which can be either a single number or an SDF style triplet.

-wireload\_model wlm\_name

Specifies the wire load model used for calculating the delays for path types.

### Examples

■ The following command sets the reference library to library fast:

set\_mp\_technology -library fast

The following command sets the wire load model used in creating path types to tsmc18\_w110:

set\_mp\_technology -wire\_load\_model tsmc18\_w110

■ The following command sets the default maximum capacitance to 2.0: set\_mp\_technology max\_capacitance 2.0

## **Related Information**

create mp path type

- <u>set mp port drive</u>
- <u>set\_mp\_port\_load</u>
- set mp max fanout limit
- <u>set mp min fanout limit</u>
- <u>set mp port max capacitance</u>
- set mp port min capacitance
- set mp port max transition
- <u>set mp port min transition</u>

## set\_num\_external\_sinks

set\_num\_external\_sinks non\_neg\_integer port\_list

Specifies top level input and output ports only, and sets the constraint for the number of external sinks that are connected to the ports in the port list. This number is factored into the wire capacitance and the wire resistance estimation for the port nets using wire-load models.

It does not add to the total fanout count for Design Rule Violation (DRV) checks. For more information on design rule violations, see the description for <u>max fanout load limit</u> in "Command Arguments for set\_global."

If you do not specify the set\_num\_external\_sinks command, the default fanout is 1 for the port (and any other internal sinks of the wire). If you specify the set\_num\_external\_sinks command, then you get that exact number added to the count of internal sinks of the wire.

## **Options and Arguments**

| non_neg_integer | Specifies the number of external sinks. <i>Default</i> : 1 |
|-----------------|------------------------------------------------------------|
| port_list       | Specifies the list of top level ports.                     |

## Example

set\_num\_external\_sinks 3 out

## **Related Information**

<u>do derive context</u>

<u>do\_time\_budget</u>

<u>set fanout load limit</u>

set num external sources

set\_port\_capacitance

<u>set port wire load</u>

### set\_num\_external\_sources

set\_num\_external\_sources non\_neg\_integer port\_list

Specifies top level input and output ports only, and sets the constraint for the number of external sources that are connected to the ports in the port list. This number is factored into the wire capacitance and the wire resistance estimation done for the port nets using the wire-load models.

It does not add to the total fanin count for Design Rule Violation (DRV) checks. If you do not use the set\_num\_external\_sources command, then the fanin is 1 for the port (and any other internal sources on the wire). If you specify the set\_num\_external\_sources command, then you get that exact number added to the count of internal sources of the wire.

### **Options and Arguments**

| non_neg_integer |                                                              |
|-----------------|--------------------------------------------------------------|
|                 | Specifies the number of external sources. <i>Default</i> : 1 |
|                 |                                                              |

port\_list

Specifies the list of top level ports.

### Example

set\_num\_external\_sources 2 in

### **Related Information**

<u>do\_derive\_context</u>

<u>do time budget</u>

set fanout load limit

<u>set\_num\_external\_sinks</u>

<u>set port capacitance</u>

set port wire load

## set\_operating\_conditions

Specifies the operating condition (process, temperature, voltage, and tree-type) for the design from a given library. The named operating condition is used by the mapping and optimization commands to appropriately select cells.

Each technology library contains one or more operating conditions. Each condition is identified by name, which specifies a set of process, temperature, voltage, and tree-type conditions as the operating condition. This information is used to calculate accurate cell delays from the nominal cell delays and the k-factors (also called derating factors) from either linear or nonlinear models.

Get a list of all operating conditions in a technology library along with their PVT and OC type values using the <u>report library</u> command.

**Note:** If you specify an operating condition, for example: set\_operating\_conditions -library *library\_name operating\_condition\_name* -pvt min, but the <u>pvt\_early\_path</u> global is set to the max corner, the set\_operating\_conditions assertion will be ignored. To apply the assertion, set the pvt\_early\_path global to min. This also applies to the max operating condition. Set the <u>pvt\_late\_path</u> global to the max corner before setting the set\_operating\_conditions -pvt max command. Using the report\_timing -early command or the report\_timing -late command will list the specified operating condition in the report.

## **Options and Arguments**

```
-library library_name
```

Specifies the technology library containing the named operating condition.

operating\_condition\_name Specifies the name of the operating condition in the library.

-pvt {min | typ | max}

Sets the operating condition for a particular PVT corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ( $\{\}$ ) and separate the values by spaces.

*Default*: The specified operating condition applies to all three PVT corners.

### Examples

■ The following command sets the operating conditions for the min PVT corner to fast\_0\_3.60:

set\_operating\_conditions -pvt min fast\_0\_3.60

■ The following timing report shows the operating conditions listed in the library:

| Operating  <br>  Condition | process  <br> | temperature | voltage | 0C type  <br> |
|----------------------------|---------------|-------------|---------|---------------|
| +                          | ++            | +           |         | +             |
| NOM                        | 1.0000        | 25.0000     | 5.0000  | balanced_tree |
| WCCOM                      | 1.2800        | 70.0000     | 4.7500  | balanced_tree |
| WCIND                      | 1.2800        | 85.0000     | 4.7500  | balanced_tree |
| WCMIL                      | 1.2800        | 125.0000    | 4.5000  | balanced_tree |
| BCCOM                      | 0.7000        | 0.0000      | 5.2500  | balanced_tree |
| BCIND                      | 0.7000        | -40.0000    | 5.2500  | balanced_tree |
| BCMIL                      | 0.7000        | -55.0000    | 5.5000  | balanced_tree |
| TST                        | 1.2800        | 25.0000     | 5.0000  | balanced_tree |
| +                          |               |             |         | +             |

You can set different operating conditions for different PVT corners. If no operating conditions were set, the report\_timing command will list the default operating condition besides the Operating Condition field, shown in the example above. The report also lists the Operating Condition (OC) Type, and the process, temperature, and voltage values for the operating\_condition used.

For more information, see"<u>Explaining How the Operating Condition Type Effects Delay</u> <u>Calculation</u>" in the Common Timing Engine (CTE) User Guide.

To set a min operating condition, make sure the global <u>pvt early path</u> is set to min. If you set the corner using the <u>pvt\_early\_path</u> and <u>pvt\_late\_path</u> globals, the operating condition set to that corner will be picked. If you specify the -pvt option with the <u>set\_operating\_conditions</u> command, the operating condition applies to all three PVT corners.

The following examples display only the timing report header to show what operating condition is used by the timer to calculate delays and slews. The pvt\_early\_path and pvt\_late\_path globals are pointing to the max corner, and the default operating condition is NOM, which is for both the min and max corners.

```
    report_timing -late
    ..
    | Timing | LATE | <==
    ..
</pre>
```

| Operating Condition | NOM      | <== |
|---------------------|----------|-----|
| PVT Mode            | max      | <== |
| Tree Type           | balanced |     |
| Process             | 1.0000   |     |
| Voltage             | 5.0000   |     |
| Temperature         | 25.0000  |     |
|                     |          |     |
| report_timing -ear  | ly       |     |
| ••                  |          |     |
| Timing              | EARLY    | <== |
| ••                  |          |     |
| Operating Condition | NOM      | <== |
| PVT Mode            | max      | <== |
| Tree Type           | balanced |     |
| Process             | 1.0000   |     |
| Voltage             | 5.0000   |     |
| Temperature         | 25.0000  |     |
|                     |          |     |

••

. .

· ·

Setting the pvt\_early\_path global to min results in the following timing report:

|   | Timing              | EARLY    | <== |
|---|---------------------|----------|-----|
| • |                     |          |     |
|   | Operating Condition | NOM      | <== |
|   | PVT Mode            | min      | <== |
|   | Tree Type           | balanced |     |
|   | Process             | 1.0000   |     |
|   | Voltage             | 5.0000   |     |
|   | Temperature         | 25.0000  |     |
|   |                     |          |     |

••

**D** The following commands set the operating conditions to max, typ, and min:

- O set\_operating\_conditions -pvt max WCCOM
- O set\_operating\_conditions -pvt min BCCOM
- O set\_operating\_conditions -pvt typ TST

#### **D** The following command shows the timing report using the -late option:

```
report_timing -late
```

```
Timing LATE <==
```

. .

| Operating Condition |  | WCCOM    | <== |
|---------------------|--|----------|-----|
| PVT Mode            |  | max      | <== |
| Tree Type           |  | balanced |     |
| Process             |  | 1.2800   | <== |
| Voltage             |  | 4.7500   | <== |
| Temperature         |  | 70.0000  | <== |

••

. .

The following command show the timing report using the -early option:

```
report_timing -early
```

| ••                  |          |  |     |
|---------------------|----------|--|-----|
| Timing              | EARLY    |  | <== |
|                     |          |  |     |
| ••                  |          |  |     |
| Operating Condition | BCCOM    |  | <== |
| PVT Mode            | min      |  | <== |
| Tree Type           | balanced |  |     |
| Process             | 0.7000   |  | <== |
| Voltage             | 5.2500   |  | <== |
| Temperature         | 0.0000   |  | <== |
|                     |          |  |     |

□ The following global sets the PVT corner to typ. The typ value is not used since neither the pvt\_early\_path, nor the pvt\_late\_path globals are pointing to typ:

```
set_global pvt_early_path typ
report_timing -early
. .
Timing
                    EARLY
                                           <==
. .
| Operating Condition | TST
                                              <==
PVT Mode
                     | typ
                                             <==
Tree Type
                     balanced
                     1.2800
Process
                                              <==
| Voltage
                     5.0000
                                              <==
Temperature
                    25.000
                                              <==
```

The following example explains how setting the operating condition effects delay calculation.

in --->INV1-->INV2--- out

This example has two inverters in series. INV1 is from library1, while INV2 is from library2. Library1 and library2, as shown below, have a scaled\_cell for INV1 and

INV2 for all three operating conditions. This means in library1 for INV1 a scaled\_cell is defined for all three operating conditions: MAXIMUM, MINIMUM, TYPICA1. This also applies to INV2 in library2.

| library1: |          |             |          |               |
|-----------|----------|-------------|----------|---------------|
| Operating | process  | temperature | voltage  | <br>OC type   |
| Condition |          |             |          |               |
| +         | +        |             | +        | +             |
| NOM       | 1.000000 | 25.000000   | 2.750000 | balanced_tree |
| MAXIMUM   | 0.780000 | 100.000000  | 2.250000 | balanced_tree |
| MINIMUM   | 0.950000 | 0.00000     | 3.750000 | balanced_tree |
| TYPICAL   | 1.500000 | 35.000000   | 3.000000 | balanced_tree |
| +         |          |             |          | +             |
| library2: |          |             |          |               |
| +         |          |             |          | +             |
| Operating | process  | temperature | voltage  | OC type       |
| Condition |          |             |          |               |
| +         | +        |             | +        | +             |
| NOM       | 1.000000 | 25.000000   | 5.000000 | balanced_tree |
| MAXIMUM   | 1.280000 | 70.000000   | 4.750000 | balanced_tree |
| MINIMUM   | 0.700000 | 0.00000     | 5.250000 | balanced_tree |
| TYPICAL   | 1.280000 | 25.000000   | 5.000000 | balanced_tree |
| +         |          |             |          | +             |

**u** The following command sets an operating condition from library2:

set\_tech\_info -library library2 -default\_operating\_conditions NORM

Even if the target\_technology is specified as "library1 library2", the default operating condition from library1 is used for timing analysis. The default operating condition from library2 is used only if library2 is the first library in the target\_technology list.

```
get_tech_info -default_operating_conditions
NOM
set_global target_technology "library2 library1"
get_tech_info -default_operating_conditions
NORM
```

□ The following command sets the operating condition to all three corners because the -pvt option is not used:

set\_operating\_condition -library library2 MAXIMUM

□ The following global sets the target technology:

set\_global target\_technology "library1 library2"

Since a scaled\_cell is defined for INV1 for the MAXIMUM operating condition, the values defined for this scaled\_cell for that operating condition are picked up. This is also true for INV2. No derating is done - means the multiplication factor is 1. The different PVT values between the operating conditions has no effect, so the scaled\_cell is used. If a scaled\_cell is not defined for this operating condition, the value picked up from the table defined for the cell is derated to the PVT values of MAXIMUM from library2.

The set\_operating\_condition command overrides any previous settings by the set\_tech\_info -default\_operating\_conditions command. Once you set the set\_operating\_condition command, any further settings using the set\_tech\_info -default\_operating\_conditions command will have no effect.

The report\_library command prints a list of all the operating conditions in a technology library along with their PVT and OC type values, as shown in the following table:

| +<br>  PVT | Operating<br>Condition | process | temperature | voltage | OC type         |
|------------|------------------------|---------|-------------|---------|-----------------|
| max        | slow_125_3.00          | 1.00    | 125.00      | 3.00    | worst_case_tree |
| typ        | slow_125_3.00          | 1.00    | 125.00      | 3.00    | worst_case_tree |
| min        | fast_0_3.60            | 0.69    | 0.00        | 3.60    | best_case_tree  |

Any operating condition that is not set is picked up from the first library in the target technology list.

■ The following command reads in another library and sets the typ condition to that library:

set\_operating\_conditions -library library\_name slow -pvt typ

The report\_library command prints the following table, assuming the OC type is balanced\_tree, and the numbers are for that condition from the library:

| + | PVT | Operating<br>Condition | process | temperature | voltage | OC type         |
|---|-----|------------------------|---------|-------------|---------|-----------------|
|   | max | slow_125_3.00          | 1.00    | 125.00      | 3.00    | worst_case_tree |
|   | typ | slow                   | 1.00    | 125.00      | 1.08    | balanced_tree   |
|   | min | fast_0_3.60            | 0.69    | 0.00        | 3.60    | best_case_tree  |

Instead of using the <code>report\_library</code> command with the <code>-operating\_conditions</code> option, query a single operating condition using the <code>get\_operating\_conditions</code> command:

```
get_operating_condition -pvt min fast_0_3.60
get_operating_condition -pvt typ slow
```

## **Related Information**

get operating conditions

get operating parameter

<u>read\_alf</u>

<u>read\_tlf</u>

<u>report library</u>

reset\_operating\_condition

set operating parameter

See the <u>Reading Timing Libraries</u> chapter in the *Common Timing Engine (CTE) User Guide* for information on setting operating conditions for timing libraries.

# set\_operating\_parameter

```
set_operating_parameter {-process float | -voltage float | -temperature float}
  [-pvt {min | typ | max}]
```

Sets the PVT operating parameters individually for the design used in calculating accurate cell delays from the nominal cell delays and the k-factors (also called derating factors) from either linear or non-linear models.

If a DCM has been loaded, the delay and slew equations in the DCM use the operating parameters specified here.

The set\_operating\_parameter command overrides the parameter value from the default operating condition of the technology library. It also overrides the parameter value from any operating condition you previously selected with the set\_operating\_condition command.

Any operating parameter value specified using the set\_operating\_parameter command has a higher precedence than the set\_operating\_condition command. However, other parameters not specified using the set\_operating\_parameter command will continue to be picked up from specified operating condition. Even if all operating parameters are specified, the wire load tree type is still picked up from operating condition.

**Note:** The do\_remove\_design -all command does not remove operating conditions, regardless of how the operating conditions are set in the design.

# **Options and Arguments**

Note: Set only one of the parameters (process, voltage, or temperature) per command.

-process float

Specifies the process multiplier.

-pvt {min | typ | max}

Sets the operating parameter for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces. *Default*: The specified operating parameter applies to all three PVT corners.

-temperature float

Specifies the temperature at which the circuit operates.

-voltage *float* 

Specifies the voltage at which the circuit operates.

# Examples

set\_operating\_parameter -voltage 3.3 -pvt typ
set\_operating\_parameter -process 1.0 -pvt typ
set\_operating\_parameter -temperature 25 -pvt typ



This is equivalent to the following command:

read\_tlf -process 1.0 -voltage 3.3 -temperature 25 -pvt typ zippy.tlf

However, without the -pvt typ option, the read\_tlf command would apply the parameters to all three PVT corners by default. In that case, results would differ from the set of set\_operating\_parameter commands with the -pvt typ option because their min and max values are taken from the library.

**Note**: If the temperature or voltage k factors are undefined in the library, or are set to zero, the set\_operating\_parameter will have *no* scaling effect on timing.

# **Related Information**

get operating parameter

<u>load dcl rule</u>

reset\_operating\_parameter

set operating conditions

See the <u>Reading Timing Libraries</u> chapter in the *Common Timing Engine (CTE) User Guide* for information on setting operating parameters for timing libraries.

# set\_operating\_voltage

```
set_operating_voltage [-ground] [-pvt {min | typ | max}] voltage
list_of_instances
```

Models operating voltage for hierarchical or leaf level instances. This command is intended for use in voltage drop analysis. For more information about IR drop, see "<u>Using Timing</u> <u>Analysis with Voltage Drops on Power and Ground Rails</u>" in the *Common Timing Engine (CTE)* User Guide.

Note: Full support for multiple supply voltages is not available in this release.

The operating voltage of a leaf level instance is determined in the following manner:

- If there is an operating voltage assertion on the instance, then that specifies its operating voltage.
- Otherwise, the voltage of the lowest level hierarchical module containing this instance, and with an operating voltage assertion is the operating voltage of the instance.
- If no such module is found, then the operating voltage is determined by the operating condition command, or by the default operating condition (or operating voltage) setting in the first library in target technology list.

**Note:** The set\_operating\_parameter -voltage command can be set for the entire design and is used in cell derating. Set an operating voltage on a leaf level instance using the set\_operating\_voltage command, which is also used in derating, but overrides the value set by set\_operating\_parameter -voltage command only for this instance.

For interconnect delay and slew calculations, the operating voltage of the driver is used. The voltage drop of the instance (if any) connected to the receiver will not affect its delay or slew (other than affecting receiver pin capacitance).

For cell delay and slew calculation, .lib and TLF allow only one set of derating factors. Therefore, the instance and its inputs are expected to be operating at the same voltage, and this voltage is used to derate the cell timing arcs.

# **Options and Arguments**

-ground

Specifies the ground bounce-voltage of an instance.list\_of\_instances Specifies the list of instances includes hierarchical and leaf level instances. Specify the instance list after the voltage value.

| -pvt {min   typ | max}                                                                                                                                                                                                                 |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | Sets the operating voltage for a particular PVT corner. Choose<br>one, two, or three PVT corners. If you choose more than one<br>corner, enclose the list in curly braces ({}) and separate the<br>values by spaces. |
|                 | <i>Default</i> : The specified operating voltage applies to all three PVT corners.                                                                                                                                   |
| voltage         |                                                                                                                                                                                                                      |
|                 | Specifies the operating voltage of the instance. This floating number is a required argument.                                                                                                                        |

# Examples

■ The following commands set the operating voltage triplet to 4.5:5.0:5.5 volts for instance ld1:

```
set_operating_voltage -pvt min 4.5 ld1
set_operating_voltage -pvt typ 5.0 ld1
set_operating_voltage -pvt max 5.5 ld1
```

■ The following commands sets the ground voltage on instance il:

set\_operating\_voltage 1.8 i1
set\_operating\_voltage -ground 0.1 i1

■ The following command provides the effective voltage operating on instance i1, which is 1.7:

get\_operating\_voltage i1

#### **Related Information**

get operating voltage

<u>read rrf</u>

<u>read\_irdrop</u>

<u>reset\_operating\_voltage</u>

set operating conditions

<u>set\_operating\_parameter</u>

# set\_path\_delay\_constraint

```
set_path_delay_constraint [{-from | -from_rise | -from_fall} pin_list]
  [{-through | -through_rise | -through_fall} pin_list]
  [{-to | -to_rise | -to_fall} pin_list] [-early | -late]
  [-clock_from list_of_clk_signames] [-edge_from {leading | trailing}]
  [-clock_to list_of_clk_signames_] [-edge_to {leading | trailing}]
  [-bidi_input_from | bidi_output_from] [-bidi_input_through |
  -bidi_output_through] [-bidi_input_to | bidi_output_to] [-reset_path] float
```

Specifies a delay that must be met (-late) or exceeded (-early). *Default*: false

Path exception constraint calculations are different depending on type of start or end point:

Sequential start or end point

Considers the clock insertion delay, uncertainty, and arrival times in the path delay constraint calculations. Effectively, the delay *through* the pin is calculated, considering the clock network delay as well.

The interpretation of a path delay statement on a hierarchical port is that of a -through constraint. Since a hierarchical port is a logical pin and does not represent a real circuit pin, constraints on such pins are treated as through constraints. If you want the constraint to be such that it is a path start or end point, move the constraint to a previous or later leaf level pin.

Combinational start or end point

Does not consider any clock delay, and the delay path constraint is measured from or to the pin.

**Note:** The global <u>timing allow register output as delay through</u> controls whether register outputs are seen as sequential or combinational start points. The default is false, meaning register outputs are combinational start points and the delay path constraint is measured from the pin.

If both the <code>-from</code> and <code>-clock\_from</code> options are specified, the path exception applies to all paths starting from the <code>-from</code> pin and all the paths starting from the <code>-clock\_from</code> signal. If both the <code>-to</code> and <code>-clock\_to</code> options are specified, the path exception applies to all the paths ending at the <code>-to</code> pin and all the paths ending at the <code>-clock\_to</code> signal.

If both the <code>-through</code> and <code>-clock\_from</code> options are specified, the path exception applies to all paths starting from the <code>-clock\_from</code> signal and going through the <code>-through</code> pin (AND operation). If both the <code>-through</code> and <code>-clock\_to</code> options are specified, the path exception applies to all paths going through the <code>-through</code> pin and ending at the <code>-clock\_to</code> signal.

# **Options and Arguments**

| -bidi_input_from   -           | bidi_output_from<br>Specifies that the assertion applies to the input or output of<br>bidirectional pins in the -from pin list. Default value is shown in<br><u>"Bidirectional Pin Defaults"</u> on page 799.        |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -bidi_input_through            | -bidi_output_through<br>Specifies that the assertion applies to the input or output of<br>bidirectional pins in the -through pin list. Default value is<br>shown in <u>"Bidirectional Pin Defaults"</u> on page 799. |
| -bidi_input_to   -bi           | di_output_to<br>Specifies that the assertion applies to the input or output of<br>bidirectional pins in the -to pin list. Default value is shown in<br><u>"Bidirectional Pin Defaults"</u> on page 799.              |
| -clock_from <i>list_of</i>     | _clk_signames<br>Sets the delay for all paths originating from the specified clock<br>signal(s).                                                                                                                     |
| -clock_to list_of_c            | $lk\_signames$<br>Sets the delay for all paths going to the specified clock signal(s).                                                                                                                               |
| <pre>-edge_from {leading</pre> | <pre>  trailing} Specifies an edge for the -clock_from option. Default: Both edges</pre>                                                                                                                             |
| -edge_to {leading              | trailing}<br>Specifies an edge for the -clock_to option.<br><i>Default</i> : Both edges                                                                                                                              |
| float                          | Specifies the delay value for the constraint.                                                                                                                                                                        |
| {-from   -from_rise            | <pre>  -from_fall} pin_list Specifies the pins that are at the start of the paths. If the -from option is used without the -to option, all paths originating from the pin_list are constrained.</pre>                |
|                                | Either the -from, -to, or -through option must be used with the set_path_delay_constraint command to identify the                                                                                                    |

|                      | paths. Specifying both the -from and -to options identifies a path with specific starting and ending points.                                                                                                                                            |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | The <i>pin_list</i> argument can contain either object IDs or<br>hierarchical names relative to the current module. The pins can<br>be on intermediate hierarchical boundaries. Use only one -from<br>(or -from_rise or -from_fall) option per command. |
|                      | Specifying set_path_delay_constraint -from a hierarchical pin treats the hierarchical pin as a -through. A -from pin must be an instance pin in order to place a constraint on a combinational path.                                                    |
|                      | By default, the $-from$ option applies the assertion to both the rising and the falling edges.                                                                                                                                                          |
|                      | Using the -from_rise option applies the assertion at the rising edge of the signal on the through pins.                                                                                                                                                 |
|                      | Using the <pre>-from_fall option applies the assertion at the falling edge of the signal on the through pins.</pre>                                                                                                                                     |
| -late   -early       | Specifies the maximum delay (-late) or minimum delay (-early).<br>Default: -late                                                                                                                                                                        |
| -reset_path          | Changes the constraint on the specified path to the new value.<br>Using this option resets a path only if the path description using<br>the -from, -through,-to options match. See Examples.                                                            |
| {-through   -through | n_rise   -through_fall} pin_list<br>Specifies the pins that the path goes through. When used<br>without the -from or -to options, all paths that go through the<br>-through pins have the specified delay.                                              |
|                      | When used with both the -from and -to options, any path starting at any pin on the -from list <i>and</i> going through any point on the -through pin list <i>and</i> going to any point on the -to list is affected by the assertion.                   |

|                      | The <i>pin_list</i> argument can contain either object IDs or<br>hierarchical names relative to the current module. Use only one<br>-from and one -to option, but many -through options in the<br>same command.                                   |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | By default, using the -through option applies the assertion to both the rising and the falling edges.                                                                                                                                             |
|                      | Using the -through_rise option applies the assertion at the rising edge of the signal on the through pins.                                                                                                                                        |
|                      | Using the <pre>-through_fall option applies the assertion at the falling edge of the signal on the through pins.</pre>                                                                                                                            |
| {-to   -to_rise   -t | o_fall} pin_list<br>Specifies the pins that are at the end of the paths. If the -to<br>option is used without the -from option, all paths ending in the<br>-to pin list have the specified delay.                                                 |
|                      | The <i>pin_list</i> argument can contain either object IDs or<br>hierarchical names relative to the current module. The pins can<br>be on intermediate hierarchical boundaries. Use only one -to<br>(or -to_rise or -to_fall) option per command. |
|                      | Specifying set_path_delay_constraint -to a hierarchical pin treats the hierarchical pin as a -through. A -to pin must be an instance pin in order to place a constraint on a combinational path.                                                  |
|                      | By default, the $-to$ option applies the assertion to both the rising and the falling edges.                                                                                                                                                      |
|                      | Using the $-to_rise$ option applies the assertion at the rising edge of the signal on the through pins.                                                                                                                                           |
|                      | Using the -to_fall option applies the assertion at the falling edge of the signal on the through pins.                                                                                                                                            |
|                      |                                                                                                                                                                                                                                                   |

# Examples

{

■ The following command constrains the delay on the path from in to out to a maximum of 3:

set\_path\_delay\_constraint -from in -to out 3

■ The following command shows the -reset\_path option. The second example sets the constraint to 6.0 and resets the 4.0 constraint to o3:

set\_path\_delay\_constraint 4.00 -to { o1 o2 o3 o4 o5 }
set\_path\_delay\_constraint 6.00 -reset\_path -to o3

Using the -reset\_path option changes the constraint on the specified path to the new value. However, if there is only one path and both paths are equivalent, using this option resets a path only when there is an exact match in the arguments. For example, the following command specifies the delay as U14/A 5:

set\_path\_delay\_constraint -through U14/A 5

The following shows the report using this command:

| +<br>  Through | Early | +<br>Late |
|----------------|-------|-----------|
| U14/A          |       | delay 5   |

If you then change the constraint to a new value using the -reset\_path option on the same path, but use a different argument as follows:

set\_path\_delay\_constraint -through U12/Z 7 -reset\_path

The report using the report\_path\_exceptions command or the report\_timing command shows the following:

| +<br>  Through | Early | Late                       |
|----------------|-------|----------------------------|
| U12/Z<br>U14/A |       | delay 7 ignored<br>delay 5 |

Using the -reset\_path option resets a path only when there is an exact match in the arguments, not when both the constraints represent the same path.

#### **Related Information**

<u>reset path exception</u>

set cycle addition

See <u>Constraint Tips</u> and <u>Specifying Path Delay Constraints</u> in the Common Timing Engine (CTE) User Guide.

# set\_path\_group

set\_path\_group [-name group\_name] [-from from\_list] [-through through\_list]
 [-to to\_list] [-clock\_from clksig\_from\_list] [-clock\_to clksig\_to\_list]

Specifies path groups for use in optimization. A path group is a collection of timing paths in the design, for which you can set different optimization objectives. See <u>set port capacitance</u> on page 1238 for more details on how to set these values once you've specified the groups.

Specifying a path group is similar to specifying a path exception, such as a false path. You can give multiple path specifications the same name, which results in all the specified paths being placed in the same path group. You can also give path groups different names (or a default name) and placed in different groups.

Initially, there is only one group, which is named "default." You cannot create any other groups with that name.

To optimize each waveform or clock in a different group, use the following script:

foreach clk [get\_clock] { set\_path\_group -clock\_to \$clk -name "group\_\$clk" }

**Note:** Timing reports show different slack times when defining and without defining path groups because of slew merging. For more information on timing differences due to slew merging, see <u>Explaining Timing Differences Caused by Slew Merging When Path Exceptions</u> <u>are Applied</u> in the *Common Timing Engine (CTE) User Guide*.

# **Options and Arguments**

-clock\_from clksig\_from\_list

Includes paths in the group whose start points are related to the listed clock signals. This includes paths from flip-flops in the transitive fanout of the clock source pin or port, and paths from ports that have input delay related to the clock waveform.

-clock\_to clksig\_to\_list

Includes paths in the group whose endpoints are related to the listed clock signals. This includes paths to flip-flops in the transitive fanin of the clock output pin or port, and paths to ports that have output delay related to the clock waveform.

-from from\_list

Specifies the path start points. The *from\_list* is a list of port or pin names. Paths starting from *from\_list* are included in the group.

**Note**: Do not use -from option with the -from\_clock option.

-name group\_name

Creates a new group with name group\_name. If a group with this name already exists, the paths or endpoints are added to that group.

The name default is an illegal name for a path group. It is reserved for the default path group (paths not belonging to any specified path group).

**Note:** If you do not specify the -name option, the system creates a name. This new name is unique, and different from all other group names. Once it has been created, you can use the new name just like any other group name. Be advised, however, that the created name may not be the same from run to run, and therefore, it is better to specifically assign names to your path groups.

Tip

Avoid problems by always assigning a group name with the -name option. Remember that default is not a legal name.

#### -through through\_list

Specifies the path through points. The *through\_list* is a list of port or pin names, or leaf cell names. The path group includes only those paths that pass through one of the points in the *through\_list*.

If the -through option is used with the -from option, the group includes only paths that start in the *from\_list* and pass through the *through\_list*.

If the -through option is used with the -to option, the group includes only paths that pass through the  $through\_list$  and end at the  $to\_list$ .

If the -through option is used with both the -from and -to options, the group includes only paths that start in the *from\_list* and pass through the *through\_list* and end at the *to\_list*.

|             | If the -through option is specified multiple times, the group includes only those paths that pass through one of the points in each through_list in the order specified.                               |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -to to_list |                                                                                                                                                                                                        |
|             | Specifies the path endpoints. The $to_list$ is a list of port or pin names. Paths ending at $to_list$ are included in the group.<br><b>Note</b> : Do not use the -to option with the -to_clock option. |

## Examples

■ The following command specifies path groups for use in optimization, and includes the path in the group whose start point is related to CLKA -name GRPA signal:

set\_path\_group -clock\_from CLKA -name GRPA

■ The following command sets a G\_PiClk path group:

set\_path\_group -name G\_PiClk -clock\_from {PiClk} -clock\_to {PiClk}

Using the report\_path\_groups command or the report\_timing -path\_group G\_PiClk command displays the following report:

| +       |          | +        |
|---------|----------|----------|
| From    | То       | Group    |
|         |          | Name     |
| +       | ++       |          |
| "PiClk" | "PiClk"  | G_PiClk  |
| "PiClk" | "VdoClk" | test_pjj |
| +       |          | +        |

# **Related Information**

report timing -path group

<u>reset path group</u>

<u>set\_port\_capacitance</u>

See <u>Using Path Groups for Optimization</u> in the Common Timing Engine (CTE) User Guide.

# set\_port\_capacitance

set\_port\_capacitance float port\_list [-pvt {min | typ | max}] [-wire\_cap]

Specifies top level input and output ports only, and specifies the capacitance external to the design based on input and output loading from other ports and nets connected to the ports of the module.

The capacitance at any port is the sum of the external port capacitances that are connected to the port. For an input port, the port capacitance refers to the capacitance of all the ports that drive the net and the capacitance of the other loads on the net. For output ports, the port capacitance refers to the capacitance of all the external sinks, (and external drivers, for the case of a net with multiple drivers) that are connected to the net, as well as the capacitance of the input port of any other external drivers.

## **Options and Arguments**

| float                | Specifies the capacitance value. The unit of capacitance must be the same as the unit of capacitance used in the library.                                                                                                                                                                                                |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| port_list            | Specifies the list of top level ports.                                                                                                                                                                                                                                                                                   |
| -pvt {min   typ   ma | Sets the port capacitance for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces.<br>Default: The specified port capacitance applies to all three PVT corners. |
| -wire_cap            | Specifies the external wire capacitance. The default specified value is the external pin capacitance.<br><b>Note:</b> The external wire capacitance is ignored if you specify the external number of source pins or the external number of sink pins, and the external wire capacitance on the same port.                |

# Example

The following command sets a 3.2 capacitance on all output ports of the current module whose names start with the string dbus:

set\_port\_capacitance 3.2 [find -port -output dbus\*]

## **Related Information**

reset\_port\_capacitance

<u>set current module</u>

- set global max capacitance limit
- set port capacitance limit
- <u>set top timing module</u>

# set\_port\_capacitance\_limit

set\_port\_capacitance\_limit [-min | -max] float port\_list

Specifies top level input and output ports only, and sets the limit on the capacitance external to the design based on input and output loading from other ports and nets connected to the specified ports of the current module.



Make sure the current module is the top timing module before applying this command.

Specify this design rule constraint on top level input and output ports. The limit, by default, is the maximum value for the total capacitances (wire capacitance and pin capacitance) of nets attached to the ports in the port list. Specify a minimum value limit with the -min option.

If the set\_global max\_capacitance\_limit (or set\_global min\_capacitance\_limit) has also been set, the most constraining value is used.

#### **Options and Arguments**

| float       | Specifies the capacitance value. Units must match the units used in the library.                                                      |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| -min   -max | Specifies minimum (or maximum) design rule constraints. If neither option is given, the default is $-max$ for backward compatibility. |
| port_list   | Specifies the list of top level ports.                                                                                                |

#### Example

set\_port\_capacitance\_limit 5.0 [find -port dbus\*]

#### **Related Information**

#### do derive context

#### <u>do time budget</u>

December 2003

- reset\_port\_capacitance\_limit
- set capacitance limit
- set fanout load limit
- set\_global max\_capacitance\_limit
- <u>set global min capacitance limit</u>
- set num external sinks
- <u>set num\_external\_sources</u>
- <u>set port capacitance</u>
- <u>set\_slew\_limit</u>
- set\_slew\_time\_limit
- set top timing module

# set\_port\_wire\_load

```
set_port_wire_load [-library library_name] wire_load_model port_list
    [-pvt {min | typ | max}]
```

Specifies the wire load for an input or output top level port of a design. The net connected to the port is associated with the specified wireload model, which is used for wire capacitance and resistance estimation.

If a net is connected to more than one port with a set\_port\_wire\_load assertion, then the worst wireload model on the net is computed and used for timing analysis.

## **Options and Arguments**

| -library <i>library_na</i> | me<br>Indicates the library containing the specified wire-load model. If<br>this option is not specified, the default is the target technology<br>library.                                                                                                                                                                           |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| port_list                  | Lists the top level ports.                                                                                                                                                                                                                                                                                                           |
| -pvt {min   typ   ma       | Sets the port wire-load model for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({}) and separate the values by spaces. <i>Default</i> : The specified port wire-load model applies to all three PVT corners. |
| wire_load_model            | Specifies the name of the wire-load model to use for estimating wire capacitance and resistance.                                                                                                                                                                                                                                     |

# Example

set\_port\_wire\_load B0X0 out

See <u>Specifying Wire Loads</u> in the *Common Timing Engine (CTE) User Guide* for more examples and detailed information.

# **Related Information**

<u>set num external sinks</u>

<u>set\_wire\_load</u>

# set\_propagated\_clock

set\_propagated\_clock [-clock clock\_list] [-pin pin\_list]

Changes the clock propagation mode to propagated mode for the given clock waveforms or pins. There are two modes of clock propagation: ideal and propagated.

- In ideal mode, the delay from a clock port to a register clock pin (network insertion delay) comes from design constraints (set\_clock\_insertion\_delay).
- In propagated mode, the network insertion delay is computed from the actual gates and interconnects in the clock network.

Note: Use the set\_clock\_propagation command to globally change the clock propagation mode for all clock networks. If the set\_clock\_propagation command is set to propagated (set\_clock\_propagation propagated), then all clock networks are assumed to be in propagated mode, and the set\_propagated\_clock and reset\_propagated\_clock commands will have no impact. If the set\_clock\_propagation command is set to ideal mode (set\_clock\_propagation ideal), then you can change some clock networks to propagated mode by using the set\_propagated\_clock command.

# **Options and Arguments**

| -clock <i>clock_list</i> | Specifies the clock where you want to change the clock propagation mode to propagated mode.                                                                                                                                                                                                                    |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -pin <i>pin_list</i>     |                                                                                                                                                                                                                                                                                                                |
|                          | Specifies one or more pins for which you want to change the clock propagation mode to propagated mode. No hierarchical pins are allowed in the <i>pin_list</i> . When a <i>pin_list</i> is specified, it effects the propagation mode for all the registers in the transitive fanout (TFO) of the pin or port. |
|                          | Either the $clock\_list$ argument or the $pin\_list$ argument must be specified. You can also specify both the $clock\_list$ and the $pin\_list$ arguments.                                                                                                                                                    |

# Examples

- The following command sets clock waveform CLK1 to propagated mode: set\_propagated\_clock -clock CLK1
- The following command changes clock waveform CLK1 back to ideal mode:

reset\_propagated\_clock -clock CLK1

#### **Related Information**

- get clock propagation
- get propagated clock
- reset propagated clock

<u>set\_clock</u>

- <u>set\_clock\_insertion\_delay</u>
- set clock propagation
- <u>set\_clock\_root</u>
- set\_clock\_uncertainty
- set propagated clock

# set\_scale\_delays

```
set_scale_delays [-clock | -data]
    [-net_delay | -cell_delay | -cell_check]
    [-incl_sdf] [-early | -late]
    [-pvt {min | typ | max}] scale_factor
```

Scales min, typ, or max delays from the library and optionally from SDF assertions by the specified scaling factor. To specify unique scaling factors and PVT for cell and net, issue the command multiple times. Use this command to remove or add a certain degree of pessimism.

#### **Options and Arguments**

| -cell_check    | Specifies scaling on timing checks.                                                                                                                                                                  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <b>Note:</b> Specifying the -cell option is equivalent to both the -cell_delay and -cell_check options.                                                                                              |
| -cell_delay    | Specifies scaling on cell delays.<br>If neither the -cell_delay nor the -net_delay option is<br>specified, the specified scaling factor applies to both types of<br>delays.                          |
| -clock         | Applies scaling only to clock networks.                                                                                                                                                              |
| -data          | Applies scaling only to data networks.                                                                                                                                                               |
|                | <b>Note</b> : If neither the -clock option or the -data option is specified, the scaling applies to both the clock and data networks.                                                                |
| -early   -late | Specifies the variation around best case (BC) and worst case<br>(WC) corners. Use these options to specify four corner data as<br>follows:<br>-early -min<br>-late -min<br>-early -max<br>-late -max |

| -incl_sdf            | Specifies scaling on SDF assertions.                                                                                                                                                                                                                                                                                                   |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -net_delay           | Specifies scaling on net delays.                                                                                                                                                                                                                                                                                                       |
| -pvt {min   typ   ma | Associates a min, typ, or max PVT corner with the scale delay.<br>Three PVT corners are allowed, namely, min, typ, and max.<br><i>Default</i> : The specified delay scaling is applied to all PVT<br>corners.                                                                                                                          |
| scale_factor         | Specifies the factor used to scale the delay. Scaling is specified<br>by the decimal notation: x. n where $x = 0$ for negative scaling<br>(reducing) or 1 for positive scaling (increasing), and $n = 0$ to 99.<br>For example: 0.95 scales delays by -5 percent<br>1.1 scales delays by 10 percent<br>1.5 scales delays by 50 percent |

# Examples

The following commands scales the library delays to 95 percent of the original value for the min PVT corner. For the max PVT corner, the library delays are scaled to 105 percent of the original value:

```
set_scale_delays -incl_sdf -pvt min 0.95
set_scale_delays -incl_sdf -pvt max 1.05
```

■ The following commands set different delay scaling for cells and nets:

```
set_scale_delays -cell_delay -pvt min 0.90
set_scale_delays -cell_delay -pvt max 1.1
set_scale_delays -net_delay -pvt min 1.1
set_scale_delays -net_delay -pvt max 1.3
```

# **Related Information**

<u>get scale delays</u>

<u>reset\_scale\_delays</u>

See <u>Analyzing BC-WC Set-Up and Hold Checks</u>" in the *Common Timing Engine (CTE) User Guide* for more information.

# set\_slew\_limit

set\_slew\_limit float port\_list - Renamed to set\_slew\_time\_limit

The set\_slew\_limit command has been renamed because it limits the slew time parameter. See <u>set slew time limit</u> on page 1253.

# set\_slew\_thresholds

set\_slew\_thresholds [-lower lower\_float] [-upper upper\_float]

Sets the lower and upper slew threshold values used for the entire design, which is called a single-threshold mode. By default, the rising input slew thresholds from the default target technology library are used for reporting all rise and fall slews. If the target technology library does not have thresholds defined, the defaults of 20-80 percent are used (some library formats use defaults of 10-90 percent, see <u>Using Different Default Thresholds for Different Library Formats</u> in the *Common Timing Engine (CTE) User Guide*). To override these default thresholds, specify the single-threshold values for the whole design using the set\_slew\_thresholds command.

The set\_slew\_thresholds command is used only for reporting purposes in the user interface. It is still your responsibility to specify slew values that conform to the design level thresholds when you use the commands set\_slew\_time, set\_slew\_time\_limit, set\_default\_slew\_time, and set\_global slew\_time\_limit.

When you use the set\_slew\_thresholds command, the delay or slew calculation scales the incoming slews to the appropriate thresholds specified in the library for this cell. After the delay or slew calculation, the output slews are scaled back to the design slew threshold values. Also, the max and min transition limits at pin level and the default max and min transition limits at library level are scaled appropriately.

# **Options and Arguments**

| -lower       | lower        | float |
|--------------|--------------|-------|
| <b>TOWOT</b> | - C // C + _ |       |

Specifies the value of the lower slew threshold value in percentage between 0 to 100 percent.

-upper upper\_float

Specifies the value of the upper slew threshold value in percentage between 0 to 100 percent.

Specify both the upper and lower values together. The values must conform to  $upper_float > lower_float$ .

**Note:** If you set the slew threshold value at a percentage of *less* than one, you will get an error message. For example: set\_slew\_threshold -lower 0.1 -upper 0.9. You will also get an error message if the specified upper threshold is the same as the lower threshold.

# Example

The following command sets the lower and upper slew threshold values used for the entire design:

set\_slew\_thresholds -lower 10 -upper 90

## **Related Information**

get slew thresholds

reset slew thresholds

#### set global lib cell thresholds for reporting

# set\_slew\_time

set\_slew\_time [-clock clk\_signame] [-early | -late] [-rise | -fall]
 [-lead | -trail] |-pos | -neg] time port\_list

Specifies the slew time for a port on the top level module of a design or for a pin on an instance of a technology cell anywhere in the hierarchy. This command is useful only in specifying a hard ramp signal as if the pin were driven by a very powerful driver. The command does not change the arrival time of an input, but changes the slew time used to compute the delay of the cell on the sink of a net.

**Note:** The set\_slew\_time command is ignored for a port if the set\_drive\_cell or set\_drive\_resistance constraints have been set for that port.

#### **Options and Arguments**

| -clock <i>clk_signame</i> | Specifies the name of the ideal (or generated) clock waveform that is associated with the slew time. If this option is not specified, the assertion applies to all clocks.                                                          |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -early   -late            | Indicates whether the slew times are with respect to the early (hold) or the late (setup) time checks of the data signal. If neither time is specified, the default is to use both.                                                 |
| -lead   -trail            | Specifies whether the slew time data signal is triggered by the leading edge or trailing edge of the clock signal.<br>Default: -lead                                                                                                |
| port_list                 | Specifies the list of top level nets or technology cell instance pins for which the slew time is specified.                                                                                                                         |
| -pos   -neg               | Specifies, for a clock signal, that the slew time should be applied to an actual clock having a positive or negative polarity with respect to the clock. Specify only one option, either -pos or -neg per command.<br>Default: -pos |
| -rise   -fall             | Specifies that the slew time should be applied to the rising edge                                                                                                                                                                   |

or the falling edge of the signal (data or clock). If neither time is specified, the default is to use both.

time

Specifies the slew time.

## Examples

set\_slew\_time 0.5 input3
set\_slew\_time -clock B0 -pos 0.1 clk\_b

## **Related Information**

<u>reset slew time</u>

set\_drive\_cell

<u>set\_drive\_resistance</u>

set global slew propagation mode

<u>set\_global\_slew\_time\_limit</u>

set slew time limit

# set\_slew\_time\_limit

set\_slew\_time\_limit [-min | -max] float [-port port\_list] [-clock clock\_list]
 [-module module\_list]

Specifies the limit (maximum or minimum) for slew time at the input and output ports of a module. The slew limit is usually derived from the design rule constraints placed on the cells that an output port is driving or an input port is driven by.

Use this command to override the default slew time limit placed on specific ports by the set\_global max\_slew\_time\_limit or the set\_global min\_slew\_time\_limit globals.

See <u>Specifying Slew Rates</u> in the *Common Timing Engine (CTE) User Guide* for more information.

## **Options and Arguments**

| -clock <i>clock_list</i> | Specifies the maximum slew limit for one or more clock waveforms.                                                                   |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| float                    | Specifies the maximum (or minimum) slew allowed.                                                                                    |
| -min   -max              | Specifies minimum (or maximum) design rule constraints. If neither option is given, the default is -max for backward compatibility. |
| -module module_list      | Specifies the list of modules to which the limit applies. All instances of the specified modules will inherit the limit value.      |
| -port port_list          | Specifies the list of ports to which the limit applies.                                                                             |

# Example

The following command sets the maximum slew time limits for bus1 and bus2 to 2.3: set\_slew\_time\_limit 2.3 {bus1 bus2}

## **Related Information**

- <u>reset slew time limit</u>
- set capacitance limit
- set\_global max\_slew\_time\_limit
- set global min slew time limit
- set global slew propagation mode
- <u>set\_slew\_time</u>

# set\_tech\_info

```
set_tech_info
     {([-library list_of_library_names]
     [-default_wire_load wlm_name]
     [-default wire load selection wireload selection table]
     [-default_operating_conditions op_cond_name]
     [-default_fanout_load float] [-default_max_capacitance float]
     [-default_max_fanout value] [-default_max_transition value]
     [-default_min_capacitance value] [-default_min_fanout value]
     [-default_min_transition value]
     [-input_threshold_pct_rise float] [-input_threshold_pct_fall float]
     [-output threshold pct rise float] [-output threshold pct fall float]
     [-slew_lower_threshold_pct_rise float]
     [-slew_lower_threshold_pct_fall float]
     [-slew_upper_threshold_pct_rise float]
     [-slew upper threshold pct fall float]
     [-slew_lower_meas_threshold_pct_rise] |
     [-slew_lower_meas_threshold_pct_fall]
     [-slew_upper_meas_threshold_pct_rise] |
     [-slew_upper_meas_threshold_pct_fall] }
     [-pvt {min | typ | max}])
     ([-library list of library names]
     -cell list_of_cell_names
     {[-dont_modify true | false] [-dont_utilize true | false]
     [-scaling_factors value]
     [-input threshold pct rise float] [-input threshold pct fall float]
     [-output_threshold_pct_rise float] [-output_threshold_pct_fall float]
     [-slew_lower_threshold_pct_rise float]
     [-slew_lower_threshold_pct_fall float]
     [-slew_upper_threshold_pct_rise float]
     [-slew_upper_threshold_pct_fall float]
     [-slew_lower_meas_threshold_pct_rise] |
     [-slew lower meas threshold pct fall]
     [-slew_upper_meas_threshold_pct_rise] |
     [-slew_upper_meas_threshold_pct_fall] }
     [-pvt {min | typ | max}])
     ([-library list_of_library_names]
     -cell list_of_cell_names
     -pin list_of_pin_names
     [-fanout_load value] [-max_fanout value] [-min_fanout value]
     [-max_transition value] [-min_transition value]
     [-max_capacitance float] [-min_capacitance float]
     [-pvt {min | typ | max}])}
```

Makes assertions (overrides values) for the specified parameters in the named target technology libraries. Apply assertions to the library, cell, or pin level and specify one PVT value at a time.

Use this command to loosen overly pessimistic values in the library. Be careful when applying overrides to vendor determined values.

**Note:** The technology library must contain the attributes for which you want to overwrite the default values.

# Options and Arguments (any level)

```
-library list_of_library_names
```

Overrides data for the named libraries. *Default*: If this option is not specified, this command affects only the first library specified with the set\_global target\_technology global.

-pvt {min | typ | max}

Sets the value for the environment corner of interest. Set one PVT corner per command. *Default*: typ.

**Note**: If you use the set\_tech\_info command without the -pvt option, the command will set the information on all pvt corners that are already loaded in the library.

# Options and Arguments (library level)

-default\_fanout\_load float

Specifies the value of the default fanout load for all pins on all cells in the library.

-default\_max\_capacitance *float* Specifies the value of the default maximum capacitance for all pins on all cells in the library.

-default\_max\_fanout float

Specifies the value of the default maximum fanout for all pins on all cells in the library.

-default\_max\_transition float

Specifies the value of the default maximum transition time for all pins on all cells in the library.

Common Timing Engine (CTE) Commands

| -default_min_capacit        | ance <i>float</i><br>Specifies the value of the default minimum capacitance for all<br>pins on all cells in the library.                 |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| -default_min_fanout         | float<br>Specifies the value of the default minimum fanout for all pins on<br>all cells in the library.                                  |
| -default_min_transit        | ion <i>float</i><br>Specifies the value of the default minimum transition time for all<br>pins on all cells in the library.              |
| -default_operating_c        | onditions op_cond_name<br>Specifies op_cond_name as the default operating conditions<br>for the library.                                 |
| -default_wire_load_s        | election wireload_selection_table<br>Specifies the default wire-load selection table for the library.                                    |
| -default_wire_load w        | <pre>lm_name Specifies the default wireload for the library.</pre>                                                                       |
| -input_threshold_pct        | _fall float<br>Specifies the value of the default input threshold percent for the<br>falling edge for all cells in the library.          |
| -input_threshold_pct        | _rise float<br>Specifies the value of the default input threshold percent for the<br>rising edge for all cells in the library.           |
| -output_threshold_pc        | t_fall <i>float</i><br>Specifies the value of the default output threshold percent for the<br>falling edge for all cells in the library. |
| -output_threshold_pc        | t_rise <i>float</i><br>Specifies the value of the default output threshold percent for the<br>rising edge for all cells in the library.  |
| Note: The following slew th | nreshold options refer to the section of the waveform where the                                                                          |

**Note:** The following slew threshold options refer to the section of the waveform where the slew is nearly linear. This is measured and extended like a linear waveform. The linear waveform, a result of extending the near-linear slew waveform, is measured at certain points. The points where this extended waveform is measured are called slew thresholds. Measured slew thresholds are determined at the time of library characterization.

## **Slew Thresholds**

| -slew_lower_threshol               | d_pct_fall <i>float</i><br>Specifies the value of the default lower threshold percent for the<br>slew time of the falling transition for all cells in the library. |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -slew_lower_threshol               | d_pct_rise <i>float</i><br>Specifies the value of the default lower threshold percent for the<br>slew time of the rising transition for all cells in the library.  |
| -slew_upper_threshol               | d_pct_fall <i>float</i><br>Specifies the value of the default upper threshold percent for the<br>slew time of the falling transition for all cells in the library. |
| -slew_upper_threshol               | d_pct_rise <i>float</i><br>Specifies the value of the default upper threshold percent for the<br>slew time of the rising transition for all cells in the library.  |
| Measured Slew Threshol             | ds                                                                                                                                                                 |
| -slew_lower_meas_thr               | eshold_pct_fall<br>Specifies the measured lower threshold percent of the slew time<br>for the falling transition for all cells in the library.                     |
| -slew_lower_meas_thr               | eshold_pct_rise<br>Specifies the measured lower threshold percent of the slew time<br>for the rising transition for all cells in the library.                      |
| -slew_upper_meas_thr               | eshold_pct_fall<br>Specifies the measured upper threshold percent of the slew time<br>for the falling transition for all cells in the library.                     |
| -slew_upper_meas_thr               | eshold_pct_rise<br>Specifies the measured upper threshold percent of the slew time<br>for the rising transition for all cells in the library.                      |
| Options and Arguments (cell level) |                                                                                                                                                                    |

-cell list\_of\_cell\_names

Specifies the cells to which the assertions are applied. Required argument for cell and pin level assertions.

| -dont_modify {true   | <pre>false} When set to true this option puts the dont_modify property on the named cells. These cells are not modified by optimization or time budgeting. Default: false.</pre>                                                                                                                                                                                |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -dont_utilize {true  | <pre>  false} Puts the dont_utilize property on the named cells, when set to true. These cells are not used in optimization. Default: false</pre>                                                                                                                                                                                                               |
| -input_threshold_pct | L_fall <i>float</i><br>Specifies the value of the default input threshold percent for the<br>falling edge for the listed cells.                                                                                                                                                                                                                                 |
| -input_threshold_pct | z_rise <i>float</i><br>Specifies the value of the default input threshold percent for the<br>rising edge for the listed cells.                                                                                                                                                                                                                                  |
| -output_threshold_pc | t_fall <i>float</i> Specifies the value of the default output threshold percent for the falling edge for the listed cells.                                                                                                                                                                                                                                      |
| -output_threshold_pc | t_rise <i>float</i><br>Specifies the value of the default output threshold percent for the<br>rising edge for the listed cells.                                                                                                                                                                                                                                 |
| -scaling_factors der | cate_table_name<br>Specifies a derating table containing scaling factors for the cell<br>delay of the named cells.                                                                                                                                                                                                                                              |
|                      | <b>Note:</b> The read_library_update command has been<br>enhanced to update scaling factor groups to the target library<br>similar to a wire-load models update. Use the<br>-scaling_factors option with the read_library_update<br>command to set a new scaling factors group for a cell or to<br>change the scaling factors group of a cell within a library. |

**Note:** The following slew threshold options refer to the section of the waveform where the slew is nearly linear. This is measured and extended like a linear waveform. The linear waveform, a result of extending the near-linear slew waveform, is measured at certain points. The points where this extended waveform is measured are called slew thresholds. Measured slew thresholds are determined at the time of library characterization.

# Slew Thresholds

| -slew_lower_threshol                 | d_pct_fall <i>float</i><br>Specifies the value of the default lower threshold percent for the<br>slew time of the falling transition for the listed cells. |
|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -slew_lower_threshol                 | d_pct_rise <i>float</i><br>Specifies the value of the default lower threshold percent for the<br>slew time of the rising transition for the listed cells.  |
| -slew_upper_threshol                 | d_pct_fall <i>float</i><br>Specifies the value of the default upper threshold percent for the<br>slew time of the falling transition for the listed cells. |
| -slew_upper_threshol                 | d_pct_rise <i>float</i><br>Specifies the value of the default upper threshold percent for the<br>slew time of the rising transition for the listed cells.  |
| Measured Slew Thresholds             |                                                                                                                                                            |
| -slew_lower_meas_thr                 | eshold_pct_fall<br>Specifies the measured lower threshold percent of the slew time<br>for the falling transition for the listed cells.                     |
| -slew_lower_meas_thr                 | eshold_pct_rise<br>Specifies the measured lower threshold percent of the slew time<br>for the rising transition for the listed cells.                      |
| -slew_upper_meas_thr                 | eshold_pct_fall<br>Specifies the measured upper threshold percent of the slew time<br>for the falling transition for the listed cells.                     |
| -slew_upper_meas_thr                 | eshold_pct_rise<br>Specifies the measured upper threshold percent of the slew time<br>for the rising transition for the listed cells.                      |
| Options and Arguments<br>(pin level) |                                                                                                                                                            |

-fanout\_load float

Specifies the value of the fanout load for the named pins.

Overrides the library default value. Specify this option only for an input pin.

-max\_fanout float Specifies the value of the maximum fanout for the named pins. Overrides the library default value. Specify this option only for an output pin.

-max\_capacitance float

Specifies the value of the maximum capacitance for the named pins. Overrides the library default value. Specify this option only for an output pin.

-max\_transition float

Specifies the value of the maximum transition time for the named pins. Overrides the library default value. Specify this option for both input and output pins.

-min\_capacitance float

Specifies the value of the minimum capacitance for the named pins. Overrides the library default value. Specify this option only for an output pin.

-min\_fanout float

Specifies the value of the minimum fanout for the named pins. Overrides the library default value. Specify this option only for an output pin.

-min\_transition float

Specifies the value of the minimum transition time for the named pins. Overrides the library default value. Specify this option for both input and output pins.

-pin list\_of\_pin\_names

Specifies the pins to which the assertions are applied. Required argument for pin level assertions.

**Note:** The pin assertions apply to a specific pin type. If the correct pin type is not specified, an error is issued.

#### Examples

The following command overrides data for the named libraries:

set\_tech\_info -library lib1 lib2 -default\_fanout\_load 1.4111

The following command specifies the cell to which the assertions are applied, and puts the dont\_utilize property on the named cell:

```
set_tech_info -cell FD2ESSA -dont_utilize true
```

The following command overrides data for the named library, specifies the cell and pins to which the assertions are applied, sets the value for the min environment corner, and specifies the value of the maximum fanout for the named pins:

set\_tech\_info -library lca300kv -cell B2I -pin Z1 Z2 -pvt min -max\_fanout 3

The following commands set the values shown in Figure 7-17 for all cells in the target technology library:

```
set_tech_info -input_threshold_pct_rise 50 -input_threshold_pct_fall 50
set_tech_info -output_threshold_pct_rise 50 -output_threshold_pct_fall 50
set_tech_info -slew_lower_threshold_pct_rise 10
-slew_upper_threshold_pct_rise 90
set_tech_info -slew_lower_threshold_pct_fall 10
-slew_upper_threshold_pct_fall 90
```

### Figure 7-17 Thresholds Example



### **Related Information**

<u>get tech info</u>

<u>reset tech info</u>

write\_library\_assertions

### set\_time\_borrow\_limit

set\_time\_borrow\_limit [-pin pin\_list] [-clock list\_of\_clksigs] borrow\_limit

Specifies the maximum time that can be borrowed by one cycle from the next cycle in order to meet timing constraints. Time borrowing is sometimes called cycle stealing. Time borrowing is performed automatically when performing timing analysis.

Use the set\_time\_borrow\_limit assertion on pins or waveforms. If the assertion is placed on an ideal (or generated) clock waveform, all latches triggered by this clock signal get the specified maximum time borrow limit. If both the clock waveform arriving at the clock pin of a latch and the clock pin itself have time borrow limit assertions, the maximum borrow limit on the latch is decided by the assertion on the latch clock pin.

### **Options and Arguments**

| borrow_limit        |                                                                                                                                                                                                                                                                             |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | Specifies a non- negative real number, which is the maximum<br>amount of time that can be borrowed. The minimum value<br>allowed is 0, which disables time borrowing. The maximum<br>allowed is equal to the pulse width minus the setup time:<br>Max = pulse width - setup |
| -clock list_of_clks | ias                                                                                                                                                                                                                                                                         |
| CIOCK TISC_OI_CINS  | Specifies the ideal (or generated) clock names to which the borrow limit applies.                                                                                                                                                                                           |
|                     | If neither the $-\texttt{pin}$ or $-\texttt{clock}$ option is specified, the borrow limit is placed on all clocks.                                                                                                                                                          |
| nin nin en instand  | na list                                                                                                                                                                                                                                                                     |
| -pin pin_or_instand | Specifies a single pin, multiple pins, or instances to which the borrow limit applies. To specify multiple pins, enclose the list with curly braces ({)} and separate the pin information with white space.                                                                 |
|                     | Use the -pin option with the clock pin of the latch (L31/G) as shown in the example below.                                                                                                                                                                                  |
|                     |                                                                                                                                                                                                                                                                             |

#### Example

set\_time\_borrow\_limit -pin L31/G 0.1

### **Related Information**

<u>get time borrow limit</u>

reset time borrow limit

Analyzing Latch-Based Designs in the Common Timing Engine (CTE) User Guide.

### set\_time\_unit

```
set_time_unit float_unit
```

Specifies the time unit for the session. If you do not include this command, the time unit specified in the first library on the target technology list is used as the session time unit.

All timing assertions (such as the set\_input\_delay and the set\_slew\_time commands) for the session must use this time unit. All reports will also use this time unit. To find out the time unit for the session, use the get\_time\_unit command.

The set\_time\_unit command resets all assertions in the new unit that you specify, so expect the delay and slew numbers to be changing based on the new assertions. For example, after the following commands are used, the slew time asserted to all input ports is (1 \* 10) ns:

```
set_time_unit 10ns
set_slew_time 1 [find -input *]
```

If you then set the time unit to something else in the middle of the session, CTE will reset timing and recompute delays and slews. For instance, if you use set\_time\_unit 100ns, the original slew assertion is changed to (1 \* 100)ns, because the set\_time\_unit command reapplies the timing assertions with the new unit.



Use the set\_time\_unit command when reading multiple libraries with different units. If you do not specify the set\_time\_unit command, you must load the libraries in the same order for all sessions to ensure that CTE uses the correct time unit. Also, it is safer to use the set\_time\_unit command in the beginning of a session before applying any assertions, and not change the units afterwards.

### **Options and Arguments**

float\_unit

Specifies the time unit for this session in nanoseconds.

### Example

The following command sets the time unit to 0.001ns which is equivalent to 1ps:

set\_time\_unit 0.001

### **Related Information**

get\_time\_unit

<u>reset\_time\_unit</u>

### set\_top\_timing\_module

set\_top\_timing\_module module\_name

Identifies the module to be used by subsequent commands as a context for setting timing constraints. This command does not reset the current module or instance.

All the constraints are set with reference to the module specified as the top timing module. The optimization commands operate on the module (and its hierarchy) set by the top timing module. If you set a new top timing module, change the context for the subsequent timing constraints and the optimization steps. The constraints applied to the previous top timing module are preserved but do not affect the steps carried out in the new top timing module.

**Note:** If a different module needs constraints set on its ports as part of the top\_timing\_module context, then set them using the set\_current\_module command.

See <u>Deriving the Timing Context in Synthesis</u> in the *Common Timing Engine (CTE) User Guide* for information and examples on how to set the timing context for synthesis, how to compile single or multiple modules, and how to compile lower-level time-budgeted modules using the set\_top\_timing\_module command.

# Important

If you subsequently set the current module or instance, make sure that the specified module or instance is below the top timing module in the hierarchy.

### **Options and Arguments**

module\_name

Specifies the name of the module being set as the timing context.

#### Example

The following command sets the control\_block module as the context for all timing constraints. Specify timing constraints for the control\_block or any instances in the downward hierarchical path:

set\_top\_timing\_module control\_block

#### **Related Information**

<u>do optimize</u>

do xform timing correction

get\_top\_timing\_module

set current module

### set\_wire\_capacitance

set\_wire\_capacitance float net\_names [-subtract\_pin\_caps] [-pvt {min | typ | max}]

Overrides the wire capacitance value used during timing analysis. This command is not written out by the write\_assertions or the <u>write\_sdc</u> commands, but wire capacitance annotations are saved in the .adb file.

By default, the total capacitance seen by the driver of the net is the specified wire capacitance, plus the sum of pin and port capacitance on the net. If you use the <code>-subtract\_pin\_caps</code> option, only the specified wire capacitance value is used.

For a PAD cell, the net PAD/out to output port exists only in a logical design but not in the physical design. It is for this reason the set\_wire\_capacitance assertion on the net that connects PAD/out to output port is not honored, and a 0 cap value is asserted. The same holds true if the PAD/input is connected directly to an input port. For example, if a design has two PAD instances, where the cell has one input, and one output, and the PAD instances outputs are connected to output ports, the set\_wire\_capacitance settings will not be annotated for (1 + 1) = 2 nets.

**Note:** The set\_wire\_resistance command is not affected, which can be successfully set on any net, including port-to-pad nets.

#### **Options and Arguments**

| float                | Specifies the wire capacitance to be backannotated. Units are determined by the library.                                                                                                                                                                                                                                          |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| net_names            | Specifies the list of nets having this capacitance.                                                                                                                                                                                                                                                                               |
| -pvt {min   typ   ma | Sets the capacitance for a particular PVT (process, voltage,<br>temperature) corner. Choose one, two, or three PVT corners. If<br>you choose more than one corner, enclose the list in curly braces<br>({}) and separate the values by spaces.<br><i>Default</i> : The specified capacitance applies to all three PVT<br>corners. |
| -subtract_pin_caps   | Calculates wire capacitance by subtracting the capacitance on pins and ports of the net from the specified wire capacitance                                                                                                                                                                                                       |

value. The wire capacitance that is backannotated does not include pin capacitance.

### Examples

■ The following commands backannotate a wire capacitance of 2 on the net named foo for min and typ environment corners, then a wire capacitance of 2.2 for max PVT:

set\_wire\_capacitance 2 foo -pvt {min typ}
set\_wire\_capacitance 2.2 foo -pvt max

■ The following command backannotates a wire capacitance of 1.5, factoring that the total pin capacitance on net foo is 0.5:

set\_wire\_capacitance 2 foo -pvt {min max} -subtract\_pin\_caps

### **Related Information**

<u>report\_net</u>

reset wire capacitance

<u>set wire resistance</u>

### set\_wire\_load

set\_wire\_load [-library library\_name] [-pvt {min | typ | max}] [-hier]
wireload\_model list\_of\_instances

Specifies the wire-load model to be used from the technology library, and sets the wire-load model on the current instance, if the list of instances is omitted. Otherwise, the wire-load model is set on all specified instances.

Use wire-load models for estimating delays before the actual wire loads are backannotated. A technology library contains different wire-load models, previously computed based on the analysis of several designs differing in area. Use the report\_library command to list all the wire-load models in a library. To set a wire load on individual ports, use the <u>set port wire load</u> command.

#### **Options and Arguments**

-hier

Affects wire-load assertions in the enclosed wire-load mode. (See <u>set wire load mode</u> on page 1274). By default (without the -hier option), in the enclosed wire load mode, the asserted wire-load model applies to only those nets for which the specified hierarchical instance is the lowest enclosing module.

If the -hier option is set, then for all nets fully contained within the hierarchical instance (or any of its lower level hierarchical instances), the asserted wire-load model is used, unless another such assertion is present on one of the lower level hierarchical instances.

In the top wire-load mode, a wire-load assertion on a hierarchical instance applies to all the nets fully enclosed within the hierarchical instance (unless there is another such wire load assertion present on one of the lower level hierarchical instances) meaning the -hier switch is always on.

The following describes how the wire load for a net is looked up. The search process starts with the lowest hierarchical instance completely enclosing the net and recursively traverses up the hierarchy chain, until it reaches (and includes) the top module.

#### Enclosed wire load mode

|                            | If a wire-load model is asserted on the lowest enclosing<br>hierarchical instance (with or without the -hier option), that<br>wire-load model is used. Otherwise, the search travels up the<br>hierarchy looking for an asserted wire-load with the -hier<br>option. If one is found, that wire load is used. Otherwise,<br>area-based lookup is used.                                                               |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | <b>Note:</b> As the search traverses up the hierarchy chain, if a wire load without a -hier option is found, that assertion is ignored. Thus, the assertion for wire-load model without the -hier option applies only to the nets fully enclosed within that specific hierarchical instance (and not in any of its lower level hierarchical instances).                                                              |
|                            | <b>Top mode</b><br>In this mode, the -hier option on the wireload assertion is<br>completely ignored. Again, start from the lowest enclosing<br>hierarchical instance and travel up the hierarchy chain. As soon<br>as a wire-load assertion is found on an instance (with or without<br>the -hier option), that wire-load model is used. If no wire-load<br>assertion is found, then the area-based lookup is used. |
| -library <i>library_na</i> | me<br>Specifies the technology library to use when searching for the<br>wire load model.                                                                                                                                                                                                                                                                                                                             |
| library_name               | Specifies the name of the technology library.                                                                                                                                                                                                                                                                                                                                                                        |
| list_of_instances          | Specifies the list of instances.                                                                                                                                                                                                                                                                                                                                                                                     |
| -pvt {min   typ   ma       | Sets the wire-load model for a particular PVT (process, voltage, temperature) corner. Choose one, two, or three PVT corners. If you choose more than one corner, enclose the list in curly braces ({ }) and separate the values by spaces.<br>Default: The specified wire-load model applies to all three PVT corners.                                                                                               |
| wireload_model             | Specifies the name of the wire-load model in the library.                                                                                                                                                                                                                                                                                                                                                            |

### Example

set\_wire\_load B5X5 {I\_block J\_block}

### **Related Information**

do derive context

<u>report library</u>

set\_current\_module

set global target technology

set port wire load

set wire load mode

See <u>Specifying Wire Loads</u> in the Common Timing Engine (CTE) User Guide.

### set\_wire\_load\_mode

set\_wire\_load\_mode {top | enclosed}

Controls the determination of the wire-load model.

### **Options and Arguments**

enclosed

Selects the wire-load model using an area lookup table for the module that is at the lowest level in the design hierarchy that contains the entire net.

top

Selects the wire-load model using the area lookup table of the top level module (as set by the set\_top\_timing\_module command). Default: top

#### Example

The following command sets the wire-load model to enclosed:

set\_wire\_load\_mode enclosed

### **Related Information**

<u>report\_library</u>

<u>reset wire load mode</u>

<u>set\_current\_module</u>

<u>set global target technology</u>

<u>set top timing module</u>

set\_wire\_load

See <u>Specifying Wire Loads</u> in the Common Timing Engine (CTE) User Guide.

### set\_wire\_load\_selection\_table

```
set_wire_load_selection_table [-library library_name] [-pvt {min | typ | max}]
        [-min_area float] wireload_selection_table
```

Overrides the wire-load selection table in the library specified by the *library\_name* argument. When *library\_name* is the target technology library, the specified wire\_load\_selection\_table is used in analysis.

### **Options and Arguments**

| -library library_name    |                                                                                           |  |
|--------------------------|-------------------------------------------------------------------------------------------|--|
|                          | Specifies the name of the technology library to search for the wire-load selection table. |  |
|                          | <i>Default</i> : The target_technology file.                                              |  |
| -min_area float          |                                                                                           |  |
|                          | Selects the area wire-load model for all area values smaller than <i>float</i> .          |  |
| -pvt {min   typ   max}   |                                                                                           |  |
|                          | Controls the choice of a wire-load selection table for different PVT values.              |  |
|                          | Default: Selects the table for all PVTs.                                                  |  |
| wireload_selection_table |                                                                                           |  |
|                          | Specifies the name of the wire-load selection table.                                      |  |

#### Example

set\_wire\_load\_selection\_table TLM

#### **Related Information**

| <u>report_lib</u> | <u>prary</u> |
|-------------------|--------------|
|-------------------|--------------|

<u>reset\_wire\_load\_selection\_table</u>

set global target technology

<u>set wire load</u>

### set\_wire\_resistance

set\_wire\_resistance [-pvt {min | typ | max}] float net\_names

Overrides the wire resistance value used during timing analysis. This command is not written out by the write\_assertions or write\_sdc commands, but wire resistance annotations are saved in the .adb file.

### **Options and Arguments**

| float                | Specifies the resistance value                                                                                                                                                                                                                                                                                                  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| net_names            | Specifies the list of nets with the resistance                                                                                                                                                                                                                                                                                  |
| -pvt {min   typ   ma | Sets the resistance for a particular PVT (process, voltage,<br>temperature) corner. Choose one, two, or three PVT corners. If<br>you choose more than one corner, enclose the list in curly braces<br>({}) and separate the values by spaces.<br><i>Default</i> : The specified resistance applies to all three PVT<br>corners. |

#### Example

The following command sets the resistance for the nets bus1 and bus2 at 4.6:

set\_wire\_resistance 4.6 {bus1 bus2}

#### **Related Information**

<u>report\_net</u>

<u>reset wire resistance</u>

<u>set wire capacitance</u>

### unload\_dcl\_rule

unload\_dcl\_rule

Removes a previously loaded binary Delay and Power Calculation Module (DPCM) from memory. The DPCM is an executable shared library that is linked to an application (such as BuildGates Synthesis) at runtime. DPCM is often abbreviated as DCM. After unloading the DCM, all timing calculations are performed without information from the DCM.

### Example

unload\_dcl\_rule

### **Related Information**

<u>load dcl rule</u>

### write\_assertions

write\_assertions [-no\_internal\_arr\_req] [-no\_timing] [-no\_tag] [file\_name]

Writes out the assertions made on the design prior to timing analysis for future reference and use. The assertions for the module may have been asserted by the user or created by the do\_derive\_context, do\_time\_budget, or do\_push commands.

The assertions for wire capacitance and wire resistance are not written out by the write\_assertions command. Wire capacitance and wire resistance are stored in the ADB file.

### **Options and Arguments**

| file_name            |                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | Specifies the name of the file in which to write the assertions. If the <i>file_name</i> argument is not specified, assertions are written to stdout.                                                                                                                                                                                                                                                        |
| -no_internal_arr_req |                                                                                                                                                                                                                                                                                                                                                                                                              |
|                      | Specifies the internal arrival times are not written to the file.                                                                                                                                                                                                                                                                                                                                            |
| -no_tag              |                                                                                                                                                                                                                                                                                                                                                                                                              |
|                      | Removes all proprietary information (set_begin_tag, -tag, -from_tag, and -info) from the output file. The resulting assertions file is in a form that is easier for a script to translate to a third-party language.                                                                                                                                                                                         |
|                      | <b>Note:</b> The -no_tag option works only for chip-level constraints.<br>If you have completed time budgeting, then using the<br>write_assertions -no_tag command for block level<br>constraints does not work. Removing tags from constraints is not<br>the solution either. This is similar to dropping constraints from the<br>design. Therefore, you can only use budgeted block constraints<br>in CTE. |
| -no_timing           |                                                                                                                                                                                                                                                                                                                                                                                                              |
|                      | Specifies the timing assertions, such as clock assertions, arrival<br>and required time assertions are not written to the file. Only<br>those assertions that are not related to timing checks, such as<br>load, drive, wire-load model, operating conditions, and so on, are<br>written out.                                                                                                                |

### Example

The following command saves all the assertions, except timing assertions, in  ${\tt my\_assert\_file}$ :

write\_assertions -no\_timing my\_assert\_file

### **Related Information**

<u>do\_derive\_context</u>

<u>do push</u>

do time budget

remove\_assertions

### write\_constraints

```
write_constraints [-max_slack slack_value] [-max_paths num_paths]
      [-coverage_ratio float] [-min_constraint float] file_name
```

Writes the constraints of the current top\_timing\_module context to the named file. The file is written in a Standard Delay Format (SDF) for timing-driven place and route using path constraint constructs to cover all nets in the design.

The write\_constraints command outputs constraints for use by place and route tools. Therefore, this command must provide a set of paths that cover the design. The paths included are only those whose slack is less than the value specified by the -max\_slack option.

#### **Options and Arguments**

| -coverage_ratio <i>floa</i> | t<br>Specifies a coverage ratio that is the number of arcs covered in<br>the constraints divided by the total number of arcs in the design.<br>Limit the number of paths by specifying a coverage_ratio. |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| file_name                   | Specifies the name of the resulting SDF file.                                                                                                                                                            |
| -max_paths num_paths        | Specifies an optional limit to the number of paths produced.<br>Default: 1000                                                                                                                            |
| -max_slack <i>slack_val</i> | ue<br>Limits the number of paths by specifying the maximum slack of<br>the net for which to write a path.<br>Default: +infinity                                                                          |
| -min_constraint floa        | t<br>Relaxes the written path constraints by the specified amount.<br>Otherwise, if the paths in the design are overconstrained, the<br>resulting constraint file is also similarly overconstrained.     |

#### Examples

set\_top\_timing\_module top
set\_current\_module top
write\_constraints constraints.sdf

See Example SDF Constraint File in the Common Timing Engine (CTE) User Guide.

### **Related Information**

<u>write\_sdf</u>

### write\_gcf\_assertions

```
write_gcf_assertions [-version {1.3 | 1.4}] [file_name]
        [-tlf_pvt { min | typ | max }]
```

Automatically translates the CTE Tcl constraints into Cadence General Constraint Format (GCF). When using timing analysis, SE-DSM, or SE-Ultra for ASIC design, there are two timing analysis engines that interact between the synthesis and the place-and-route phase. The frontend of the flow uses the Common Timing Engine (CTE) and the backend uses Pearl<sup>®</sup> from the place-and-route tool suite. Pearl also reads the TLF libraries to calculate the delays in the ASIC during floorplanning and place & route. Pearl utilizes the GCF constraints file in conjunction with the TLF libraries or the Verilog gate-level netlist to create the file to drive all the floorplanning and place-and-route phases of Cadence Design Planner and Silicon Ensemble. This combination yields a very tight correlation between the timing reports generated by Pearl and those generated by Cadence timing analysis. This combination also speeds up the conversion process to final silicon. Other flows like the SE-PKS flow use CTE throughout and do not require any constraint translation to GCF.

### **Options and Arguments**

| file_name            | Specifies the file name. If it is not specified, the default is the standard output.                                                                                                                                          |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -tlf_pvt {min   typ  | <pre>max} Writes out the min, typ, and max TLF library. The typ library defaults (if not specified) to the first library read by the read_tlf command. Default: Writes out the typ library</pre>                              |
| -version {1.3   1.4} | Specifies the version of GCF to write out. The version shows in the header of the GCF file and is used by the tools that read GCF. Version 1.4 has more constructs for greater inter-tool compatibility. <i>Default</i> : 1.4 |

### Example

The following command writes out the file cpu.gcf:

```
write_gcf_assertions cpu.gcf
```

### **Related Information**

<u>read\_tlf</u>

<u>read\_verilog</u>

<u>read\_vhdl</u>

<u>report\_timing</u>

<u>write\_verilog</u>

See <u>Generating GCF Files</u> in the Common Timing Engine (CTE) User Guide.

## write\_library\_assertions

write\_library\_assertions [-library list\_of\_library\_names] file\_name

Writes out assertions you have made to the named libraries using the set\_tech\_info command.

### **Options and Arguments**

file\_name

Specifies the name of the output file. Required argument.

-library list\_of\_library\_names

Reports data for the named libraries. *Default*: All libraries specified with the set\_global target\_technology global.

#### Example

The following command writes out all assertions previously defined by the set\_tech\_info command:

write\_library\_assertions assert.txt

The contents of <code>assert.txt</code> shows that two default values in the <code>cb</code> library have been overwritten:

set\_tech\_info -library cb -default\_max\_transition 5.000000 -pvt typ
set\_tech\_info -library cb -default\_max\_capacitance 2.500000 -pvt min

#### **Related Information**

<u>get\_tech\_info</u>

<u>reset tech info</u>

set\_tech\_info

# write\_rspf

write\_rspf
 OBSOLETE: Use write\_spf instead.

The write\_rspf command is no longer supported, use write\_spf instead.

### **Related Information**

<u>write spf</u>

### write\_sdc

```
write_sdc [-version {sdc1.1 | sdc1.2 | sdc1.3}] [-include_wire_rc]
    [-leading_edge_falling clock_name] [-comment_non_integer_multicycle]
    [-exclude_ignored_exceptions] [-format {sdc|pttcl}] file_name
```

Uses equivalent timing constraints to perform RTL synthesis and gate level timing analysis in PKS and PrimeTime respectively. See <u>SDC Constraint Support Guide</u> for more details about this command.

**Note:** The write\_sdc command does not support design budgeting constraints.

To write out the set\_operating\_conditions command with the -analysis\_type option, use the -format option with the write\_sdc command to write out the PrimeTime tcl format.

### **Options and Arguments**

```
-comment_non_integer_multicycle
                          By default, write_sdc rounds up the setup or hold multiplier
                          value. In CTE, the value is of type float (for instance, you can
                          assign a cycle addition of 2.3). Synopsys supports only integer
                          values. By default, write_sdc rounds the float value to the
                          nearest integer. Use the following to override this default:
                          write_sdc -comment_non_integer_multicycle
-exclude_ignored_exceptions
                          By default, write sdc writes out all ignored exceptions. Use
                          this option if you do not want these exceptions to be written out.
                          Note: Using this option may increase the write_sdc runtime.
file_name
                          Specifies the name of the Synopsys design constraint (SDC)
                          output file.
-format {sdc|pttcl}
                          Writes output in the PrimeTime tcl format.
                          Use the SDC format to write out only the constraints and options
                          that are standardized in the SDC specifications.
```

|                      | Use the pttcl format to write out a non-standard option.<br>Currently, only the non-standard options of the<br>set_operating_condtions constraint is written out.                                                                                                              |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -include_wire_rc     | Allows the translation of the CTE set_wire_capacitance<br>and set_wire_resistance commands to the Synopsys<br>set_load and set_resistance commands. By default, this<br>translation is disabled, because translating these commands for<br>large designs can take a long time. |
| -leading_edge_fallin |                                                                                                                                                                                                                                                                                |
| -version             | By default, write_sdc writes out the translations in sdc1.3 format. Use this option if you want output in the SDC1.1 or SDC1.2 format.                                                                                                                                         |

### **Related Information**

<u>read dc script</u>

sdc write unambiguous names

### write\_sdf

write\_sdf [-version { 2.1 | 3.0 }] [-precision non\_neg\_integer]
 [-scale float] [-delimiter char] [ {-early | -late} ]
 [-transform\_out\_to\_out\_arcs] [-celltiming {all | none | nochecks}]
 [-interconn {all | none | noport | noinport | nooutport}]
 [-edges {edged | library | noedge | check\_edge}] [-remashold] [-splitrecrem]
 [-splitsetuphold] [-condelse] [-nonegchecks] [-force\_calculation]
 [file\_name] [-compute\_clock\_network\_delays]

Writes delays to a Standard Delay Format (SDF) file.

*Default*: The write\_sdf command uses the delays already cached by the system and writes only values of the triplets specified by the pvt\_early\_path and pvt\_late\_path globals. Using the -force\_calculation option calculates each PVT with a slew depth of 2.

By default, this command writes 0 delays for the clock network when the clock propagation mode is ideal.

**Note:** The -compute\_clock\_network\_delays option only works with the -force\_calculation option.

For supported SDF constructs, see <u>Supported SDF Constructs</u> in the *Common Timing Engine* (*CTE*) *User Guide*.

### **Options and Arguments**

-celltiming {all | none | nochecks} Specifies which cell delays and timing checks to write out. Default: all

all

Writes all cell delays and timing checks to the SDF file. This is the default.

nochecks Disables the writing of timing checks only.

#### none

Prevents cell delays and timing checks from being written into the SDF file.

-compute\_clock\_network\_delays

Use the -compute\_clock\_network\_delays option with the -force\_calculation option to write the actual delays for

|                        | clock network elements (gates and interconnections) when the clock propagation mode is ideal.                                                                                                                                                                                                                                                                                                                                                         |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -condelse              | Writes CONDELSE constructs with the default value when a COND construct is written.                                                                                                                                                                                                                                                                                                                                                                   |
|                        | <b>Note:</b> Use this argument with the -version 3.0 option (see page <u>1292</u> ).                                                                                                                                                                                                                                                                                                                                                                  |
| -delimiter <i>char</i> | Specifies the hierarchy divider character to use in the SDF output file. This option sets the hierarchy divider of only the write_sdf command. If omitted, the default ac_shell hierarchy divider character (/) is used as the write_sdf default.                                                                                                                                                                                                     |
| -early   -late         | Specifies an early mode or late mode analysis for computing SDF delays. <i>Default</i> : -late                                                                                                                                                                                                                                                                                                                                                        |
|                        | Using these options only affects the input slew used to compute delays when the -force_calculation option is specified, or when the write sdf force calculation global is set to true.                                                                                                                                                                                                                                                                |
|                        | If you specify the -early option, the slews associated with the<br>early path are used to compute timing arc delays. If you specify<br>the -late option, the slews associated with the late path are<br>used to compute timing arc delays. These options are ignored if<br>the -force_calculation option is not used. For more<br>information, see <u>Writing Out SDF Delay Files</u> in the <i>Common</i><br><i>Timing Engine (CTE) User Guide</i> . |
| -edges {edged   libr   | Sary   noedge  check_edge}<br>Specifies the edges values. Refer to <u>Table 7-9 on page 1292</u> for<br>full qualifications of the possible values for the edges option.<br><i>Default</i> : edged                                                                                                                                                                                                                                                    |
|                        | <b>check_edge</b><br>Keeps edge specifiers on timing check arcs but does not add<br>edge specifiers on combinational arcs.                                                                                                                                                                                                                                                                                                                            |

|                      | edged<br>Writes the SDF IOPATH and timing checks with appropriate<br>edges.                                                                                                                                                                                                |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | <b>library</b><br>Assumes that the <i>sdf_edges</i> attributes are specified in the<br>.lib file or the library. The default <i>sdf_edges</i> value of a timing<br>arc is noedge.                                                                                          |
|                      | noedge<br>Defined in <u>Table 7-9 on page 1292</u> .                                                                                                                                                                                                                       |
| file_name            | Specifies the name of the SDF output file. If omitted, this argument defaults to stdout.                                                                                                                                                                                   |
| -force_calculation   | Forces the recomputation of delays during write_sdf and writes triplets (min:typ:max). This was the default behavior prior to 4.0.8. Use this option for backward compatibility with 4.0, but be aware that this option significantly increases the run time of write_sdf. |
|                      | See <u>Writing Out SDF Delay Files</u> in the <i>Common Timing Engine (CTE) User Guide</i> for more information.                                                                                                                                                           |
| -interconn {all   no | ne   noport   noinport   nooutport}<br>Specifies which interconnect delays to write.<br>Default: all                                                                                                                                                                       |
|                      | all<br>Writes all INTERCONN delays into the SDF file. This is the<br>default if the -interconn option is not specified.                                                                                                                                                    |
|                      | none<br>No INTERCONN delays are written into the SDF file.                                                                                                                                                                                                                 |
|                      | noport<br>No top level port INTERCONN delays are written into the SDF file.                                                                                                                                                                                                |
|                      | noinport<br>Disables only the input port INTERCONN delays.                                                                                                                                                                                                                 |

|                     | nooutport<br>Disables only the output port INTERCONN delays.                                                                                                                                                                                                            |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -nonegchecks        | Converts all negative timing check values to 0.0.                                                                                                                                                                                                                       |
| -precision non_neg_ | <i>integer</i><br>Controls the number of digits appearing after the decimal point<br>in the output SDF file. The default precision is the value of the<br>report_precision.                                                                                             |
| -remashold          | Converts the SDF v2.1 unsupported REMOVAL (and the REMOVAL portion of the RECREM constructs) to HOLD checks when used with the -version 2.1 option. <i>Default</i> : Not to write out the unsupported checks.                                                           |
|                     | Converts the REMOVAL checks to HOLD checks when combined<br>with the -version 3.0 option. The RECREM checks are split into<br>a RECOVERY check and a HOLD check. This option automatically<br>splits the RECREM checks.<br>Default: To maintain the version 3.0 checks. |
| -scale <i>float</i> | Specifies a multiplier to the delay values used in the SDF file.<br>This option does not change the timescale setting of the SDF<br>file. The delay values are scaled, but the units are the same.<br><i>Default</i> : 1                                                |
| -splitrecrem        | Splits the RECREM checks into a RECOVERY check and a REMOVAL check.<br>Default: To write the combined RECREM check.                                                                                                                                                     |
|                     | <b>Note:</b> Use this option only with the version 3.0 option (see page <u>1292</u> ).                                                                                                                                                                                  |
| -splitsetuphold     | Splits the SETUPHOLD timing checks into separate SETUP and HOLD checks.<br>Default: To write the combined SETUPHOLD checks.                                                                                                                                             |

#### -transform\_out\_to\_out\_arcs

Writes out all output-to-output timing arcs as input-to-output arcs. Input-to-output arc delays are computed by adding the delay from the input pin to one of the output pins plus the delay from that output pin to the other output pin. For instance, in the following figure, the delay between in and out 2 would be the sum of delay1 and delay2.



Specifies whether to generate the SDF V2.1 or V3.0. The default SDF version is 3.0. Used in combination with the <u>remashold</u> option.

|                                                      | edged Value                           | library Value                                                                               | noedge Value                                                                                                                               |
|------------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| IOPATH from<br>a unate input<br>pin to output<br>pin | No edge<br>specifier                  | No edge specifier                                                                           | No edge<br>specifier                                                                                                                       |
| IOPATH from<br>a non-unate<br>input pin to           | Edge<br>specifier at<br>the input pin | Edge specifier at the input pin when<br>sdf_edges is either "both_edges" or<br>"start_edge" | No edge<br>specifier                                                                                                                       |
| output pin                                           |                                       |                                                                                             | When merging<br>edged paths, the<br>maximum values<br>are used for<br>MAX and TYP<br>fields; minimum<br>values are used<br>for MIN fields. |

| Table 7-9 | <b>Definition of</b> | -edges | Option | Values |
|-----------|----------------------|--------|--------|--------|
|-----------|----------------------|--------|--------|--------|

|                                                       | edged Value                                                                            | library Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | noedge Value                                                       |
|-------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| IOPATH of a<br>clock/enable<br>pin to data<br>out pin | Edge<br>specifier at<br>the input pin                                                  | Edge specifier at the input pin when sdf_edges is either "both_edges" or "start_edge"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | No edge<br>specifier                                               |
| Timing<br>Checks                                      | Edge<br>specifiers<br>match the<br>check arcs<br>specified in<br>the timing<br>library | <ul> <li>Overridden by value of the sdf_edges attribute</li> <li>For both_edges, the timing checks will contain edge specifier on both starting and ending pins</li> <li>For start_edge, the starting pin (for HOLD type check) or ending pin (for SETUP type check) is edge-specified</li> <li>For end_edge, the ending pin (for HOLD style check) or the starting pin (for SETUP type check) is edge-specified</li> <li>The timing checks are duplicated or combined appropriately. The start_edge and end_edge are interpreted as first and second events, respectively, of the Verilog-XL's \$hold() and \$setup system tasks</li> </ul> | Only the edge<br>specifiers of the<br>reference pin are<br>written |

#### Table 7-9 Definition of -edges Option Values, continued

### Examples

The following command writes out an SDF 2.1 compliant output file named my.sdf with 4 digits after the decimal point:

write\_sdf -version 2.1 -precision 4 my.sdf

■ The following example SDF files compare the output of -edges edged to the output of -edges noedge.

Resultant SDF with -edges set to edged:

```
(HOLD (posedge D) (posedge CK) (-0.14:-0.14:-0.14))
(HOLD (negedge D) (posedge CK) (-0.06:-0.06:-0.06))
```

(SETUP (posedge D) (posedge CK) (0.22:0.22:0.22)) (SETUP (negedge D) (posedge CK) (0.41:0.41:0.41))

With -edges set to noedge only the edge specifiers of the clock pin are written.

(HOLD D (posedge CK) (-0.14:-0.06:-0.06)) (SETUP D (posedge CK) (0.22:0.41:0.41))

### **Related Information**

<u>write\_pdef</u>

<u>write\_verilog</u>

See <u>Writing Out SDF Delay Files</u> in the Common Timing Engine (CTE) User Guide.

For supported SDF constructs, see <u>Supported SDF Constructs</u>.

### write\_spf

Writes out the reduced parasitics model to the named file. Reduced parasitics models can come from reduced or detailed parasitics previously loaded using the read\_spf or read\_spef commands, or from parasitics extracted from a PKS Steiner tree.

**Note:** This command replaces the obsolete write\_rspf command.

### **Options and Arguments**

| -add_pks_rspf        | Writes out a reduced model from PKS Steiner tree into the SPF file. Writes out reduced models (Pi-Elmore or Ctotal-Elmore) regardless of whether they were created from global or final routes. |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| file_name            | Specifies the name of the file to which the reduced SPF is written.                                                                                                                             |
| -no_instance_section | Tells the system not to write the instance section of the SPF file.<br>Some tools require the instance section, you should check<br>before using this option.                                   |
| -pvt {min   typ   ma | x}<br>Specifies which PVT value to write. SPF format supports only<br>one value (no pairs or triplets). Choose min, typ, or max.                                                                |

### Example

write\_spf -pvt min min.rspf

### **Related Information**

<u>read\_spf</u>

<u>read\_spef</u>

### write\_timing\_windows

write\_timing\_windows [-sstorm] [-pin] output\_file

Generates a Timing Window File (TWF) used by crosstalk analysis tools such as Celtic<sup>™</sup> or delay calculator tools such as SignalStorm<sup>™</sup>. The TWF file mainly contains the earliest and the latest possible arrival times that a signal may arrive on a net or a pin.

For an example of the Timing Window File format see the <u>CeltIC manual</u>.

**Note:** SignalStorm requires a pin-based timing windows file. Using the -sstorm option, PKS writes out pin-based timing windows for SignalStorm.

#### **Options and Arguments**

filename

Specifies the TWF filename.

-pin:

Generates a TWF for each pin instead of each net. *Default*: Generates a TWF for the CeltIC crosstalk analysis tool, which contains timing windows on each net.

**Note**: The -pin option is ignored when writing out a timing windows file for SignalStorm.

-sstorm

Generates a Timing Windows File (TWF) for the SignalStorm delay calculator tool.

# 1

# **Temporary Commands**



This chapter contains descriptions for temporary commands, which usually begin with an underscore (\_), intended for use only in the situations described. These commands are often untested, unsupported, and intended only as temporary workarounds. Also, some of these functions are considered high risk, in that they may cause serious problems with your design if not used with extreme caution.

If you are using a hidden command in your flow and would like it documented, please let us know by using the *CDSDoc Feedback* button or by e-mailing *synthesis\_hidden@cadence.com*.

This chapter contains the following sections:

- <u>Timing Analysis on page 1310Datapath Synthesis</u> on page 1299
- Optimization on page 1302
- <u>PKS</u> on page 1307

# **Timing Analysis on page 1310Datapath Synthesis**

This section describes the hidden commands associated with Datapath Synthesis in BuildGates Synthesis and Cadence PKS.

- <u>write datapath pdef</u> on page 1300
- <u>Turning on the Prototype DP GUI</u> on page 1301

### write\_datapath\_pdef

write\_datapath\_pdef [-hier] [-module <module\_name>]

Provides you with access to the hierarchical relative placement for DP partitions. The command outputs the hierarchical relative placement (PDEF 3.0) for the DP partitions in the current module or the module specified. If the -hier option is specified, PDEF is output for all instances of DP partitions contained in the hierarchy below the current module. You can then use this PDEF with other third party tools or use it to manually floorplan a design with multiple DP partitions instead of using the automated flow.

#### **Options and Arguments**

-hier

Outputs all instances of DP partitions contained in the hierarchy below the current module in the PDEF.

-module <module\_name>

Outputs only the module specified in the PDEF.

# Turning on the Prototype DP GUI

We are in the process of developing a graphical user interface for datapath synthesis. To see and try the prototype version available in this release, launch BuildGates Extreme Synthesis or Cadence PKS as follows:

bgx\_shell -gui -set show\_dp\_tab=1
pks\_shell -gui -set show\_dp\_tab=1

**Note:** Because this is a prototype version, functionality is not complete or stable.

# Optimization

This section describes the hidden commands associated with optimization used in BuildGates Synthesis and Cadence PKS.

- <u>get cell area</u> on page 1303
- get cell pin load on page 1304
- <u>set\_cell\_area</u> on page 1305
- <u>set cell pin load</u> on page 1306

### get\_cell\_area

get\_cell\_area *cell\_id* 

Returns the area of the specified cell.

#### **Options and Arguments**

cell\_id

Specifies the object identifier associated with a cell.

#### **Related Information**

<u>set\_cell\_area</u>

#### Examples

>get\_cell\_area 60979 16.0

## get\_cell\_pin\_load

get\_cell\_pin\_load [-library library\_name] -cell cell\_name -pin pin\_name

Returns the capacitive load at the specified pin of a cell in the library. The units of the load are the same as the units used in the library.

#### **Options and Arguments**

| library library_name   |                                                                                                                                            |  |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|
|                        | Specifies the name of the library.                                                                                                         |  |
| -cell <i>cell_name</i> |                                                                                                                                            |  |
|                        | Specifies the name of the cell. If this option is omitted the pin load for all cells in the named libraries are returned.                  |  |
| -pin <i>pin_name</i>   |                                                                                                                                            |  |
|                        | Specifies the name of the pin. If this option is omitted the pin load for all pins on the named cells in the named libraries are returned. |  |

#### **Related Information**

<u>set cell pin load</u>

#### Examples

```
>get_cell_pin_load -cell IV -pin z
2.0
```

### set\_cell\_area

set\_cell\_area cell\_id float

Sets the area of the specified cell.

#### **Options and Arguments**

cell\_id

Specifies the object identifier associated with a cell.

float

Specifies the value of the cell area.

#### Examples

set\_cell\_area 60979 16.0

## set\_cell\_pin\_load

set\_cell\_pin\_load [-library library\_name] -cell cell\_name -pin pin\_name float

Sets the value of the capacitive load at the specified pin of a cell in the library. The units of the load are the same as the units used in the library.

#### **Options and Arguments**

| Specifies the load value to be set on the pin.                                                                                |  |  |
|-------------------------------------------------------------------------------------------------------------------------------|--|--|
| library library name                                                                                                          |  |  |
| Specifies the name of the library where the cell can be found. By default, the target library is searched for the named cell. |  |  |
| -cell <i>cell_name</i>                                                                                                        |  |  |
| Specifies the name of the cell for which pin load is applied.                                                                 |  |  |
| -pin <i>pin_name</i>                                                                                                          |  |  |
| Specifies the name of the pin.                                                                                                |  |  |
|                                                                                                                               |  |  |

#### **Related Information**

get\_cell\_pin\_load

# PKS

This section describes hidden commands associated with Cadence PKS.

- <u>generate\_lut\_from\_routes</u> on page 1308
- <u>report steiner route</u> on page 1309

### \_generate\_lut\_from\_routes

\_generate\_lut\_from\_routes str [-two\_luts]

After the design has been routed (global or detail), issuing this command completes a statistical analysis of the real routes and vias, including route layer assignment and length and number of vias used. From the statistics, one or two luts will be generated. You can then restart the run using this lut for steiner RC calculation. See the <u>set layer usages table</u> and the <u>set net physical attribute</u> commands for more information. The purpose of this command is to bring better pre- and post- route timing correlation without requiring you to know the lut.

#### **Options and Arguments**

Represents the file name of the generated lut. This is a required option.

-two\_luts

str

Generates two luts, one for signal nets and one for clock nets. The file name of the signal net lut is specified as  $str\_signal$  while the clock lut is specified as  $str\_clock$ . If this option is not specified, which is the default, one lut will be generated, for both signal and clock nets.

#### Examples

- The following command creates a file named gen\_lut in the current directory: \_generate\_lut\_from\_routes gen\_lut
- The following command creates two files in the current directory, one is gen\_lut\_signal and the other is gen\_lut\_clock.

\_generate\_lut\_from\_routes gen\_lut -two\_luts

#### report\_steiner\_route

report\_steiner\_route net\_name

Output to stdout:

Outputs a list of all vertices (pins are named with a <cB> for boundary pins, < I> for instance pins), and a list of edges connecting the vertices.

#### **Examples**

```
pks_shell[10]>report_steiner {tdigit_flag}
Net tdigit_flag .....
NET: tdigit_flag
CbPIN:Test7/tdigit_flag LOC:92000,692000
IPIN:DIGIT_REG_INST/flag_out_reg/Q LOC:319600,114500
Total Lumped C: 0.106609 Total Lumped R: 0.303157 Source of parasitics: Steiner
tree
```

```
>>>>> Steiner Route Summary
v1: 319600,692000 (C=0.0533045)
v2: 92000,692000 (C=0.0152007) (<cB>tdigit_flag)
v3: 319600,114500 (C=0.0381038) (< I>DIGIT_REG_INST/flag_out_reg/Q)
e1: V 1: v3->v1 (R=0.220976) (L=577500)
e2: H 2: v2->v1 (R=0.0821811) (L=227600)
Summary for Net tdigit_flag :
Number Of Pins = 2 Number of StPoints = 1
Number of Edges = 2
StRoute Length = 805100 BBOX = <92000,114500,319600,692000> HP Length = 805100
Total Lumped C: 0.106609
Total Lumped R: 0.303157
```

# **Timing Analysis**

This section describes the hidden commands associated with timing analysis in BuildGates Synthesis and Cadence PKS.

- <u>convert delays to assertions</u> on page 1311
- <u>get cell area</u> on page 1312
- <u>set cell area</u> on page 1313
- write design timing on page 1314
- <u>write timing windows clock arrival</u> on page 1316
- <u>write\_timing\_windows\_fast\_mode</u> on page 1317
- <u>write timing windows slack info</u> on page 1318

### \_convert\_delays\_to\_assertions

-convert\_delays\_to\_assertions

Forces the delay system to convert all delays into sdf assertions. This is needed when you want to load in an incremental sdf.

### \_get\_cell\_area

get\_cell\_area

Gets the cell area in the timing library.

Using these commands has several limitations:

- By default, cell areas (as in report\_area) are taken from physical cells, not the timing library area cell data. To use the area reported by get\_cell\_area or set by set\_cell\_area, set the global use\_lef\_area to false.
- The actual meaning of the timing library cell area is somewhat vague. The read\_tlf command will either read the gate count (if present) or the transistor count (if present) as a gate area if the area property is missing.

If the timing library file is incorrect, it is usually better to correct the file rather than using the set\_cell\_area command to correct the area after loading.

### \_set\_cell\_area

set\_cell\_area

Sets the cell area in the timing library.

# \_write\_design\_timing

\_write\_design\_timing outfile

Writes out names in the DEF naming style. This is the file format used by Nanoroute.

The precision follows the report\_precision global variable setup. By default the precision is 2.

The following shows the file format:

```
CAPACITANCE_UNIT <multi> <unit>
TIME_UNIT <multi> <unit>
```

PORT <boundary\_pin\_name>

| - 010                                        |          |                                                                                                                |
|----------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------|
|                                              | CAP      | <cap></cap>                                                                                                    |
|                                              |          | <pre># output pin -&gt; pin cap + total wire cap</pre>                                                         |
|                                              | SLACK    | <late_rise> <late_fall> <early_rise> <early_fall></early_fall></early_rise></late_fall></late_rise>            |
|                                              |          | <pre># worst timing slack of this pin</pre>                                                                    |
|                                              | SLEW     | <late_rise> <late_fall> <early_rise> <early_fall></early_fall></early_rise></late_fall></late_rise>            |
|                                              |          | # transition time of this pin                                                                                  |
|                                              | DELAY    | <late_rise> <late_fall> <early_rise> <early_fall></early_fall></early_rise></late_fall></late_rise>            |
|                                              |          | # input pin -> inc. delay from driver to this pin                                                              |
|                                              |          | # output pin -> max delay of the timing arc which end at this pin                                              |
|                                              | ARRIVAL  | <late_rise> <late_fall> <early_rise> <early_fall></early_fall></early_rise></late_fall></late_rise>            |
|                                              |          | <pre># arrival time of this pin, if it's available</pre>                                                       |
|                                              | REQUIRED | <late_rise> <late_fall> <early_rise> <early_fall></early_fall></early_rise></late_fall></late_rise>            |
|                                              |          | <pre># required time of this pin, if it's available</pre>                                                      |
| ;                                            |          | # ; at end of PORT                                                                                             |
|                                              |          |                                                                                                                |
| PORT <boundary_pin_name></boundary_pin_name> |          |                                                                                                                |
|                                              | :        |                                                                                                                |
|                                              | :        |                                                                                                                |
| ;                                            |          | # ; at end of PORT                                                                                             |
|                                              |          |                                                                                                                |
|                                              |          |                                                                                                                |
| INST <inst_name></inst_name>                 |          |                                                                                                                |
| PIN <pin_name></pin_name>                    |          |                                                                                                                |
|                                              | CAP      | <cap> # input pin -&gt; pin cap</cap>                                                                          |
|                                              |          | # output pin -> pin cap + total wire cap                                                                       |
|                                              | SLACK    | <pre><late_rise> <late_fall> <early_rise> <early_fall></early_fall></early_rise></late_fall></late_rise></pre> |
|                                              | -        | # worst timing slack of this pin                                                                               |
|                                              | SLEW     | <pre></pre>                                                                                                    |
|                                              |          |                                                                                                                |

#### Command Reference for BuildGates Synthesis and Cadence PKS Temporary Commands

```
# transition time of this pin
            <late_rise> <late_fall> <early_rise> <early_fall>
   DELAY
            # input pin -> inc. delay from driver to this pin
            # output pin -> max delay of the timing arc which end at this pin
   ARRIVAL <late_rise> <late_fall> <early_rise> <early_fall>
            # arrival time of this pin, if it's available
   REQUIRED <late_rise> <late_fall> <early_rise> <early_fall>
            # required time of this pin, if it's available
 PIN <pin_name>
        :
        :
;
          # ; at end of INST
INST <inst_name>
       :
       :
;
```

# \_write\_timing\_windows\_clock\_arrival

\_write\_timing\_windows\_clock\_arrival {true|false}

Set to false by default, so that a clock arrival time assertion set using set\_clock\_arrival\_time command will not be listed in the timing windows file. Setting this global to false will also improve runtime.

### \_write\_timing\_windows\_fast\_mode

\_write\_timing\_windows\_fast\_mode {true|false}

Set to true by default, so that the write\_timing\_windows command will not create hash tables to sort out the timing windows per clock phase. You will see significant runtime improvement when this global is set to true.

When the global is set to false, the write\_timing\_windows command behaves in the old mode where it sorts the timing windows per clock phase and takes longer time.

# \_write\_timing\_windows\_slack\_info

Set to true by default because CeltIC<sup>™</sup> uses the slack information for better accuracy. However, setting this global to false improves runtime.

# Index

# Numerics

39158 h2t head 2.top read\_def <u>720</u>

# A

ac\_shell <u>33</u> add\_netconn <u>36</u> add\_physical\_connection <u>479</u> alias <u>37</u> all\_children <u>38</u> all\_parents <u>40</u>

# В

bg\_shell <u>41</u> bgx\_shell <u>44</u>

# С

check\_batch 342 check\_cg\_logic 378 check design 481 check\_dft\_rules 692 check\_dist <u>344</u> check\_host <u>345</u> check\_libraries\_and\_design\_compatibility 482 check\_library 483 check\_netlist 47 check\_option 49 check timing 803 create\_blockage 485 create instance 52 create\_layer\_usages\_table 488 create\_module 53 create\_mp\_constraint\_arc 810 create mp\_delay\_arc 813 create\_mp\_drive\_type 816 create\_mp\_load\_type 818

create\_mp\_model <u>819</u> create\_mp\_path\_type <u>820</u> create\_mp\_port <u>822</u> create\_net <u>54</u> create\_physical\_cluster <u>489</u> create\_physical\_instance <u>492</u> create\_physical\_net <u>494</u> create\_physical\_pin <u>495</u> create\_placement\_area <u>497</u> create\_port <u>56</u>

# D

delete attribute 57 delete\_aware\_component 58 delete netconn 59 delete object 60 delete\_unconnected\_ports 61 display\_scan\_chains 695 do\_analyze\_crosstalk 824 do blast busses 62 do\_build\_clock\_tree 300 do\_build\_generic <u>65</u> do\_build\_physical\_tree <u>305</u> do change module architecture 70 do\_change\_name 72 do\_cleanup\_netlist 77 do\_copy\_module 78 do cppr analysis 830 <u>80</u> do create hierarchy do\_delete\_buffer 82 do derive context 832 8<u>3</u> do dissolve hierarchy do extract critical 85 do\_extract\_fanin 88 do extract fanout 90 do extract lef model 499 do extract model 834 do\_extract\_non\_critical 92 do extract route parasitics 500 do\_groute 501 do initialize\_floorplan 508 do insert buffer 95 do insert filler cells 509 do optimize 97

do pipeline check 112 do\_pipeline\_insert 113 do\_pipeline\_remove 113 do pipeline retime 113 do\_place 510 do\_pop\_module <u>114</u> do\_pull 518 do\_push 521 do\_push\_module 115 do\_rebind 116 do\_remove\_cg\_dummy\_hierarchy 380 do remove design 119 do\_remove\_filler\_cells 525 do\_remove\_route 526 do remove scan order data 697 do\_rename 120 do\_reset\_floorplan 527 do\_route 528 do signalstorm 841 do\_time\_budget 845 do\_uniquely\_instantiate 122 do\_wroute 535 do\_wroute\_eco 544 do\_xform\_buffer 124 do\_xform\_buffer\_tree 126 do xform clone 128 do\_xform\_connect\_scan 698 do\_xform\_fast\_optimize 130 do\_xform\_fix\_design\_rule\_violations 132 do xform\_fix\_dft\_violations 704 do xform fix hold 134 do\_xform\_fix\_multiport\_nets 136 do\_xform\_footprint 137 do\_xform\_insert\_repeaters 139 do\_xform\_insert\_shadow\_dft 706 do\_xform\_insert\_sleep\_mode 381 do xform insert testpoint 712 <u>1</u>38 do\_xform\_ipo do\_xform\_map 141 do xform\_optimize\_clock\_gate 383 do\_xform\_optimize\_clock\_tree 308 do\_xform\_optimize\_generic <u>143</u> do\_xform\_optimize\_power <u>386</u> do\_xform\_optimize\_slack 144 do\_xform\_pre\_placement\_optimize\_slack 145 do\_xform\_prevent\_crosstalk 146 do xform prevent wire self heat 148 do\_xform\_propagate\_constants 149 do\_xform\_reclaim\_area 150 do\_xform\_remove\_redundancy 152

do\_xform\_resize <u>153</u> do\_xform\_restructure <u>155</u> do\_xform\_run\_repair\_file <u>156</u> do\_xform\_structure <u>161</u> do\_xform\_tcorr\_eco <u>553</u> do\_xform\_timing\_correction <u>849</u> do\_xform\_unmap <u>163</u> dump\_adb <u>165</u>

# Ε

eval\_bottom\_up 166

# F

find <u>169</u>

# G

generate\_supply\_rails\_on\_rows 554 get\_area 176 get\_attribute 178 get build id 179 get\_buswidth 180 get\_capacitance\_unit 850 get\_cell\_area 181 get\_cell\_drive 851 get\_cell\_pin\_load 853 get\_clock 855 get\_clock\_gating\_options 390 get\_clock\_propagation 857 get\_clock\_source 858 get\_clock\_tree\_constraints 317 get clock tree objects 318 get\_clock\_tree\_power 392 get cluster 555 get\_cluster\_contents 556 get\_cluster\_names 558 get\_cluster\_physical\_info 559 859 get\_constant\_for\_timing get\_crosstalk\_threshold 182 get\_crosstalk\_tolerance 183 get\_current\_cluster 560 <u>5</u>61 get\_current\_congestion det current instance 184 get\_current\_module 185 get current utilization 562 get\_dcl\_calculation\_mode 861

get\_dcl\_functional\_mode <u>862</u> get\_dcl\_functional\_mode\_array 863 get\_dcl\_level 864 aet derived clock 865 get\_dft\_config\_mode 716 get\_drive\_pin 866 get\_dynamic\_peak\_power 393 get\_dynamic\_power 394 get equivalent cells 186 get\_fanin 868 get\_fanout 870 get\_flow\_compatible\_mode 872 get\_gating\_instance\_list 396 get\_global 187 aet around net 563 get\_hdl\_file 188 get\_hdl\_hierarchy 189 get\_hdl\_top\_level 191 get\_hdl\_type 192 get\_host\_info 346 get\_info 193 get\_job\_info 349 get\_library\_layer\_offset 564 get\_list\_of\_cg\_instances 398 get\_load\_pin 873 aet logic 0 net 565 get\_logic\_1\_net 566 get\_message\_count 195 get\_message\_verbosity 196 get\_min\_porosity\_for\_over\_block\_routing 567 get\_min\_wire\_length 568 get\_module\_worst\_slack 876 get\_names 197 get\_net 198 get\_operating\_conditions 877 get\_operating\_parameter 878 get\_operating\_voltage 880 get\_parent\_instances <u>200</u> get\_physical\_info 569 get\_pin\_location 572 get\_power 399 get\_power\_display\_unit 402 get\_power\_net 573 get\_power\_optimization\_options 403 get\_propagated\_clock 881 get\_route\_availability 574 get\_scale\_delays 883 get\_scan\_chain\_info 717 get slack 885 get\_sleep\_mode\_instance\_list 404

get\_sleep\_mode\_options 406 get\_slew\_thresholds 887 <u>57</u>5 get\_special\_netpins get state of design 201 get\_steiner\_capacitance 576 get\_steiner\_channel\_width 577 get\_steiner\_length 578 get\_steiner\_resistance 579 get\_tech\_info 888 get\_tempfilename 203 get\_time\_borrow\_limit 895 get\_time\_unit 896 get\_timing 897 get\_top\_timing\_module 901 get version 204 get\_weight\_batch\_option 355

# Η

help 205 highlight 206

issue\_message 207

# Κ

kill\_job 356

# L

libcompile <u>902</u> limit <u>208</u> load\_dcl\_rule <u>903</u>

# Μ

modify\_physical\_cluster 580

# Ρ

pks\_shell <u>583</u> prune\_routes <u>586</u>

# Q

quit <u>210</u>

# R

read adb 211 read alf 904 read cap table 587 read\_cap\_table\_update 589 read change file 590 read ctlf 907 read\_dc\_script 908 read\_def 591 read dotlib 911 read\_edif 213 read\_gns 594 read\_irdrop 914 read\_layer\_usages 595 read lef 596 read lef update 598 read library update 915 read\_ola 918 read\_pdef 600 read\_rrf 920 read saif 407 read\_scan\_order\_file 720 read\_sdf <u>922</u> read\_spef <u>929</u> read spf 931 read\_stamp <u>933</u> read\_symbol <u>214</u> read symbol update 215 read\_tcf 409 read\_tcf\_update 412 read\_tlf 935 read vcd 416 read\_verilog <u>216</u> read\_vhdl <u>219</u> read wdb 602 record\_macro 222 remove\_assertions 938 remove\_blockage 603 remove dft assertions 722 remove host 358 remove\_job 359 remove\_physical\_cluster 604 remove\_physical\_connection 605 remove physical instance 606

remove\_physical\_net 607 remove\_physical\_pin 608 remove\_placement\_area 609 remove supply rails on rows 610 report\_analysis\_coverage 944 report\_annotated\_check 948 report\_annotations 950 report\_area 223 report\_aware\_library 226 report\_block\_halo 611 report\_blockage 612 report\_cell\_instance 953 report\_cell\_instance\_timing 958 report\_clock\_tree 320 report clock tree violations 327 report\_clocks <u>959</u> report\_cluster <u>613</u> report\_crosstalk\_violations 227 report\_design\_rule\_violations 229 report\_dft\_assertions 726 report\_dft\_registers 728 report\_fanin 964 report\_fanout 966 report\_floorplan\_parameters 614 report\_fsm 231 report functional mode 968 report\_globals 234 report\_grow\_parameters 616 report\_hierarchy 236 report\_inactive\_arcs 969 report\_job 360 report\_library 972 report\_net 975 report\_net\_distribution 617 report\_net\_rc 618 report\_overlap 620 report path exceptions 978 report\_path\_group\_options 238 report\_path\_group\_timing 982 report\_path\_groups 981 report\_physical\_library 621 report placement area 622 report\_poles\_residues <u>983</u> report\_ports 985 report\_power 422 report\_preroute\_parameters 623 report\_resources 240 report slew for power analysis 431 report\_supply\_rails\_on\_rows 624 report\_tc\_stats 434 report\_timing 990

report unplaced 625 report\_vhdl\_library 246 report\_wire\_self\_heat\_violation 247 reset capacitance limit 1013 1015 reset\_capacitance\_unit reset\_clock\_gating\_check 1016 reset\_clock\_info\_change 1018 reset\_clock\_insertion\_delay 1020 reset\_clock\_root 1022 reset\_clock\_tree\_constraints 329 1024 reset\_clock\_uncertainty reset constant for timing 1027 reset\_crosstalk\_threshold 249 reset\_dcl\_calculation\_mode 1028 reset dcl functional mode 1029 reset\_dcl\_level 1030 reset\_default\_slew\_time 1031 reset\_dft\_compatible\_clock\_domains 731 reset\_dft\_fix\_violations 732 reset\_dft\_internal\_clock\_domain 733 reset\_dft\_transparent 734 reset\_disable\_cell\_timing 1032 reset\_disable\_clock\_gating\_check 1034 reset\_disable\_timing 1035 reset\_dist\_bits <u>361</u> reset dist point 363 362 reset\_dist\_rlimit reset\_dist\_weight 364 reset\_dont\_modify 250 reset\_dont\_move 626 reset\_dont\_scan 736 <u>73</u>7 reset\_dont\_toiuch\_scan reset\_dont\_touch\_scan 737 reset\_drive\_cell 1037 reset\_drive\_resistance 1039 <u>1041</u> reset\_external\_delay reset failsafe 252 reset\_fanout\_load 1043 reset\_fanout\_load\_limit 1044 reset\_feedback\_loop\_snipped\_arcs 1045 reset functional mode 1046 reset generated clock 1047 reset\_global 253 reset\_ideal\_net 1048 reset\_input\_delay 1049 reset\_must\_scan 738 reset\_net\_physical\_attribute 627 1051 reset num external sinks reset\_num\_external\_sources 1052 reset\_operating\_condition 1053 reset\_operating\_parameter 1055

reset\_operating\_voltage 1056 reset\_path\_exception 1057 reset\_path\_group 1063 reset port capacitance 1066 reset\_port\_capacitance\_limit 1067 reset\_port\_wire\_load 1068 reset\_propagated\_clock 1069 reset\_register\_type 254 reset\_scale\_delays 1071 reset\_scan\_data 739 reset\_slew\_for\_power\_analysis 437 reset\_slew\_limit 1073 reset\_slew\_thresholds 1074 reset\_slew\_time 1075 reset slew time limit 1077 reset\_switching\_activity 439 reset\_tech\_info 1078 reset\_test\_mode\_setup 740 reset\_time\_borrow\_limit 1085 reset time unit 1086 reset\_vhdl\_library 255 reset\_wire\_capacitance 1087 reset wire load 1088 reset\_wire\_load\_mode 1089 reset\_wire\_load\_selection\_table 1090 reset wire resistance 1091 reset\_wire\_self\_heat\_prevention 256

# S

save mp model 1092 set\_annotated\_check 1094 set\_annotated\_delay 1096 257 set\_attribute set\_aware\_component\_property 261 set\_aware\_library 262 set\_block\_halo 629 set\_block\_rc\_rule 630 set\_capacitance\_limit 1100 set\_capacitance\_unit 1103 set case analysis 1104 1106 set\_cell\_pin\_load set\_cell\_property 263 set clock 1108 set\_clock\_arrival\_time 1111 set\_clock\_gating\_check 1112 set\_clock\_gating\_options 441 set\_clock\_info\_change 1116 set\_clock\_insertion\_delay 1120 set\_clock\_propagation <u>1124</u>

set\_clock\_required\_time 1126 set\_clock\_root 1127 set\_clock\_transition 1129 set clock tree constraints 330 set\_clock\_uncertainty 1130 set constant\_for\_timing 1134 set\_current\_cluster 632 set\_current\_instance 265 set\_current\_module 266 set\_cycle\_addition 1136 set\_data\_arrival\_time 1143 set\_data\_required\_time 1144 set\_dcl\_calculation\_mode 1145 set\_dcl\_functional\_mode 1146 set dcl level 1147 set\_default\_core\_site 633 set\_default\_slew\_time 1148 set\_dft\_clock\_waveform 741 set\_dft\_compatible\_chains 747 set\_dft\_compatible\_clock\_domain 743 set\_dft\_compatible\_clock\_domains 743 set\_dft\_fix\_violations 749 set\_dft\_internal\_clock\_domain 752 set\_dft\_lockup\_element 754 set\_dft\_transparent 755 set disable cell timing 1149 set\_disable\_clock\_gating\_check 1151 set\_disable\_timing 1153 set\_dissolve\_hierarchy 267 set\_dist\_bits 365 set\_dist\_point 366 set\_dist\_rlimit 368 set\_dist\_weight 373 set\_dont\_modify 268 set\_dont\_move 634 set\_dont\_scan 757 set dont touch scan 758 set\_drive\_cell 1156 set drive resistance 1163 set\_external\_delay 1167 set\_failsafe 271 1172 set\_false\_path set\_fanout\_load 1179 set\_fanout\_load\_limit 1179 set\_floorplan\_parameters 635 set\_flow\_compatible\_mode 1180 set\_functional\_mode 1183 set generated clock 1184 set\_global 272 set\_ground\_net 639 set\_grow\_anchors 640

set\_grow\_parameters 642 set\_host\_config 369 set\_host\_list 372 set ideal net 1191 set\_input\_delay 1193 set\_layer\_usages\_table 644 set\_lef\_multiplier 646 set\_library\_layer\_offset 648 set\_logic\_0\_net 649 set\_logic\_1\_net 650 set\_logic0 273 set\_logic1 274 set\_lssd\_aux\_clock 759 set\_lssd\_scan\_clock\_a 760 set lssd scan clock b 761 set\_max\_delay 1196 set\_max\_scan\_chain\_length 762 set\_message\_count 275 set\_message\_verbosity 276 set\_min\_delay 1197 set\_min\_porosity\_for\_over\_block\_routing 651 set\_min\_RC\_multipliers 653 set\_min\_wire\_length 654 set\_mp\_area 1198 set\_mp\_global\_parameter 1199 1201 set\_mp\_max\_fanout\_limit set\_mp\_min\_fanout\_limit 1202 set\_mp\_port\_drive 1203 set\_mp\_port\_load 1205 set\_mp\_port\_max\_capacitance 1207 set\_mp\_port\_max\_transition 1209 set\_mp\_port\_min\_capacitance 1211 set\_mp\_port\_min\_transition <u>1213</u> set\_mp\_technology 1215 set\_must\_scan 765 set net physical attribute 655 set\_num\_external\_sinks 1217 1218 set num\_external\_sources set\_number\_of\_scan\_chains 767 set\_operating\_conditions 1219 set\_operating\_parameter 1226 set\_operating\_voltage 1228 set\_path\_delay\_constraint 1230 set\_path\_group <u>1235</u> set\_path\_group\_options 277 set\_physical\_info 659 set physical instance 661 set\_pin\_location 662 set\_pin\_status 664 set\_port\_capacitance 1238

set port capacitance limit 1240 set\_port\_property <u>279</u> set\_port\_wire\_load <u>1242</u> set power display unit 453 set\_power\_net 666 set\_power\_optimization\_options 454 set\_power\_stripe\_spec 667 set\_preroute\_parameters 669 set\_propagated\_clock <u>12</u>44 set\_register\_type <u>280</u> set\_route\_availability 671 set scale delays 1246 set\_scan\_chain\_segment 772 set\_scan\_data 775 set scan equivalent 779 set\_scan\_mode 780 set\_scan\_style 782 set\_sleep\_mode\_options 457 set\_slew\_for\_power\_analysis 459 set slew limit 1248 <u>12</u>49 set\_slew\_thresholds set\_slew\_time 1251 set\_slew\_time\_limit 1253 set\_steiner\_channel\_width 673 set\_steiner\_mode 674 set supply rails on rows 676 set\_switching\_activity 461 set\_table\_style 282 set\_tech\_info 1255 set\_test\_mode\_setup 783 set\_test\_scan\_clock 785 set\_time\_borrow\_limit <u>1263</u> set\_time\_unit 1265 set\_top\_timing\_module 1267 set\_unconnected 286 set\_vhdl\_library 287 set weight batch option 374 set\_wire\_capacitance 1269 set\_wire\_load 1271 set\_wire\_load\_mode 1274 set wire load selection table 1275 set wire resistance 1276

# U

unalias <u>289</u> unload\_dcl\_rule <u>1277</u>

# V

vbg\_pks\_display\_ilist <u>677</u> vbg\_pks\_group\_delete <u>678</u> vbg\_pks\_group\_display <u>679</u>

# W

write adb 290 write assertions 1278 write atpg info 786 write\_clock\_gating\_attribute 463 write constraints 1280 write\_def 680 write edif 292 write qcf assertions 1282 write\_gns 682 write\_gns\_lib 684 write\_layer\_usages 685 write\_library\_assertions 1284 write\_pdef 686 write psf 465 write rspf 1285 write scan order file 787 write\_sdc 1286 write sdf 1288 write\_sleep\_mode\_attribute 466 write\_spf 1295 write tcf 468 write\_timing\_windows <u>1296</u> write\_verilog 294 29<u>6</u> write\_vhdl write wdb 688